2022-03-27 13:30:22 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								#!/bin/bash
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Function to display CLI help  
						 
					
						
							
								
									
										
										
										
											2025-01-29 06:24:56 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								show_cli_help( )  { 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    echo  -e " 
 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-07 00:55:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Usage:
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 00:31:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								flatpak run [ FLATPAK-RUN-OPTION]  net.retrodeck.retrodeck [ ARGUMENTS] 
							 
						 
					
						
							
								
									
										
										
										
											2022-05-18 14:10:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Arguments:
							 
						 
					
						
							
								
									
										
										
										
											2024-09-08 13:43:06 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    -h, --help                          \t   Print this help 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -v, --version                       \t   Print RetroDECK version
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --show-config                       \t   Print information about the RetroDECK configuration file and its contents
							 
						 
					
						
							
								
									
										
										
										
											2025-02-07 00:55:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --debug                             \t   Enable debug logging for  this run of RetroDECK
							 
						 
					
						
							
								
									
										
										
										
											2024-09-08 13:43:06 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --configurator                      \t   Starts the RetroDECK Configurator
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    --compress-one <file>               \t   Compresses target file to a compatible format
							 
						 
					
						
							
								
									
										
										
										
											2024-09-12 05:49:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --compress-all <format>             \t   Compresses all supported games into a compatible format.\n \t \t \t \t \t \t   Available formats are \" chd\" , \" zip\" , \" rvz\"  and \" all\" 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-07 06:35:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --reset <component>                 \t   Reset RetroDECK or one or more component/emulator configurations to default values. WARNING: no confirmation prompt
							 
						 
					
						
							
								
									
										
										
										
											2025-02-10 07:34:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --factory-reset                     \t   Factory Reset, triggers the initial setup WARNING: no confirmation prompt
							 
						 
					
						
							
								
									
										
										
										
											2025-01-31 00:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --test-upgrade <version>            \t   Test upgrading RetroDECK to a specific version, developer use only
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 05:35:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --set <preset> <system/all> [ value]  \t   Configure or toggle a preset. Examples: --set borders, --set borders all true,\n \t \t \t \t \t \t   --set borders gba false. Use --set-help for  more information
							 
						 
					
						
							
								
									
										
										
										
											2025-02-07 06:35:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    --open <component/emulator>         \t   Open a specific component or emulator\n \t \t \t \t \t \t   --open --list for  a list of available components
							 
						 
					
						
							
								
									
										
										
										
											2024-09-08 13:43:06 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-12-18 01:06:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Game Launch:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    [ <options>]  <game_path>             \t   Start a game using the default emulator or\n \t \t \t \t \t \t   the one defined in ES-DE for  game or system
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    \t  Options:
							 
						 
					
						
							
								
									
										
										
										
											2024-09-12 05:49:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    \t  \t -e ( emulator) \t  Run the game with the defined emulator ( optional) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    \t  \t -s ( system) \t  Force the game running with the defined system, for  example running a gb game on gba ( optional) 
							 
						 
					
						
							
								
									
										
										
										
											2024-12-18 01:06:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    \t  \t -m ( manual) \t  Manual mode: show the list of available emulator to choose from ( optional) 
							 
						 
					
						
							
								
									
										
										
										
											2022-05-18 14:10:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For flatpak run specific options please run: flatpak run -h
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-02-07 00:55:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The RetroDECK Team
							 
						 
					
						
							
								
									
										
										
										
											2022-05-18 14:10:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								https://retrodeck.net
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								" 
  
						 
					
						
							
								
									
										
										
										
											2025-01-29 06:24:56 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Check if is an infromational message  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# If so, set LOG_SILENT to true, source the global.sh script,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# show the needed information and quit  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								case  " $1 "  in 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -h| --help) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    LOG_SILENT = true 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    source  /app/libexec/global.sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  [ [  " $version "  = ~ ^[ 0-9]  ] ] ;  then 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-04 19:40:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      echo  " RetroDECK v $version " 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      echo  " RetroDECK  $version " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    show_cli_help
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -v| --version) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    LOG_SILENT = true 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    source  /app/libexec/global.sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  [ [  " $version "  = ~ ^[ 0-9]  ] ] ;  then 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-04 19:40:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      echo  " RetroDECK v $version " 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      echo  " RetroDECK  $version " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    exit  0 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-10 07:34:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ; ; 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 05:35:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  --set-help) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    LOG_SILENT = true 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    source  /app/libexec/global.sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "\nUsed to toggle or set a preset.\n\nAvailable presets are:" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fetch_all_presets |  tr ' '  ','  |  sed 's/,/, /g' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "\nUsage: --set <preset> <system/all> [value]" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "\nExamples:" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "  Force borders to be ON for GBA:" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "    make_preset_changes borders gba on" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "  Force borders to be OFF for all supported systems:" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "    make_preset_changes borders all off" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "  Toggle GBA in preset borders (this will disable if enabled and vice versa):" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "    make_preset_changes borders gba" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "  Toggle all in preset borders:" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "    make_preset_changes borders all" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    echo  -e "\nYou can also use 'true' or 'false' instead of 'on' and 'off'.\nThe forced status is case insensitive." 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ; ; 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								esac  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								source  /app/libexec/global.sh 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Process command-line arguments  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								while  [ [  $#  -gt 0  ] ] ;  do  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # If the first argument is -e, -s, -m, or a valid file, attempt to launch the game 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  [  -f " $1 "  ]  ||  [ [  " $1 "  = =  "-e"  ||  " $1 "  = =  "-s"  ||  " $1 "  = =  "-m"  ] ] ;  then 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        echo  " $LOG_BUFFER " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        log i " Game start option detected:  $1 " 
							 
						 
					
						
							
								
									
										
										
										
											2025-01-29 06:24:56 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        run_game " $@ " 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  " $1 "  in
							 
						 
					
						
							
								
									
										
										
										
											2025-02-21 02:35:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        --show-config) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          echo  "" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          cat " $rd_conf " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        ; ; 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        --debug) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            logging_level = "debug" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            shift 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        --compress-one) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            cli_compress_single_game " $2 " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        --compress-all) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            cli_compress_all_games " $2 " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            shift  2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        --configurator) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            sh /app/tools/configurator.sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        --reset) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            component = " ${ @ : 2 } " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  [  -z " $component "  ] ;  then 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                echo  "You are about to reset one or more RetroDECK components or emulators." 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                echo  -e " Available options are:\nall,  $( prepare_component --list |  tr ' '  ','  |  sed 's/,/, /g' ) " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                read  -p "Please enter the component you would like to reset: "  component
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                component = $( echo  " $component "  |  tr '[:upper:]'  '[:lower:]' ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            log d " Resetting component:  $component " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            prepare_component "reset"  " $component " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        --factory-reset) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            prepare_component --factory-reset
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        --test-upgrade) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  [ [  " $2 "  = ~ ^.+ ] ] ;  then 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                echo  " You are about to test upgrading RetroDECK from version  $2  to  $hard_version " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                read  -p "Enter 'y' to continue, 'n' to start RetroDECK normally: "  response
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  [ [  $response  = =  [ yY]  ] ] ;  then 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    version = " $2 " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    logging_level = "debug"   # Temporarily enable debug logging 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    shift  2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    shift 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                echo  "Error: Invalid format. Usage: --test-upgrade <version>" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                exit  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        --set) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            preset = " $2 " 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 05:35:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            system = " $3 " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            value = " $4 " 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  [  " $preset "  = =  "cheevos"  ] ;  then 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 05:35:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								              echo  "Error: The 'cheevos' preset is not yet supported via CLI. Please use the RetroDECK Configurator." 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								              exit  1 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  [  -z " $preset "  ] ;  then 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 05:35:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								              echo  "Error: No preset specified. Usage: --set <preset> <system/all> [value] (use --set-help for more information)" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								              exit  1 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            fi 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 05:35:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            make_preset_changes " $preset "  " $system "  " $value " 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-20 01:27:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        --open) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            open_component " ${ @ : 2 } " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            exit  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        -*) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # Catch-all for unrecognized options starting with a dash 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            log e " Error: Unknown option ' $1 ' " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            echo  " Error: Unrecognized option ' $1 '. Use -h or --help for usage information. " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            exit  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        *) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # If it reaches here and is an unrecognized argument, report the error 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            log e " Error: Command or file ' $1 ' not recognized. " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            echo  " Error: Command or file ' $1 ' not recognized. Use -h or --help for usage information. " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            exit  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ; ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    esac 
							 
						 
					
						
							
								
									
										
										
										
											2022-05-18 14:10:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								done  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-09-06 12:46:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# if lockfile exists  
						 
					
						
							
								
									
										
										
										
											2023-05-10 13:57:28 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  [  -f " $lockfile "  ] ;  then  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  if  [  " $hard_version "  !=  " $version "  ] ;  then 
							 
						 
					
						
							
								
									
										
										
										
											2024-08-08 18:05:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    log d "Update triggered" 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 13:11:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    log d "Lockfile found but the version doesn't match with the config file" 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-04 16:34:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    log i " Config file's version is  $version  but the actual version is  $hard_version " 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-03 15:07:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  grep -qF "cooker"  <<<  $hard_version ;  then  # If newly-installed version is a "cooker" build 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-04 09:17:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      log d "Newly-installed version is a \"cooker\" build" 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-18 16:23:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      configurator_generic_dialog "RetroDECK Cooker Warning"  "RUNNING COOKER VERSIONS OF RETRODECK CAN BE EXTREMELY DANGEROUS AND ALL OF YOUR RETRODECK DATA\n(INCLUDING BIOS FILES, BORDERS, DOWNLOADED MEDIA, GAMELISTS, MODS, ROMS, SAVES, STATES, SCREENSHOTS, TEXTURE PACKS AND THEMES)\nARE AT RISK BY CONTINUING!" 
							 
						 
					
						
							
								
									
										
										
										
											2024-08-06 02:08:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      set_setting_value $rd_conf  "update_repo"  " $cooker_repository_name "  retrodeck "options" 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-19 14:03:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      set_setting_value $rd_conf  "update_check"  "true"  retrodeck "options" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      set_setting_value $rd_conf  "developer_options"  "true"  retrodeck "options" 
							 
						 
					
						
							
								
									
										
										
										
											2024-08-08 18:05:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      cooker_base_version = $( echo  $version  |  cut -d'-'  -f2) 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-28 20:07:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      choice = $( rd_zenity --icon-name= net.retrodeck.retrodeck --info --no-wrap --ok-label= "Upgrade"  --extra-button= "Don't Upgrade"  --extra-button= "Full Wipe and Fresh Install"  \
 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-03 15:07:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      --window-icon= "/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg"  \
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      --title "RetroDECK Cooker Upgrade"  \
 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-18 16:12:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      --text= "You appear to be upgrading to a \"cooker\" build of RetroDECK.\n\nWould you like to perform the standard post-update process, skip the post-update process or remove ALL existing RetroDECK folders and data (including ROMs and saves) to start from a fresh install?\n\nPerforming the normal post-update process multiple times may lead to unexpected results." ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-03 15:07:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      rc = $?  # Capture return code, as "Yes" button has no text value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      if  [ [  $rc  = =  "1"  ] ] ;  then  # If any button other than "Yes" was clicked 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  [ [  $choice  = =  "Don't Upgrade"  ] ] ;  then  # If user wants to bypass the post_update.sh process this time. 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-04 16:34:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          log i "Skipping upgrade process for cooker build, updating stored version in retrodeck.cfg" 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-03 15:07:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          set_setting_value $rd_conf  "version"  " $hard_version "  retrodeck # Set version of currently running RetroDECK to updated retrodeck.cfg 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-18 16:12:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        elif  [ [  $choice  = =  "Full Wipe and Fresh Install"  ] ] ;  then  # Remove all RetroDECK data and start a fresh install 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-18 16:23:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          if  [ [  $( configurator_generic_question_dialog "RetroDECK Cooker Reset"  "This is going to remove all of the data in all locations used by RetroDECK!\n\n(INCLUDING BIOS FILES, BORDERS, DOWNLOADED MEDIA, GAMELISTS, MODS, ROMS, SAVES, STATES, SCREENSHOTS, TEXTURE PACKS AND THEMES)\n\nAre you sure you want to contine?" )  = =  "true"  ] ] ;  then 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  [ [  $( configurator_generic_question_dialog "RetroDECK Cooker Reset"  "Are you super sure?\n\nThere is no going back from this process, everything is gonzo.\nDust in the wind.\n\nYesterdays omelette." )  = =  "true"  ] ] ;  then 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								              if  [ [  $( configurator_generic_question_dialog "RetroDECK Cooker Reset"  "But are you super DUPER sure? We REAAAALLLLLYY want to make sure you know what is happening here.\n\nThe ~/retrodeck and ~/.var/app/net.retrodeck.retrodeck folders and ALL of their contents\nare about to be PERMANENTLY removed.\n\nStill sure you want to proceed?" )  = =  "true"  ] ] ;  then 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                configurator_generic_dialog "RetroDECK Cooker Reset"  "Ok, if you're that sure, here we go!" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  [ [  $( configurator_generic_question_dialog "RetroDECK Cooker Reset"  "(Are you actually being serious here? Because we are...\n\nNo backsies.)" )  = =  "true"  ] ] ;  then 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-04 16:34:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                  log w "Removing RetroDECK data and starting fresh" 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-18 16:23:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                  rm -rf /var
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                  rm -rf " $HOME /retrodeck " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 13:11:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                  rm -rf " $rdhome " 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-18 16:23:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                  source  /app/libexec/global.sh
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                  finit
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								              fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          fi 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-03 15:07:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      else 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-04 09:17:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        log i " Performing normal upgrade process for version  $cooker_base_version " 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-03 15:07:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        version = $cooker_base_version  # Temporarily assign cooker base version to $version so update script can read it properly. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        post_update
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else  # If newly-installed version is a normal build. 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-19 21:08:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      if  grep -qF "cooker"  <<<  $version ;  then  # If previously installed version was a cooker build 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-10 13:57:28 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        cooker_base_version = $( echo  $version  |  cut -d'-'  -f2) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        version = $cooker_base_version  # Temporarily assign cooker base version to $version so update script can read it properly. 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-18 15:26:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        set_setting_value $rd_conf  "update_repo"  "RetroDECK"  retrodeck "options" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        set_setting_value $rd_conf  "update_check"  "false"  retrodeck "options" 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-20 19:56:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        set_setting_value $rd_conf  "update_ignore"  ""  retrodeck "options" 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-19 14:03:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        set_setting_value $rd_conf  "developer_options"  "false"  retrodeck "options" 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-18 15:26:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      fi 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-03 15:07:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      post_update       # Executing post update script 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-14 12:49:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fi 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-06 12:46:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  fi 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Else, LOCKFILE IS NOT EXISTING (WAS REMOVED)  
						 
					
						
							
								
									
										
										
										
											2022-05-19 14:30:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# if the lock file doesn't exist at all means that it's a fresh install or a triggered reset  
						 
					
						
							
								
									
										
										
										
											2022-10-13 12:21:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								else  
						 
					
						
							
								
									
										
										
										
											2024-01-04 16:34:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  log w "Lockfile not found" 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-17 13:53:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  finit             # Executing First/Force init 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-02 09:21:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								fi  
						 
					
						
							
								
									
										
										
										
											2022-05-19 14:30:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-03-30 14:04:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  [ [  $multi_user_mode  = =  "true"  ] ] ;  then  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  multi_user_determine_current_user
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								fi  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-05-08 20:54:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Run optional startup checks  
						 
					
						
							
								
									
										
										
										
											2024-03-12 14:13:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  [ [  $( check_is_steam_deck)  = =  "true"  ] ] ;  then  # Only warn about Desktop Mode on Steam Deck, ignore for other platforms  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  desktop_mode_warning
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								fi  
						 
					
						
							
								
									
										
										
										
											2023-05-08 20:54:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								low_space_warning
							 
						 
					
						
							
								
									
										
										
										
											2023-03-07 17:00:32 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-03-27 19:52:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Check if there is a new version of RetroDECK available, if update_check=true in retrodeck.cfg and there is network connectivity available.  
						 
					
						
							
								
									
										
										
										
											2024-03-04 09:17:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								log i "Check if there is a new version of RetroDECK available" 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-08 17:52:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  [ [  $update_check  = =  "true"  ] ] ;  then  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  if  [ [  $( check_network_connectivity)  = =  "true"  ] ] ;  then 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-04 09:17:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    log d "Running function check_for_version_update" 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-08 17:52:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    check_for_version_update
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  fi 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-04 09:17:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  log i "You're running the latest version" 
							 
						 
					
						
							
								
									
										
										
										
											2023-03-27 19:52:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								fi  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-12-22 15:34:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Normal Startup  
						 
					
						
							
								
									
										
										
										
											2023-04-14 12:49:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								start_retrodeck
							 
						 
					
						
							
								
									
										
										
										
											2024-10-28 01:01:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# After everything is closed we run the quit function  
						 
					
						
							
								
									
										
										
										
											2024-09-08 00:31:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								quit_retrodeck