@ -25,6 +25,15 @@ function op_install() { 
			
		
	
		
		
			
				
					
					  echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] op installed successfully. Open a new shell to use it.\n "    echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] op installed successfully. Open a new shell to use it.\n "   
			
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					function  loge( )  {  
			
		
	
		
		
			
				
					
					  if  [ [  -f " $LOG_FILE "  ] ] ;  then   
			
		
	
		
		
			
				
					
					    # error type   
			
		
	
		
		
			
				
					
					    echo  " $1 "  >> $LOG_FILE   
			
		
	
		
		
			
				
					
					    # error log   
			
		
	
		
		
			
				
					
					    echo  " $2 "  >> $LOG_FILE   
			
		
	
		
		
			
				
					
					  fi   
			
		
	
		
		
			
				
					
					}  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					function  op_run_command( )  { function  op_run_command( )  {  
			
		
	
		
		
			
				
					
					  CMD = " $@ "    CMD = " $@ "   
			
		
	
		
		
			
				
					
					  echo  -e " ${ BOLD } Running: ${ NC }   $CMD "    echo  -e " ${ BOLD } Running: ${ NC }   $CMD "   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -97,11 +106,13 @@ function op_check_os() { 
			
		
	
		
		
			
				
					
					          ; ;            ; ;   
			
		
	
		
		
			
				
					
					        * )          * )   
			
		
	
		
		
			
				
					
					          echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] Incompatible Ubuntu version  $VERSION_CODENAME  detected! "            echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] Incompatible Ubuntu version  $VERSION_CODENAME  detected! "   
			
		
	
		
		
			
				
					
					          loge "ERROR_INCOMPATIBLE_UBUNTU"  " $VERSION_CODENAME "   
			
		
	
		
		
			
				
					
					          return  1            return  1   
			
		
	
		
		
			
				
					
					          ; ;            ; ;   
			
		
	
		
		
			
				
					
					      esac        esac   
			
		
	
		
		
			
				
					
					    else      else   
			
		
	
		
		
			
				
					
					      echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] No /etc/os-release on your system. Make sure you're running on Ubuntu, or similar! "        echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] No /etc/os-release on your system. Make sure you're running on Ubuntu, or similar! "   
			
		
	
		
		
			
				
					
					      loge "ERROR_UNKNOWN_UBUNTU"   
			
		
	
		
		
			
				
					
					      return  1        return  1   
			
		
	
		
		
			
				
					
					    fi      fi   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -109,6 +120,7 @@ function op_check_os() { 
			
		
	
		
		
			
				
					
					    echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] macos detected.\n "      echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] macos detected.\n "   
			
		
	
		
		
			
				
					
					  else    else   
			
		
	
		
		
			
				
					
					    echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] OS type  $OSTYPE  not supported! "      echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] OS type  $OSTYPE  not supported! "   
			
		
	
		
		
			
				
					
					    loge "ERROR_UNKNOWN_OS"  " $OSTYPE "   
			
		
	
		
		
			
				
					
					    return  1      return  1   
			
		
	
		
		
			
				
					
					  fi    fi   
			
		
	
		
		
			
				
					
					} }  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -120,11 +132,13 @@ function op_check_python() { 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  if  [ [  -z $INSTALLED_PYTHON_VERSION  ] ] ;  then    if  [ [  -z $INSTALLED_PYTHON_VERSION  ] ] ;  then   
			
		
	
		
		
			
				
					
					    echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] python3 not found on your system. You need python version at least  $( echo  $REQUIRED_PYTHON_VERSION  |  tr -d -c '[0-9.]' )  to continue! "      echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] python3 not found on your system. You need python version at least  $( echo  $REQUIRED_PYTHON_VERSION  |  tr -d -c '[0-9.]' )  to continue! "   
			
		
	
		
		
			
				
					
					    loge "ERROR_PYTHON_NOT_FOUND"   
			
		
	
		
		
			
				
					
					    return  1      return  1   
			
		
	
		
		
			
				
					
					  elif  [ [  $( echo  $INSTALLED_PYTHON_VERSION  |  grep -o '[0-9]\+\.[0-9]\+'  |  tr -d -c '[0-9]' )  -ge $( echo  $REQUIRED_PYTHON_VERSION  |  tr -d -c '[0-9]' )  ] ] ;  then    elif  [ [  $( echo  $INSTALLED_PYTHON_VERSION  |  grep -o '[0-9]\+\.[0-9]\+'  |  tr -d -c '[0-9]' )  -ge $( echo  $REQUIRED_PYTHON_VERSION  |  tr -d -c '[0-9]' )  ] ] ;  then   
			
		
	
		
		
			
				
					
					    echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ]  $INSTALLED_PYTHON_VERSION  detected. "      echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ]  $INSTALLED_PYTHON_VERSION  detected. "   
			
		
	
		
		
			
				
					
					  else    else   
			
		
	
		
		
			
				
					
					    echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] You need python version at least  $( echo  $REQUIRED_PYTHON_VERSION  |  tr -d -c '[0-9.]' )  to continue! "      echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] You need python version at least  $( echo  $REQUIRED_PYTHON_VERSION  |  tr -d -c '[0-9.]' )  to continue! "   
			
		
	
		
		
			
				
					
					    loge "ERROR_PYTHON_VERSION"  " $INSTALLED_PYTHON_VERSION "   
			
		
	
		
		
			
				
					
					    return  1      return  1   
			
		
	
		
		
			
				
					
					  fi    fi   
			
		
	
		
		
			
				
					
					} }  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -173,22 +187,35 @@ function op_setup() { 
			
		
	
		
		
			
				
					
					  echo  "Installing dependencies..."    echo  "Installing dependencies..."   
			
		
	
		
		
			
				
					
					  st = " $( date +%s) "    st = " $( date +%s) "   
			
		
	
		
		
			
				
					
					  if  [ [  " $OSTYPE "  = =  "linux-gnu" * ] ] ;  then    if  [ [  " $OSTYPE "  = =  "linux-gnu" * ] ] ;  then   
			
		
	
		
		
			
				
					
					    op_run_command $OPENPILOT_ROOT /tools/ubuntu_setup.sh      SETUP_SCRIPT = "tools/ubuntu_setup.sh"   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  elif  [ [  " $OSTYPE "  = =  "darwin" * ] ] ;  then    elif  [ [  " $OSTYPE "  = =  "darwin" * ] ] ;  then   
			
		
	
		
		
			
				
					
					    op_run_command $OPENPILOT_ROOT /tools/mac_setup.sh     SETUP_SCRIPT = "tools/mac_setup.sh"   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  fi   
			
		
	
		
		
			
				
					
					  if  ! op_run_command " $OPENPILOT_ROOT / $SETUP_SCRIPT " ;  then   
			
		
	
		
		
			
				
					
					    echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] Dependencies installation failed! "   
			
		
	
		
		
			
				
					
					    loge "ERROR_DEPENDENCIES_INSTALLATION"   
			
		
	
		
		
			
				
					
					    return  1   
			
		
	
		
		
			
				
					
					  fi    fi   
			
		
	
		
		
			
				
					
					  et = " $( date +%s) "    et = " $( date +%s) "   
			
		
	
		
		
			
				
					
					  echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] Dependencies installed successfully in  $(( et -  st))  seconds.\n "    echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] Dependencies installed successfully in  $(( et -  st))  seconds.\n "   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  echo  "Getting git submodules..."    echo  "Getting git submodules..."   
			
		
	
		
		
			
				
					
					  st = " $( date +%s) "    st = " $( date +%s) "   
			
		
	
		
		
			
				
					
					  op_run_command git submodule update --filter= blob:none --jobs 4  --init --recursive   if  ! op_run_command git submodule update --filter= blob:none --jobs 4  --init --recursive;  then   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] Getting git submodules failed! "   
			
		
	
		
		
			
				
					
					    loge "ERROR_GIT_SUBMODULES"   
			
		
	
		
		
			
				
					
					    return  1   
			
		
	
		
		
			
				
					
					  fi   
			
		
	
		
		
			
				
					
					  et = " $( date +%s) "    et = " $( date +%s) "   
			
		
	
		
		
			
				
					
					  echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] Submodules installed successfully in  $(( et -  st))  seconds.\n "    echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] Submodules installed successfully in  $(( et -  st))  seconds.\n "   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  echo  "Pulling git lfs files..."    echo  "Pulling git lfs files..."   
			
		
	
		
		
			
				
					
					  st = " $( date +%s) "    st = " $( date +%s) "   
			
		
	
		
		
			
				
					
					  op_run_command git lfs pull   if  ! op_run_command git lfs pull;  then   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    echo  -e "  ↳ [ ${ RED } ✗ ${ NC } ] Pulling git lfs files failed! "   
			
		
	
		
		
			
				
					
					    loge "ERROR_GIT_LFS"   
			
		
	
		
		
			
				
					
					    return  1   
			
		
	
		
		
			
				
					
					  fi   
			
		
	
		
		
			
				
					
					  et = " $( date +%s) "    et = " $( date +%s) "   
			
		
	
		
		
			
				
					
					  echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] Files pulled successfully in  $(( et -  st))  seconds.\n "    echo  -e "  ↳ [ ${ GREEN } ✔ ${ NC } ] Files pulled successfully in  $(( et -  st))  seconds.\n "   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -307,6 +334,7 @@ function _op() { 
			
		
	
		
		
			
				
					
					    --dry )             shift  1;  DRY = "1"  ; ;      --dry )             shift  1;  DRY = "1"  ; ;   
			
		
	
		
		
			
				
					
					    -n |  --no-verify )  shift  1;  NO_VERIFY = "1"  ; ;      -n |  --no-verify )  shift  1;  NO_VERIFY = "1"  ; ;   
			
		
	
		
		
			
				
					
					    -v |  --verbose )    shift  1;  VERBOSE = "1"  ; ;      -v |  --verbose )    shift  1;  VERBOSE = "1"  ; ;   
			
		
	
		
		
			
				
					
					    -l |  --log )        shift  1;  LOG_FILE = " $1 "  ;  shift  1  ; ;   
			
		
	
		
		
			
				
					
					  esac    esac   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  # parse Commands    # parse Commands