From c49a6e8b4722981519d28f9e04a94d9e8796b9ec Mon Sep 17 00:00:00 2001 From: anthonycaccese <anthonycaccese@gmail.com> Date: Mon, 5 Sep 2022 08:23:50 -0400 Subject: [PATCH 001/124] ES_Settings.xml - Theme & Scraper Updates Turn on Screenshots, PhysicalMedia to enable MixImages to be generated Set MiximageBoxSize to small Set GamelistVideoPillarbox to false --- es-configs/es_settings.xml | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/es-configs/es_settings.xml b/es-configs/es_settings.xml index 8feeb468..599b3987 100644 --- a/es-configs/es_settings.xml +++ b/es-configs/es_settings.xml @@ -14,7 +14,7 @@ <bool name="FoldersOnTop" value="true" /> <bool name="GamelistFilters" value="true" /> <bool name="GamelistVideoAudio" value="true" /> -<bool name="GamelistVideoPillarbox" value="true" /> +<bool name="GamelistVideoPillarbox" value="false" /> <bool name="GamelistVideoScanlines" value="false" /> <bool name="IgnoreGamelist" value="false" /> <bool name="InputOnlyFirstController" value="false" /> @@ -49,9 +49,9 @@ <bool name="ScrapeGameNames" value="true" /> <bool name="ScrapeMarquees" value="true" /> <bool name="ScrapeMetadata" value="true" /> -<bool name="ScrapePhysicalMedia" value="false" /> +<bool name="ScrapePhysicalMedia" value="true" /> <bool name="ScrapeRatings" value="true" /> -<bool name="ScrapeScreenshots" value="false" /> +<bool name="ScrapeScreenshots" value="true" /> <bool name="ScrapeTitleScreens" value="false" /> <bool name="ScrapeVideos" value="true" /> <bool name="ScraperExcludeRecursively" value="true" /> @@ -101,7 +101,7 @@ <string name="LaunchScreenDuration" value="normal" /> <string name="MediaDirectory" value="" /> <string name="MenuOpeningEffect" value="scale-up" /> -<string name="MiximageBoxSize" value="medium" /> +<string name="MiximageBoxSize" value="small" /> <string name="MiximagePhysicalMediaSize" value="medium" /> <string name="MiximageResolution" value="1280x800" /> <string name="MiximageScreenshotScaling" value="sharp" /> @@ -118,4 +118,4 @@ <string name="ThemeSet" value="art-book-next" /> <string name="TransitionStyle" value="slide" /> <string name="UIMode" value="full" /> -<string name="UIMode_passkey" value="uuddlrlrba" /> \ No newline at end of file +<string name="UIMode_passkey" value="uuddlrlrba" /> From 1ca1a5a8c1b98b74ebed57a345d06aa39778e997 Mon Sep 17 00:00:00 2001 From: anthonycaccese <anthonycaccese@gmail.com> Date: Mon, 5 Sep 2022 08:38:37 -0400 Subject: [PATCH 002/124] Updated included themes Updated Art-Book-Next (Auto Collection Images, Steam Deck Color Scheme, MixImage Support) Added Alekfull NX (Light Color Version) Added Retrofix Revisited --- net.retrodeck.retrodeck.yml | 32 ++++++++++++++++++-------------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 529f712d..c5857faf 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -242,6 +242,8 @@ modules: # ES-DE - END + # ES-DE Themes - START + - name: art-book-next buildsystem: simple build-commands: @@ -250,27 +252,29 @@ modules: sources: - type: git url: https://github.com/anthonycaccese/art-book-next-retropie.git - commit: 5b953838424e029e7ad534d2a20a7c7f7f5b9e8a - - - name: art-book-next-no-meta + commit: cbd282eb05bb2deb138dad99c3420be56d35c1b8 + + - name: alekfull-nx-light buildsystem: simple build-commands: - - mkdir -p ${FLATPAK_DEST}/share/emulationstation/themes/art-book-next-no-meta/ - - mv -f * ${FLATPAK_DEST}/share/emulationstation/themes/art-book-next-no-meta/ + - mkdir -p ${FLATPAK_DEST}/share/emulationstation/themes/alekfull-nx-light/ + - mv -f * ${FLATPAK_DEST}/share/emulationstation/themes/alekfull-nx-light/ sources: - type: git - url: https://github.com/anthonycaccese/art-book-next-retropie.git - commit: 3b93a8e2bea9d65aee5b0d07f07f56e76653a265 - - - name: art-book-next-miximage + url: https://github.com/anthonycaccese/alekfull-nx-retropie.git + commit: b02be0fde13b1a9c9f09064edbb517901beb62c7 + + - name: retrofix-revisited buildsystem: simple build-commands: - - mkdir -p ${FLATPAK_DEST}/share/emulationstation/themes/art-book-next-miximage/ - - mv -f * ${FLATPAK_DEST}/share/emulationstation/themes/art-book-next-miximage/ + - mkdir -p ${FLATPAK_DEST}/share/emulationstation/themes/retrofix-revisited/ + - mv -f * ${FLATPAK_DEST}/share/emulationstation/themes/retrofix-revisited/ sources: - type: git - url: https://github.com/anthonycaccese/art-book-next-retropie.git - commit: 87b580aceabcf53149e1398039377416bdbd056c + url: https://github.com/anthonycaccese/retrofix-revisited-retropie.git + commit: 6e75c9521426e69eb9abcb39d135d97a17d14568 + + # ES-DE Themes - END # External manifests start @@ -1378,4 +1382,4 @@ modules: sources: - type: git url: https://github.com/XargonWan/RetroDECK.git - branch: cooker \ No newline at end of file + branch: cooker From 03196eb5676e56e72ee2668392026ed3e06ee99e Mon Sep 17 00:00:00 2001 From: Stefano <stefano@newesis.com> Date: Mon, 5 Sep 2022 17:11:54 +0200 Subject: [PATCH 003/124] Added rewind tool (missing racfg location) --- es-configs/tools-gamelist.xml | 7 +++++++ tools/rewind.sh | 23 +++++++++++++++++++++++ 2 files changed, 30 insertions(+) create mode 100755 tools/rewind.sh diff --git a/es-configs/tools-gamelist.xml b/es-configs/tools-gamelist.xml index e59195be..b171f16a 100644 --- a/es-configs/tools-gamelist.xml +++ b/es-configs/tools-gamelist.xml @@ -98,4 +98,11 @@ <nogamecount>true</nogamecount> <nomultiscrape>true</nomultiscrape> </game> + <game> + <path>./rewind.sh</path> + <name>Rewind toggler</name> + <desc>Enable or disable the rewind function for some RetroArch cores.</desc> + <nogamecount>true</nogamecount> + <nomultiscrape>true</nomultiscrape> + </game> </gameList> \ No newline at end of file diff --git a/tools/rewind.sh b/tools/rewind.sh new file mode 100755 index 00000000..abc79a22 --- /dev/null +++ b/tools/rewind.sh @@ -0,0 +1,23 @@ +#!/bin/bash + +racfg="" + +zenity --question \ +--no-wrap --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ +--title "RetroDECK" \ +--text="Do you want to enable the rewind function in RetroArch cores?\n\nNOTE:\nThis may impact on performances expecially on the latest systems." + +if [ $? == 0 ] #yes, enable +then + sed -i 's%rewind_enable = .*%rewind_enable = "true"' $racfg + zenity --info \ + --no-wrap --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ + --title "RetroDECK" \ + --text="Rewind enabled\!\nYou can check on Libretro docs to see which cores supports this function." +else # no, disable + sed -i 's%rewind_enable = .*%rewind_enable = "false"' $racfg + zenity --info \ + --no-wrap --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ + --title "RetroDECK" \ + --text="Rewind disabled." +fi From 389afd40061c8f82daf800791388a0cc10cecb39 Mon Sep 17 00:00:00 2001 From: Stefano <stefano@newesis.com> Date: Mon, 5 Sep 2022 17:12:18 +0200 Subject: [PATCH 004/124] Added rewind tool (missing racfg location) --- es-configs/tools-gamelist.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/tools-gamelist.xml b/es-configs/tools-gamelist.xml index b171f16a..2df4ef4f 100644 --- a/es-configs/tools-gamelist.xml +++ b/es-configs/tools-gamelist.xml @@ -105,4 +105,4 @@ <nogamecount>true</nogamecount> <nomultiscrape>true</nomultiscrape> </game> -</gameList> \ No newline at end of file +</gameList> \ No newline at end of file From 08b82838cd7c01e7a5a011979ba0bcb635e15568 Mon Sep 17 00:00:00 2001 From: XargonWan <xargonwan@gmail.com> Date: Mon, 5 Sep 2022 20:16:14 +0200 Subject: [PATCH 005/124] Added write_coinf to the lockfile script --- retrodeck.sh | 1 + 1 file changed, 1 insertion(+) diff --git a/retrodeck.sh b/retrodeck.sh index c00608a9..842afcb5 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -222,6 +222,7 @@ ra_init() { create_lock() { # creating RetroDECK's lock file and writing the version number in it echo "$version" > "$lockfile" + conf_write } post_update() { From 8a7de033d79a81215ff5d77ae0b038b9d4ea02c9 Mon Sep 17 00:00:00 2001 From: XargonWan <6771419+XargonWan@users.noreply.github.com> Date: Mon, 5 Sep 2022 20:49:54 +0200 Subject: [PATCH 006/124] DUCKSTATION: added first config --- emu-configs/duckstation/settings.ini | 230 +++++++++++++++++++++++++++ retrodeck.sh | 8 + 2 files changed, 238 insertions(+) create mode 100644 emu-configs/duckstation/settings.ini diff --git a/emu-configs/duckstation/settings.ini b/emu-configs/duckstation/settings.ini new file mode 100644 index 00000000..a4ce96e0 --- /dev/null +++ b/emu-configs/duckstation/settings.ini @@ -0,0 +1,230 @@ +[Main] +SettingsVersion = 3 +EmulationSpeed = 1.000000 +FastForwardSpeed = 0.000000 +TurboSpeed = 0.000000 +SyncToHostRefreshRate = false +IncreaseTimerResolution = true +InhibitScreensaver = true +StartPaused = false +StartFullscreen = false +PauseOnFocusLoss = true +PauseOnMenu = true +SaveStateOnExit = true +ConfirmPowerOff = true +LoadDevicesFromSaveStates = true +ApplyGameSettings = true +AutoLoadCheats = true +DisableAllEnhancements = false +RewindEnable = false +RewindFrequency = 10.000000 +RewindSaveSlots = 10 +RunaheadFrameCount = 0.000000 +ControllerBackend = SDL +ControllerEnhancedMode = false +EnableDiscordPresence = false + + +[Console] +Region = Auto +Enable8MBRAM = false + + +[CPU] +ExecutionMode = Recompiler +OverclockNumerator = 1 +OverclockDenominator = 1 +OverclockEnable = false +RecompilerMemoryExceptions = false +RecompilerBlockLinking = true +ICache = false +FastmemMode = true + + +[GPU] +Renderer = Vulkan +ResolutionScale = 1 +Multisamples = 1 +UseDebugDevice = false +UseSoftwareRendererForReadbacks = false +PerSampleShading = false +UseThread = true +ThreadedPresentation = true +TrueColor = false +ScaledDithering = true +TextureFilter = Nearest +DownsampleMode = Disabled +DisableInterlacing = true +ForceNTSCTimings = false +WidescreenHack = false +ChromaSmoothing24Bit = false +PGXPEnable = false +PGXPCulling = true +PGXPTextureCorrection = true +PGXPVertexCache = false +PGXPCPU = false +PGXPPreserveProjFP = false +PGXPTolerance = -1.000000 +PGXPDepthBuffer = false +PGXPDepthClearThreshold = 300.000000 + + +[Display] +CropMode = Overscan +ActiveStartOffset = 0 +ActiveEndOffset = 0 +LineStartOffset = 0 +LineEndOffset = 0 +AspectRatio = Auto (Game Native) +CustomAspectRatioNumerator = 4 +Force4_3For24Bit = false +LinearFiltering = true +IntegerScaling = false +Stretch = false +PostProcessing = false +ShowOSDMessages = true +ShowFPS = false +ShowVPS = false +ShowSpeed = false +ShowResolution = false +ShowStatusIndicators = true +ShowEnhancements = false +Fullscreen = false +VSync = false +DisplayAllFrames = false +PostProcessChain = +MaxFPS = 0.000000 +InternalResolutionScreenshots = false + + +[CDROM] +ReadaheadSectors = 8 +RegionCheck = false +LoadImageToRAM = false +MuteCDAudio = false +ReadSpeedup = 1 +SeekSpeedup = 1 + + +[Audio] +Backend = Cubeb +OutputVolume = 100 +FastForwardVolume = 100 +BufferSize = 2048 +Resampling = true +OutputMuted = 0 +Sync = true +DumpOnBoot = false + + +[BIOS] +SearchDirectory = /home/deck/retrodeck/bios +PathNTSCU = +PathNTSCJ = +PathPAL = +PatchTTYEnable = false +PatchFastBoot = false + + +[Controller1] +Type = DigitalController +ButtonUp = Keyboard/W +ButtonDown = Keyboard/S +ButtonLeft = Keyboard/A +ButtonRight = Keyboard/D +ButtonSelect = Keyboard/Backspace +ButtonStart = Keyboard/Return +ButtonTriangle = Keyboard/Keypad+8 +ButtonCross = Keyboard/Keypad+2 +ButtonSquare = Keyboard/Keypad+4 +ButtonCircle = Keyboard/Keypad+6 +ButtonL1 = Keyboard/Q +ButtonL2 = Keyboard/1 +ButtonR1 = Keyboard/E +ButtonR2 = Keyboard/3 + + +[Controller2] +Type = None + + +[Controller3] +Type = None + + +[Controller4] +Type = None + + +[Controller5] +Type = None + + +[Controller6] +Type = None + + +[Controller7] +Type = None + + +[Controller8] +Type = None + + +[MemoryCards] +Card1Type = PerGameTitle +Card2Type = None +UsePlaylistTitle = true + + +[ControllerPorts] +MultitapMode = Disabled + + +[Logging] +LogLevel = Info +LogFilter = +LogToConsole = true +LogToDebug = false +LogToWindow = false +LogToFile = false + + +[Debug] +ShowVRAM = false +DumpCPUToVRAMCopies = false +DumpVRAMToCPUCopies = false +ShowGPUState = false +ShowCDROMState = false +ShowSPUState = false +ShowTimersState = false +ShowMDECState = false +ShowDMAState = false + + +[Hacks] +DMAMaxSliceTicks = 1000 +DMAHaltTicks = 100 +GPUFIFOSize = 16 +GPUMaxRunAhead = 128 + + +[Hotkeys] +FastForward = Keyboard/Tab +TogglePause = Keyboard/Space +ToggleFullscreen = Keyboard/Alt+Return +Screenshot = Keyboard/F10 +OpenQuickMenu = Keyboard/Escape + + +[Cheevos] +Enabled = true +TestMode = false +UnofficialTestMode = false +UseFirstDiscFromPlaylist = true + + +[UI] +MainWindowGeometry = AdnQywADAAAAAADrAAAAEQAABAoAAALpAAAA6wAAAC4AAAQKAAAC6QAAAAAAAAAABQAAAADrAAAALgAABAoAAALp +MainWindowState = AAAA/wAAAAD9AAAAAAAAAyAAAAI9AAAABAAAAAQAAAAIAAAACPwAAAABAAAAAgAAAAEAAAAOAHQAbwBvAGwAQgBhAHIBAAAAAP////8AAAAAAAAAAA== diff --git a/retrodeck.sh b/retrodeck.sh index 842afcb5..34e2829e 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -169,6 +169,14 @@ standalones_init() { cp -fv $emuconfigs/ppssppsdl/* /var/config/ppsspp/PSP/SYSTEM/ sed -i 's#/home/deck/retrodeck#'$rdhome'#g' /var/config/ppsspp/PSP/SYSTEM/ppsspp.ini + # PPSSPPSDL + echo "------------------------" + echo "Initializing DUCKSTATION" + echo "------------------------" + mkdir -p /var/config/duckstation/ + cp -fv $emuconfigs/duckstation/* /var/config/duckstation + sed -i 's#/home/deck/retrodeck/bios#'$rdhome/bios'#g' /var/config/ppsspp/PSP/SYSTEM/settings.ini + # PICO-8 # Moved PICO-8 stuff in the finit as only it knows here roms folders is From cf4eb42855e6d16547170763efd3c3c524331000 Mon Sep 17 00:00:00 2001 From: anthonycaccese <anthonycaccese@gmail.com> Date: Mon, 5 Sep 2022 16:02:58 -0400 Subject: [PATCH 007/124] Update Alekfull-NX Theme to Latest Version Updated metadata layout --- net.retrodeck.retrodeck.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index c5857faf..246c908b 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -262,7 +262,7 @@ modules: sources: - type: git url: https://github.com/anthonycaccese/alekfull-nx-retropie.git - commit: b02be0fde13b1a9c9f09064edbb517901beb62c7 + commit: 67c8c8dee086bd06bcdc6dc34bb9bef1e1c11be7 - name: retrofix-revisited buildsystem: simple From 481b2f8c559537a48f89b05a5d1519416ee925e4 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 6 Sep 2022 14:46:59 +0200 Subject: [PATCH 008/124] Simplyfing variable system --- global.sh | 27 ++++++++++++++++--- net.retrodeck.retrodeck.yml | 2 +- retrodeck.sh | 52 ++++++++++++++++--------------------- 3 files changed, 47 insertions(+), 34 deletions(-) diff --git a/global.sh b/global.sh index 6f69a74e..0c69693d 100755 --- a/global.sh +++ b/global.sh @@ -2,9 +2,22 @@ # This file is containing some global function needed for the script such as the config file tools -rd_conf="/var/config/retrodeck/retrodeck.cfg" +rd_conf="/var/config/retrodeck/retrodeck.cfg" # RetroDECK config file path -conf_init() { +# if everything is working put this stuff down there +if [ ! -f $rd_conf ] +then + # Init default values, this may be overwritten by retrodeck.cfg as it sourced later with global.sh + lockfile="/var/config/retrodeck/.lock" # where the lockfile is located + emuconfigs="/app/retrodeck/emu-configs" # folder with all the default emulator configs + sdcard="/run/media/mmcblk0p1" # Steam Deck SD default path + rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck + media_folder="$HOME/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into + themes_folder="$HOME/retrodeck/themes" # the themes folder + hard_version="$(cat '/app/retrodeck/version')" # hardcoded version (in the readonly filesystem) +fi + +#conf_init() { # initializing and reading the retrodeck config file if [ ! -f $rd_conf ] then # I have to initialize the variables as they cannot be red from an empty config file @@ -16,7 +29,13 @@ conf_init() { echo "#!/bin/bash" >> $rd_conf # version info taken from the version file - version="$(cat /app/retrodeck/version)" + # if the version variable is not set means that is a first installation, so we populate with the hardcoded version + if [ -z $version ] + then + version="$hard_version" + #else + # version="$version" + fi echo "version=$version" >> $rd_conf # the retrodeck home, aka ~/retrodeck @@ -41,7 +60,7 @@ conf_init() { echo "Loading it" source $rd_conf fi -} +#} conf_write() { # writes the variables in the retrodeck config file diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 246c908b..77bd3695 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -61,7 +61,7 @@ modules: # This module is used to define the RetroDECK version # If the version is set as cooker it will automatically generate the version tag based on the date # else it will just put what is written, "v" is not needed - # The version number is stored in /var/conf/retrodeck/version + # The version number is hardcoded in /app/retrodeck/version # # UPDATE STEPS FOR MAIN: # [ ] Update the VERSION variable diff --git a/retrodeck.sh b/retrodeck.sh index 34e2829e..963a5158 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -1,17 +1,7 @@ #!/bin/bash -# Init default values, this may be overwritten by retrodeck.cfg as it sourced later with global.sh - -lockfile="/var/config/retrodeck/.lock" # where the lockfile is located -emuconfigs="/app/retrodeck/emu-configs" # folder with all the default emulator configs -sdcard="/run/media/mmcblk0p1" # Steam Deck SD default path -rd_conf="/var/config/retrodeck/retrodeck.cfg" # RetroDECK config file path -version="$(cat /app/retrodeck/version)" # version info taken from the version file -rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck -media_folder="$HOME/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into -themes_folder="$HOME/retrodeck/themes" # the themes folder - source /app/bin/global.sh +#conf_init # We moved the lockfile in /var/config/retrodeck in order to solve issue #53 - Remove in a few versions if [ -f "$HOME/retrodeck/.lock" ] @@ -228,8 +218,8 @@ ra_init() { } create_lock() { - # creating RetroDECK's lock file and writing the version number in it - echo "$version" > "$lockfile" + # creating RetroDECK's lock file and writing the version in the config file + touch "$lockfile" conf_write } @@ -438,7 +428,7 @@ finit() { for i in "$@"; do case $i in -h*|--help*) - echo "RetroDECK v""$(cat /var/config/retrodeck/version)" + echo "RetroDECK v""$version" echo " Usage: flatpak run [FLATPAK-RUN-OPTION] net.retrodeck-retrodeck [ARGUMENTS] @@ -459,12 +449,12 @@ https://retrodeck.net exit ;; --version*|-v*) - conf_init + #conf_init echo "RetroDECK v$version" exit ;; --info-msg*) - conf_init + #conf_init echo "RetroDECK v$version" echo "RetroDECK config file is in: $rd_conf" echo "Contents:" @@ -497,23 +487,27 @@ https://retrodeck.net done # UPDATE TRIGGERED -# if lockfile exists but the version doesn't match -if [ -f "$lockfile" ] && [ "$(cat "$lockfile")" != "$version" ]; +# if lockfile exists +if [ -f "$lockfile" ] then - echo "Lockfile version is "$(cat "$lockfile")" but the actual version is $version" - conf_init # Initializing/reading the config file (sourced from global.sh) - post_update # Executing post update script - conf_write # Writing variables in the config file (sourced from global.sh) - start_retrodeck - exit 0 -fi -# LOCKFILE REMOVED + #conf_init # Initializing/reading the config file (sourced from global.sh) + + # ...but the version doesn't match with the config file + if [ "$hard_version" != "$version" ]; + then + echo "Config file's version is "$(cat "$version")" but the actual version is $hard_version" + post_update # Executing post update script + conf_write # Writing variables in the config file (sourced from global.sh) + start_retrodeck + exit 0 + fi + +# Else, LOCKFILE IS NOT EXISTING (WAS REMOVED) # if the lock file doesn't exist at all means that it's a fresh install or a triggered reset -if [ ! -f "$lockfile" ]; -then +else echo "Lockfile not found" - conf_init # Initializing/reading the config file (sourced from global.sh) + #conf_init # Initializing/reading the config file (sourced from global.sh) finit # Executing First/Force init conf_write # Writing variables in the config file (sourced from global.sh) exit 0 From f2c6dd59bb5c86be05a9d5c8932118074d55b2d0 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 6 Sep 2022 15:24:36 +0200 Subject: [PATCH 009/124] Simplyfing variable system - step 2 --- global.sh | 76 +++++++++++++++++----------------------------------- retrodeck.sh | 1 - 2 files changed, 24 insertions(+), 53 deletions(-) diff --git a/global.sh b/global.sh index 0c69693d..98829902 100755 --- a/global.sh +++ b/global.sh @@ -2,66 +2,38 @@ # This file is containing some global function needed for the script such as the config file tools -rd_conf="/var/config/retrodeck/retrodeck.cfg" # RetroDECK config file path +# Static variables +rd_conf="/var/config/retrodeck/retrodeck.cfg" # RetroDECK config file path +emuconfigs="/app/retrodeck/emu-configs" # folder with all the default emulator configs +lockfile="/var/config/retrodeck/.lock" # where the lockfile is located +sdcard="/run/media/mmcblk0p1" # Steam Deck SD default path +hard_version="$(cat '/app/retrodeck/version')" # hardcoded version (in the readonly filesystem) -# if everything is working put this stuff down there + +# If there is no config file I initalize the file with the the default values if [ ! -f $rd_conf ] then - # Init default values, this may be overwritten by retrodeck.cfg as it sourced later with global.sh - lockfile="/var/config/retrodeck/.lock" # where the lockfile is located - emuconfigs="/app/retrodeck/emu-configs" # folder with all the default emulator configs - sdcard="/run/media/mmcblk0p1" # Steam Deck SD default path + + echo "RetroDECK config file not found in $rd_conf" + echo "Initializing" + + echo "#!/bin/bash" >> $rd_conf + version="$hard_version" # if we are here means that the we are in a new installation, so the version is valorized with the hardcoded one rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck + roms_folder="$rdhome/roms" # the default roms folder path media_folder="$HOME/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into themes_folder="$HOME/retrodeck/themes" # the themes folder - hard_version="$(cat '/app/retrodeck/version')" # hardcoded version (in the readonly filesystem) + + # writing the needed variables in the config file + conf_write + +# If the config file is existing i just read the variables (source it) +else + echo "Found RetroDECK config file in $rd_conf" + echo "Loading it" + source $rd_conf fi -#conf_init() { - # initializing and reading the retrodeck config file - if [ ! -f $rd_conf ] - then # I have to initialize the variables as they cannot be red from an empty config file - echo "RetroDECK config file not found in $rd_conf" - echo "Initializing" - touch $rd_conf - - # Variables to manage: adding a variable here means adding it to conf_write() - echo "#!/bin/bash" >> $rd_conf - - # version info taken from the version file - # if the version variable is not set means that is a first installation, so we populate with the hardcoded version - if [ -z $version ] - then - version="$hard_version" - #else - # version="$version" - fi - echo "version=$version" >> $rd_conf - - # the retrodeck home, aka ~/retrodeck - rdhome="$HOME/retrodeck" - echo "rdhome=$rdhome" >> $rd_conf - - # default roms folder location (internal) - roms_folder="$roms_folder" - echo "roms_folder=$roms_folder" >> $rd_conf - - # default media folder location (internal) - media_folder="$media_folder" - echo "media_folder=$media_folder" >> $rd_conf - - # default themes folder location (internal) - themes_folder="$themes_folder" - echo "themes_folder=$themes_folder" >> $rd_conf - - - else # i just read the variables - echo "Found RetroDECK config file in $rd_conf" - echo "Loading it" - source $rd_conf - fi -#} - conf_write() { # writes the variables in the retrodeck config file diff --git a/retrodeck.sh b/retrodeck.sh index 963a5158..f5ba4071 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -1,7 +1,6 @@ #!/bin/bash source /app/bin/global.sh -#conf_init # We moved the lockfile in /var/config/retrodeck in order to solve issue #53 - Remove in a few versions if [ -f "$HOME/retrodeck/.lock" ] From 38fd3088233cb02a21c4470328c8018ccd935263 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 6 Sep 2022 17:46:48 +0200 Subject: [PATCH 010/124] CITRA: trying to fix shader cache --- es-configs/es_find_rules.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/es_find_rules.xml b/es-configs/es_find_rules.xml index baa96687..3e71b426 100644 --- a/es-configs/es_find_rules.xml +++ b/es-configs/es_find_rules.xml @@ -100,7 +100,7 @@ <emulator name="CITRA"> <!-- Nintendo 3DS emulator Citra --> <rule type="systempath"> - <entry>citra</entry> + <entry>citra-qt</entry> <entry>citra-emu.citra-nightly</entry> <entry>org.citra_emu.citra</entry> </rule> From 53a5d81f5ebaccad3bbc6083f6bcd0082c078e75 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 6 Sep 2022 18:04:44 +0200 Subject: [PATCH 011/124] OPERA-3DO: removed aoutload (workaround), removed unsupported ext --- emu-configs/retroarch-core-options.cfg | 1 + es-configs/es_systems.xml | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/emu-configs/retroarch-core-options.cfg b/emu-configs/retroarch-core-options.cfg index b7ab1bd2..4656d63a 100644 --- a/emu-configs/retroarch-core-options.cfg +++ b/emu-configs/retroarch-core-options.cfg @@ -385,6 +385,7 @@ mupen64plus-txHiresEnable = "False" mupen64plus-txHiresFullAlphaChannel = "False" mupen64plus-u-cbutton = "C4" mupen64plus-virefresh = "Auto" +opera_savestate_auto_load = "False" pcsx2_accurate_date = "enabled" pcsx2_anisotropic_filter = "0" pcsx2_aspect_ratio = "0" diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index 8c898921..73957de1 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -5,7 +5,7 @@ <name>3do</name> <fullname>3DO</fullname> <path>%ROMPATH%/3do</path> - <extension>.iso .ISO .bin .BIN .chd .CHD .cue .CUE .7z .7Z .zip .ZIP</extension> + <extension>.iso .ISO .bin .BIN .chd .CHD .cue .CUE</extension> <command label="Opera">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/opera_libretro.so %ROM%</command> <platform>3do</platform> <theme>3do</theme> From 9d47a3a8c40ab921c519bb1efa7090014ae7fe79 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 6 Sep 2022 21:34:31 +0200 Subject: [PATCH 012/124] Workflow: fix the stuck mount --- .github/workflows/cooker-selfhosted.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/cooker-selfhosted.yml b/.github/workflows/cooker-selfhosted.yml index 5f394a55..9b039617 100644 --- a/.github/workflows/cooker-selfhosted.yml +++ b/.github/workflows/cooker-selfhosted.yml @@ -34,6 +34,7 @@ jobs: - name: Initialize enviornment run: | + while [[ $(findmnt /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles) != "" ]]; do sudo umount /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles; done git pull git submodule init git submodule update From 0af81f45ee554580e5aad9f27b0dd0a99044cc87 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 6 Sep 2022 21:40:27 +0200 Subject: [PATCH 013/124] Workflow: fix the stuck mount -fix2 --- .github/workflows/cooker-selfhosted.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/cooker-selfhosted.yml b/.github/workflows/cooker-selfhosted.yml index 9b039617..6c779de7 100644 --- a/.github/workflows/cooker-selfhosted.yml +++ b/.github/workflows/cooker-selfhosted.yml @@ -17,6 +17,9 @@ jobs: runs-on: self-hosted steps: + - name: Remove stuck mounts + run: while [[ $(findmnt /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles) != "" ]]; do sudo umount /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles; done + - name: Get date for artifacts id: date run: echo "::set-output name=date::$(date +'%Y%m%d_%H%M%S')" @@ -34,7 +37,6 @@ jobs: - name: Initialize enviornment run: | - while [[ $(findmnt /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles) != "" ]]; do sudo umount /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles; done git pull git submodule init git submodule update From 2fb7186d7ac42a69d403f51617757c438abb4d7b Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 6 Sep 2022 21:42:10 +0200 Subject: [PATCH 014/124] Workflow: fix the stuck mount -fix3 --- .github/workflows/cooker-selfhosted.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/cooker-selfhosted.yml b/.github/workflows/cooker-selfhosted.yml index 6c779de7..a37c1870 100644 --- a/.github/workflows/cooker-selfhosted.yml +++ b/.github/workflows/cooker-selfhosted.yml @@ -18,7 +18,7 @@ jobs: steps: - name: Remove stuck mounts - run: while [[ $(findmnt /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles) != "" ]]; do sudo umount /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles; done + run: umount -f /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles/* - name: Get date for artifacts id: date From 60e5eb0ecf541b3e112bc0e19821f3c449d42ef2 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 6 Sep 2022 21:43:15 +0200 Subject: [PATCH 015/124] Workflow: fix the stuck mount -fix4 --- .github/workflows/cooker-selfhosted.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/cooker-selfhosted.yml b/.github/workflows/cooker-selfhosted.yml index a37c1870..d3f7729e 100644 --- a/.github/workflows/cooker-selfhosted.yml +++ b/.github/workflows/cooker-selfhosted.yml @@ -18,7 +18,8 @@ jobs: steps: - name: Remove stuck mounts - run: umount -f /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles/* + run: sudo umount -f /home/administrator/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles/* + continue-on-error: true - name: Get date for artifacts id: date From 361e28396f098fa4c3a85f7fc2c0cb302028a528 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 7 Sep 2022 20:29:23 +0200 Subject: [PATCH 016/124] Removed unused fix theme tool --- es-configs/tools-gamelist.xml | 7 ------- tools/theme-fix.sh | 31 ------------------------------- 2 files changed, 38 deletions(-) delete mode 100644 tools/theme-fix.sh diff --git a/es-configs/tools-gamelist.xml b/es-configs/tools-gamelist.xml index 2df4ef4f..3a838881 100644 --- a/es-configs/tools-gamelist.xml +++ b/es-configs/tools-gamelist.xml @@ -84,13 +84,6 @@ <nogamecount>true</nogamecount> <nomultiscrape>true</nomultiscrape> </game> --> - <game> - <path>./theme-fix.sh</path> - <name>Theme fix</name> - <desc>Clean some of the scraped data in order to beautify the new theme. This is needed if you got scraped data since v0.4.2 or earlier.</desc> - <nogamecount>true</nogamecount> - <nomultiscrape>true</nomultiscrape> - </game> <game> <path>./configure-emulators.sh</path> <name>Configure Emulators</name> diff --git a/tools/theme-fix.sh b/tools/theme-fix.sh deleted file mode 100644 index 66c71254..00000000 --- a/tools/theme-fix.sh +++ /dev/null @@ -1,31 +0,0 @@ -#!/bin/bash - -zenity \ ---icon-name=net.retrodeck.retrodeck \ ---question \ ---no-wrap \ ---window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ ---title "RetroDECK" \ ---ok-label "Yes" \ ---cancel-label "No" \ ---text="This tool is will clean some unuseful scraped data in order to beautify the theme.\nDo you want to delete and fix it?" - -if [ $? == 0 ] #yes - Internal -then - find ~/retrodeck/.downloaded_media -name miximages -type d -print0|xargs -0 rm -rfv -- - find ~/retrodeck/.downloaded_media -name 3dboxes -type d -print0|xargs -0 rm -rfv -- - find ~/retrodeck/.downloaded_media -name titlescreens -type d -print0|xargs -0 rm -rfv -- - find ~/retrodeck/.downloaded_media -name backcovers -type d -print0|xargs -0 rm -rfv -- - find ~/retrodeck/.downloaded_media -namephysicalmedia -type d -print0|xargs -0 rm -rfv -- - find ~/retrodeck/.downloaded_media -namescreenshots -type d -print0|xargs -0 rm -rfv -- - rm -rf ~/retrodeck/.downloaded_media/thumbnails - ln -s ~/retrodeck/.downloaded_media/covers ~/retrodeck/.downloaded_media/thumbnails -fi - -zenity \ ---icon-name=net.retrodeck.retrodeck \ ---info \ ---no-wrap \ ---window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ ---title "RetroDECK" \ ---text="Scraped data is now cleaned and fixed, please restart RetroDECK to reload the games list." \ No newline at end of file From 7124cfda342553f31649c4ebe4050106d396c78a Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 7 Sep 2022 20:37:27 +0200 Subject: [PATCH 017/124] Updated Duckstation config --- tools/move-roms.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/move-roms.sh b/tools/move-roms.sh index 85b83fc8..00dac00a 100644 --- a/tools/move-roms.sh +++ b/tools/move-roms.sh @@ -8,7 +8,7 @@ then exit 0 fi -conf_init +#conf_init zenity --question --no-wrap --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" --title "RetroDECK" --cancel-label="Cancel" --ok-label "Browse" --text="The roms folder is now: $roms_folder\nplease select the new location.\nA retrodeck/roms folder will be created starting from the directory that you selected." if [ $? == 1 ] #cancel From dc04ad1dc38e5524cc49da0977729da1d537fb1c Mon Sep 17 00:00:00 2001 From: XargonWan <6771419+XargonWan@users.noreply.github.com> Date: Wed, 7 Sep 2022 20:45:50 +0200 Subject: [PATCH 018/124] SX2: Updated config for QT --- emu-configs/PCSX2/GS.ini | 89 ++++++ emu-configs/PCSX2/PCSX2.ini | 449 +++++++++++++++++++++++++++ emu-configs/{ => PCSX2}/PCSX2_ui.ini | 2 +- emu-configs/{ => PCSX2}/PCSX2_vm.ini | 0 4 files changed, 539 insertions(+), 1 deletion(-) create mode 100644 emu-configs/PCSX2/GS.ini create mode 100644 emu-configs/PCSX2/PCSX2.ini rename emu-configs/{ => PCSX2}/PCSX2_ui.ini (98%) rename emu-configs/{ => PCSX2}/PCSX2_vm.ini (100%) diff --git a/emu-configs/PCSX2/GS.ini b/emu-configs/PCSX2/GS.ini new file mode 100644 index 00000000..d91aa444 --- /dev/null +++ b/emu-configs/PCSX2/GS.ini @@ -0,0 +1,89 @@ +CaptureHeight = 480 +CaptureWidth = 640 +DisableDualSourceBlend = 0 +DisableFramebufferFetch = 0 +DumpReplaceableMipmaps = 0 +DumpReplaceableTextures = 0 +DumpTexturesWithFMVActive = 0 +HWDisableReadbacks = 0 +IntegerScaling = 0 +LoadTextureReplacements = 0 +LoadTextureReplacementsAsync = 1 +MaxAnisotropy = 0 +NTSC_Saturation = 1 +OsdScale = 100 +OsdShowCPU = 0 +OsdShowFPS = 0 +OsdShowGPU = 0 +OsdShowGSStats = 0 +OsdShowIndicators = 1 +OsdShowMessages = 1 +OsdShowResolution = 0 +OsdShowSpeed = 0 +OverrideGeometryShaders = -1 +OverrideTextureBarriers = -1 +PrecacheTextureReplacements = 0 +Renderer = 14 +ShadeBoost = 0 +ShadeBoost_Brightness = 50 +ShadeBoost_Contrast = 50 +ShadeBoost_Saturation = 50 +TVShader = 0 +ThreadedPresentation = 0 +UseBlitSwapChain = 0 +UseDebugDevice = 0 +UserHacks = 1 +UserHacks_AutoFlush = 0 +UserHacks_CPU_FB_Conversion = 0 +UserHacks_DisableDepthSupport = 0 +UserHacks_DisablePartialInvalidation = 1 +UserHacks_Disable_Safe_Features = 0 +UserHacks_HalfPixelOffset = 0 +UserHacks_Half_Bottom_Override = -1 +UserHacks_SkipDraw_End = 0 +UserHacks_SkipDraw_Start = 0 +UserHacks_TCOffsetX = 0 +UserHacks_TCOffsetY = 0 +UserHacks_TextureInsideRt = 0 +UserHacks_TriFilter = 0 +UserHacks_WildHack = 0 +UserHacks_align_sprite_X = 0 +UserHacks_merge_pp_sprite = 0 +UserHacks_round_sprite_offset = 0 +aa1 = 1 +accurate_blending_unit = 1 +accurate_date = 1 +autoflush_sw = 1 +capture_enabled = 0 +capture_out_dir = /tmp/GS_Capture +capture_threads = 4 +conservative_framebuffer = 1 +crc_hack_level = -1 +disable_shader_cache = 0 +dithering_ps2 = 2 +dump = 0 +extrathreads = 2 +extrathreads_height = 4 +filter = 2 +fxaa = 0 +interlace = 7 +linear_present = 1 +mipmap = 1 +mipmap_hw = -1 +override_GL_ARB_shader_image_load_store = -1 +override_GL_ARB_sparse_texture = -1 +paltex = 0 +png_compression_level = 1 +preload_frame_with_gs_data = 0 +save = 0 +savef = 0 +savel = 5000 +saven = 0 +savet = 0 +savez = 0 +shaderfx = 0 +shaderfx_conf = shaders/GS_FX_Settings.ini +shaderfx_glsl = shaders/GS.fx +texture_preloading = 0 +upscale_multiplier = 2 +wrap_gs_mem = 0 diff --git a/emu-configs/PCSX2/PCSX2.ini b/emu-configs/PCSX2/PCSX2.ini new file mode 100644 index 00000000..26bb2f01 --- /dev/null +++ b/emu-configs/PCSX2/PCSX2.ini @@ -0,0 +1,449 @@ +[UI] +SettingsVersion = 1 +MainWindowGeometry = AdnQywADAAAAAAAAAAAAAAAAA7UAAAJ/AAAAAAAAAAAAAAO1AAACfwAAAAAAAAAABQAAAAAAAAAAAAAAA7UAAAJ/ +MainWindowState = AAAA/wAAAAD9AAAAAAAAA7YAAAJXAAAABAAAAAQAAAAIAAAACPwAAAABAAAAAgAAAAEAAAAOAHQAbwBvAGwAQgBhAHIAAAAAAP////8AAAAAAAAAAA== +PauseOnFocusLoss = true +StartFullscreen = true + + +[EmuCore] +CdvdVerboseReads = false +CdvdDumpBlocks = false +CdvdShareWrite = false +EnablePatches = true +EnableCheats = false +EnablePINE = false +EnableWideScreenPatches = false +EnableNoInterlacingPatches = false +EnableRecordingTools = true +EnableGameFixes = true +SaveStateOnShutdown = true +ConsoleToStdio = false +HostFs = false +PatchBios = false +PatchRegion = +BackupSavestate = true +SavestateZstdCompression = true +McdEnableEjection = true +McdFolderAutoManage = true +GzipIsoIndexTemplate = $(f).pindex.tmp +BlockDumpSaveDirectory = + + +[EmuCore/Speedhacks] +EECycleRate = 0 +EECycleSkip = 0 +fastCDVD = false +IntcStat = true +WaitLoop = true +vuFlagHack = true +vuThread = true +vu1Instant = true + + +[EmuCore/CPU] +FPU.DenormalsAreZero = true +FPU.FlushToZero = true +FPU.Roundmode = 3 +AffinityControlMode = 0 +VU.DenormalsAreZero = true +VU.FlushToZero = true +VU.Roundmode = 3 + + +[EmuCore/CPU/Recompiler] +EnableEE = true +EnableIOP = true +EnableEECache = false +EnableVU0 = true +EnableVU1 = true +vuOverflow = true +vuExtraOverflow = false +vuSignOverflow = false +vuUnderflow = false +fpuOverflow = true +fpuExtraOverflow = false +fpuFullMode = false +StackFrameChecks = false +PreBlockCheckEE = false +PreBlockCheckIOP = false + + +[EmuCore/GS] +VsyncQueueSize = 2 +FrameLimitEnable = true +VsyncEnable = 0 +FramerateNTSC = 59.940000 +FrameratePAL = 50.000000 +SyncToHostRefreshRate = false +AspectRatio = Auto 4:3/3:2 +FMVAspectRatioSwitch = Off +Zoom = 100.000000 +StretchY = 100.000000 +CropLeft = 0 +CropTop = 0 +CropRight = 0 +CropBottom = 0 +pcrtc_antiblur = true +disable_interlace_offset = false +pcrtc_offsets = false +pcrtc_overscan = false +IntegerScaling = false +linear_present = true +UseDebugDevice = false +UseBlitSwapChain = false +disable_shader_cache = false +DisableDualSourceBlend = false +DisableFramebufferFetch = false +ThreadedPresentation = false +SkipDuplicateFrames = false +OsdShowMessages = true +OsdShowSpeed = false +OsdShowFPS = false +OsdShowCPU = false +OsdShowGPU = false +OsdShowResolution = false +OsdShowGSStats = false +OsdShowIndicators = true +HWDisableReadbacks = false +accurate_date = true +paltex = false +autoflush_sw = true +preload_frame_with_gs_data = false +wrap_gs_mem = false +mipmap = true +UserHacks = false +UserHacks_align_sprite_X = false +UserHacks_AutoFlush = false +UserHacks_CPU_FB_Conversion = false +UserHacks_DisableDepthSupport = false +UserHacks_DisablePartialInvalidation = false +UserHacks_Disable_Safe_Features = false +UserHacks_merge_pp_sprite = false +UserHacks_WildHack = false +UserHacks_TextureInsideRt = false +fxaa = false +ShadeBoost = false +shaderfx = false +dump = false +save = false +savef = false +savet = false +savez = false +DumpReplaceableTextures = false +DumpReplaceableMipmaps = false +DumpTexturesWithFMVActive = false +DumpDirectTextures = true +DumpPaletteTextures = true +LoadTextureReplacements = false +LoadTextureReplacementsAsync = true +PrecacheTextureReplacements = false +deinterlace = 7 +OsdScale = 100 +Renderer = -1 +upscale_multiplier = 1 +mipmap_hw = -1 +accurate_blending_unit = 1 +crc_hack_level = -1 +filter = 2 +texture_preloading = 2 +GSDumpCompression = 1 +dithering_ps2 = 2 +MaxAnisotropy = 0 +extrathreads = 2 +extrathreads_height = 4 +TVShader = 0 +UserHacks_SkipDraw_Start = 0 +UserHacks_SkipDraw_End = 0 +UserHacks_Half_Bottom_Override = -1 +UserHacks_HalfPixelOffset = 0 +UserHacks_round_sprite_offset = 0 +UserHacks_TCOffsetX = 0 +UserHacks_TCOffsetY = 0 +UserHacks_CPUSpriteRenderBW = 0 +UserHacks_TriFilter = -1 +OverrideTextureBarriers = -1 +OverrideGeometryShaders = -1 +ShadeBoost_Brightness = 50 +ShadeBoost_Contrast = 50 +ShadeBoost_Saturation = 50 +saven = 0 +savel = 5000 +Adapter = +shaderfx_conf = shaders/GS_FX_Settings.ini +shaderfx_glsl = shaders/GS.fx + + +[SPU2/Mixing] +Interpolation = 5 +FinalVolume = 100 +VolumeAdjustC = 0.000000 +VolumeAdjustFL = 0.000000 +VolumeAdjustFR = 0.000000 +VolumeAdjustBL = 0.000000 +VolumeAdjustBR = 0.000000 +VolumeAdjustSL = 0.000000 +VolumeAdjustSR = 0.000000 +VolumeAdjustLFE = 0.000000 + + +[SPU2/Output] +OutputModule = cubeb +Latency = 100 +SynchMode = 0 +SpeakerConfiguration = 0 +DplDecodingLevel = 0 + + +[DEV9/Eth] +EthEnable = false +EthApi = Unset +EthDevice = +EthLogDNS = false +InterceptDHCP = false +PS2IP = 0.0.0.0 +Mask = 0.0.0.0 +Gateway = 0.0.0.0 +DNS1 = 0.0.0.0 +DNS2 = 0.0.0.0 +AutoMask = true +AutoGateway = true +ModeDNS1 = Auto +ModeDNS2 = Auto + + +[DEV9/Eth/Hosts] +Count = 0 + + +[DEV9/Hdd] +HddEnable = false +HddFile = DEV9hdd.raw +HddSizeSectors = 83886080 + + +[EmuCore/Gamefixes] +VuAddSubHack = false +FpuMulHack = false +FpuNegDivHack = false +XgKickHack = false +EETimingHack = false +SoftwareRendererFMVHack = false +SkipMPEGHack = false +OPHFlagHack = false +DMABusyHack = false +VIFFIFOHack = false +VIF1StallHack = false +GIFFIFOHack = false +GoemonTlbHack = false +IbitHack = false +VUSyncHack = false +VUOverflowHack = false +BlitInternalFPSHack = false + + +[EmuCore/Profiler] +Enabled = false +RecBlocks_EE = true +RecBlocks_IOP = true +RecBlocks_VU0 = true +RecBlocks_VU1 = true + + +[EmuCore/Debugger] +ShowDebuggerOnStart = false +AlignMemoryWindowStart = true +FontWidth = 8 +FontHeight = 12 +WindowWidth = 0 +WindowHeight = 0 +MemoryViewBytesPerRow = 16 + + +[EmuCore/TraceLog] +Enabled = false +EE.bitset = 0 +IOP.bitset = 0 + + +[Filenames] +BIOS = + + +[Framerate] +NominalScalar = 1.000000 +TurboScalar = 2.000000 +SlomoScalar = 0.500000 + + +[MemoryCards] +Slot1_Enable = true +Slot1_Filename = Mcd001.ps2 +Slot2_Enable = true +Slot2_Filename = Mcd002.ps2 +Multitap1_Slot2_Enable = false +Multitap1_Slot2_Filename = Mcd-Multitap1-Slot02.ps2 +Multitap1_Slot3_Enable = false +Multitap1_Slot3_Filename = Mcd-Multitap1-Slot03.ps2 +Multitap1_Slot4_Enable = false +Multitap1_Slot4_Filename = Mcd-Multitap1-Slot04.ps2 +Multitap2_Slot2_Enable = false +Multitap2_Slot2_Filename = Mcd-Multitap2-Slot02.ps2 +Multitap2_Slot3_Enable = false +Multitap2_Slot3_Filename = Mcd-Multitap2-Slot03.ps2 +Multitap2_Slot4_Enable = false +Multitap2_Slot4_Filename = Mcd-Multitap2-Slot04.ps2 + + +[Folders] +Bios = ../../../../../retrodeck/bios/pcsx2 +Snapshots = ../../../../../retrodeck/screenshots +SaveStates = ../../../../../retrodeck/states +MemoryCards = ../../../../../retrodeck/saves/pcsx2 +Logs = logs +Cheats = cheats +CheatsWS = cheats_ws +CheatsNI = cheats_ni +Cache = cache +Textures = textures +InputProfiles = inputprofiles + + +[InputSources] +SDL = true +SDLControllerEnhancedMode = false +XInput = false +RawInput = false + + +[Hotkeys] +ToggleFullscreen = Keyboard/Alt & Keyboard/Return +CycleAspectRatio = Keyboard/F6 +CycleInterlaceMode = Keyboard/F5 +CycleMipmapMode = Keyboard/Insert +GSDumpMultiFrame = Keyboard/Control & Keyboard/Shift & Keyboard/F8 +Screenshot = SDL-0/Back & SDL-0/A +GSDumpSingleFrame = Keyboard/Shift & Keyboard/F8 +ToggleSoftwareRendering = Keyboard/F9 +InputRecToggleMode = Keyboard/Shift & Keyboard/R +LoadStateFromSlot = SDL-0/Back & SDL-0/LeftShoulder +SaveStateToSlot = SDL-0/Back & SDL-0/RightShoulder +NextSaveStateSlot = SDL-0/Back & SDL-0/DPadUp +PreviousSaveStateSlot = SDL-0/Back & SDL-0/DPadDown +OpenPauseMenu = SDL-0/Back & SDL-0/Y +ToggleFrameLimit = Keyboard/F4 +TogglePause = SDL-0/Back & SDL-0/B +ToggleSlowMotion = Keyboard/Shift & Keyboard/Backtab +ToggleTurbo = Keyboard/Tab +HoldTurbo = Keyboard/L + + +[Pad] +MultitapPort1 = false +MultitapPort2 = false +PointerXScale = 8.000000 +PointerYScale = 8.000000 +PointerXInvert = false +PointerYInvert = false + + +[Pad1] +Type = DualShock2 +Deadzone = 0.000000 +AxisScale = 1.330000 +LargeMotorScale = 1.000000 +SmallMotorScale = 1.000000 +PressureModifier = 0.500000 +Up = SDL-0/-RightY +Right = SDL-0/DPadRight +Down = SDL-0/DPadDown +Left = SDL-0/DPadLeft +Triangle = SDL-0/Y +Circle = SDL-0/B +Cross = SDL-0/A +Square = SDL-0/X +Select = SDL-0/Back +Start = SDL-0/Start +L1 = SDL-0/LeftShoulder +L2 = SDL-0/+LeftTrigger +R1 = SDL-0/RightShoulder +R2 = SDL-0/+RightTrigger +L3 = SDL-0/LeftStick +R3 = SDL-0/RightStick +LUp = SDL-0/-LeftY +LRight = SDL-0/+LeftX +LDown = SDL-0/+LeftY +LLeft = SDL-0/-LeftX +RUp = SDL-0/-RightY +RRight = SDL-0/+RightX +RDown = SDL-0/+RightY +RLeft = SDL-0/-RightX +SmallMotor = SDL-0/SmallMotor +LargeMotor = SDL-0/LargeMotor + + +[Pad2] +Type = None +Deadzone = 0.000000 +AxisScale = 1.330000 +LargeMotorScale = 1.000000 +SmallMotorScale = 1.000000 +PressureModifier = 0.500000 + + +[Pad3] +Type = None +Deadzone = 0.000000 +AxisScale = 1.330000 +LargeMotorScale = 1.000000 +SmallMotorScale = 1.000000 +PressureModifier = 0.500000 + + +[Pad4] +Type = None +Deadzone = 0.000000 +AxisScale = 1.330000 +LargeMotorScale = 1.000000 +SmallMotorScale = 1.000000 +PressureModifier = 0.500000 + + +[Pad5] +Type = None +Deadzone = 0.000000 +AxisScale = 1.330000 +LargeMotorScale = 1.000000 +SmallMotorScale = 1.000000 +PressureModifier = 0.500000 + + +[Pad6] +Type = None +Deadzone = 0.000000 +AxisScale = 1.330000 +LargeMotorScale = 1.000000 +SmallMotorScale = 1.000000 +PressureModifier = 0.500000 + + +[Pad7] +Type = None +Deadzone = 0.000000 +AxisScale = 1.330000 +LargeMotorScale = 1.000000 +SmallMotorScale = 1.000000 +PressureModifier = 0.500000 + + +[Pad8] +Type = None +Deadzone = 0.000000 +AxisScale = 1.330000 +LargeMotorScale = 1.000000 +SmallMotorScale = 1.000000 +PressureModifier = 0.500000 + + +[GameList] +RecursivePaths = /home/deck/retrodeck/roms/ps2 diff --git a/emu-configs/PCSX2_ui.ini b/emu-configs/PCSX2/PCSX2_ui.ini similarity index 98% rename from emu-configs/PCSX2_ui.ini rename to emu-configs/PCSX2/PCSX2_ui.ini index 00f098ce..891b6cab 100644 --- a/emu-configs/PCSX2_ui.ini +++ b/emu-configs/PCSX2/PCSX2_ui.ini @@ -40,7 +40,7 @@ UseDefaultLangs=enabled UseDefaultCheats=enabled UseDefaultCheatsWS=enabled UseDefaultTextures=enabled -Bios=~/retrodeck/bios +Bios=/run/media/deck/DeckSD/retrodeck/roms/bios Snapshots=/var/config/PCSX2/snaps Savestates=/var/config/PCSX2/sstates MemoryCards=/var/config/PCSX2/memcards diff --git a/emu-configs/PCSX2_vm.ini b/emu-configs/PCSX2/PCSX2_vm.ini similarity index 100% rename from emu-configs/PCSX2_vm.ini rename to emu-configs/PCSX2/PCSX2_vm.ini From 1513a60d52583557b8b7511decb9c23b9c715dfd Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 7 Sep 2022 20:52:36 +0200 Subject: [PATCH 019/124] PCSX2: sedded configs --- emu-configs/PCSX2/PCSX2.ini | 10 +++++----- emu-configs/PCSX2/PCSX2_ui.ini | 2 +- retrodeck.sh | 3 ++- 3 files changed, 8 insertions(+), 7 deletions(-) diff --git a/emu-configs/PCSX2/PCSX2.ini b/emu-configs/PCSX2/PCSX2.ini index 26bb2f01..6a820bf6 100644 --- a/emu-configs/PCSX2/PCSX2.ini +++ b/emu-configs/PCSX2/PCSX2.ini @@ -296,10 +296,10 @@ Multitap2_Slot4_Filename = Mcd-Multitap2-Slot04.ps2 [Folders] -Bios = ../../../../../retrodeck/bios/pcsx2 -Snapshots = ../../../../../retrodeck/screenshots -SaveStates = ../../../../../retrodeck/states -MemoryCards = ../../../../../retrodeck/saves/pcsx2 +Bios = ~/retrodeck/bios/pcsx2 +Snapshots = ~/retrodeck/screenshots +SaveStates = ~/retrodeck/states +MemoryCards = ~/retrodeck/saves/pcsx2 Logs = logs Cheats = cheats CheatsWS = cheats_ws @@ -446,4 +446,4 @@ PressureModifier = 0.500000 [GameList] -RecursivePaths = /home/deck/retrodeck/roms/ps2 +RecursivePaths = ~/retrodeck/roms/ps2 diff --git a/emu-configs/PCSX2/PCSX2_ui.ini b/emu-configs/PCSX2/PCSX2_ui.ini index 891b6cab..72e94628 100644 --- a/emu-configs/PCSX2/PCSX2_ui.ini +++ b/emu-configs/PCSX2/PCSX2_ui.ini @@ -40,7 +40,7 @@ UseDefaultLangs=enabled UseDefaultCheats=enabled UseDefaultCheatsWS=enabled UseDefaultTextures=enabled -Bios=/run/media/deck/DeckSD/retrodeck/roms/bios +Bios=~/retrodeck/roms/bios Snapshots=/var/config/PCSX2/snaps Savestates=/var/config/PCSX2/sstates MemoryCards=/var/config/PCSX2/memcards diff --git a/retrodeck.sh b/retrodeck.sh index f5ba4071..e5b7e580 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -98,8 +98,9 @@ standalones_init() { echo "Initializing PCSX2" echo "----------------------" mkdir -pv /var/config/PCSX2/inis/ - cp -fvr $emuconfigs/PCSX2_ui.ini /var/config/PCSX2/inis/ + cp -fvr $emuconfigs/PCSX2/* /var/config/PCSX2/inis/ sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/PCSX2/inis/PCSX2_ui.ini + sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/PCSX2/inis/PCSX2.ini cp -fvr $emuconfigs/GS.ini /var/config/PCSX2/inis/ cp -fvr $emuconfigs/PCSX2_vm.ini /var/config/PCSX2/inis/ dir_prep "$rdhome/states" "/var/config/PCSX2/sstates" From e86555ce970ea1520c06f17d3855ab84ac05fb66 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 7 Sep 2022 20:54:36 +0200 Subject: [PATCH 020/124] PCSX2: cleaned old files --- emu-configs/GS.ini | 89 ---------------------------------------------- retrodeck.sh | 2 -- 2 files changed, 91 deletions(-) delete mode 100644 emu-configs/GS.ini diff --git a/emu-configs/GS.ini b/emu-configs/GS.ini deleted file mode 100644 index d91aa444..00000000 --- a/emu-configs/GS.ini +++ /dev/null @@ -1,89 +0,0 @@ -CaptureHeight = 480 -CaptureWidth = 640 -DisableDualSourceBlend = 0 -DisableFramebufferFetch = 0 -DumpReplaceableMipmaps = 0 -DumpReplaceableTextures = 0 -DumpTexturesWithFMVActive = 0 -HWDisableReadbacks = 0 -IntegerScaling = 0 -LoadTextureReplacements = 0 -LoadTextureReplacementsAsync = 1 -MaxAnisotropy = 0 -NTSC_Saturation = 1 -OsdScale = 100 -OsdShowCPU = 0 -OsdShowFPS = 0 -OsdShowGPU = 0 -OsdShowGSStats = 0 -OsdShowIndicators = 1 -OsdShowMessages = 1 -OsdShowResolution = 0 -OsdShowSpeed = 0 -OverrideGeometryShaders = -1 -OverrideTextureBarriers = -1 -PrecacheTextureReplacements = 0 -Renderer = 14 -ShadeBoost = 0 -ShadeBoost_Brightness = 50 -ShadeBoost_Contrast = 50 -ShadeBoost_Saturation = 50 -TVShader = 0 -ThreadedPresentation = 0 -UseBlitSwapChain = 0 -UseDebugDevice = 0 -UserHacks = 1 -UserHacks_AutoFlush = 0 -UserHacks_CPU_FB_Conversion = 0 -UserHacks_DisableDepthSupport = 0 -UserHacks_DisablePartialInvalidation = 1 -UserHacks_Disable_Safe_Features = 0 -UserHacks_HalfPixelOffset = 0 -UserHacks_Half_Bottom_Override = -1 -UserHacks_SkipDraw_End = 0 -UserHacks_SkipDraw_Start = 0 -UserHacks_TCOffsetX = 0 -UserHacks_TCOffsetY = 0 -UserHacks_TextureInsideRt = 0 -UserHacks_TriFilter = 0 -UserHacks_WildHack = 0 -UserHacks_align_sprite_X = 0 -UserHacks_merge_pp_sprite = 0 -UserHacks_round_sprite_offset = 0 -aa1 = 1 -accurate_blending_unit = 1 -accurate_date = 1 -autoflush_sw = 1 -capture_enabled = 0 -capture_out_dir = /tmp/GS_Capture -capture_threads = 4 -conservative_framebuffer = 1 -crc_hack_level = -1 -disable_shader_cache = 0 -dithering_ps2 = 2 -dump = 0 -extrathreads = 2 -extrathreads_height = 4 -filter = 2 -fxaa = 0 -interlace = 7 -linear_present = 1 -mipmap = 1 -mipmap_hw = -1 -override_GL_ARB_shader_image_load_store = -1 -override_GL_ARB_sparse_texture = -1 -paltex = 0 -png_compression_level = 1 -preload_frame_with_gs_data = 0 -save = 0 -savef = 0 -savel = 5000 -saven = 0 -savet = 0 -savez = 0 -shaderfx = 0 -shaderfx_conf = shaders/GS_FX_Settings.ini -shaderfx_glsl = shaders/GS.fx -texture_preloading = 0 -upscale_multiplier = 2 -wrap_gs_mem = 0 diff --git a/retrodeck.sh b/retrodeck.sh index e5b7e580..cd01bdb2 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -101,8 +101,6 @@ standalones_init() { cp -fvr $emuconfigs/PCSX2/* /var/config/PCSX2/inis/ sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/PCSX2/inis/PCSX2_ui.ini sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/PCSX2/inis/PCSX2.ini - cp -fvr $emuconfigs/GS.ini /var/config/PCSX2/inis/ - cp -fvr $emuconfigs/PCSX2_vm.ini /var/config/PCSX2/inis/ dir_prep "$rdhome/states" "/var/config/PCSX2/sstates" dir_prep "$rdhome/screenshots" "/var/config/PCSX2/snaps" dir_prep "$rdhome/.logs" "/var/config/PCSX2/logs" From c4bd4cc36561f309a47e2c3bbdabe2e3f279bbc0 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 7 Sep 2022 20:57:49 +0200 Subject: [PATCH 021/124] Fixed configured emulator tool --- tools/configure-emulators.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/tools/configure-emulators.sh b/tools/configure-emulators.sh index a646bf47..f469bfc8 100755 --- a/tools/configure-emulators.sh +++ b/tools/configure-emulators.sh @@ -20,7 +20,7 @@ emulator="$(zenity --list \ "Duckstation" \ "MelonDS" \ "PCSX2-QT" \ -"PCSX2 (Legacy)" \ +"PCSX2-Legacy" \ "PPSSPP" \ "RPCS3" \ "XEMU" \ @@ -41,10 +41,10 @@ then elif [ $emulator == "MelonDS" ] then melonDS -elif [ $emulator == "PCSX2 (Legacy)" ] +elif [ $emulator == "PCSX2-Legacy" ] then pcsx2 -elif [ $emulator == "pcsx2-qt" ] +elif [ $emulator == "PCSX2-QT" ] then pcsx2-qt elif [ $emulator == "PPSSPP" ] From 974f66c505c3f8730d12aed5cb620242ce78b8db Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Thu, 8 Sep 2022 17:45:57 +0200 Subject: [PATCH 022/124] DOLPHIN: fixed some paths --- emu-configs/dolphin/Dolphin.ini | 10 +++++----- retrodeck.sh | 3 +-- 2 files changed, 6 insertions(+), 7 deletions(-) diff --git a/emu-configs/dolphin/Dolphin.ini b/emu-configs/dolphin/Dolphin.ini index bb6ae945..a6f1c2ea 100644 --- a/emu-configs/dolphin/Dolphin.ini +++ b/emu-configs/dolphin/Dolphin.ini @@ -24,19 +24,19 @@ DSPHLE = True Fullscreen = True DisableScreenSaver = True [GBA] -BIOS = /var/data/dolphin-emu/GBA/gba_bios.bin +BIOS = ~/retrodeck/bios Rom1 = Rom2 = Rom3 = Rom4 = SavesInRomPath = False -SavesPath = /var/data/dolphin-emu/GBA/Saves/ +SavesPath = ~/retrodeck/saves Threads = True [General] -ISOPath0 = /run/user/1000/doc/9cd3cde7/wii -ISOPath1 = /run/user/1000/doc/14708e0c/gc +ISOPath0 = ~/retrodeck/roms/wii +ISOPath1 = ~/retrodeck/roms/gc ISOPaths = 2 -WiiSDCardPath = /var/data/dolphin-emu/Wii/sd.raw +WiiSDCardPath = ~/retrodeck/saves/sd.raw WirelessMac = 00:17:ab:83:9b:d4 HotkeysRequireFocus = True RecursiveISOPaths = True diff --git a/retrodeck.sh b/retrodeck.sh index cd01bdb2..adb5e4ed 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -90,8 +90,7 @@ standalones_init() { echo "----------------------" mkdir -pv /var/config/dolphin-emu/ cp -fvr "$emuconfigs/dolphin/"* /var/config/dolphin-emu/ - dir_prep "$rdhome/saves" "/var/data/dolphin-emu/GBA/Saves" - dir_prep "$rdhome/saves" "/var/data/dolphin-emu/Wii" + sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/dolphin-emu/Dolphin.ini # pcsx2 echo "----------------------" From 217a7fd0833a281868a2096ba7d23306f81ade1f Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Thu, 8 Sep 2022 17:50:52 +0200 Subject: [PATCH 023/124] Hiddem Primehack for the moment --- es-configs/es_systems.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index 73957de1..3f8d3a60 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -565,7 +565,7 @@ <extension>.gcm .GCM .iso .ISO .wbfs .WBFS .wia .WIA .ciso .CISO .gcz .GCZ .elf .ELF .dol .DOL .dff .DFF .json .JSON .rvz .RVZ .tgc .TGC .wad .WAD .m3u .M3U .7z .7Z .zip .ZIP</extension> <command label="Dolphin">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/dolphin_libretro.so %ROM%</command> <command label="Dolphin (Standalone)">%EMULATOR_DOLPHIN% -b -e %ROM%</command> - <command label="PrimeHack (Standalone)">%EMULATOR_PRIMEHACK% -b -e %ROM%</command> +<!-- <command label="PrimeHack (Standalone)">%EMULATOR_PRIMEHACK% -b -e %ROM%</command> --> <platform>gc</platform> <theme>gc</theme> </system> From d688fc61a69e020ff88965919ea740b4b0dedaac Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Fri, 9 Sep 2022 08:42:16 +0200 Subject: [PATCH 024/124] CEMU: updated --- net.retrodeck.retrodeck.yml | 46 +++++++++++++++++++++++-------------- 1 file changed, 29 insertions(+), 17 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 77bd3695..ba25b907 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1314,23 +1314,35 @@ modules: # CEMU - START - # - name: Cemu - # buildsystem: cmake-ninja - # builddir: true - # config-opts: - # - -DENABLE_VCPKG=false - # - -DCMAKE_BUILD_TYPE=Release - # #- -DCMAKE_C_COMPILER=/usr/bin/gcc - # #- -DCMAKE_CXX_COMPILER=/usr/bin/g++ - # - -Dimgui_LINK_LIBRARIES=/app/lib/imgui - # sources: - # - type: git - # url: https://github.com/cemu-project/Cemu - # commit: d8da8a54a6c08296a884b892d714cabcb7e4bdb5 - # - type: git - # dest: 3rdparty/imgui/imgui - # url: https://github.com/ocornut/imgui.git - # commit: 60bea052a92cbb4a93b221002fdf04f0da3698e1 + - name: cemu + buildsystem: cmake-ninja + builddir: true + build-options: + env: + CC: clang + CXX: clang++ + AR: llvm-ar + RANLIB: llvm-ranlib + ldflags: -fuse-ld=lld + prepend-ld-library-path: /usr/lib/sdk/llvm13/lib + prepend-path: /usr/lib/sdk/llvm13/bin + config-opts: + - -DCMAKE_BUILD_TYPE=RelWithDebInfo + - -DENABLE_VCPKG=false + sources: + - type: git + url: https://github.com/cemu-project/Cemu + tag: v2.0-1 + commit: e5d7d5d1736019d08e1ff8d9bd2e385330c5b7de + - type: git + dest: 3rdparty/imgui/imgui + url: https://github.com/ocornut/imgui.git + commit: 60bea052a92cbb4a93b221002fdf04f0da3698e1 + cleanup: + - /app/include + - /app/lib/*.a + - /app/lib/*.la + - /app/lib/pkgconfig # CEMU - END From c69a960c3d7dd9a62df95617366bf76348871b22 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Fri, 9 Sep 2022 08:42:45 +0200 Subject: [PATCH 025/124] CEMU: updated --- net.retrodeck.retrodeck.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index ba25b907..55a36c9a 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1313,6 +1313,7 @@ modules: # Duckstation - END # CEMU - START + # temporary here: https://github.com/Eonfge/flathub/blob/8bb2905b0fefdff820a2b65dac2a7cde916d3ce5/info.cemu.Cemu.yaml - name: cemu buildsystem: cmake-ninja From e154b90f5653a7109962e737e7a410b2f6edab8f Mon Sep 17 00:00:00 2001 From: anthonycaccese <anthonycaccese@gmail.com> Date: Sat, 10 Sep 2022 09:39:26 -0400 Subject: [PATCH 026/124] Updated Art-Book-Next to latest version commit: 23932f484a9949313baf80f92b2fbca38a7a8f37 --- net.retrodeck.retrodeck.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 55a36c9a..1a8cf21c 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -252,7 +252,7 @@ modules: sources: - type: git url: https://github.com/anthonycaccese/art-book-next-retropie.git - commit: cbd282eb05bb2deb138dad99c3420be56d35c1b8 + commit: 23932f484a9949313baf80f92b2fbca38a7a8f37 - name: alekfull-nx-light buildsystem: simple From 7cd36ef9496f1f357bd58ae3e709e4e67d1f164f Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 17:02:11 +0200 Subject: [PATCH 027/124] CEMU: updated manifest --- net.retrodeck.retrodeck.yml | 64 +++++++++++++++++++++++++++---------- 1 file changed, 47 insertions(+), 17 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 1a8cf21c..ef2477d9 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1315,30 +1315,60 @@ modules: # CEMU - START # temporary here: https://github.com/Eonfge/flathub/blob/8bb2905b0fefdff820a2b65dac2a7cde916d3ce5/info.cemu.Cemu.yaml - - name: cemu + # Needed for imgui + - name: glad buildsystem: cmake-ninja - builddir: true - build-options: - env: - CC: clang - CXX: clang++ - AR: llvm-ar - RANLIB: llvm-ranlib - ldflags: -fuse-ld=lld - prepend-ld-library-path: /usr/lib/sdk/llvm13/lib - prepend-path: /usr/lib/sdk/llvm13/bin config-opts: - -DCMAKE_BUILD_TYPE=RelWithDebInfo + - -DBUILD_SHARED_LIBS=true + - -DGLAD_REPRODUCIBLE=true + - -DGLAD_INSTALL=true + sources: + - type: archive + url: https://github.com/Dav1dde/glad/archive/refs/tags/v0.1.36.tar.gz + sha256: 8470ed1b0e9fbe88e10c34770505c8a1dc8ccb78cadcf673331aaf5224f963d2 + + # Needed for imgui + - name: glfw + buildsystem: cmake-ninja + builddir: true + config-opts: + - -DBUILD_SHARED_LIBS=ON + - -DGLFW_BUILD_EXAMPLES=OFF + - -DGLFW_BUILD_TESTS=OFF + - -DGLFW_BUILD_DOCS=OFF + sources: + - type: archive + url: https://github.com/glfw/glfw/releases/download/3.3.2/glfw-3.3.2.zip + sha256: 08a33a512f29d7dbf78eab39bd7858576adcc95228c9efe8e4bc5f0f3261efc7 + cleanup: + - /include + - /lib/pkgconfig + + - name: imgui + buildsystem: cmake + sources: + - type: archive + url: https://github.com/ocornut/imgui/archive/refs/tags/v1.88.zip + sha256: 81087a74599e5890a07b636887cee73a7dc1a9eb9e1f19a4a0d82a76090bf4c2 + - type: file + path: imguiCMakeLists.txt + dest-filename: CMakeLists.txt + + - name: Cemu + buildsystem: cmake-ninja + builddir: true + config-opts: - -DENABLE_VCPKG=false + - -DCMAKE_BUILD_TYPE=release + - -DCMAKE_C_COMPILER=/usr/bin/gcc + - -DCMAKE_CXX_COMPILER=/usr/bin/g++ + - -G Ninja + - -DCMAKE_MAKE_PROGRAM=/usr/bin/ninja sources: - type: git url: https://github.com/cemu-project/Cemu - tag: v2.0-1 - commit: e5d7d5d1736019d08e1ff8d9bd2e385330c5b7de - - type: git - dest: 3rdparty/imgui/imgui - url: https://github.com/ocornut/imgui.git - commit: 60bea052a92cbb4a93b221002fdf04f0da3698e1 + commit: d8da8a54a6c08296a884b892d714cabcb7e4bdb5 cleanup: - /app/include - /app/lib/*.a From 42924742e6e0d2379ca5d7045e1ff80827a4327b Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 17:30:27 +0200 Subject: [PATCH 028/124] PCSX2-QT: updated --- net.retrodeck.retrodeck.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index ef2477d9..cc7244b1 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -867,8 +867,8 @@ modules: - ln -s "${FLATPAK_DEST}/pcsx2-qt/usr/bin/pcsx2-qt" "${FLATPAK_DEST}/bin/pcsx2-qt" sources: - type: file - url: https://github.com/PCSX2/pcsx2/releases/download/v1.7.3271/pcsx2-v1.7.3271-linux-AppImage-64bit-AVX2-Qt.AppImage - sha256: 34aca477585bf9492b8f51ae066fe52c2a321c7b5656b9b76df97d51f75e4f85 + url: https://github.com/PCSX2/pcsx2/releases/download/v1.7.3300/pcsx2-v1.7.3300-linux-AppImage-64bit-AVX2-Qt.AppImage + sha256: 2785b1290bcbff36f1bcea66d61322975b194a383836f805daafe46aade7ce0f # PCSX2 - END From dde08bc106cd48502fece57e00f0a842e17ef43d Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 17:35:36 +0200 Subject: [PATCH 029/124] PCSX2-QT: increased menu scaling --- emu-configs/PCSX2/GS.ini | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/emu-configs/PCSX2/GS.ini b/emu-configs/PCSX2/GS.ini index d91aa444..93ca603a 100644 --- a/emu-configs/PCSX2/GS.ini +++ b/emu-configs/PCSX2/GS.ini @@ -11,7 +11,7 @@ LoadTextureReplacements = 0 LoadTextureReplacementsAsync = 1 MaxAnisotropy = 0 NTSC_Saturation = 1 -OsdScale = 100 +OsdScale = 250 OsdShowCPU = 0 OsdShowFPS = 0 OsdShowGPU = 0 From 9abf73fa9a07b85a6d3d42086440984cf7530253 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 17:37:48 +0200 Subject: [PATCH 030/124] PCSX2-QT: setted as default emulator --- es-configs/es_systems.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index 3f8d3a60..78d392a7 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -1070,9 +1070,9 @@ <name>ps2</name> <fullname>Sony PlayStation 2</fullname> <path>%ROMPATH%/ps2</path> + <command label="PCSX2 (Standalone)">%EMULATOR_PCSX2% -batch %ROM%</command> <extension>.bin .BIN .chd .CHD .ciso .CISO .cso .CSO .dump .DUMP .elf .ELF .gz .GZ .m3u .M3U .mdf .MDF .img .IMG .iso .ISO .isz .ISZ .ngr .NRG</extension> <command label="PCSX2">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/pcsx2_libretro.so %ROM%</command> - <command label="PCSX2 (Standalone)">%EMULATOR_PCSX2% -batch %ROM%</command> <command label="PCSX2 Legacy (Standalone)">%EMULATOR_PCSX2-LEGACY% --nogui %ROM%</command> <!-- <command label="Play! (Standalone)">%EMULATOR_PLAY!% --disc %ROM%</command> --> <platform>ps2</platform> From 20fa2f86271c64474c36d5be72077f3fb027ba23 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 17:47:22 +0200 Subject: [PATCH 031/124] PCSX2-QT: bios folder was wrong --- emu-configs/PCSX2/PCSX2.ini | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/emu-configs/PCSX2/PCSX2.ini b/emu-configs/PCSX2/PCSX2.ini index 6a820bf6..1cd87ed8 100644 --- a/emu-configs/PCSX2/PCSX2.ini +++ b/emu-configs/PCSX2/PCSX2.ini @@ -296,7 +296,7 @@ Multitap2_Slot4_Filename = Mcd-Multitap2-Slot04.ps2 [Folders] -Bios = ~/retrodeck/bios/pcsx2 +Bios = ~/retrodeck/bios Snapshots = ~/retrodeck/screenshots SaveStates = ~/retrodeck/states MemoryCards = ~/retrodeck/saves/pcsx2 From 29a9d7f2cbf2e54be7ca26dc85a255d49996bcd1 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 17:47:53 +0200 Subject: [PATCH 032/124] WRAPPER: version string was not updated --- retrodeck.sh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/retrodeck.sh b/retrodeck.sh index adb5e4ed..61362ab3 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -216,6 +216,7 @@ ra_init() { create_lock() { # creating RetroDECK's lock file and writing the version in the config file + version=$hard_version touch "$lockfile" conf_write } @@ -493,7 +494,7 @@ then # ...but the version doesn't match with the config file if [ "$hard_version" != "$version" ]; then - echo "Config file's version is "$(cat "$version")" but the actual version is $hard_version" + echo "Config file's version is $version but the actual version is $hard_version" post_update # Executing post update script conf_write # Writing variables in the config file (sourced from global.sh) start_retrodeck From d361a12ec3579aa3d245cfad217394c5a2f2ab6a Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 17:57:17 +0200 Subject: [PATCH 033/124] Pushed tools ection in the end --- es-configs/es_systems.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index 78d392a7..dc76308e 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -1612,7 +1612,7 @@ <theme>zxspectrum</theme> </system> <system> - <name>tools</name> + <name>zzztools</name> <fullname>RetroDECK Tools</fullname> <path>/var/config/retrodeck/tools</path> <extension>.sh .SH</extension> From 1fb8263039344522a3f4091444e1893874af2c8b Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 18:47:14 +0200 Subject: [PATCH 034/124] Pushed tools ection in the end (without cemu) --- net.retrodeck.retrodeck.yml | 118 ++++++++++++++++++------------------ 1 file changed, 59 insertions(+), 59 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index cc7244b1..9def52cc 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1316,65 +1316,65 @@ modules: # temporary here: https://github.com/Eonfge/flathub/blob/8bb2905b0fefdff820a2b65dac2a7cde916d3ce5/info.cemu.Cemu.yaml # Needed for imgui - - name: glad - buildsystem: cmake-ninja - config-opts: - - -DCMAKE_BUILD_TYPE=RelWithDebInfo - - -DBUILD_SHARED_LIBS=true - - -DGLAD_REPRODUCIBLE=true - - -DGLAD_INSTALL=true - sources: - - type: archive - url: https://github.com/Dav1dde/glad/archive/refs/tags/v0.1.36.tar.gz - sha256: 8470ed1b0e9fbe88e10c34770505c8a1dc8ccb78cadcf673331aaf5224f963d2 - - # Needed for imgui - - name: glfw - buildsystem: cmake-ninja - builddir: true - config-opts: - - -DBUILD_SHARED_LIBS=ON - - -DGLFW_BUILD_EXAMPLES=OFF - - -DGLFW_BUILD_TESTS=OFF - - -DGLFW_BUILD_DOCS=OFF - sources: - - type: archive - url: https://github.com/glfw/glfw/releases/download/3.3.2/glfw-3.3.2.zip - sha256: 08a33a512f29d7dbf78eab39bd7858576adcc95228c9efe8e4bc5f0f3261efc7 - cleanup: - - /include - - /lib/pkgconfig - - - name: imgui - buildsystem: cmake - sources: - - type: archive - url: https://github.com/ocornut/imgui/archive/refs/tags/v1.88.zip - sha256: 81087a74599e5890a07b636887cee73a7dc1a9eb9e1f19a4a0d82a76090bf4c2 - - type: file - path: imguiCMakeLists.txt - dest-filename: CMakeLists.txt - - - name: Cemu - buildsystem: cmake-ninja - builddir: true - config-opts: - - -DENABLE_VCPKG=false - - -DCMAKE_BUILD_TYPE=release - - -DCMAKE_C_COMPILER=/usr/bin/gcc - - -DCMAKE_CXX_COMPILER=/usr/bin/g++ - - -G Ninja - - -DCMAKE_MAKE_PROGRAM=/usr/bin/ninja - sources: - - type: git - url: https://github.com/cemu-project/Cemu - commit: d8da8a54a6c08296a884b892d714cabcb7e4bdb5 - cleanup: - - /app/include - - /app/lib/*.a - - /app/lib/*.la - - /app/lib/pkgconfig - +# - name: glad +# buildsystem: cmake-ninja +# config-opts: +# - -DCMAKE_BUILD_TYPE=RelWithDebInfo +# - -DBUILD_SHARED_LIBS=true +# - -DGLAD_REPRODUCIBLE=true +# - -DGLAD_INSTALL=true +# sources: +# - type: archive +# url: https://github.com/Dav1dde/glad/archive/refs/tags/v0.1.36.tar.gz +# sha256: 8470ed1b0e9fbe88e10c34770505c8a1dc8ccb78cadcf673331aaf5224f963d2 +# +# # Needed for imgui +# - name: glfw +# buildsystem: cmake-ninja +# builddir: true +# config-opts: +# - -DBUILD_SHARED_LIBS=ON +# - -DGLFW_BUILD_EXAMPLES=OFF +# - -DGLFW_BUILD_TESTS=OFF +# - -DGLFW_BUILD_DOCS=OFF +# sources: +# - type: archive +# url: https://github.com/glfw/glfw/releases/download/3.3.2/glfw-3.3.2.zip +# sha256: 08a33a512f29d7dbf78eab39bd7858576adcc95228c9efe8e4bc5f0f3261efc7 +# cleanup: +# - /include +# - /lib/pkgconfig +# +# - name: imgui +# buildsystem: cmake +# sources: +# - type: archive +# url: https://github.com/ocornut/imgui/archive/refs/tags/v1.88.zip +# sha256: 81087a74599e5890a07b636887cee73a7dc1a9eb9e1f19a4a0d82a76090bf4c2 +# - type: file +# path: imguiCMakeLists.txt +# dest-filename: CMakeLists.txt +# +# - name: Cemu +# buildsystem: cmake-ninja +# builddir: true +# config-opts: +# - -DENABLE_VCPKG=false +# - -DCMAKE_BUILD_TYPE=release +# - -DCMAKE_C_COMPILER=/usr/bin/gcc +# - -DCMAKE_CXX_COMPILER=/usr/bin/g++ +# - -G Ninja +# - -DCMAKE_MAKE_PROGRAM=/usr/bin/ninja +# sources: +# - type: git +# url: https://github.com/cemu-project/Cemu +# commit: d8da8a54a6c08296a884b892d714cabcb7e4bdb5 +# cleanup: +# - /app/include +# - /app/lib/*.a +# - /app/lib/*.la +# - /app/lib/pkgconfig +# # CEMU - END # External manifests end From fc551002cc3a0fb325b0901d1c925d8dd791758c Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 20:15:02 +0200 Subject: [PATCH 035/124] PCSX2: fixed savefolder path --- emu-configs/PCSX2/PCSX2.ini | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/emu-configs/PCSX2/PCSX2.ini b/emu-configs/PCSX2/PCSX2.ini index 1cd87ed8..ba358450 100644 --- a/emu-configs/PCSX2/PCSX2.ini +++ b/emu-configs/PCSX2/PCSX2.ini @@ -299,7 +299,7 @@ Multitap2_Slot4_Filename = Mcd-Multitap2-Slot04.ps2 Bios = ~/retrodeck/bios Snapshots = ~/retrodeck/screenshots SaveStates = ~/retrodeck/states -MemoryCards = ~/retrodeck/saves/pcsx2 +MemoryCards = ~/retrodeck/saves/ps2 Logs = logs Cheats = cheats CheatsWS = cheats_ws From 9e89dba63b3c533cf927fea08384c153e686bea9 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 20:17:49 +0200 Subject: [PATCH 036/124] Dolphin: changed saves path --- emu-configs/dolphin/Dolphin.ini | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/emu-configs/dolphin/Dolphin.ini b/emu-configs/dolphin/Dolphin.ini index a6f1c2ea..26926c3f 100644 --- a/emu-configs/dolphin/Dolphin.ini +++ b/emu-configs/dolphin/Dolphin.ini @@ -30,7 +30,7 @@ Rom2 = Rom3 = Rom4 = SavesInRomPath = False -SavesPath = ~/retrodeck/saves +SavesPath = ~/retrodeck/saves/gba Threads = True [General] ISOPath0 = ~/retrodeck/roms/wii From 3966549f7a348e1726c7a7d93f30b111186d8eeb Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 20:27:39 +0200 Subject: [PATCH 037/124] Redirected saves and states folders for the standalone emulators --- emu-configs/PCSX2/PCSX2.ini | 4 ++-- emu-configs/PCSX2/PCSX2_ui.ini | 8 ++++---- emu-configs/citra-qt-config.ini | 4 ++-- emu-configs/dolphin/Dolphin.ini | 2 +- emu-configs/melonDS.ini | 4 ++-- emu-configs/xemu.toml | 2 +- 6 files changed, 12 insertions(+), 12 deletions(-) diff --git a/emu-configs/PCSX2/PCSX2.ini b/emu-configs/PCSX2/PCSX2.ini index ba358450..32b0c443 100644 --- a/emu-configs/PCSX2/PCSX2.ini +++ b/emu-configs/PCSX2/PCSX2.ini @@ -298,8 +298,8 @@ Multitap2_Slot4_Filename = Mcd-Multitap2-Slot04.ps2 [Folders] Bios = ~/retrodeck/bios Snapshots = ~/retrodeck/screenshots -SaveStates = ~/retrodeck/states -MemoryCards = ~/retrodeck/saves/ps2 +SaveStates = ~/retrodeck/states/ps2/pcsx2 +MemoryCards = ~/retrodeck/saves/ps2/pcsx2/memcards Logs = logs Cheats = cheats CheatsWS = cheats_ws diff --git a/emu-configs/PCSX2/PCSX2_ui.ini b/emu-configs/PCSX2/PCSX2_ui.ini index 72e94628..14214053 100644 --- a/emu-configs/PCSX2/PCSX2_ui.ini +++ b/emu-configs/PCSX2/PCSX2_ui.ini @@ -41,10 +41,10 @@ UseDefaultCheats=enabled UseDefaultCheatsWS=enabled UseDefaultTextures=enabled Bios=~/retrodeck/roms/bios -Snapshots=/var/config/PCSX2/snaps -Savestates=/var/config/PCSX2/sstates -MemoryCards=/var/config/PCSX2/memcards -Logs=/var/config/PCSX2/logs +Snapshots=~/retrodeck/screenshots +Savestates=~/retrodeck/states/ps2/pcsx2 +MemoryCards=~/retrodeck/saves/ps2/memcards +Logs=~/retrodeck/.logs Langs=/app/share/PCSX2/resources/locale Cheats=/var/config/PCSX2/cheats CheatsWS=/var/config/PCSX2/cheats_ws diff --git a/emu-configs/citra-qt-config.ini b/emu-configs/citra-qt-config.ini index a6a37549..3cd0a0cb 100644 --- a/emu-configs/citra-qt-config.ini +++ b/emu-configs/citra-qt-config.ini @@ -106,9 +106,9 @@ use_cpu_jit=true use_cpu_jit\default=true [Data%20Storage] -nand_directory=~/retrodeck/saves/Citra/nand/ +nand_directory=~/retrodeck/saves/n3ds/citra/nand/ nand_directory\default=false -sdmc_directory=~/retrodeck/saves/Citra/sdmc/ +sdmc_directory=~/retrodeck/saves/n3ds/citra/sdmc/ sdmc_directory\default=false use_virtual_sd=true use_virtual_sd\default=true diff --git a/emu-configs/dolphin/Dolphin.ini b/emu-configs/dolphin/Dolphin.ini index 26926c3f..59737d0f 100644 --- a/emu-configs/dolphin/Dolphin.ini +++ b/emu-configs/dolphin/Dolphin.ini @@ -36,7 +36,7 @@ Threads = True ISOPath0 = ~/retrodeck/roms/wii ISOPath1 = ~/retrodeck/roms/gc ISOPaths = 2 -WiiSDCardPath = ~/retrodeck/saves/sd.raw +WiiSDCardPath = ~/retrodeck/saves/wii/dolphin/sd.raw WirelessMac = 00:17:ab:83:9b:d4 HotkeysRequireFocus = True RecursiveISOPaths = True diff --git a/emu-configs/melonDS.ini b/emu-configs/melonDS.ini index d64acf91..b1443132 100644 --- a/emu-configs/melonDS.ini +++ b/emu-configs/melonDS.ini @@ -123,8 +123,8 @@ RecentROM_6= RecentROM_7= RecentROM_8= RecentROM_9= -SaveFilePath=~/retrodeck/saves -SavestatePath=~/retrodeck/states +SaveFilePath=~/retrodeck/saves/nds/melonds +SavestatePath=~/retrodeck/states/nds/melonds CheatFilePath= EnableCheats=0 MouseHide=0 diff --git a/emu-configs/xemu.toml b/emu-configs/xemu.toml index 7e804f0e..1c119bd3 100644 --- a/emu-configs/xemu.toml +++ b/emu-configs/xemu.toml @@ -25,6 +25,6 @@ mem_limit = '128' [sys.files] bootrom_path = '/home/deck/retrodeck/bios/mcpx_1.0.bin' flashrom_path = '/home/deck/retrodeck/bios/Complex.bin' -eeprom_path = '/home/deck/retrodeck/saves/xbox-eeprom.bin' +eeprom_path = '/home/deck/retrodeck/saves/xbox/xemu/xbox-eeprom.bin' hdd_path = '/home/deck/retrodeck/bios/xbox_hdd.qcow2' From 8607036f73c4db18e1f3072243578a6cacd58b59 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 10 Sep 2022 20:45:35 +0200 Subject: [PATCH 038/124] DOLPHIN: fixed paths --- retrodeck.sh | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/retrodeck.sh b/retrodeck.sh index 61362ab3..43b5d3f5 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -91,6 +91,12 @@ standalones_init() { mkdir -pv /var/config/dolphin-emu/ cp -fvr "$emuconfigs/dolphin/"* /var/config/dolphin-emu/ sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/dolphin-emu/Dolphin.ini + dir_prep "$rdhome/saves/gc/dolphin/EUR" "/var/data/dolphin-emu/GC/EUR" + dir_prep "$rdhome/saves/gc/dolphin/USA" "/var/data/dolphin-emu/GC/USA" + dir_prep "$rdhome/saves/gc/dolphin/JAP" "/var/data/dolphin-emu/GC/JAP" + dir_prep "$rdhome/screenshots" "/var/data/dolphin-emu/ScreenShots" + dir_prep "$rdhome/states" "/var/data/dolphin-emu/StateSaves" + dir_prep "$rdhome/saves/wii/dolphin" "/var/data/dolphin-emu/Wii/" # pcsx2 echo "----------------------" From ca28b6cf3b2fcd4234f4aadfa4f14dd355c920d2 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 11:25:31 +0200 Subject: [PATCH 039/124] Updated 0.5.0b version notes --- net.retrodeck.retrodeck.appdata.xml | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/net.retrodeck.retrodeck.appdata.xml b/net.retrodeck.retrodeck.appdata.xml index 6f83a9d0..7f60ff52 100644 --- a/net.retrodeck.retrodeck.appdata.xml +++ b/net.retrodeck.retrodeck.appdata.xml @@ -66,10 +66,18 @@ <url>https://github.com/XargonWan/RetroDECK/releases/tag/0.5.5b</url> <description> <ul> - <li>Theme revamp!</li> + <li>IMPORTANT: Started saves migration, the saves are being moved to retrodeck/saves/systemname/emulator, so if the emulator cannot load your saves you have to move them to the new path</li> + <li>Theme revamp and more themes available such as the old one</li> <li>Updated RetroArch and its cores from 1.10.2 to 1.10.3</li> - <li>Added a tool to clean up the scraped data in order to make it compatible with the new Art-Book, it's suggested to run it</li> + <li>Updated all the standalone emulators to their latrest releases</li> + <li>Updated ES-DE to the 1.2.6</li> + <li>Removed the unavailable emualtors fom the ES-DE list to avoid confusion</li> + <li>Updated XEMU configurations and added its (free) assets</li> + <li>Added assets for RetroArch, PPSSPP and BlueMSX (libretro)</li> + <li>New emulator: PCSX2-QT, it's now the default PS2 emulator. Former PCSX2 emulator is now callerd PCSX2 (Legacy).</li> + <li>New emualtor: Duckstation for PSX.</li> <li>New varialbes system: now some variables such as game folder location are saved in /app/retrodeck/retrodeck.cfg.</li> + <li>Solved an issue where Dolphin (Standalone) was not save in the intended riectories.</li> </ul> </description> From d6e149c92d272fdc3c358804b1f62ff43b607e13 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 11:27:02 +0200 Subject: [PATCH 040/124] Updated 0.5.0b version notes --- net.retrodeck.retrodeck.appdata.xml | 1 + 1 file changed, 1 insertion(+) diff --git a/net.retrodeck.retrodeck.appdata.xml b/net.retrodeck.retrodeck.appdata.xml index 7f60ff52..c2790b28 100644 --- a/net.retrodeck.retrodeck.appdata.xml +++ b/net.retrodeck.retrodeck.appdata.xml @@ -68,6 +68,7 @@ <ul> <li>IMPORTANT: Started saves migration, the saves are being moved to retrodeck/saves/systemname/emulator, so if the emulator cannot load your saves you have to move them to the new path</li> <li>Theme revamp and more themes available such as the old one</li> + <li>A custom ROMs folder can be now selected during the first setup.</li> <li>Updated RetroArch and its cores from 1.10.2 to 1.10.3</li> <li>Updated all the standalone emulators to their latrest releases</li> <li>Updated ES-DE to the 1.2.6</li> From 20115e634b19f7914e3f4efd0dac034da2caae35 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 22:03:45 +0200 Subject: [PATCH 041/124] DOLPHIN-SA: is now the default emulator for GC and Wii --- es-configs/es_systems.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index dc76308e..2862719f 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -563,8 +563,8 @@ <fullname>Nintendo GameCube</fullname> <path>%ROMPATH%/gc</path> <extension>.gcm .GCM .iso .ISO .wbfs .WBFS .wia .WIA .ciso .CISO .gcz .GCZ .elf .ELF .dol .DOL .dff .DFF .json .JSON .rvz .RVZ .tgc .TGC .wad .WAD .m3u .M3U .7z .7Z .zip .ZIP</extension> - <command label="Dolphin">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/dolphin_libretro.so %ROM%</command> <command label="Dolphin (Standalone)">%EMULATOR_DOLPHIN% -b -e %ROM%</command> + <command label="Dolphin">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/dolphin_libretro.so %ROM%</command> <!-- <command label="PrimeHack (Standalone)">%EMULATOR_PRIMEHACK% -b -e %ROM%</command> --> <platform>gc</platform> <theme>gc</theme> @@ -1512,8 +1512,8 @@ <fullname>Nintendo Wii</fullname> <path>%ROMPATH%/wii</path> <extension>.gcm .GCM .iso .ISO .wbfs .WBFS .wia .WIA .ciso .CISO .gcz .GCZ .elf .ELF .dol .DOL .dff .DFF .json .JSON .rvz .RVZ .tgc .TGC .wad .WAD .m3u .M3U .7z .7Z .zip .ZIP</extension> - <command label="Dolphin">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/dolphin_libretro.so %ROM%</command> <command label="Dolphin (Standalone)">%EMULATOR_DOLPHIN% -b -e %ROM%</command> + <command label="Dolphin">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/dolphin_libretro.so %ROM%</command> <!-- <command label="PrimeHack (Standalone)">%EMULATOR_PRIMEHACK% -b -e %ROM%</command> --> <platform>wii</platform> <theme>wii</theme> From ccc76b948c5d4ea9674d9e86950af13ea668b394 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 22:34:51 +0200 Subject: [PATCH 042/124] Updated CPC core overrides --- emu-configs/retroarch-core-options.cfg | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/emu-configs/retroarch-core-options.cfg b/emu-configs/retroarch-core-options.cfg index 4656d63a..3ef89aa7 100644 --- a/emu-configs/retroarch-core-options.cfg +++ b/emu-configs/retroarch-core-options.cfg @@ -44,6 +44,20 @@ beetle_psx_skip_bios = "disabled" beetle_psx_use_mednafen_memcard0_method = "libretro" beetle_psx_widescreen_hack = "disabled" beetle_psx_widescreen_hack_aspect_ratio = "16:9" +cap32_advanced_green_phosphor = "15" +cap32_autorun = "enabled" +cap32_combokey = "y" +cap32_db_mapkeys = "enabled" +cap32_floppy_sound = "enabled" +cap32_gfx_colors = "24bit" +cap32_lang_layout = "english" +cap32_model = "6128" +cap32_ram = "128" +cap32_retrojoy0 = "auto" +cap32_retrojoy1 = "auto" +cap32_scr_intensity = "8" +cap32_scr_tube = "color" +cap32_statusbar = "onloading" citra_analog_function = "C-Stick and Touchscreen Pointer" citra_custom_textures = "disabled" citra_deadzone = "15" From 3dc03fa49917faf6bc13a6663252c02771d49989 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 22:55:00 +0200 Subject: [PATCH 043/124] Initialized savefolders --- retrodeck.sh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/retrodeck.sh b/retrodeck.sh index 43b5d3f5..9935d743 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -103,6 +103,7 @@ standalones_init() { echo "Initializing PCSX2" echo "----------------------" mkdir -pv /var/config/PCSX2/inis/ + mkdir -pv "$rdhome/saves/ps2/pcsx2/memcards" cp -fvr $emuconfigs/PCSX2/* /var/config/PCSX2/inis/ sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/PCSX2/inis/PCSX2_ui.ini sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/PCSX2/inis/PCSX2.ini @@ -116,6 +117,8 @@ standalones_init() { echo "Initializing MELONDS" echo "----------------------" mkdir -pv /var/config/melonDS/ + mkdir -pv "$rdhome/saves/nds/melonds" + mkdir -pv "$rdhome/states/nds/melonds" dir_prep "$rdhome/bios" "/var/config/melonDS/bios" cp -fvr $emuconfigs/melonDS.ini /var/config/melonDS/ # Replace ~/retrodeck with $rdhome as ~ cannot be understood by MelonDS @@ -126,6 +129,8 @@ standalones_init() { echo "Initializing CITRA" echo "------------------------" mkdir -pv /var/config/citra-emu/ + mkdir -pv "$rdhome/saves/n3ds/citra/nand/" + mkdir -pv "$rdhome/saves/n3ds/citra/sdmc/" cp -fv $emuconfigs/citra-qt-config.ini /var/config/citra-emu/qt-config.ini sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/citra-emu/qt-config.ini #TODO: do the same with roms folders after new variables is pushed (check even the others qt-emu) From 7922100d1775874ab05eb36d2c488e17a55ec3bb Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 23:00:59 +0200 Subject: [PATCH 044/124] PCSX2: config tweaked --- emu-configs/PCSX2/PCSX2.ini | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/emu-configs/PCSX2/PCSX2.ini b/emu-configs/PCSX2/PCSX2.ini index 32b0c443..e99a089c 100644 --- a/emu-configs/PCSX2/PCSX2.ini +++ b/emu-configs/PCSX2/PCSX2.ini @@ -139,7 +139,7 @@ LoadTextureReplacements = false LoadTextureReplacementsAsync = true PrecacheTextureReplacements = false deinterlace = 7 -OsdScale = 100 +OsdScale = 250 Renderer = -1 upscale_multiplier = 1 mipmap_hw = -1 @@ -336,6 +336,7 @@ TogglePause = SDL-0/Back & SDL-0/B ToggleSlowMotion = Keyboard/Shift & Keyboard/Backtab ToggleTurbo = Keyboard/Tab HoldTurbo = Keyboard/L +ShutdownVM = SDL-0/Start & SDL-0/Back [Pad] @@ -354,7 +355,7 @@ AxisScale = 1.330000 LargeMotorScale = 1.000000 SmallMotorScale = 1.000000 PressureModifier = 0.500000 -Up = SDL-0/-RightY +Up = SDL-0/DPadUp Right = SDL-0/DPadRight Down = SDL-0/DPadDown Left = SDL-0/DPadLeft @@ -446,4 +447,4 @@ PressureModifier = 0.500000 [GameList] -RecursivePaths = ~/retrodeck/roms/ps2 +RecursivePaths = ~/retrodeck/roms/ps2 \ No newline at end of file From ab7b121fa0d810e2e72a3931f6a38be20839ad73 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 23:04:04 +0200 Subject: [PATCH 045/124] PCSX2: fixed bios folder --- retrodeck.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/retrodeck.sh b/retrodeck.sh index 9935d743..85b4347c 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -110,7 +110,7 @@ standalones_init() { dir_prep "$rdhome/states" "/var/config/PCSX2/sstates" dir_prep "$rdhome/screenshots" "/var/config/PCSX2/snaps" dir_prep "$rdhome/.logs" "/var/config/PCSX2/logs" - dir_prep "$rdhome/bios" "$rdhome/bios/pcsx2/bios" + dir_prep "$rdhome/bios" "$rdhome/bios/pcsx2" # MelonDS echo "----------------------" From 77388827a0c11ffa70cda04d05469775dcc6022c Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 23:07:12 +0200 Subject: [PATCH 046/124] HIdden Ryujinx as it`s still not buildable --- es-configs/es_systems.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index 2862719f..4991cd56 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -1375,7 +1375,7 @@ <path>%ROMPATH%/switch</path> <extension>.nca .NCA .nro .NRO .nso .NSO .nsp .NSP .xci .XCI .7z .7Z .zip .ZIP</extension> <command label="Yuzu (Standalone)">%EMULATOR_YUZU% -f -g %ROM%</command> - <command label="Ryujinx (Standalone)">%EMULATOR_RYUJINX% %ROM%</command> + <!-- <command label="Ryujinx (Standalone)">%EMULATOR_RYUJINX% %ROM%</command> --> <platform>switch</platform> <theme>switch</theme> </system> From 798c8cf13213f9ffc4181aba1e0dfc037206facf Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 11 Sep 2022 23:41:51 +0200 Subject: [PATCH 047/124] Started to populate the logs folder --- retrodeck.sh | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/retrodeck.sh b/retrodeck.sh index 85b4347c..1c652e78 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -79,6 +79,7 @@ standalones_init() { # initializing the firmware folder dir_prep "$rdhome/bios/switch/registered" "/var/data/yuzu/nand/system/Contents/registered" # configuring Yuzu + dir_prep "$rdhome/.logs/yuzu" "/var/data/yuzu/log" mkdir -pv /var/config/yuzu/ cp -fvr $emuconfigs/yuzu/* /var/config/yuzu/ sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/yuzu/qt-config.ini @@ -131,6 +132,7 @@ standalones_init() { mkdir -pv /var/config/citra-emu/ mkdir -pv "$rdhome/saves/n3ds/citra/nand/" mkdir -pv "$rdhome/saves/n3ds/citra/sdmc/" + dir_prep "$rdhome/.logs/citra" "/var/data/citra-emu/log" cp -fv $emuconfigs/citra-qt-config.ini /var/config/citra-emu/qt-config.ini sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/citra-emu/qt-config.ini #TODO: do the same with roms folders after new variables is pushed (check even the others qt-emu) @@ -183,6 +185,7 @@ standalones_init() { ra_init() { dir_prep "$rdhome/bios" "/var/config/retroarch/system" + dir_prep "$rdhome/.logs/retroarch" "/var/config/retroarch/logs" mkdir -pv /var/config/retroarch/cores/ cp /app/share/libretro/cores/* /var/config/retroarch/cores/ cp -fv $emuconfigs/retroarch.cfg /var/config/retroarch/ @@ -252,6 +255,7 @@ post_update() { dir_prep "$media_folder" "/var/config/emulationstation/.emulationstation/downloaded_media" dir_prep "$themes_folder" "/var/config/emulationstation/.emulationstation/themes" mkdir -pv $rdhome/.logs #this was added later, maybe safe to remove in a few versions + # Resetting es_systems, now we need it but in the future I should think a better solution, maybe with sed cp -fv /app/retrodeck/es_settings.xml /var/config/emulationstation/.emulationstation/es_settings.xml From f9b3f729abc147724b6810fa926c93258c661e91 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 13:22:13 +0200 Subject: [PATCH 048/124] SWANSTATION: graduated --- emu-configs/retroarch-core-options.cfg | 104 +++++++++++++++++++++++++ es-configs/es_systems.xml | 2 +- 2 files changed, 105 insertions(+), 1 deletion(-) diff --git a/emu-configs/retroarch-core-options.cfg b/emu-configs/retroarch-core-options.cfg index 3ef89aa7..6be315ae 100644 --- a/emu-configs/retroarch-core-options.cfg +++ b/emu-configs/retroarch-core-options.cfg @@ -159,6 +159,110 @@ dolphin_wait_for_shaders = "disabled" dolphin_widescreen = "enabled" dolphin_widescreen_hack = "disabled" dolphin_wiimote_continuous_scanning = "disabled" +duckstation_BIOS.PatchFastBoot = "true" +duckstation_BIOS.PathNTSCJ = "scph5500.bin" +duckstation_BIOS.PathNTSCU = "scph5501.bin" +duckstation_BIOS.PathPAL = "scph5502.bin" +duckstation_CDROM.LoadImagePatches = "false" +duckstation_CDROM.LoadImageToRAM = "false" +duckstation_CDROM.MuteCDAudio = "false" +duckstation_CDROM.PreCacheCHD = "false" +duckstation_CDROM.ReadaheadSectors = "8" +duckstation_CDROM.ReadSpeedup = "1" +duckstation_CDROM.ReadThread = "true" +duckstation_CDROM.RegionCheck = "false" +duckstation_CDROM.SeekSpeedup = "1" +duckstation_Console.Enable8MBRAM = "false" +duckstation_Console.Region = "Auto" +duckstation_Controller1.AnalogDPadInDigitalMode = "true" +duckstation_Controller1.AxisScale = "1.00f" +duckstation_Controller1.ForceAnalogOnReset = "false" +duckstation_Controller1.SteeringDeadzone = "0.10" +duckstation_Controller1.TwistResponse = "linear" +duckstation_Controller1.VibrationBias = "8" +duckstation_Controller1.XScale = "1.00" +duckstation_Controller2.AnalogDPadInDigitalMode = "true" +duckstation_Controller2.AxisScale = "1.00f" +duckstation_Controller2.ForceAnalogOnReset = "false" +duckstation_Controller2.SteeringDeadzone = "0.00" +duckstation_Controller2.TwistResponse = "linear" +duckstation_Controller2.VibrationBias = "8" +duckstation_Controller2.XScale = "1.00" +duckstation_Controller3.AnalogDPadInDigitalMode = "true" +duckstation_Controller3.AxisScale = "1.00f" +duckstation_Controller3.ForceAnalogOnReset = "false" +duckstation_Controller3.SteeringDeadzone = "0.10" +duckstation_Controller3.TwistResponse = "linear" +duckstation_Controller3.VibrationBias = "8" +duckstation_Controller4.AnalogDPadInDigitalMode = "true" +duckstation_Controller4.AxisScale = "1.00f" +duckstation_Controller4.ForceAnalogOnReset = "false" +duckstation_Controller4.SteeringDeadzone = "0.10" +duckstation_Controller4.TwistResponse = "linear" +duckstation_Controller4.VibrationBias = "8" +duckstation_Controller5.AnalogDPadInDigitalMode = "true" +duckstation_Controller5.AxisScale = "1.00f" +duckstation_Controller5.ForceAnalogOnReset = "false" +duckstation_Controller5.VibrationBias = "8" +duckstation_Controller6.AnalogDPadInDigitalMode = "true" +duckstation_Controller6.AxisScale = "1.00f" +duckstation_Controller6.ForceAnalogOnReset = "false" +duckstation_Controller6.VibrationBias = "8" +duckstation_Controller7.AnalogDPadInDigitalMode = "true" +duckstation_Controller7.AxisScale = "1.00f" +duckstation_Controller7.ForceAnalogOnReset = "false" +duckstation_Controller7.VibrationBias = "8" +duckstation_Controller8.AnalogDPadInDigitalMode = "true" +duckstation_Controller8.AxisScale = "1.00f" +duckstation_Controller8.ForceAnalogOnReset = "false" +duckstation_Controller8.VibrationBias = "8" +duckstation_ControllerPorts.MultitapMode = "Disabled" +duckstation_CPU.ExecutionMode = "Recompiler" +duckstation_CPU.FastmemMode = "MMap" +duckstation_CPU.FastmemRewrite = "false" +duckstation_CPU.Overclock = "100" +duckstation_CPU.RecompilerBlockLinking = "true" +duckstation_CPU.RecompilerICache = "false" +duckstation_Display.ActiveEndOffset = "0" +duckstation_Display.ActiveStartOffset = "0" +duckstation_Display.AspectRatio = "Auto" +duckstation_Display.CropMode = "Borders" +duckstation_Display.CustomAspectRatioDenominator = "3" +duckstation_Display.CustomAspectRatioNumerator = "4" +duckstation_Display.Force4_3For24Bit = "false" +duckstation_Display.LineEndOffset = "0" +duckstation_Display.LineStartOffset = "0" +duckstation_Display.ShowOSDMessages = "true" +duckstation_GPU.ChromaSmoothing24Bit = "false" +duckstation_GPU.DisableInterlacing = "true" +duckstation_GPU.DownsampleMode = "Disabled" +duckstation_GPU.ForceNTSCTimings = "false" +duckstation_GPU.MSAA = "4" +duckstation_GPU.PGXPCPU = "false" +duckstation_GPU.PGXPCulling = "true" +duckstation_GPU.PGXPDepthBuffer = "false" +duckstation_GPU.PGXPEnable = "true" +duckstation_GPU.PGXPPreserveProjFP = "false" +duckstation_GPU.PGXPTextureCorrection = "true" +duckstation_GPU.PGXPTolerance = "-1.0" +duckstation_GPU.PGXPVertexCache = "false" +duckstation_GPU.Renderer = "Vulkan" +duckstation_GPU.ResolutionScale = "3" +duckstation_GPU.ScaledDithering = "true" +duckstation_GPU.TextureFilter = "Bilinear" +duckstation_GPU.TrueColor = "false" +duckstation_GPU.UseSoftwareRendererForReadbacks = "false" +duckstation_GPU.UseThread = "true" +duckstation_GPU.WidescreenHack = "false" +duckstation_Logging.LogLevel = "Info" +duckstation_Main.ApplyGameSettings = "true" +duckstation_Main.LoadDevicesFromSaveStates = "false" +duckstation_Main.RunaheadFrameCount = "0" +duckstation_MemoryCards.Card1Type = "Libretro" +duckstation_MemoryCards.Card2Type = "None" +duckstation_MemoryCards.UsePlaylistTitle = "true" +duckstation_TextureReplacements.EnableVRAMWriteReplacements = "false" +duckstation_TextureReplacements.PreloadTextures = "false" gambatte_audio_resampler = "sinc" gambatte_dark_filter_level = "0" gambatte_gb_bootloader = "enabled" diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index 4991cd56..4899e218 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -1123,10 +1123,10 @@ <fullname>Sony PlayStation</fullname> <path>%ROMPATH%/psx</path> <extension>.bin .BIN .cbn .CBN .ccd .CCD .chd .CHD .cue .CUE .ecm .ECM .exe .EXE .img .IMG .iso .ISO .m3u .M3U .mdf .MDF .mds .MDS .pbp .PBP .psexe .PSEXE .psf .PSF .toc .TOC .z .Z .znx .ZNX .7z .7Z .zip .ZIP</extension> + <command label="SwanStation">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/swanstation_libretro.so %ROM%</command> <command label="Beetle PSX">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/mednafen_psx_libretro.so %ROM%</command> <command label="Beetle PSX HW">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/mednafen_psx_hw_libretro.so %ROM%</command> <command label="PCSX ReARMed">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/pcsx_rearmed_libretro.so %ROM%</command> - <command label="SwanStation">%EMULATOR_RETROARCH% -L %CORE_RETROARCH%/swanstation_libretro.so %ROM%</command> <command label="DuckStation (Standalone)">%EMULATOR_DUCKSTATION% -batch %ROM%</command> <!-- <command label="Mednafen (Standalone)">%EMULATOR_MEDNAFEN% -force_module psx %ROM%</command> --> <platform>psx</platform> From 503b7b896a29fab8fba78b726077a21af935585b Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 13:30:13 +0200 Subject: [PATCH 049/124] PCSX2: Updated to 1.13.2 --- net.retrodeck.retrodeck.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 9def52cc..6b6ab2f5 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1217,8 +1217,8 @@ modules: sources: - type: git url: https://github.com/hrydgard/ppsspp.git - tag: v1.12.3 - commit: ce0a45cf0fcdd5bebf32208b9998f68dfc1107b7 + tag: v1.13.2 + commit: 9fe6338e3bf397f8a009a51a282c139dfa180eb6 x-checker-data: type: git tag-pattern: ^v([\d.]+)$ From 8550d316079e9b0a45b49dcebdafb34e92575600 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 13:30:32 +0200 Subject: [PATCH 050/124] PPSSPP: updated to 1.13.2 --- net.retrodeck.retrodeck.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 6b6ab2f5..a12a3c00 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1196,7 +1196,7 @@ modules: # PRIMEHACK - END - # PPSSPP - START + # PPSSPP - START # https://github.com/flathub/org.ppsspp.PPSSPP - name: ppsspp From b9d0ca9af7d6da09f6b9278c36ba059854cb6803 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 13:34:38 +0200 Subject: [PATCH 051/124] YUZU: updated to mainline-0-1163 --- net.retrodeck.retrodeck.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index a12a3c00..eb8d07da 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -550,8 +550,8 @@ modules: sources: - type: git url: https://github.com/yuzu-emu/yuzu-mainline.git - tag: mainline-0-1150 - commit: e5774ced75e1d19c5a42cac719f7de475a3630b3 + tag: mainline-0-1163 + commit: f0a6d73fe2cf94ddcef54516d261c21816cd48d1 disable-shallow-clone: true x-checker-data: type: git @@ -1196,7 +1196,7 @@ modules: # PRIMEHACK - END - # PPSSPP - START + # PPSSPP - START # https://github.com/flathub/org.ppsspp.PPSSPP - name: ppsspp From 3da8aa55d6b082806a14a408d63a45722288a3f7 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 13:38:23 +0200 Subject: [PATCH 052/124] CITRA: updated to nightly-1785 --- net.retrodeck.retrodeck.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index eb8d07da..4f86b759 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -613,12 +613,14 @@ modules: # # Ryujinx - END # CITRA - START + # https://github.com/flathub/org.citra_emu.citra - name: citra buildsystem: cmake-ninja builddir: true config-opts: - -DCMAKE_BUILD_TYPE=Release + - -DCMAKE_INTERPROCEDURAL_OPTIMIZATION=ON - -DENABLE_QT_TRANSLATION=ON - -DCITRA_ENABLE_COMPATIBILITY_REPORTING=ON - -DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON @@ -634,8 +636,8 @@ modules: sources: - type: git url: https://github.com/citra-emu/citra-nightly.git - tag: nightly-1772 - commit: 355933218d00603c910cd0a9daead0b1cd72a3c3 + tag: nightly-1785 + commit: baecc18d8c5365af0dddb231bc8c0a9c03850bf6 disable-shallow-clone: true x-checker-data: type: git From 432fc10f5d7d9ef708c80c7e5f12a033be0bcbd9 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 13:42:30 +0200 Subject: [PATCH 053/124] PCSX2-QT: Updated to v1.7.3304 --- net.retrodeck.retrodeck.yml | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 4f86b759..e5c972cb 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -766,8 +766,8 @@ modules: sources: - type: git url: https://github.com/PCSX2/pcsx2.git - tag: v1.7.3229 - commit: e3eae7fbe83aad3952e3ed6a8e56fc016b51a9c3 + tag: v1.7.3301 + commit: f3f495d23b5fabe8c6e7278f046a3312898e6f04 # PCSX2 Flathub Workaround - START # This workaround disables the PCSX2 libraries (disable-submodules: true) and install them separately @@ -857,6 +857,7 @@ modules: # Inspired by: # https://github.com/flathub/com.zettlr.Zettlr/blob/master/com.zettlr.Zettlr.yaml + # https://pcsx2.net/downloads/ - name: pcsx2-qt-appimage buildsystem: simple @@ -869,8 +870,8 @@ modules: - ln -s "${FLATPAK_DEST}/pcsx2-qt/usr/bin/pcsx2-qt" "${FLATPAK_DEST}/bin/pcsx2-qt" sources: - type: file - url: https://github.com/PCSX2/pcsx2/releases/download/v1.7.3300/pcsx2-v1.7.3300-linux-AppImage-64bit-AVX2-Qt.AppImage - sha256: 2785b1290bcbff36f1bcea66d61322975b194a383836f805daafe46aade7ce0f + url: https://github.com/PCSX2/pcsx2/releases/download/v1.7.3304/pcsx2-v1.7.3304-linux-AppImage-64bit-AVX2-Qt.AppImage + sha256: 04e56b9e6113fefce7057b2dd19f0501b79d36f31c718406bda45204a2be121a # PCSX2 - END From 0597e2d93d51fa1fa537cfa563e7a676aafa92f4 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 13:44:51 +0200 Subject: [PATCH 054/124] XEMU: updated to v0.7.70 --- net.retrodeck.retrodeck.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index e5c972cb..ede3487e 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1028,14 +1028,14 @@ modules: sources: - type: git url: https://github.com/mborgerson/xemu.git - tag: v0.7.58 - commit: 6f878ede01ad1992392dde22b506a3c00fab87c4 + tag: v0.7.70 + commit: 080022833db0896b8af4482e726200acd51507a0 x-checker-data: type: json url: https://api.github.com/repos/mborgerson/xemu/releases/latest tag-query: .tag_name - version-query: $tag | sub("^gh-release/"; "") timestamp-query: .published_at + version-query: .tag_name # XEMU - END From 84fe2f8b1dfd6b194da3b77e1aa0fda47233e12a Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 13:49:30 +0200 Subject: [PATCH 055/124] RPCS3: Updated --- net.retrodeck.retrodeck.yml | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index ede3487e..e84213e0 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -914,8 +914,8 @@ modules: - -Ddocumentation=disabled sources: - type: archive - url: https://www.freedesktop.org/software/libevdev/libevdev-1.12.1.tar.xz - sha256: 1dbba41bc516d3ca7abc0da5b862efe3ea8a7018fa6e9b97ce9d39401b22426c + url: https://www.freedesktop.org/software/libevdev/libevdev-1.13.0.tar.xz + sha256: 9edf2006cc86a5055279647c38ec923d11a821ee4dc2c3033e8d20e8ee237cd9 x-checker-data: type: anitya project-id: 20540 @@ -1089,8 +1089,8 @@ modules: CXX: clang++ RANLIB: llvm-ranlib ldflags: -fuse-ld=lld - prepend-ld-library-path: /usr/lib/sdk/llvm13/lib - prepend-path: /usr/lib/sdk/llvm13/bin + prepend-ld-library-path: /usr/lib/sdk/llvm14/lib + prepend-path: /usr/lib/sdk/llvm14/bin config-opts: - -DCMAKE_BUILD_TYPE=Release - -DBUILD_SHARED_LIBS=OFF @@ -1114,7 +1114,7 @@ modules: sources: - type: git url: https://github.com/RPCS3/llvm-mirror.git - commit: 509d31ad89676522f7121b3bb8688f7d29b7ee60 + commit: c725f494c91611018f5d830eca22c0a1662c0f31 - type: git url: https://github.com/intel/ittapi.git dest: ittapi/ittapi @@ -1124,8 +1124,8 @@ modules: buildsystem: cmake-ninja builddir: true build-options: - append-ld-library-path: /usr/lib/sdk/llvm13/lib - append-path: /usr/lib/sdk/llvm13/bin + append-ld-library-path: /usr/lib/sdk/llvm14/lib + append-path: /usr/lib/sdk/llvm14/bin cflags: *optflags cflags-override: true cxxflags: *optflags @@ -1155,7 +1155,8 @@ modules: sources: - type: git url: https://github.com/RPCS3/rpcs3.git - commit: e9570d1a0045926f63ec8ea9af68f81743d4f365 + branch: master + commit: b9e20dc5c9d7776ff27923600da004a8a57bc132 # RPCS3 - END From 63cd9bc2712a4d3c474e349cfbc6205d9c0a0926 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 19:35:25 +0200 Subject: [PATCH 056/124] RPCS3: Updated --- net.retrodeck.retrodeck.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index e84213e0..6d91399e 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1156,7 +1156,7 @@ modules: - type: git url: https://github.com/RPCS3/rpcs3.git branch: master - commit: b9e20dc5c9d7776ff27923600da004a8a57bc132 + commit: 2807be7080ab71d5c542a2bef7323f9b43f192e6 # RPCS3 - END From 22c3ff08dcf444751c52d8158908d2b269901076 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 13 Sep 2022 22:47:12 +0200 Subject: [PATCH 057/124] PCSX2: legacy downgraded to v1.7.3229 as wasn't compiling --- net.retrodeck.retrodeck.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 6d91399e..98f4ebad 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -766,8 +766,8 @@ modules: sources: - type: git url: https://github.com/PCSX2/pcsx2.git - tag: v1.7.3301 - commit: f3f495d23b5fabe8c6e7278f046a3312898e6f04 + tag: v1.7.3229 + commit: e3eae7fbe83aad3952e3ed6a8e56fc016b51a9c3 # PCSX2 Flathub Workaround - START # This workaround disables the PCSX2 libraries (disable-submodules: true) and install them separately From 2a9fdc72d1e715b91542add71e735e30513a643f Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 14 Sep 2022 12:17:47 +0200 Subject: [PATCH 058/124] RPCS3: Updated llvm13 to llvm14 --- net.retrodeck.retrodeck.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 98f4ebad..dfe3cf40 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -4,7 +4,7 @@ runtime-version: 5.15-21.08 #runtime-version: 6.3 # bumped because of pcsx2-qt sdk: org.kde.Sdk sdk-extensions: - - org.freedesktop.Sdk.Extension.llvm13 # Needed for rpcs3 + - org.freedesktop.Sdk.Extension.llvm14 # Needed for rpcs3 - org.freedesktop.Sdk.Extension.dotnet6 # Needed for Ryujinx base: io.qt.qtwebengine.BaseApp # Needed for Yuzu base-version: 5.15-21.08 # Needed for Yuzu From 0ef7676ef73f0f70771e4041bca187dbf4b43da7 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Fri, 16 Sep 2022 09:11:41 +0200 Subject: [PATCH 059/124] WRAPPER: bugfix --- retrodeck.sh | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/retrodeck.sh b/retrodeck.sh index 1c652e78..960e949b 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -371,11 +371,10 @@ finit() { --title "RetroDECK" --cancel-label="Cancel" \ --ok-label "Browse" \ --text="SD Card was not find in the default location.\nPlease choose the SD Card root.\nA retrodeck/roms folder will be created starting from the directory that you selected." - browse + browse # Calling the browse function else roms_folder="$sdcard/retrodeck/roms" echo "ROMs folder = $roms_folder" - exit 0 fi ;; From 577264a16ace36920fb1af94a5855bc0e878d9bf Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Fri, 16 Sep 2022 09:21:16 +0200 Subject: [PATCH 060/124] Removed move roms tool to be added as CLI --- es-configs/tools-gamelist.xml | 4 ++-- tools/{move-roms.sh => move-roms.sh.disabled} | 0 2 files changed, 2 insertions(+), 2 deletions(-) rename tools/{move-roms.sh => move-roms.sh.disabled} (100%) diff --git a/es-configs/tools-gamelist.xml b/es-configs/tools-gamelist.xml index 3a838881..68f116fa 100644 --- a/es-configs/tools-gamelist.xml +++ b/es-configs/tools-gamelist.xml @@ -70,14 +70,14 @@ <nogamecount>true</nogamecount> <nomultiscrape>true</nomultiscrape> </game> - <game> +<!-- <game> <path>./move-roms.sh</path> <name>Move roms folder</name> <desc>Move roms folder from internal to external and vice versa.</desc> <nogamecount>true</nogamecount> <nomultiscrape>true</nomultiscrape> </game> -<!-- <game> + <game> <path>./overlays.sh</path> <name>Overlays configuration</name> <desc>Configure or disable borders and shaders.</desc> diff --git a/tools/move-roms.sh b/tools/move-roms.sh.disabled similarity index 100% rename from tools/move-roms.sh rename to tools/move-roms.sh.disabled From 2dddf4359b0bf88396baaf93ae0a2a04600bc694 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Fri, 16 Sep 2022 20:26:44 +0200 Subject: [PATCH 061/124] PPSSPP: maybe moving this up is fixing yuzu on flathub --- net.retrodeck.retrodeck.yml | 174 ++++++++++++++++++------------------ 1 file changed, 87 insertions(+), 87 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index dfe3cf40..9f4912ad 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -401,6 +401,93 @@ modules: url: https://buildbot.libretro.com/stable/1.10.3/linux/x86_64/RetroArch_cores.7z sha256: 33abf39839687f8faba202ed5dcf3a54c06266a49fad35f0521fa445523d009f + # PPSSPP - START + # https://github.com/flathub/org.ppsspp.PPSSPP + + - name: ppsspp + buildsystem: cmake-ninja + config-opts: + - -DUSE_SYSTEM_FFMPEG=OFF # turn this on? + - -DUSE_SYSTEM_LIBZIP=ON + - -DUSE_SYSTEM_ZSTD=ON + + - -DUSE_WAYLAND_WSI=ON + - -DUSING_X11_VULKAN=ON + - -DUSING_QT_UI=OFF + + - -DBUILD_TESTING=OFF + - -DOpenGL_GL_PREFERENCE=GLVND + build-options: + - -DX86_64=ON + sources: + - type: git + url: https://github.com/hrydgard/ppsspp.git + tag: v1.13.2 + commit: 9fe6338e3bf397f8a009a51a282c139dfa180eb6 + x-checker-data: + type: git + tag-pattern: ^v([\d.]+)$ + + # PPSSPP Flathub Workaround - START + # This workaround disables the PPSSPP libraries (disable-submodules: true) and install them separately + # This is only to make it buildable by the flathub builder as normaly it seems not to be needed + disable-submodules: true + - type: git + dest: SDL/macOS + commit: f19a1d54b8a5af6cc378ea307e0ec676922eb4cc + url: https://github.com/hrydgard/ppsspp-mac-sdl + - type: git + dest: assets/debugger + commit: 36ad6b19b22de2075a01a4f0c765e3ef514dc38f + url: https://github.com/unknownbrackets/ppsspp-debugger.git + - type: git + dest: dx9sdk + commit: 7751cf73f5c06f1be21f5f31c3e2d9a7bacd3a93 + url: https://github.com/hrydgard/minidx9.git + - type: git + dest: ext/SPIRV-Cross + commit: 9acb9ec31f5a8ef80ea6b994bb77be787b08d3d1 + url: https://github.com/KhronosGroup/SPIRV-Cross.git + - type: git + dest: ext/armips + commit: 7885552b208493a6a0f21663770c446c3ba65576 + url: https://github.com/Kingcom/armips.git + - type: git + dest: ext/discord-rpc + commit: 963aa9f3e5ce81a4682c6ca3d136cddda614db33 + url: https://github.com/discordapp/discord-rpc.git + - type: git + dest: ext/glslang + commit: dc11adde23c455a24e13dd54de9b4ede8bdd7db8 + url: https://github.com/hrydgard/glslang.git + - type: git + dest: ext/miniupnp + commit: 3a87be33e797ba947b2b2a5f8d087f6c3ff4d93e + url: https://github.com/hrydgard/miniupnp.git + - type: git + dest: ext/native/tools/prebuilt + commit: cbea79dc8fef4d9210e2bac7e7b9b5ff3388197a + url: https://github.com/hrydgard/ppsspp-freetype.git + - type: git + dest: ext/rapidjson + commit: 73063f5002612c6bf64fe24f851cd5cc0d83eef9 + disable-submodules: true + url: https://github.com/Tencent/rapidjson.git + - type: git + dest: ext/zstd + commit: a488ba114ec17ea1054b9057c26a046fc122b3b6 + url: https://github.com/facebook/zstd.git + - type: git + dest: ffmpeg + commit: 3ad7ddb9eb2af898dce8c4b5e9a28b77b3f7ddd7 + url: https://github.com/hrydgard/ppsspp-ffmpeg.git + - type: git + dest: pspautotests + commit: 682a4303aba63a50c91ae0fa6928c9dac8ca9b92 + url: https://github.com/hrydgard/pspautotests.git + # PPSSPP Flathub Workaround - END + # PPSSPP - END + # Yuzu - START # https://github.com/flathub/org.yuzu_emu.yuzu # WHEN UPADTING: remember to update rd-submodules/yuzu contents @@ -1200,93 +1287,6 @@ modules: # PRIMEHACK - END - # PPSSPP - START - # https://github.com/flathub/org.ppsspp.PPSSPP - - - name: ppsspp - buildsystem: cmake-ninja - config-opts: - - -DUSE_SYSTEM_FFMPEG=OFF # turn this on? - - -DUSE_SYSTEM_LIBZIP=ON - - -DUSE_SYSTEM_ZSTD=ON - - - -DUSE_WAYLAND_WSI=ON - - -DUSING_X11_VULKAN=ON - - -DUSING_QT_UI=OFF - - - -DBUILD_TESTING=OFF - - -DOpenGL_GL_PREFERENCE=GLVND - build-options: - - -DX86_64=ON - sources: - - type: git - url: https://github.com/hrydgard/ppsspp.git - tag: v1.13.2 - commit: 9fe6338e3bf397f8a009a51a282c139dfa180eb6 - x-checker-data: - type: git - tag-pattern: ^v([\d.]+)$ - - # PPSSPP Flathub Workaround - START - # This workaround disables the PPSSPP libraries (disable-submodules: true) and install them separately - # This is only to make it buildable by the flathub builder as normaly it seems not to be needed - disable-submodules: true - - type: git - dest: SDL/macOS - commit: f19a1d54b8a5af6cc378ea307e0ec676922eb4cc - url: https://github.com/hrydgard/ppsspp-mac-sdl - - type: git - dest: assets/debugger - commit: 36ad6b19b22de2075a01a4f0c765e3ef514dc38f - url: https://github.com/unknownbrackets/ppsspp-debugger.git - - type: git - dest: dx9sdk - commit: 7751cf73f5c06f1be21f5f31c3e2d9a7bacd3a93 - url: https://github.com/hrydgard/minidx9.git - - type: git - dest: ext/SPIRV-Cross - commit: 9acb9ec31f5a8ef80ea6b994bb77be787b08d3d1 - url: https://github.com/KhronosGroup/SPIRV-Cross.git - - type: git - dest: ext/armips - commit: 7885552b208493a6a0f21663770c446c3ba65576 - url: https://github.com/Kingcom/armips.git - - type: git - dest: ext/discord-rpc - commit: 963aa9f3e5ce81a4682c6ca3d136cddda614db33 - url: https://github.com/discordapp/discord-rpc.git - - type: git - dest: ext/glslang - commit: dc11adde23c455a24e13dd54de9b4ede8bdd7db8 - url: https://github.com/hrydgard/glslang.git - - type: git - dest: ext/miniupnp - commit: 3a87be33e797ba947b2b2a5f8d087f6c3ff4d93e - url: https://github.com/hrydgard/miniupnp.git - - type: git - dest: ext/native/tools/prebuilt - commit: cbea79dc8fef4d9210e2bac7e7b9b5ff3388197a - url: https://github.com/hrydgard/ppsspp-freetype.git - - type: git - dest: ext/rapidjson - commit: 73063f5002612c6bf64fe24f851cd5cc0d83eef9 - disable-submodules: true - url: https://github.com/Tencent/rapidjson.git - - type: git - dest: ext/zstd - commit: a488ba114ec17ea1054b9057c26a046fc122b3b6 - url: https://github.com/facebook/zstd.git - - type: git - dest: ffmpeg - commit: 3ad7ddb9eb2af898dce8c4b5e9a28b77b3f7ddd7 - url: https://github.com/hrydgard/ppsspp-ffmpeg.git - - type: git - dest: pspautotests - commit: 682a4303aba63a50c91ae0fa6928c9dac8ca9b92 - url: https://github.com/hrydgard/pspautotests.git - # PPSSPP Flathub Workaround - END - # PPSSPP - END - # Duckstation - START # https://github.com/flathub/org.duckstation.DuckStation From b2391ef5cdca45e9e5a1014976d9f9e38e74e79f Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 17 Sep 2022 09:08:13 +0200 Subject: [PATCH 062/124] RPCS3: removed branch specification as it was breaking the build --- net.retrodeck.retrodeck.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 9f4912ad..c68cfcc9 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1242,8 +1242,7 @@ modules: sources: - type: git url: https://github.com/RPCS3/rpcs3.git - branch: master - commit: 2807be7080ab71d5c542a2bef7323f9b43f192e6 + commit: 9d9e18f6147760f2502401ea0b0d4b3524f051c8 # RPCS3 - END From f1f03b60dc7408306936c484d89e4bdb8e61e0ef Mon Sep 17 00:00:00 2001 From: XargonWan <xargonwan@gmail.com> Date: Sat, 17 Sep 2022 17:03:25 +0200 Subject: [PATCH 063/124] GLOBAL.SH: added debug code to conf_write --- global.sh | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/global.sh b/global.sh index 98829902..58652eda 100755 --- a/global.sh +++ b/global.sh @@ -37,6 +37,10 @@ fi conf_write() { # writes the variables in the retrodeck config file + echo "DEBUG: printing the config file content before writing it:" + cat $rd_conf + echo "" + echo "Writing the config file: $rd_conf" # TODO: this can be optimized with a while and a list of variables to check @@ -65,4 +69,8 @@ conf_write() { sed -i "s%themes_folder=.*%themes_folder=$themes_folder%" $rd_conf fi + echo "DEBUG: New contents:" + cat $rd_conf + echo "" + } \ No newline at end of file From f4aef1fa80406175d1caeffece203def97866a92 Mon Sep 17 00:00:00 2001 From: XargonWan <xargonwan@gmail.com> Date: Sat, 17 Sep 2022 17:17:27 +0200 Subject: [PATCH 064/124] GLOBAL.SH: added some hypens --- global.sh | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/global.sh b/global.sh index 58652eda..8a4af0de 100755 --- a/global.sh +++ b/global.sh @@ -11,7 +11,7 @@ hard_version="$(cat '/app/retrodeck/version')" # hardcoded version ( # If there is no config file I initalize the file with the the default values -if [ ! -f $rd_conf ] +if [ ! -f "$rd_conf" ] then echo "RetroDECK config file not found in $rd_conf" @@ -31,14 +31,14 @@ then else echo "Found RetroDECK config file in $rd_conf" echo "Loading it" - source $rd_conf + source "$rd_conf" fi conf_write() { # writes the variables in the retrodeck config file echo "DEBUG: printing the config file content before writing it:" - cat $rd_conf + cat "$rd_conf" echo "" echo "Writing the config file: $rd_conf" @@ -46,31 +46,31 @@ conf_write() { # TODO: this can be optimized with a while and a list of variables to check if [ ! -z "$version" ] #if the variable is not null then I update it then - sed -i "s%version=.*%version=$version%" $rd_conf + sed -i "s%version=.*%version=$version%" "$rd_conf" fi if [ ! -z "$rdhome" ] then - sed -i "s%rdhome=.*%rdhome=$rdhome%" $rd_conf + sed -i "s%rdhome=.*%rdhome=$rdhome%" "$rd_conf" fi if [ ! -z "$roms_folder" ] then - sed -i "s%roms_folder=.*%roms_folder=$roms_folder%" $rd_conf + sed -i "s%roms_folder=.*%roms_folder=$roms_folder%" "$rd_conf" fi if [ ! -z "$media_folder" ] then - sed -i "s%media_folder=.*%media_folder=$media_folder%" $rd_conf + sed -i "s%media_folder=.*%media_folder=$media_folder%" "$rd_conf" fi if [ ! -z "$themes_folder" ] then - sed -i "s%themes_folder=.*%themes_folder=$themes_folder%" $rd_conf + sed -i "s%themes_folder=.*%themes_folder=$themes_folder%" "$rd_conf" fi echo "DEBUG: New contents:" - cat $rd_conf + cat "$rd_conf" echo "" } \ No newline at end of file From c728be71d9cf8fa1aad071c2b47cb7cfec0d25f2 Mon Sep 17 00:00:00 2001 From: XargonWan <xargonwan@gmail.com> Date: Sat, 17 Sep 2022 17:20:39 +0200 Subject: [PATCH 065/124] GLOBAL.SH: moved write_conf function on top --- global.sh | 51 +++++++++++++++++++++++++-------------------------- 1 file changed, 25 insertions(+), 26 deletions(-) diff --git a/global.sh b/global.sh index 8a4af0de..160f3fae 100755 --- a/global.sh +++ b/global.sh @@ -9,31 +9,6 @@ lockfile="/var/config/retrodeck/.lock" # where the lockfile sdcard="/run/media/mmcblk0p1" # Steam Deck SD default path hard_version="$(cat '/app/retrodeck/version')" # hardcoded version (in the readonly filesystem) - -# If there is no config file I initalize the file with the the default values -if [ ! -f "$rd_conf" ] -then - - echo "RetroDECK config file not found in $rd_conf" - echo "Initializing" - - echo "#!/bin/bash" >> $rd_conf - version="$hard_version" # if we are here means that the we are in a new installation, so the version is valorized with the hardcoded one - rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck - roms_folder="$rdhome/roms" # the default roms folder path - media_folder="$HOME/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into - themes_folder="$HOME/retrodeck/themes" # the themes folder - - # writing the needed variables in the config file - conf_write - -# If the config file is existing i just read the variables (source it) -else - echo "Found RetroDECK config file in $rd_conf" - echo "Loading it" - source "$rd_conf" -fi - conf_write() { # writes the variables in the retrodeck config file @@ -73,4 +48,28 @@ conf_write() { cat "$rd_conf" echo "" -} \ No newline at end of file +} + +# If there is no config file I initalize the file with the the default values +if [ ! -f "$rd_conf" ] +then + + echo "RetroDECK config file not found in $rd_conf" + echo "Initializing" + + echo "#!/bin/bash" >> $rd_conf + version="$hard_version" # if we are here means that the we are in a new installation, so the version is valorized with the hardcoded one + rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck + roms_folder="$rdhome/roms" # the default roms folder path + media_folder="$HOME/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into + themes_folder="$HOME/retrodeck/themes" # the themes folder + + # writing the needed variables in the config file + conf_write + +# If the config file is existing i just read the variables (source it) +else + echo "Found RetroDECK config file in $rd_conf" + echo "Loading it" + source "$rd_conf" +fi \ No newline at end of file From f86f8958d30b9b2a251c7ded8567c7b405191de2 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 09:04:44 +0200 Subject: [PATCH 066/124] Enahcned default sd card check --- global.sh | 3 ++- retrodeck.sh | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/global.sh b/global.sh index 160f3fae..dc105d84 100755 --- a/global.sh +++ b/global.sh @@ -6,7 +6,7 @@ rd_conf="/var/config/retrodeck/retrodeck.cfg" # RetroDECK config file path emuconfigs="/app/retrodeck/emu-configs" # folder with all the default emulator configs lockfile="/var/config/retrodeck/.lock" # where the lockfile is located -sdcard="/run/media/mmcblk0p1" # Steam Deck SD default path +default_sd="/run/media/mmcblk0p1" # Steam Deck SD default path hard_version="$(cat '/app/retrodeck/version')" # hardcoded version (in the readonly filesystem) conf_write() { @@ -63,6 +63,7 @@ then roms_folder="$rdhome/roms" # the default roms folder path media_folder="$HOME/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into themes_folder="$HOME/retrodeck/themes" # the themes folder + sdcard="$default_sd" # Steam Deck SD default path # writing the needed variables in the config file conf_write diff --git a/retrodeck.sh b/retrodeck.sh index 960e949b..e50a7ea3 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -373,7 +373,7 @@ finit() { --text="SD Card was not find in the default location.\nPlease choose the SD Card root.\nA retrodeck/roms folder will be created starting from the directory that you selected." browse # Calling the browse function else - roms_folder="$sdcard/retrodeck/roms" + roms_folder="$sdcard/retrodeck/roms" # sdcard variable is correct as its given by browse function echo "ROMs folder = $roms_folder" fi ;; From 23fd76e205e3c355cfccab668940051a516eb03d Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 09:05:20 +0200 Subject: [PATCH 067/124] Enahcned default sd card check --- global.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/global.sh b/global.sh index dc105d84..ccdfa559 100755 --- a/global.sh +++ b/global.sh @@ -63,7 +63,7 @@ then roms_folder="$rdhome/roms" # the default roms folder path media_folder="$HOME/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into themes_folder="$HOME/retrodeck/themes" # the themes folder - sdcard="$default_sd" # Steam Deck SD default path + sdcard="$default_sd" # Steam Deck SD default path # writing the needed variables in the config file conf_write From 5ff512665a205bb41438f8c5a95663f98a220e79 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 09:20:35 +0200 Subject: [PATCH 068/124] Fixed variables creation --- global.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/global.sh b/global.sh index ccdfa559..67182e05 100755 --- a/global.sh +++ b/global.sh @@ -61,8 +61,8 @@ then version="$hard_version" # if we are here means that the we are in a new installation, so the version is valorized with the hardcoded one rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck roms_folder="$rdhome/roms" # the default roms folder path - media_folder="$HOME/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into - themes_folder="$HOME/retrodeck/themes" # the themes folder + media_folder="$rdhome/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into + themes_folder="$rdhome/retrodeck/themes" # the themes folder sdcard="$default_sd" # Steam Deck SD default path # writing the needed variables in the config file From 67d7b4d74fdd120ae673652ab4fe1c96114f5435 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 09:25:49 +0200 Subject: [PATCH 069/124] Fixed variables system --- global.sh | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/global.sh b/global.sh index 67182e05..cf432324 100755 --- a/global.sh +++ b/global.sh @@ -57,14 +57,23 @@ then echo "RetroDECK config file not found in $rd_conf" echo "Initializing" - echo "#!/bin/bash" >> $rd_conf + # Initializing the variables version="$hard_version" # if we are here means that the we are in a new installation, so the version is valorized with the hardcoded one rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck roms_folder="$rdhome/roms" # the default roms folder path - media_folder="$rdhome/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into - themes_folder="$rdhome/retrodeck/themes" # the themes folder + media_folder="$rdhome/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into + themes_folder="$rdhome/retrodeck/themes" # the themes folder sdcard="$default_sd" # Steam Deck SD default path + # Writing the variables for the first time + echo "#!/bin/bash" >> $rd_conf + echo "version=$version" >> $rd_conf + echo "rdhome=$rdhome" >> $rd_conf + echo "roms_folder=$roms_folder" >> $rd_conf + echo "media_folder=$media_folder" >> $rd_conf + echo "themes_folder=$themes_folder" >> $rd_conf + echo "sdcard=$sdcard" >> $rd_conf + # writing the needed variables in the config file conf_write From a3ae3922269bc2836909c1cb3e4df1d511c90bbe Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 09:27:22 +0200 Subject: [PATCH 070/124] Fixed variables system -fix1 --- global.sh | 3 --- 1 file changed, 3 deletions(-) diff --git a/global.sh b/global.sh index cf432324..3ed2c545 100755 --- a/global.sh +++ b/global.sh @@ -74,9 +74,6 @@ then echo "themes_folder=$themes_folder" >> $rd_conf echo "sdcard=$sdcard" >> $rd_conf - # writing the needed variables in the config file - conf_write - # If the config file is existing i just read the variables (source it) else echo "Found RetroDECK config file in $rd_conf" From 66dc991ae77ecfedd28f894f410837ece56b9c7c Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 09:28:58 +0200 Subject: [PATCH 071/124] Fixed variables system -fix2 --- global.sh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/global.sh b/global.sh index 3ed2c545..5cb2e902 100755 --- a/global.sh +++ b/global.sh @@ -44,6 +44,11 @@ conf_write() { sed -i "s%themes_folder=.*%themes_folder=$themes_folder%" "$rd_conf" fi + if [ ! -z "$sdcard" ] + then + sed -i "s%sdcard=.*%sdcard=$sdcard%" "$rd_conf" + fi + echo "DEBUG: New contents:" cat "$rd_conf" echo "" From 10311c1d339747ca39dd6e12419cabf1922801dc Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 10:26:58 +0200 Subject: [PATCH 072/124] YUZU: updated to the latest mainline --- net.retrodeck.retrodeck.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index c68cfcc9..b87a1178 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -637,8 +637,8 @@ modules: sources: - type: git url: https://github.com/yuzu-emu/yuzu-mainline.git - tag: mainline-0-1163 - commit: f0a6d73fe2cf94ddcef54516d261c21816cd48d1 + tag: mainline-0-1171 + commit: 3b25d1fe22f5eee7a046432884d78b25a3950988 disable-shallow-clone: true x-checker-data: type: git From b6d286e9072ddacf457b045db2f01d2c83cba8ea Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 11:09:52 +0200 Subject: [PATCH 073/124] YUZU: fixed roms path --- emu-configs/yuzu/qt-config.ini | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/emu-configs/yuzu/qt-config.ini b/emu-configs/yuzu/qt-config.ini index 6149a971..d44de0c4 100644 --- a/emu-configs/yuzu/qt-config.ini +++ b/emu-configs/yuzu/qt-config.ini @@ -947,7 +947,7 @@ Paths\gamedirs\4\deep_scan=false Paths\gamedirs\4\deep_scan\default=true Paths\gamedirs\4\expanded=true Paths\gamedirs\4\expanded\default=true -Paths\gamedirs\4\path=/run/user/1000/doc/a06af84a/Pictures +Paths\gamedirs\4\path=~/retrodeck/roms/switch Paths\gamedirs\size=4 Paths\language=en Paths\language\default=false @@ -956,7 +956,7 @@ Paths\romsPath=~/retrodeck/roms/switch Paths\symbolsPath= Screenshots\enable_screenshot_save_as=true Screenshots\enable_screenshot_save_as\default=true -Screenshots\screenshot_path=/var/data/yuzu/screenshots +Screenshots\screenshot_path=~/retrodeck/screenshots Shortcuts\Main%20Window\Audio%20Mute\Unmute\Context=1 Shortcuts\Main%20Window\Audio%20Mute\Unmute\Context\default=true Shortcuts\Main%20Window\Audio%20Mute\Unmute\Controller_KeySeq= From d55a684010d507f2760c19db795588a79ec9d0ff Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 14:13:07 +0200 Subject: [PATCH 074/124] Added workflow to push cooke to flathub --- .github/workflows/flathub_push_cooker.yml | 75 +++++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 .github/workflows/flathub_push_cooker.yml diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml new file mode 100644 index 00000000..76e1a77f --- /dev/null +++ b/.github/workflows/flathub_push_cooker.yml @@ -0,0 +1,75 @@ +name: push-cooker-flathub + +#on: +# push: +# branches: +# - cooker* +# pull_request: +# branches: +# - cooker* + +# workflow_dispatch: + + +jobs: + + Pushing_cooker_into_flathub: + runs-on: self-hosted + steps: + + - name: Pushing + run: + | + # EDITABLES: + rd_branch="cooker" + gits_folder="gits" # without last / + + # NON-EDITABLES + branch="$rd_branch-"$(date +%d%m%y.%H%M) + + mkdir -p $gits_folder + cd $gits_folder + rm -rf flathub + git clone --recursive https://github.com/flathub/net.retrodeck.retrodeck.git flathub + git clone --recursive https://github.com/XargonWan/RetroDECK RetroDECK + cd $gits_folder/RetroDECK + git checkout $rd_branch + git submodule init + git submodule update + # NOTE: the only linked submodules are: rd-submodules/retroarch + # these must be included in the exclusion list as they must be redownloaded + #sync -rav --progress --exclude={'res/screenshots/','shared-modules/','rd-submodules/retroarch','.git/','docs','retrodeck-flatpak/','retrodeck-flatpak-cooker/','.flatpak-builder/'} ~/RetroDECK/ ~/flathub/ + + cd $gits_folder/flathub + git checkout -b $branch + git rm -rf * + git clean -fxd # restroing git index + + # Copying only a few files as the others are cloned by git in retrodeck.sh + cd $gits_folder/RetroDECK + cp -rf \ + 'rd-submodules' \ + 'flathub.json' \ + 'LICENSE' \ + 'net.retrodeck.retrodeck.appdata.xml' \ + 'net.retrodeck.retrodeck.desktop' \ + 'net.retrodeck.retrodeck.yml' \ + 'README.md' \ + $gits_folder/flathub/ + cd $gits_folder/flathub + + rm -rf .git/modules/* + # Adding the real submodules, please update this every time a submodule is added + git rm -rf shared-modules + git submodule add https://github.com/flathub/shared-modules.git shared-modules + + git rm -rf rd-submodules/retroarch + git submodule add https://github.com/flathub/org.libretro.RetroArch.git rd-submodules/retroarch + + # unbinds all submodules + git submodule deinit -f . + # checkout again + git submodule update --init --recursive + git add * + git commit -m "Updated flathub/net.retrodeck.retrodeck from RetroDECK/$rd_branch" + git push origin $branch \ No newline at end of file From 36766b06448d65c7b8c91f81acdd6d4b9b36e819 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 14:14:34 +0200 Subject: [PATCH 075/124] Added workflow to push cooke to flathub -fix1 --- .github/workflows/flathub_push_cooker.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index 76e1a77f..3ed848ee 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -1,6 +1,6 @@ name: push-cooker-flathub -#on: +on: # push: # branches: # - cooker* @@ -8,7 +8,7 @@ name: push-cooker-flathub # branches: # - cooker* -# workflow_dispatch: + workflow_dispatch: jobs: From a2b8ee0f5cd5027b26b189b4243eeffb120fb5d4 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Mon, 19 Sep 2022 17:49:59 +0200 Subject: [PATCH 076/124] PCSX2-QT updated --- net.retrodeck.retrodeck.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index b87a1178..14cac767 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -957,8 +957,8 @@ modules: - ln -s "${FLATPAK_DEST}/pcsx2-qt/usr/bin/pcsx2-qt" "${FLATPAK_DEST}/bin/pcsx2-qt" sources: - type: file - url: https://github.com/PCSX2/pcsx2/releases/download/v1.7.3304/pcsx2-v1.7.3304-linux-AppImage-64bit-AVX2-Qt.AppImage - sha256: 04e56b9e6113fefce7057b2dd19f0501b79d36f31c718406bda45204a2be121a + url: https://github.com/PCSX2/pcsx2/releases/download/v1.7.3325/pcsx2-v1.7.3325-linux-AppImage-64bit-AVX2-Qt.AppImage + sha256: 5fa89570fb68b8a729dc0589e568d3a09b2b9243d4d66a5b7086975fb02e95e4 # PCSX2 - END From 2e7b3dd8c50fafd7655c773c1fe391e4c66a7513 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 20 Sep 2022 09:42:46 +0200 Subject: [PATCH 077/124] TOOLS: valorized retroarch config paths --- tools/cheevos.sh | 2 +- tools/rewind.sh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/tools/cheevos.sh b/tools/cheevos.sh index 71897d8a..877c4998 100755 --- a/tools/cheevos.sh +++ b/tools/cheevos.sh @@ -1,6 +1,6 @@ #!/bin/bash -racfg="" +racfg="/var/config/retroarch/retroarch.cfg" login=$(zenity --forms --title="RetroAchievements Login" \ --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ diff --git a/tools/rewind.sh b/tools/rewind.sh index abc79a22..c60c246a 100755 --- a/tools/rewind.sh +++ b/tools/rewind.sh @@ -1,6 +1,6 @@ #!/bin/bash -racfg="" +racfg="/var/config/retroarch/retroarch.cfg" zenity --question \ --no-wrap --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ From 836b2484fa2a39fb0099b79752a3c042bc89d6c4 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:14:26 +0200 Subject: [PATCH 078/124] MANIFEST: disabled duplicate ffmpeg module --- net.retrodeck.retrodeck.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 14cac767..80ed3587 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -477,10 +477,10 @@ modules: dest: ext/zstd commit: a488ba114ec17ea1054b9057c26a046fc122b3b6 url: https://github.com/facebook/zstd.git - - type: git - dest: ffmpeg - commit: 3ad7ddb9eb2af898dce8c4b5e9a28b77b3f7ddd7 - url: https://github.com/hrydgard/ppsspp-ffmpeg.git + #- type: git + # dest: ffmpeg + # commit: 3ad7ddb9eb2af898dce8c4b5e9a28b77b3f7ddd7 + # url: https://github.com/hrydgard/ppsspp-ffmpeg.git - type: git dest: pspautotests commit: 682a4303aba63a50c91ae0fa6928c9dac8ca9b92 From e29bd8c0c9b3c1d173c276265d2778c3fcc954fb Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:17:22 +0200 Subject: [PATCH 079/124] Juggling with workflow --- .../{flathub_push_cooker.yml => flathub_push_cooker.yml.old} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename .github/workflows/{flathub_push_cooker.yml => flathub_push_cooker.yml.old} (100%) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml.old similarity index 100% rename from .github/workflows/flathub_push_cooker.yml rename to .github/workflows/flathub_push_cooker.yml.old From 6bfc08aa02a63e3b9d98f0bbb1c0193cf706a379 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:17:41 +0200 Subject: [PATCH 080/124] Juggling with workflow --- .../{flathub_push_cooker.yml.old => flathub_push_cooker.yml} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename .github/workflows/{flathub_push_cooker.yml.old => flathub_push_cooker.yml} (100%) diff --git a/.github/workflows/flathub_push_cooker.yml.old b/.github/workflows/flathub_push_cooker.yml similarity index 100% rename from .github/workflows/flathub_push_cooker.yml.old rename to .github/workflows/flathub_push_cooker.yml From 58c29c73c45bceeaa11394bd65a4a7d575c5ea18 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:21:06 +0200 Subject: [PATCH 081/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index 3ed848ee..f252839a 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -1,4 +1,4 @@ -name: push-cooker-flathub +name: PUSH-cooker-flathub on: # push: @@ -16,10 +16,9 @@ jobs: Pushing_cooker_into_flathub: runs-on: self-hosted steps: - - name: Pushing - run: - | + shell: bash + run: | # EDITABLES: rd_branch="cooker" gits_folder="gits" # without last / From c7289c52925c4b19e0f2356408aaa5afcc09dcee Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:22:19 +0200 Subject: [PATCH 082/124] Update flathub_push_cooker.yml --- .github/workflows/flathub_push_cooker.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index f252839a..90d7a280 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -10,7 +10,6 @@ on: workflow_dispatch: - jobs: Pushing_cooker_into_flathub: @@ -71,4 +70,4 @@ jobs: git submodule update --init --recursive git add * git commit -m "Updated flathub/net.retrodeck.retrodeck from RetroDECK/$rd_branch" - git push origin $branch \ No newline at end of file + git push origin $branch From b2894ca38f762c01f918ef9e27c2b620efa9b464 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:26:53 +0200 Subject: [PATCH 083/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index 90d7a280..0d9421ba 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -1,3 +1,4 @@ + name: PUSH-cooker-flathub on: From 946672304cb7539189aa9d38799835ca31036292 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:30:30 +0200 Subject: [PATCH 084/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 74 ----------------------- 1 file changed, 74 deletions(-) delete mode 100644 .github/workflows/flathub_push_cooker.yml diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml deleted file mode 100644 index 0d9421ba..00000000 --- a/.github/workflows/flathub_push_cooker.yml +++ /dev/null @@ -1,74 +0,0 @@ - -name: PUSH-cooker-flathub - -on: -# push: -# branches: -# - cooker* -# pull_request: -# branches: -# - cooker* - - workflow_dispatch: - -jobs: - - Pushing_cooker_into_flathub: - runs-on: self-hosted - steps: - - name: Pushing - shell: bash - run: | - # EDITABLES: - rd_branch="cooker" - gits_folder="gits" # without last / - - # NON-EDITABLES - branch="$rd_branch-"$(date +%d%m%y.%H%M) - - mkdir -p $gits_folder - cd $gits_folder - rm -rf flathub - git clone --recursive https://github.com/flathub/net.retrodeck.retrodeck.git flathub - git clone --recursive https://github.com/XargonWan/RetroDECK RetroDECK - cd $gits_folder/RetroDECK - git checkout $rd_branch - git submodule init - git submodule update - # NOTE: the only linked submodules are: rd-submodules/retroarch - # these must be included in the exclusion list as they must be redownloaded - #sync -rav --progress --exclude={'res/screenshots/','shared-modules/','rd-submodules/retroarch','.git/','docs','retrodeck-flatpak/','retrodeck-flatpak-cooker/','.flatpak-builder/'} ~/RetroDECK/ ~/flathub/ - - cd $gits_folder/flathub - git checkout -b $branch - git rm -rf * - git clean -fxd # restroing git index - - # Copying only a few files as the others are cloned by git in retrodeck.sh - cd $gits_folder/RetroDECK - cp -rf \ - 'rd-submodules' \ - 'flathub.json' \ - 'LICENSE' \ - 'net.retrodeck.retrodeck.appdata.xml' \ - 'net.retrodeck.retrodeck.desktop' \ - 'net.retrodeck.retrodeck.yml' \ - 'README.md' \ - $gits_folder/flathub/ - cd $gits_folder/flathub - - rm -rf .git/modules/* - # Adding the real submodules, please update this every time a submodule is added - git rm -rf shared-modules - git submodule add https://github.com/flathub/shared-modules.git shared-modules - - git rm -rf rd-submodules/retroarch - git submodule add https://github.com/flathub/org.libretro.RetroArch.git rd-submodules/retroarch - - # unbinds all submodules - git submodule deinit -f . - # checkout again - git submodule update --init --recursive - git add * - git commit -m "Updated flathub/net.retrodeck.retrodeck from RetroDECK/$rd_branch" - git push origin $branch From 19e28c4e17b4b37af3830cb08b609a185b65e008 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:34:28 +0200 Subject: [PATCH 085/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 74 +++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 .github/workflows/flathub_push_cooker.yml diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml new file mode 100644 index 00000000..f01647aa --- /dev/null +++ b/.github/workflows/flathub_push_cooker.yml @@ -0,0 +1,74 @@ + +name: PUSH-cooker-flathub + +on: +# push: +# branches: +# - cooker* +# pull_request: +# branches: +# - cooker* + + workflow_dispatch: + +jobs: + + Pushing_cooker_into_flathub: + runs-on: self-hosted + steps: + - name: Pushing + shell: bash + run: | + # EDITABLES: + rd_branch="cooker" + gits_folder="gits" # without last / + + # NON-EDITABLES + branch="$rd_branch-"$(date +%d%m%y.%H%M) + + mkdir -p $gits_folder + cd $gits_folder + rm -rf flathub + git clone --recursive https://github.com/flathub/net.retrodeck.retrodeck.git flathub + git clone --recursive https://github.com/XargonWan/RetroDECK RetroDECK + cd $gits_folder/RetroDECK + git checkout $rd_branch + git submodule init + git submodule update + # NOTE: the only linked submodules are: rd-submodules/retroarch + # these must be included in the exclusion list as they must be redownloaded + #sync -rav --progress --exclude={'res/screenshots/','shared-modules/','rd-submodules/retroarch','.git/','docs','retrodeck-flatpak/','retrodeck-flatpak-cooker/','.flatpak-builder/'} ~/RetroDECK/ ~/flathub/ + + cd $gits_folder/flathub + git checkout -b $branch + git rm -rf * + git clean -fxd # restroing git index + + # Copying only a few files as the others are cloned by git in retrodeck.sh + cd $gits_folder/RetroDECK + cp -rf \ + 'rd-submodules' \ + 'flathub.json' \ + 'LICENSE' \ + 'net.retrodeck.retrodeck.appdata.xml' \ + 'net.retrodeck.retrodeck.desktop' \ + 'net.retrodeck.retrodeck.yml' \ + 'README.md' \ + $gits_folder/flathub/ + cd $gits_folder/flathub + + rm -rf .git/modules/* + # Adding the real submodules, please update this every time a submodule is added + git rm -rf shared-modules + git submodule add https://github.com/flathub/shared-modules.git shared-modules + + git rm -rf rd-submodules/retroarch + git submodule add https://github.com/flathub/org.libretro.RetroArch.git rd-submodules/retroarch + + # unbinds all submodules + git submodule deinit -f . + # checkout again + git submodule update --init --recursive + git add * + git commit -m "Updated flathub/net.retrodeck.retrodeck from RetroDECK/$rd_branch" + git push origin $branch \ No newline at end of file From 8cb76d694c382d57cfc22b5b1401bca71328e4c4 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:35:57 +0200 Subject: [PATCH 086/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index f01647aa..c519b935 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -14,7 +14,7 @@ on: jobs: Pushing_cooker_into_flathub: - runs-on: self-hosted + runs-on: ubuntu-latest steps: - name: Pushing shell: bash From 0a98779aa970938e250390276caba1ca8274d518 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:46:37 +0200 Subject: [PATCH 087/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index c519b935..d9c53c3b 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -26,9 +26,11 @@ jobs: # NON-EDITABLES branch="$rd_branch-"$(date +%d%m%y.%H%M) - mkdir -p $gits_folder + mkdir -vp $gits_folder cd $gits_folder - rm -rf flathub + if [ -d flathub ]; then + rm -rfv flathub + fi git clone --recursive https://github.com/flathub/net.retrodeck.retrodeck.git flathub git clone --recursive https://github.com/XargonWan/RetroDECK RetroDECK cd $gits_folder/RetroDECK From 53c5c14e11fc2bc2a82b00dd4bdf07d6f9fcbe6b Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:48:54 +0200 Subject: [PATCH 088/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index d9c53c3b..c61de2e2 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -32,6 +32,7 @@ jobs: rm -rfv flathub fi git clone --recursive https://github.com/flathub/net.retrodeck.retrodeck.git flathub + cd $gits_folder git clone --recursive https://github.com/XargonWan/RetroDECK RetroDECK cd $gits_folder/RetroDECK git checkout $rd_branch From 95828579fb01554e10a4afcdf84c235a307056e3 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:53:05 +0200 Subject: [PATCH 089/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index c61de2e2..338f1244 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -21,7 +21,7 @@ jobs: run: | # EDITABLES: rd_branch="cooker" - gits_folder="gits" # without last / + gits_folder="${GITHUB_WORKSPACE}/gits" # without last / # NON-EDITABLES branch="$rd_branch-"$(date +%d%m%y.%H%M) From 21356e6f0cb860d7c591193e123f8a90ec9d40e8 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:56:42 +0200 Subject: [PATCH 090/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index 338f1244..58d477bf 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -58,14 +58,18 @@ jobs: 'net.retrodeck.retrodeck.yml' \ 'README.md' \ $gits_folder/flathub/ - cd $gits_folder/flathub - rm -rf .git/modules/* + cd $gits_folder/flathub + rm -rfv .git/modules/* # Adding the real submodules, please update this every time a submodule is added - git rm -rf shared-modules + if [ -d shared-modules ]; then + git rm -rfv shared-modules + fi git submodule add https://github.com/flathub/shared-modules.git shared-modules - git rm -rf rd-submodules/retroarch + if [ -d rd-submodules/retroarch ]; then + git rm -rfv rd-submodules/retroarch + fi git submodule add https://github.com/flathub/org.libretro.RetroArch.git rd-submodules/retroarch # unbinds all submodules From 7a5250aaa8b77d31eaa31d61b8bafa0f30af0fa0 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 09:58:29 +0200 Subject: [PATCH 091/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index 58d477bf..b146e2ea 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -29,7 +29,7 @@ jobs: mkdir -vp $gits_folder cd $gits_folder if [ -d flathub ]; then - rm -rfv flathub + rm -rf flathub fi git clone --recursive https://github.com/flathub/net.retrodeck.retrodeck.git flathub cd $gits_folder @@ -63,12 +63,12 @@ jobs: rm -rfv .git/modules/* # Adding the real submodules, please update this every time a submodule is added if [ -d shared-modules ]; then - git rm -rfv shared-modules + git rm -rf shared-modules fi git submodule add https://github.com/flathub/shared-modules.git shared-modules if [ -d rd-submodules/retroarch ]; then - git rm -rfv rd-submodules/retroarch + git rm -rf rd-submodules/retroarch fi git submodule add https://github.com/flathub/org.libretro.RetroArch.git rd-submodules/retroarch From e470d26c6bfeb7465f497d7110fe8012c0a5c8ad Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 10:00:21 +0200 Subject: [PATCH 092/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index b146e2ea..a204c5c1 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -60,7 +60,9 @@ jobs: $gits_folder/flathub/ cd $gits_folder/flathub - rm -rfv .git/modules/* + if [ -d .git/modules ]; then + rm -rfv .git/modules/* + fi # Adding the real submodules, please update this every time a submodule is added if [ -d shared-modules ]; then git rm -rf shared-modules From 950b7193eaf60d173594dddb0e7c484167208ae4 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 10:11:29 +0200 Subject: [PATCH 093/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index a204c5c1..304fb6ba 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -63,10 +63,12 @@ jobs: if [ -d .git/modules ]; then rm -rfv .git/modules/* fi + # Adding the real submodules, please update this every time a submodule is added + if [ -d shared-modules ]; then git rm -rf shared-modules - fi + fi git submodule add https://github.com/flathub/shared-modules.git shared-modules if [ -d rd-submodules/retroarch ]; then From 80f4a075a6ddd84041ae8c2783b9fca7f33462d4 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 11:37:47 +0200 Subject: [PATCH 094/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index 304fb6ba..5c2bf1c1 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -71,10 +71,10 @@ jobs: fi git submodule add https://github.com/flathub/shared-modules.git shared-modules - if [ -d rd-submodules/retroarch ]; then - git rm -rf rd-submodules/retroarch + if [ -d $gits_folder/RetroDECK/rd-submodules/retroarch ]; then + git rm -rf $gits_folder/RetroDECK/rd-submodules/retroarch fi - git submodule add https://github.com/flathub/org.libretro.RetroArch.git rd-submodules/retroarch + git submodule add https://github.com/flathub/org.libretro.RetroArch.git $gits_folder/RetroDECK/rd-submodules/retroarch # unbinds all submodules git submodule deinit -f . From b505a76de2861458cf5dad74ac4b5bbf134d621f Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 11:40:33 +0200 Subject: [PATCH 095/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index 5c2bf1c1..b7588fc2 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -60,6 +60,8 @@ jobs: $gits_folder/flathub/ cd $gits_folder/flathub + ls -la + if [ -d .git/modules ]; then rm -rfv .git/modules/* fi @@ -71,10 +73,10 @@ jobs: fi git submodule add https://github.com/flathub/shared-modules.git shared-modules - if [ -d $gits_folder/RetroDECK/rd-submodules/retroarch ]; then - git rm -rf $gits_folder/RetroDECK/rd-submodules/retroarch + if [ -d rd-submodules/retroarch ]; then + git rm -rf rd-submodules/retroarch fi - git submodule add https://github.com/flathub/org.libretro.RetroArch.git $gits_folder/RetroDECK/rd-submodules/retroarch + git submodule add https://github.com/flathub/org.libretro.RetroArch.git rd-submodules/retroarch # unbinds all submodules git submodule deinit -f . From ffb5250f9cda715dcf6fb1665005acd7e853b3ef Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 11:45:38 +0200 Subject: [PATCH 096/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index b7588fc2..de908b0f 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -71,12 +71,12 @@ jobs: if [ -d shared-modules ]; then git rm -rf shared-modules fi - git submodule add https://github.com/flathub/shared-modules.git shared-modules + git submodule add https://github.com/flathub/shared-modules.git ./shared-modules if [ -d rd-submodules/retroarch ]; then git rm -rf rd-submodules/retroarch fi - git submodule add https://github.com/flathub/org.libretro.RetroArch.git rd-submodules/retroarch + git submodule add https://github.com/flathub/org.libretro.RetroArch.git ./rd-submodules/retroarch # unbinds all submodules git submodule deinit -f . From 7ceed88b2ea38b074c5f17dd6b26e004097f785b Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 11:48:24 +0200 Subject: [PATCH 097/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index de908b0f..d9ede557 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -69,12 +69,12 @@ jobs: # Adding the real submodules, please update this every time a submodule is added if [ -d shared-modules ]; then - git rm -rf shared-modules + git rm -rf --ignore-unmatch shared-modules fi git submodule add https://github.com/flathub/shared-modules.git ./shared-modules if [ -d rd-submodules/retroarch ]; then - git rm -rf rd-submodules/retroarch + git rm -rf --ignore-unmatch rd-submodules/retroarch fi git submodule add https://github.com/flathub/org.libretro.RetroArch.git ./rd-submodules/retroarch From e45b5e99b5bf56839fe9f68ecf84e301a41494f1 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 11:51:37 +0200 Subject: [PATCH 098/124] Juggling with workflow --- .github/workflows/flathub_push_cooker.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/flathub_push_cooker.yml b/.github/workflows/flathub_push_cooker.yml index d9ede557..788a47f9 100644 --- a/.github/workflows/flathub_push_cooker.yml +++ b/.github/workflows/flathub_push_cooker.yml @@ -70,11 +70,13 @@ jobs: if [ -d shared-modules ]; then git rm -rf --ignore-unmatch shared-modules + rm -rfv shared-modules fi git submodule add https://github.com/flathub/shared-modules.git ./shared-modules if [ -d rd-submodules/retroarch ]; then git rm -rf --ignore-unmatch rd-submodules/retroarch + rm -rfv rd-submodules/retroarch fi git submodule add https://github.com/flathub/org.libretro.RetroArch.git ./rd-submodules/retroarch From 7b482ea8b1fce99742fdffea3d0fa9556dfeeb7a Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 16:22:00 +0200 Subject: [PATCH 099/124] Various fixes by RavenKilit --- global.sh | 6 +++--- retrodeck.sh | 4 ++++ tools/cheevos.sh | 6 +++--- 3 files changed, 10 insertions(+), 6 deletions(-) diff --git a/global.sh b/global.sh index 5cb2e902..b67d81f8 100755 --- a/global.sh +++ b/global.sh @@ -66,12 +66,12 @@ then version="$hard_version" # if we are here means that the we are in a new installation, so the version is valorized with the hardcoded one rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck roms_folder="$rdhome/roms" # the default roms folder path - media_folder="$rdhome/retrodeck/downloaded_media" # the media folder, where all the scraped data is downloaded into - themes_folder="$rdhome/retrodeck/themes" # the themes folder + media_folder="$rdhome/downloaded_media" # the media folder, where all the scraped data is downloaded into + themes_folder="$rdhome/themes" # the themes folder sdcard="$default_sd" # Steam Deck SD default path # Writing the variables for the first time - echo "#!/bin/bash" >> $rd_conf + echo '#!/bin/bash' >> $rd_conf echo "version=$version" >> $rd_conf echo "rdhome=$rdhome" >> $rd_conf echo "roms_folder=$roms_folder" >> $rd_conf diff --git a/retrodeck.sh b/retrodeck.sh index e50a7ea3..f8907030 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -383,6 +383,10 @@ finit() { advanced ;; + 1 ) # X button quits + kill $$ + ;; + esac mkdir -pv $roms_folder diff --git a/tools/cheevos.sh b/tools/cheevos.sh index 877c4998..c7ec4374 100755 --- a/tools/cheevos.sh +++ b/tools/cheevos.sh @@ -13,6 +13,6 @@ arrIN=(${login//=SEP=/ }) user=${arrIN[0]} pass=${arrIN[1]} -sed -i "s%cheevos_enable =.*%cheevos_enable = \"true\"" $racfg -sed -i "s%cheevos_username =.*%cheevos_username = \"$user\"" $racfg -sed -i "s%cheevos_password =.*%cheevos_password = \"$pass\"" $racfg +sed -i "s%cheevos_enable =.*%cheevos_enable = \"true\"%" $racfg +sed -i "s%cheevos_username =.*%cheevos_username = \"$user\"%" $racfg +sed -i "s%cheevos_password =.*%cheevos_password = \"$pass\"%" $racfg From d69fcc6dd9e76f5857bed8f0bb61903950792aad Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 18:03:52 +0200 Subject: [PATCH 100/124] PPSSPP: fix --- net.retrodeck.retrodeck.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 80ed3587..f02bc5e5 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -407,7 +407,7 @@ modules: - name: ppsspp buildsystem: cmake-ninja config-opts: - - -DUSE_SYSTEM_FFMPEG=OFF # turn this on? + - -DUSE_SYSTEM_FFMPEG=ON # default: off, turn this on? - -DUSE_SYSTEM_LIBZIP=ON - -DUSE_SYSTEM_ZSTD=ON From 98fe517bd368990c0c8b387d1f1186c8e91b2945 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 20:36:12 +0200 Subject: [PATCH 101/124] PPSSPP: restored its ffmpeg --- net.retrodeck.retrodeck.yml | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index f02bc5e5..14b1afea 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -196,7 +196,7 @@ modules: sources: - type: git url: https://github.com/FFmpeg/FFmpeg.git - tag: n5.1 + tag: n5.1.1 - name: freeimage no-autogen: true @@ -477,10 +477,10 @@ modules: dest: ext/zstd commit: a488ba114ec17ea1054b9057c26a046fc122b3b6 url: https://github.com/facebook/zstd.git - #- type: git - # dest: ffmpeg - # commit: 3ad7ddb9eb2af898dce8c4b5e9a28b77b3f7ddd7 - # url: https://github.com/hrydgard/ppsspp-ffmpeg.git + - type: git + dest: ffmpeg + commit: 3ad7ddb9eb2af898dce8c4b5e9a28b77b3f7ddd7 + url: https://github.com/hrydgard/ppsspp-ffmpeg.git - type: git dest: pspautotests commit: 682a4303aba63a50c91ae0fa6928c9dac8ca9b92 From d3520503e96fb10646b81cf82817dd13e9d9b7b8 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Wed, 21 Sep 2022 23:46:02 +0200 Subject: [PATCH 102/124] PPSSPP: restored its ffmpeg -fix1 --- net.retrodeck.retrodeck.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 14b1afea..dad7b2ec 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -407,7 +407,7 @@ modules: - name: ppsspp buildsystem: cmake-ninja config-opts: - - -DUSE_SYSTEM_FFMPEG=ON # default: off, turn this on? + - -DUSE_SYSTEM_FFMPEG=OFF # default: off, turn this on? - -DUSE_SYSTEM_LIBZIP=ON - -DUSE_SYSTEM_ZSTD=ON From 8980d9cbb46a8cc90ad9314185469dbfb77389d2 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 24 Sep 2022 20:28:49 +0200 Subject: [PATCH 103/124] Bugfixes by RavenKilit --- global.sh | 3 ++ net.retrodeck.retrodeck.yml | 23 ++++---- retrodeck.sh | 104 +++++++++++++++++------------------- 3 files changed, 66 insertions(+), 64 deletions(-) diff --git a/global.sh b/global.sh index b67d81f8..9355d61a 100755 --- a/global.sh +++ b/global.sh @@ -79,6 +79,9 @@ then echo "themes_folder=$themes_folder" >> $rd_conf echo "sdcard=$sdcard" >> $rd_conf + echo "Setting config file permissions" + chmod +rwx $rd_conf + # If the config file is existing i just read the variables (source it) else echo "Found RetroDECK config file in $rd_conf" diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index dad7b2ec..17a92647 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -1386,20 +1386,23 @@ modules: buildsystem: simple build-commands: - # Prep the ES-DE and RetroArch config files - I will have to SED/XMLSTARLET them soon + # Initializing retrodeck config folder + - mkdir -p /var/config/retrodeck + + # Prep the ES-DE and RetroArch config files - I will have to SED/XMLSTARLET them soon - rm -rf /app/share/emulationstation/resources/systems/unix/es_find_rules.xml - cp es-configs/es_find_rules.xml /app/share/emulationstation/resources/systems/unix/ - rm -rf /app/share/emulationstation/resources/systems/unix/es_systems.xml - cp es-configs/es_systems.xml /app/share/emulationstation/resources/systems/unix/ - # These must be put in home folder, managed by retrodeck.sh + # These must be put in home folder, managed by retrodeck.sh - cp es-configs/es_settings.xml ${FLATPAK_DEST}/retrodeck/es_settings.xml - # Logo, res + # Logo, res - rm -f /app/share/emulationstation/resources/graphics/splash.svg - cp res/splash.svg /app/share/emulationstation/resources/graphics/splash.svg - cp res/icon.svg /app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg - # Tools + # Tools - mkdir -p ${FLATPAK_DEST}/retrodeck/tools/ - cp tools/* ${FLATPAK_DEST}/retrodeck/tools/ - mv -f es-configs/tools-gamelist.xml ${FLATPAK_DEST}/retrodeck/ @@ -1410,18 +1413,18 @@ modules: - cp global.sh /app/bin/global.sh - chmod +x /app/bin/global.sh - # Desktop entry + # Desktop entry - cp net.retrodeck.retrodeck.desktop /app/share/applications/net.retrodeck.retrodeck.desktop - # TODO: group the configs per-emu and optimize the following cps, like already done with Dolphin. Please not that some files may be renamed, check retrodeck.sh to know how (and fix it after the edit) + # TODO: group the configs per-emu and optimize the following cps, like already done with Dolphin. Please not that some files may be renamed, check retrodeck.sh to know how (and fix it after the edit) - # Initializing default emulator configs + # Initializing default emulator configs - cp -r emu-configs ${FLATPAK_DEST}/retrodeck/emu-configs/ - # Overlays - #- cp -r overlays ${FLATPAK_DEST}/retrodeck/overlays Disabled in 0.4.2b as it will be introduced in 0.5.0b + # Overlays + #- cp -r overlays ${FLATPAK_DEST}/retrodeck/overlays Disabled in 0.4.2b as it will be introduced in 0.5.0b - # Placing appdata + # Placing appdata - mkdir -p ${FLATPAK_DEST}/share/appdata - cp net.retrodeck.retrodeck.appdata.xml ${FLATPAK_DEST}/share/appdata diff --git a/retrodeck.sh b/retrodeck.sh index f8907030..ee2cec90 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -169,7 +169,7 @@ standalones_init() { cp -fv $emuconfigs/ppssppsdl/* /var/config/ppsspp/PSP/SYSTEM/ sed -i 's#/home/deck/retrodeck#'$rdhome'#g' /var/config/ppsspp/PSP/SYSTEM/ppsspp.ini - # PPSSPPSDL + # DUCKSTATION echo "------------------------" echo "Initializing DUCKSTATION" echo "------------------------" @@ -299,40 +299,40 @@ browse(){ done } -advanced(){ - # function to give advanced install options - echo "Advaced choosed" - - choice=$(zenity --icon-name=net.retrodeck.retrodeck --info --no-wrap \ - --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" --title "RetroDECK" \ - --ok-label "ROMs" \ - --extra-button "Media" \ - --extra-button "Themes" \ - --extra-button "Back" \ - --text="What do you want to change?\n\nROMS folder = $roms_folder\nMedia folder (scraped data) = $media_folder\nThemes folder=$themes_folder" ) - echo "Choice is $choice" - - case $choice in - - "" ) # Internal (yes) - echo "ROMs" - ;; - - "Media" ) - echo "Media" - ;; - - "Themes" ) - echo "Themes" - ;; - - "Back" ) # Browse + not found fallback - echo "Back" - finit - ;; - - esac -} +#advanced(){ +# # function to give advanced install options +# echo "Advaced choosed" +# +# choice=$(zenity --icon-name=net.retrodeck.retrodeck --info --no-wrap \ +# --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" --title "RetroDECK" \ +# --ok-label "ROMs" \ +# --extra-button "Media" \ +# --extra-button "Themes" \ +# --extra-button "Back" \ +# --text="What do you want to change?\n\nROMS folder = $roms_folder\nMedia folder (scraped data) = $media_folder\nThemes folder=$themes_folder" ) +# echo "Choice is $choice" +# +# case $choice in +# +# "" ) # Internal (yes) +# echo "ROMs" +# ;; +# +# "Media" ) +# echo "Media" +# ;; +# +# "Themes" ) +# echo "Themes" +# ;; +# +# "Back" ) # Browse + not found fallback +# echo "Back" +# finit +# ;; +# +# esac +#} finit() { # Force/First init, depending on the situation @@ -342,24 +342,24 @@ finit() { # Internal or SD Card? choice=$(zenity --icon-name=net.retrodeck.retrodeck --info --no-wrap \ --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" --title "RetroDECK" \ - --ok-label "Internal" \ + --ok-label "Cancel" \ + --extra-button "Internal" \ --extra-button "SD Card" \ - --extra-button "Advanced" \ - --extra-button "Cancel" \ + #--extra-button "Advanced" \ --text="Welcome to the first configuration of RetroDECK.\nThe setup will be quick but please READ CAREFULLY each message in order to avoid misconfigurations.\n\nWhere do you want your roms folder to be located?" ) echo "Choice is $choice" case $choice in - "" ) # Internal (yes) - echo "Internal selected" - roms_folder="$rdhome/roms" - ;; - - "Cancel" ) + "" ) # Cancel or X button quits echo "Now quitting" kill $$ - ;; + ;; + + "Internal" ) # Internal + echo "Internal selected" + roms_folder="$rdhome/roms" + ;; "SD Card" ) echo "SD Card selected" @@ -376,16 +376,12 @@ finit() { roms_folder="$sdcard/retrodeck/roms" # sdcard variable is correct as its given by browse function echo "ROMs folder = $roms_folder" fi - ;; + ;; - "Advanced" ) # Browse + not found fallback - echo "Advanced" - advanced - ;; - - 1 ) # X button quits - kill $$ - ;; + #"Advanced" ) # Browse + not found fallback + # echo "Advanced" + # advanced + #;; esac From c896d943ac487ea65bbf39eff1d4b8e248d7e103 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sat, 24 Sep 2022 20:38:40 +0200 Subject: [PATCH 104/124] Updated appdata --- net.retrodeck.retrodeck.appdata.xml | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/net.retrodeck.retrodeck.appdata.xml b/net.retrodeck.retrodeck.appdata.xml index c2790b28..c750ca63 100644 --- a/net.retrodeck.retrodeck.appdata.xml +++ b/net.retrodeck.retrodeck.appdata.xml @@ -68,17 +68,16 @@ <ul> <li>IMPORTANT: Started saves migration, the saves are being moved to retrodeck/saves/systemname/emulator, so if the emulator cannot load your saves you have to move them to the new path</li> <li>Theme revamp and more themes available such as the old one</li> - <li>A custom ROMs folder can be now selected during the first setup.</li> <li>Updated RetroArch and its cores from 1.10.2 to 1.10.3</li> - <li>Updated all the standalone emulators to their latrest releases</li> - <li>Updated ES-DE to the 1.2.6</li> - <li>Removed the unavailable emualtors fom the ES-DE list to avoid confusion</li> + <li>Updated all the standalone emulators to their latest releases</li> + <li>Updated ES-DE to 1.2.6</li> + <li>Removed the unavailable emualtors from the ES-DE list to avoid confusion</li> <li>Updated XEMU configurations and added its (free) assets</li> - <li>Added assets for RetroArch, PPSSPP and BlueMSX (libretro)</li> - <li>New emulator: PCSX2-QT, it's now the default PS2 emulator. Former PCSX2 emulator is now callerd PCSX2 (Legacy).</li> + <li>Added free assets for RetroArch, PPSSPP and BlueMSX (libretro)</li> + <li>New emulator: PCSX2-QT, it's now the default PS2 emulator. Former PCSX2 emulator is now called PCSX2 (Legacy).</li> <li>New emualtor: Duckstation for PSX.</li> - <li>New varialbes system: now some variables such as game folder location are saved in /app/retrodeck/retrodeck.cfg.</li> - <li>Solved an issue where Dolphin (Standalone) was not save in the intended riectories.</li> + <li>New varialbes system: now some variables such as game folder location are saved in /var/config/retrodeck/retrodeck.cfg.</li> + <li>Solved an issue where Dolphin (Standalone) was not saving in the intended riectories.</li> </ul> </description> From 7a85e4fdbedf6933cf0863dfba4e19592612bc35 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 25 Sep 2022 19:48:17 +0200 Subject: [PATCH 105/124] ES-DE: disabled halt on invalid media files --- es-configs/es_settings.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/es_settings.xml b/es-configs/es_settings.xml index 599b3987..15a842eb 100644 --- a/es-configs/es_settings.xml +++ b/es-configs/es_settings.xml @@ -55,7 +55,7 @@ <bool name="ScrapeTitleScreens" value="false" /> <bool name="ScrapeVideos" value="true" /> <bool name="ScraperExcludeRecursively" value="true" /> -<bool name="ScraperHaltOnInvalidMedia" value="true" /> +<bool name="ScraperHaltOnInvalidMedia" value="false" /> <bool name="ScraperIncludeFolders" value="false" /> <bool name="ScraperInteractive" value="false" /> <bool name="ScraperOverwriteData" value="false" /> From d6216f945e519c342996f95f9a31b8101db3c09d Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Sun, 25 Sep 2022 19:57:32 +0200 Subject: [PATCH 106/124] Yuzu: flathub workaround --- net.retrodeck.retrodeck.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index 17a92647..d7510677 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -635,6 +635,7 @@ modules: - install -Dm755 ../yuzu-launcher.sh /app/bin/yuzu-launcher - install -Dm644 ../dist/yuzu.svg /app/share/icons/hicolor/scalable/apps/yuzu.svg sources: + - disable-submodules: true # FLATHUB WORKAROUND - type: git url: https://github.com/yuzu-emu/yuzu-mainline.git tag: mainline-0-1171 From 30d779281b8a41cfebda708b9e63ff1710078bee Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 14:05:40 +0200 Subject: [PATCH 107/124] RPCS3 installer, proto script --- tools/rpcs3-installer.sh.proto | 37 ++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 tools/rpcs3-installer.sh.proto diff --git a/tools/rpcs3-installer.sh.proto b/tools/rpcs3-installer.sh.proto new file mode 100644 index 00000000..282a62cb --- /dev/null +++ b/tools/rpcs3-installer.sh.proto @@ -0,0 +1,37 @@ +#!/bin/bash + +THIS MUST BE PUT IN RETRODECK.SH +mkdir -p $rdhome/roms/ps3/emudir +mkdir -p $rdhome/roms/ps3/dump + +zenity: "Hey I will destroy everything in $rdhome/roms/ps3/dump" + +zenity: this will take a while, have a coffee + +rpcs3 --installpkg $rdhome/roms/ps3/dump/* + +for each folder in $rdhome/roms/ps3/emudir/dev_hdd0/game/ + + gameid=foldername + + if gamename.desktop doesnt exist + + gamename=we need a file with ID - names + echo in $rdhome/roms/ps3/$gamname.desktop EOF<< + + [Desktop Entry] + Encoding=UTF-8 + Version=1.0 + Type=Application + Terminal=false + Name=$gamename + Exec="source global.sh && rpcs3 --no-gui $rdhome/roms/ps3/emudir/dev_hdd0/game/$gameid" + Icon="$rdhome/roms/ps3/emudir/dev_hdd0/game/$gameid/ICON0.PNG" +EOF + + fi +done + +rm -rf $rdhome/roms/ps3/dump/* + +zenity: done, restart retrodeck please \ No newline at end of file From 082d3c026be298ddcab2f3a1dfcf86dbef9d16d9 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 14:09:20 +0200 Subject: [PATCH 108/124] RPCS3: added desktop extension --- es-configs/es_systems.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index 4899e218..e58e0e00 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -1082,7 +1082,7 @@ <name>ps3</name> <fullname>Sony PlayStation 3</fullname> <path>%ROMPATH%/ps3</path> - <extension>.desktop .ps3 .PS3 .ps3dir .PS3DIR</extension> + <extension>.desktop .ps3 .PS3 .ps3dir .PS3DIR .desktop .DESKTOP</extension> <command label="RPCS3 Shortcut (Standalone)">%ENABLESHORTCUTS% %EMULATOR_OS-SHELL% %ROM%</command> <command label="RPCS3 Directory (Standalone)">%EMULATOR_RPCS3% --no-gui %ROM%</command> <platform>ps3</platform> From 4912ec1dcaa972721916602d341bd923438045f5 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 14:09:56 +0200 Subject: [PATCH 109/124] RPCS3: desktop extension was already there lol --- es-configs/es_systems.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index e58e0e00..4899e218 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -1082,7 +1082,7 @@ <name>ps3</name> <fullname>Sony PlayStation 3</fullname> <path>%ROMPATH%/ps3</path> - <extension>.desktop .ps3 .PS3 .ps3dir .PS3DIR .desktop .DESKTOP</extension> + <extension>.desktop .ps3 .PS3 .ps3dir .PS3DIR</extension> <command label="RPCS3 Shortcut (Standalone)">%ENABLESHORTCUTS% %EMULATOR_OS-SHELL% %ROM%</command> <command label="RPCS3 Directory (Standalone)">%EMULATOR_RPCS3% --no-gui %ROM%</command> <platform>ps3</platform> From 6bae283239d14f622cb399a8624dac7a5412084e Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 15:18:17 +0200 Subject: [PATCH 110/124] Fixed tools section --- es-configs/es_systems.xml | 2 +- tools/rpcs3-installer.sh.proto | 20 +++++++++++++++++++- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/es-configs/es_systems.xml b/es-configs/es_systems.xml index 4899e218..07087026 100644 --- a/es-configs/es_systems.xml +++ b/es-configs/es_systems.xml @@ -1612,7 +1612,7 @@ <theme>zxspectrum</theme> </system> <system> - <name>zzztools</name> + <name>tools</name> <fullname>RetroDECK Tools</fullname> <path>/var/config/retrodeck/tools</path> <extension>.sh .SH</extension> diff --git a/tools/rpcs3-installer.sh.proto b/tools/rpcs3-installer.sh.proto index 282a62cb..71f81684 100644 --- a/tools/rpcs3-installer.sh.proto +++ b/tools/rpcs3-installer.sh.proto @@ -2,12 +2,30 @@ THIS MUST BE PUT IN RETRODECK.SH mkdir -p $rdhome/roms/ps3/emudir -mkdir -p $rdhome/roms/ps3/dump +#mkdir -p $rdhome/roms/ps3/dump cannot install in nogui + +#user must install via emulator + +source global.sh + +install_ps3_fw(){ + + # Implement a check to see if the firmware is already installed then call this function + + mkdir -p $rdhome/roms/ps3/.emudir + + mkdir -p $rdhome/roms/ps3/tmp + chmod 777 $rdhome/roms/ps3/tmp + wget http://dus01.ps3.update.playstation.net/update/ps3/image/us/2022_0510_95307e1b51d3bcc33a274db91488d29f/PS3UPDAT.PUP -P $rdhome/roms/ps3/tmp/ + rpcs3 --installfw $rdhome/roms/ps3/tmp/PS3UPDAT.PUP + rm -rf $rdhome/roms/ps3/tmp +} zenity: "Hey I will destroy everything in $rdhome/roms/ps3/dump" zenity: this will take a while, have a coffee +# this seems not to be working as rpcs3 doesn't support installation in --no-gui mode rpcs3 --installpkg $rdhome/roms/ps3/dump/* for each folder in $rdhome/roms/ps3/emudir/dev_hdd0/game/ From 5a4fad3c157f0e19f6c883cbb9920f17f48807e4 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 15:22:04 +0200 Subject: [PATCH 111/124] Fixed RPCS3 proto loader --- tools/rpcs3-installer.sh.proto | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tools/rpcs3-installer.sh.proto b/tools/rpcs3-installer.sh.proto index 71f81684..62b8885b 100644 --- a/tools/rpcs3-installer.sh.proto +++ b/tools/rpcs3-installer.sh.proto @@ -43,8 +43,8 @@ for each folder in $rdhome/roms/ps3/emudir/dev_hdd0/game/ Type=Application Terminal=false Name=$gamename - Exec="source global.sh && rpcs3 --no-gui $rdhome/roms/ps3/emudir/dev_hdd0/game/$gameid" - Icon="$rdhome/roms/ps3/emudir/dev_hdd0/game/$gameid/ICON0.PNG" + Exec=rpcs3 --no-gui $rdhome/roms/ps3/emudir/dev_hdd0/game/$gameid + Icon=$rdhome/roms/ps3/emudir/dev_hdd0/game/$gameid/ICON0.PNG EOF fi From 1e6ff2ecf8e995f1ff84aa3ca854ef00ac3310c0 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 15:51:36 +0200 Subject: [PATCH 112/124] RPCS3: tweaked config --- emu-configs/{ => rpcs3}/config.yml | 33 ++++++++++++++------ emu-configs/rpcs3/vfs.yml | 49 ++++++++++++++++++++++++++++++ retrodeck.sh | 3 +- 3 files changed, 74 insertions(+), 11 deletions(-) rename emu-configs/{ => rpcs3}/config.yml (87%) create mode 100644 emu-configs/rpcs3/vfs.yml diff --git a/emu-configs/config.yml b/emu-configs/rpcs3/config.yml similarity index 87% rename from emu-configs/config.yml rename to emu-configs/rpcs3/config.yml index b57d6713..b8555168 100644 --- a/emu-configs/config.yml +++ b/emu-configs/rpcs3/config.yml @@ -11,18 +11,21 @@ Core: Thread Scheduler Mode: Operating System Set DAZ and FTZ: false SPU Decoder: Recompiler (LLVM) - SPU GETLLAR polling detection: false + SPU Reservation Busy Waiting Percentage: 0 + SPU GETLLAR Busy Waiting Percentage: 100 SPU Debug: false MFC Debug: false - Preferred SPU Threads: 0 + Preferred SPU Threads: 1 SPU delay penalty: 3 SPU loop detection: false Max SPURS Threads: 6 - SPU Block Size: Safe + SPU Block Size: Mega Accurate GETLLAR: false Accurate SPU DMA: false + Accurate SPU Reservations: true Accurate Cache Line Stores: false Accurate RSX reservation access: false + RSX FIFO Accuracy: Fast SPU Verification: true SPU Cache: true SPU Profiler: false @@ -53,6 +56,10 @@ Core: TSX Transaction First Limit: 800 TSX Transaction Second Limit: 2000 Clocks scale: 100 + SPU Wake-Up Delay: 0 + SPU Wake-Up Delay Thread Mask: 63 + Max CPU Preempt Count: 0 + Allow RSX CPU Preemptions: true Sleep Timers Accuracy: As Host Performance Report Threshold: 500 Enable Performance Report: false @@ -62,6 +69,7 @@ VFS: Initialize Directories: true Limit disk cache size: false Disk cache maximum size (MB): 5120 + Empty /dev_hdd0/tmp/: true Video: Renderer: Vulkan Resolution: 1280x720 @@ -83,6 +91,7 @@ Video: Force High Precision Z buffer: false Strict Rendering Mode: false Disable ZCull Occlusion Queries: false + Disable Video Output: false Disable Vertex Cache: false Disable FIFO Reordering: false Enable Frame Skip: false @@ -91,7 +100,7 @@ Video: Disable Vulkan Memory Allocator: false Use full RGB output range: true Strict Texture Flushing: false - Disable native float16 support: false + Disable native float16 support: true Multithreaded RSX: false Relaxed ZCULL Sync: false Enable 3D: false @@ -120,7 +129,7 @@ Video: Asynchronous Texture Streaming 2: false Enable FidelityFX Super Resolution Upscaling: false FidelityFX CAS Sharpening Intensity: 50 - Asynchronous Queue Scheduler: Safe + Asynchronous Queue Scheduler: Fast Performance Overlay: Enabled: false Enable Framerate Graph: false @@ -159,7 +168,7 @@ Audio: Master Volume: 100 Enable Buffering: true Desired Audio Buffer Duration: 100 - Enable Time Stretching: false + Enable Time Stretching: true Time Stretching Threshold: 75 Microphone Type: "Null" Microphone Devices: "@@@@@@@@@@@@" @@ -189,15 +198,19 @@ Net: DNS address: 8.8.8.8 IP swap list: "" PSN status: Disconnected +Savestate: + Start Paused: false + Suspend Emulation Savestate Mode: true + Inspection Mode Savestates: false + Save Disc Game Data: false Miscellaneous: Automatically start games after boot: true - Exit RPCS3 when process finishes: false - Start games in fullscreen mode: false + Exit RPCS3 when process finishes: true + Start games in fullscreen mode: true Prevent display sleep while running games: true Show trophy popups: true Show shader compilation hint: true Use native user interface: true GDB Server: 127.0.0.1:2345 Silence All Logs: false - Window Title Format: "FPS: %F | %R | %V | %T [%t]" -Log: {} \ No newline at end of file + Window Title Format: "FPS: %F | %R | %V | %T [%t]" \ No newline at end of file diff --git a/emu-configs/rpcs3/vfs.yml b/emu-configs/rpcs3/vfs.yml new file mode 100644 index 00000000..f5b89a9f --- /dev/null +++ b/emu-configs/rpcs3/vfs.yml @@ -0,0 +1,49 @@ +$(EmulatorDir): "/home/deck/retrodeck/roms/ps3/emudir" +/dev_hdd0/: $(EmulatorDir)dev_hdd0/ +/dev_hdd1/: $(EmulatorDir)dev_hdd1/ +/dev_flash/: $(EmulatorDir)dev_flash/ +/dev_flash2/: $(EmulatorDir)dev_flash2/ +/dev_flash3/: $(EmulatorDir)dev_flash3/ +/dev_bdvd/: $(EmulatorDir)dev_bdvd/ +/app_home/: "" +/dev_usb***/: + /dev_usb000: + Path: $(EmulatorDir)dev_usb000/ + Serial: "" + VID: "" + PID: "" + /dev_usb001: + Path: "" + Serial: "" + VID: "" + PID: "" + /dev_usb002: + Path: "" + Serial: "" + VID: "" + PID: "" + /dev_usb003: + Path: "" + Serial: "" + VID: "" + PID: "" + /dev_usb004: + Path: "" + Serial: "" + VID: "" + PID: "" + /dev_usb005: + Path: "" + Serial: "" + VID: "" + PID: "" + /dev_usb006: + Path: "" + Serial: "" + VID: "" + PID: "" + /dev_usb007: + Path: "" + Serial: "" + VID: "" + PID: "" \ No newline at end of file diff --git a/retrodeck.sh b/retrodeck.sh index ee2cec90..122ebcef 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -144,7 +144,8 @@ standalones_init() { echo "Initializing RPCS3" echo "------------------------" mkdir -pv /var/config/rpcs3/ - cp -fvr $emuconfigs/config.yml /var/config/rpcs3/ + cp -fvr $emuconfigs/rpcs3/* /var/config/rpcs3/ + sed -i 's#/home/deck/retrodeck#'$rdhome'#g' /var/config/rpcs3/vfs.yml # XEMU echo "------------------------" From 8a0e645bc0046369ce05dd37c7b78bf61587106b Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 17:06:39 +0200 Subject: [PATCH 113/124] RA: enabled advanced settings --- emu-configs/retroarch.cfg | 2 +- retrodeck.sh | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/emu-configs/retroarch.cfg b/emu-configs/retroarch.cfg index 265c05f8..5d0577b1 100644 --- a/emu-configs/retroarch.cfg +++ b/emu-configs/retroarch.cfg @@ -2821,7 +2821,7 @@ menu_screensaver_timeout = "0" menu_scroll_delay = "256" menu_scroll_fast = "false" menu_shader_pipeline = "2" -menu_show_advanced_settings = "false" +menu_show_advanced_settings = "true" menu_show_configurations = "true" menu_show_core_updater = "false" menu_show_dump_disc = "true" diff --git a/retrodeck.sh b/retrodeck.sh index 122ebcef..12d2ed94 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -261,6 +261,9 @@ post_update() { # Resetting es_systems, now we need it but in the future I should think a better solution, maybe with sed cp -fv /app/retrodeck/es_settings.xml /var/config/emulationstation/.emulationstation/es_settings.xml + # 0.4 -> 0.5 + # Saves migration - Part 1: Standalones + ra_init standalones_init tools_init From ef2186b5a135097a2a6dfb3f7a85b2120c7c08ad Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 17:10:25 +0200 Subject: [PATCH 114/124] RA: enabled touch mode --- emu-configs/retroarch.cfg | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/emu-configs/retroarch.cfg b/emu-configs/retroarch.cfg index 5d0577b1..db4b873e 100644 --- a/emu-configs/retroarch.cfg +++ b/emu-configs/retroarch.cfg @@ -2809,7 +2809,7 @@ menu_mouse_enable = "true" menu_navigation_browser_filter_supported_extensions_enable = "true" menu_navigation_wraparound_enable = "true" menu_pause_libretro = "true" -menu_pointer_enable = "false" +menu_pointer_enable = "true" menu_rgui_full_width_layout = "true" menu_rgui_shadows = "false" menu_rgui_transparency = "true" From 966ec539ddf14e0ffca87925467d885cb2f895e0 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 17:55:30 +0200 Subject: [PATCH 115/124] Save migration - imp1 --- retrodeck.sh | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/retrodeck.sh b/retrodeck.sh index 12d2ed94..dbd9b243 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -108,7 +108,7 @@ standalones_init() { cp -fvr $emuconfigs/PCSX2/* /var/config/PCSX2/inis/ sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/PCSX2/inis/PCSX2_ui.ini sed -i 's#~/retrodeck#'$rdhome'#g' /var/config/PCSX2/inis/PCSX2.ini - dir_prep "$rdhome/states" "/var/config/PCSX2/sstates" + dir_prep "$rdhome/states/ps2/pcsx2" "/var/config/PCSX2/sstates" dir_prep "$rdhome/screenshots" "/var/config/PCSX2/snaps" dir_prep "$rdhome/.logs" "/var/config/PCSX2/logs" dir_prep "$rdhome/bios" "$rdhome/bios/pcsx2" @@ -263,6 +263,22 @@ post_update() { # 0.4 -> 0.5 # Saves migration - Part 1: Standalones + + #mv -fv OLD_CITRA_SAVES ~/retrodeck/saves/n3ds/citra/nand/ + #mv -fv OLD_CITRA_STATES ~/retrodeck/saves/n3ds/citra/sdmc/ + + mv -fv /home/deck/retrodeck/states/*.ml* ~/retrodeck/states/nds/melonds + + #eeprom_path = '/home/deck/retrodeck/saves/xbox/xemu/xbox-eeprom.bin' + #SavesPath = ~/retrodeck/saves/gba + #WiiSDCardPath = ~/retrodeck/saves/wii/dolphin/sd.raw + + mv -fv /home/deck/.var/app/net.retrodeck.retrodeck/config/PCSX2/memcards/* ~/retrodeck/saves/ps2/memcards + + #SaveStates = ~/retrodeck/states/ps2/pcsx2 + #MemoryCards = ~/retrodeck/saves/ps2/pcsx2/memcards + + #ppsspp? ra_init standalones_init From 9f6d61e30a9ebee056ea3e72a0f4b888323964a9 Mon Sep 17 00:00:00 2001 From: XargonWan <XargonWan@gmail.com> Date: Tue, 27 Sep 2022 18:01:38 +0200 Subject: [PATCH 116/124] Save migration - imp2 --- retrodeck.sh | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/retrodeck.sh b/retrodeck.sh index dbd9b243..71de4556 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -151,7 +151,7 @@ standalones_init() { echo "------------------------" echo "Initializing XEMU" echo "------------------------" - mkdir -pv $rdhome/saves/xemu + mkdir -pv $rdhome/saves/xbox/xemu/ cp -fv $emuconfigs/xemu.toml /var/data/xemu/xemu.toml sed -i 's#/home/deck/retrodeck#'$rdhome'#g' /var/data/xemu/xemu.toml # Preparing HD dummy Image if the image is not found @@ -264,19 +264,14 @@ post_update() { # 0.4 -> 0.5 # Saves migration - Part 1: Standalones - #mv -fv OLD_CITRA_SAVES ~/retrodeck/saves/n3ds/citra/nand/ - #mv -fv OLD_CITRA_STATES ~/retrodeck/saves/n3ds/citra/sdmc/ + #mv -fv OLD_CITRA_SAVES $rdhome/saves/n3ds/citra/nand/ + #mv -fv OLD_CITRA_STATES $rdhome/saves/n3ds/citra/sdmc/ - mv -fv /home/deck/retrodeck/states/*.ml* ~/retrodeck/states/nds/melonds + mv -fv $rdhome/states/*.ml* $rdhome/states/nds/melonds - #eeprom_path = '/home/deck/retrodeck/saves/xbox/xemu/xbox-eeprom.bin' - #SavesPath = ~/retrodeck/saves/gba - #WiiSDCardPath = ~/retrodeck/saves/wii/dolphin/sd.raw + mv -fv $rdhome/saves/xemu/* $rdhome/saves/xbox/xemu/ - mv -fv /home/deck/.var/app/net.retrodeck.retrodeck/config/PCSX2/memcards/* ~/retrodeck/saves/ps2/memcards - - #SaveStates = ~/retrodeck/states/ps2/pcsx2 - #MemoryCards = ~/retrodeck/saves/ps2/pcsx2/memcards + mv -fv /var/config/PCSX2/memcards/* $rdhome/saves/ps2/memcards #ppsspp? From f4c5f2c987a83ff25492a04c036110a4c355c905 Mon Sep 17 00:00:00 2001 From: icenine451 <benjamin.r.shelton@protonmail.com> Date: Thu, 29 Sep 2022 17:26:02 -0400 Subject: [PATCH 117/124] Function to sort saves/states into system folders --- emu-configs/retroarch.cfg | 4 +- global.sh | 4 ++ retrodeck.sh | 111 +++++++++++++++++++++++++++++++++++++- 3 files changed, 116 insertions(+), 3 deletions(-) diff --git a/emu-configs/retroarch.cfg b/emu-configs/retroarch.cfg index 265c05f8..b4da870c 100644 --- a/emu-configs/retroarch.cfg +++ b/emu-configs/retroarch.cfg @@ -3067,9 +3067,9 @@ show_hidden_files = "false" slowmotion_ratio = "3.000000" soft_filter_enable = "false" soft_filter_index = "0" -sort_savefiles_by_content_enable = "false" +sort_savefiles_by_content_enable = "true" sort_savefiles_enable = "false" -sort_savestates_by_content_enable = "false" +sort_savestates_by_content_enable = "true" sort_savestates_enable = "false" sort_screenshots_by_content_enable = "false" state_slot = "0" diff --git a/global.sh b/global.sh index b67d81f8..6547d9c0 100755 --- a/global.sh +++ b/global.sh @@ -66,6 +66,8 @@ then version="$hard_version" # if we are here means that the we are in a new installation, so the version is valorized with the hardcoded one rdhome="$HOME/retrodeck" # the retrodeck home, aka ~/retrodeck roms_folder="$rdhome/roms" # the default roms folder path + saves_folder="$rdhome/saves" # the default saves folder path + states_folder="$rdhome/states" # the default states folder path media_folder="$rdhome/downloaded_media" # the media folder, where all the scraped data is downloaded into themes_folder="$rdhome/themes" # the themes folder sdcard="$default_sd" # Steam Deck SD default path @@ -75,6 +77,8 @@ then echo "version=$version" >> $rd_conf echo "rdhome=$rdhome" >> $rd_conf echo "roms_folder=$roms_folder" >> $rd_conf + echo "saves_folder=$saves_folder" >> $rd_conf + echo "states_folder=$states_folder" >> $rd_conf echo "media_folder=$media_folder" >> $rd_conf echo "themes_folder=$themes_folder" >> $rd_conf echo "sdcard=$sdcard" >> $rd_conf diff --git a/retrodeck.sh b/retrodeck.sh index f8907030..374eff4f 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -185,7 +185,7 @@ standalones_init() { ra_init() { dir_prep "$rdhome/bios" "/var/config/retroarch/system" - dir_prep "$rdhome/.logs/retroarch" "/var/config/retroarch/logs" + dir_prep "$rdhome/.logs/retroarch" "/var/config/retroarch/logs" mkdir -pv /var/config/retroarch/cores/ cp /app/share/libretro/cores/* /var/config/retroarch/cores/ cp -fv $emuconfigs/retroarch.cfg /var/config/retroarch/ @@ -264,6 +264,115 @@ post_update() { standalones_init tools_init + versionwheresaveschanged="0.4.5b" # Hardcoded break point between unsorted and sorted saves + + if [[ $(sed -e "s/\.//g" <<< $hard_version) > $(sed -e "s/\.//g" <<< $versionwheresaveschanged) ]] && [[ ! $(sed -e "s/\.//g" <<< $hard_version) == $(sed -e "s/\.//g" <<< $version) ]]; then # Check if user is upgrading from the version where save organization was changed. Try not to reuse this, it things 0.4.5b is newer than 0.4.5 + migration_logfile=$rdhome/.logs/savemove_"$(date +"%Y_%m_%d_%I_%M_%p").log" + save_backup_file=$rdhome/savebackup_"$(date +"%Y_%m_%d_%I_%M_%p").zip" + state_backup_file=$rdhome/statesbackup_"$(date +"%Y_%m_%d_%I_%M_%p").zip" + + # NOTE: This Zenity command may need to be one line, it broke when I pasted it into a sandbox file + + zenity --icon-name=net.retrodeck.retrodeck --info --no-wrap \ + --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ + --title "RetroDECK" \ + --text="You are updating to a version of RetroDECK where save and state file sorting has changed!\n\nYour existing saves will be backed up to $save_backup_file\n\nYour existing states will be backed up to $state_backup_file\n\nIf a save or state cannot be sorted automatically it will remain in its original directory so you can sort it manually.\n\nIf you encounter any issues, a log of the sorting process is stored at $migration_logfile" + + allgames=($(find "$roms_folder" -maxdepth 2 -mindepth 2 ! -name "systeminfo.txt" ! -name "systems.txt" ! -name "*^*" | sed -e "s/ /\^/g")) # Build an array of all games and multi-disc-game-containing folders, adding whitespace placeholder + + allsaves=($(find "$saves_folder" -mindepth 1 -maxdepth 1 -name "*.*" | sed -e "s/ /\^/g")) # Build an array of all save files, ignoring standalone emulator sub-folders, adding whitespace placeholder + + allstates=($(find "$states_folder" -mindepth 1 -maxdepth 1 -name "*.*" | sed -e "s/ /\^/g")) # Build an array of all state files, ignoring standalone emulator sub-folders, adding whitespace placeholder + + totalsaves=${#allsaves[@]} + totalstates=${#allstates[@]} + filesleft= + current_dest_folder= + gamestoskip= + + tar -C $rdhome -czf $save_backup_file saves # Backup save directory for safety + echo "Saves backed up to" $save_backup_file >> $migration_logfile + tar -C $rdhome -czf $state_backup_file states # Backup state directory for safety + echo "States backed up to" $state_backup_file >> $migration_logfile + + ( + movefile() { # Take matching save and rom files and sort save into appropriate system folder + echo "# $filesleft files remaining..." # These lines update the Zenity progress bar + progress=$(( 100 - (( 100 / "$totalfiles" ) * "$filesleft" ))) + echo $progress + filesleft=$((filesleft-1)) + if [[ ! " ${gamestoskip[*]} " =~ " ${1} " ]]; then # If the current game name exists multiple times in array ie. /roms/snes/Mortal Kombat 3.zip and /roms/genesis/Mortal Kombat 3.zip, skip and alert user to sort manually + game=$(sed -e "s/\^/ /g" <<< "$1") # Remove whitespace placeholder + gamebasename=$(basename "$game" | sed -e 's/\..*//') # Extract pure file name ie. /roms/snes/game1.zip becomes game1 + systemdir="$(basename "$(dirname "$1")")" # Extract parent directory identifying system ROM belongs to + matches=($(find "$roms_folder" -maxdepth 2 -mindepth 2 -name "$gamebasename"".*" | sed -e 's/ /^/g' | sed -e 's/\..*//')) # Search for multiple instances of pure game name, adding to skip list if found + if [[ ${#matches[@]} -gt 1 ]]; then + echo "ERROR: Multiple ROMS found with name:" $gamebasename "Please sort saves and states for these ROMS manually" >> $migration_logfile + gamestoskip+=("$1") + return + fi + echo "INFO: Examining ROM file:" "$game" >> $migration_logfile + echo "INFO: System detected as" $systemdir >> $migration_logfile + sosfile=$(sed -e "s/\^/ /g" <<< "$2") # Remove whitespace placeholder from s-ave o-r s-tate file + sosbasename="$(basename "$save")" # Extract pure file name ie. /saves/game1.sav becomes game1 + echo "INFO: Current save or state being examined for match:" $sosfile >> $migration_logfile + echo "INFO: Matching save or state" $sosfile "and game" $game "found." >> $migration_logfile + echo "INFO: Moving save or state to" $current_dest_folder"/"$systemdir"/"$sosbasename >> $migration_logfile + if [[ ! -d $current_dest_folder"/"$systemdir ]]; then # If system directory doesn't exist for save yet, create it + mkdir $current_dest_folder"/"$systemdir + fi + mv \'$sosfile\' $current_dest_folder"/"$systemdir\/\'$sosbasename\' # Move save to appropriate system directory + else + echo "WARNING: Game with name" "$(basename "$1" | sed -e "s/\^/ /g")" "already found. Skipping to next game..." >> $migration_logfile # Inform user of game being skipped due to duplicate ROM names + fi + } + + find "$roms_folder" -mindepth 2 -maxdepth 2 -name "*\^*" -exec echo "ERROR: Game named" {} "found, please move save manually" \; >> $migration_logfile # Warn user if any of their files have the whitespace replacement character used by the script + + totalfiles=$totalsaves #set variables for save file migration + filesleft=$totalsaves + current_dest_folder=$saves_folder + + for i in "${allsaves[@]}"; do # For each save file, compare to every ROM file name looking for a match + found= + currentsave=($(basename "$i" | sed -e 's/\..*//')) # Extract pure file name ie. /saves/game1.sav becomes game1 + for j in "${allgames[@]}"; do + currentgame=($(basename "$j" | sed -e 's/\..*//')) # Extract pure file name ie. /roms/snes/game1.zip becomes game1 + [[ $currentgame == $currentsave ]] && { found=1; break; } # If names match move to next stage, otherwise skip + done + [[ -n $found ]] && movefile $j $i || echo "ERROR: No ROM match found for save file" $i | sed -e 's/\^/ /g' >> $migration_logfile # If a match is found, run movefile() otherwise warn user of stranded save file + done + + totalfiles=$totalstates #set variables for state file migration + filesleft=$totalstates + current_dest_folder=$states_folder + + for i in "${allstates[@]}"; do # For each state file, compare to every ROM file name looking for a match + found= + currentstate=($(basename "$i" | sed -e 's/\..*//')) # Extract pure file name ie. /states/game1.sav becomes game1 + for j in "${allgames[@]}"; do + currentgame=($(basename "$j" | sed -e 's/\..*//')) # Extract pure file name ie. /roms/snes/game1.zip becomes game1 + [[ $currentgame == $currentstate ]] && { found=1; break; } # If names match move to next stage, otherwise skip + done + [[ -n $found ]] && movefile $j $i || echo "ERROR: No ROM match found for state file" $i | sed -e 's/\^/ /g' >> $migration_logfile # If a match is found, run movefile() otherwise warn user of stranded state file + done + + ) | + zenity --progress \ + --icon-name=net.retrodeck.retrodeck \ + --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ + --title="Processing Files" \ + --text="# files remaining..." \ + --percentage=0 \ + --no-cancel \ + --auto-close + + # NOTE: This Zenity command may need to be one line, it broke when I pasted it into a sandbox file + + else + echo "Version" $version "is after the save and state organization was changed, no need to sort again" + fi + create_lock } From 4f8f771f151f0c910ed7e1cbe9ce83a5fb68b109 Mon Sep 17 00:00:00 2001 From: icenine451 <benjamin.r.shelton@protonmail.com> Date: Sat, 1 Oct 2022 09:58:05 -0400 Subject: [PATCH 118/124] Add new variables to be written to rd_conf --- global.sh | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/global.sh b/global.sh index 6547d9c0..f64efebd 100755 --- a/global.sh +++ b/global.sh @@ -34,6 +34,16 @@ conf_write() { sed -i "s%roms_folder=.*%roms_folder=$roms_folder%" "$rd_conf" fi + if [ ! -z "$saves_folder" ] + then + sed -i "s%saves_folder=.*%saves_folder=$saves_folder%" "$rd_conf" + fi + + if [ ! -z "$states_folder" ] + then + sed -i "s%states_folder=.*%states_folder=$states_folder%" "$rd_conf" + fi + if [ ! -z "$media_folder" ] then sed -i "s%media_folder=.*%media_folder=$media_folder%" "$rd_conf" From a0a3017336dfa7ab1368c9fa41f1aef2dcb9c5e5 Mon Sep 17 00:00:00 2001 From: icenine451 <benjamin.r.shelton@protonmail.com> Date: Sat, 1 Oct 2022 11:44:12 -0400 Subject: [PATCH 119/124] Fix some bugs and add some extra logs --- retrodeck.sh | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/retrodeck.sh b/retrodeck.sh index 374eff4f..5f60f394 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -264,6 +264,8 @@ post_update() { standalones_init tools_init + # Perform save and state migration if needed + versionwheresaveschanged="0.4.5b" # Hardcoded break point between unsorted and sorted saves if [[ $(sed -e "s/\.//g" <<< $hard_version) > $(sed -e "s/\.//g" <<< $versionwheresaveschanged) ]] && [[ ! $(sed -e "s/\.//g" <<< $hard_version) == $(sed -e "s/\.//g" <<< $version) ]]; then # Check if user is upgrading from the version where save organization was changed. Try not to reuse this, it things 0.4.5b is newer than 0.4.5 @@ -297,7 +299,7 @@ post_update() { ( movefile() { # Take matching save and rom files and sort save into appropriate system folder - echo "# $filesleft files remaining..." # These lines update the Zenity progress bar + echo "# $filesleft $currentlybeingmoved remaining..." # These lines update the Zenity progress bar progress=$(( 100 - (( 100 / "$totalfiles" ) * "$filesleft" ))) echo $progress filesleft=$((filesleft-1)) @@ -314,14 +316,16 @@ post_update() { echo "INFO: Examining ROM file:" "$game" >> $migration_logfile echo "INFO: System detected as" $systemdir >> $migration_logfile sosfile=$(sed -e "s/\^/ /g" <<< "$2") # Remove whitespace placeholder from s-ave o-r s-tate file - sosbasename="$(basename "$save")" # Extract pure file name ie. /saves/game1.sav becomes game1 + sospurebasename="$(basename "$sosfile")" # Extract pure file name ie. /saves/game1.sav becomes game1 echo "INFO: Current save or state being examined for match:" $sosfile >> $migration_logfile echo "INFO: Matching save or state" $sosfile "and game" $game "found." >> $migration_logfile echo "INFO: Moving save or state to" $current_dest_folder"/"$systemdir"/"$sosbasename >> $migration_logfile if [[ ! -d $current_dest_folder"/"$systemdir ]]; then # If system directory doesn't exist for save yet, create it - mkdir $current_dest_folder"/"$systemdir + echo "WARNING: Creating missing system directory" $current_dest_folder"/"$systemdir + mkdir $current_dest_folder/$systemdir fi - mv \'$sosfile\' $current_dest_folder"/"$systemdir\/\'$sosbasename\' # Move save to appropriate system directory + mv "$sosfile" -t $current_dest_folder/$systemdir # Move save to appropriate system directory + return else echo "WARNING: Game with name" "$(basename "$1" | sed -e "s/\^/ /g")" "already found. Skipping to next game..." >> $migration_logfile # Inform user of game being skipped due to duplicate ROM names fi @@ -330,7 +334,8 @@ post_update() { find "$roms_folder" -mindepth 2 -maxdepth 2 -name "*\^*" -exec echo "ERROR: Game named" {} "found, please move save manually" \; >> $migration_logfile # Warn user if any of their files have the whitespace replacement character used by the script totalfiles=$totalsaves #set variables for save file migration - filesleft=$totalsaves + filesleft=$totalsaves + currentlybeingmoved="saves" current_dest_folder=$saves_folder for i in "${allsaves[@]}"; do # For each save file, compare to every ROM file name looking for a match @@ -344,7 +349,8 @@ post_update() { done totalfiles=$totalstates #set variables for state file migration - filesleft=$totalstates + filesleft=$totalstates + currentlybeingmoved="states" current_dest_folder=$states_folder for i in "${allstates[@]}"; do # For each state file, compare to every ROM file name looking for a match From b71c5a490b9a616ad6bcbeb0210b8d21512ee192 Mon Sep 17 00:00:00 2001 From: icenine451 <benjamin.r.shelton@protonmail.com> Date: Sat, 1 Oct 2022 11:59:49 -0400 Subject: [PATCH 120/124] Added warning about how long migration can take --- retrodeck.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/retrodeck.sh b/retrodeck.sh index 5f60f394..54043997 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -278,7 +278,7 @@ post_update() { zenity --icon-name=net.retrodeck.retrodeck --info --no-wrap \ --window-icon="/app/share/icons/hicolor/scalable/apps/net.retrodeck.retrodeck.svg" \ --title "RetroDECK" \ - --text="You are updating to a version of RetroDECK where save and state file sorting has changed!\n\nYour existing saves will be backed up to $save_backup_file\n\nYour existing states will be backed up to $state_backup_file\n\nIf a save or state cannot be sorted automatically it will remain in its original directory so you can sort it manually.\n\nIf you encounter any issues, a log of the sorting process is stored at $migration_logfile" + --text="You are updating to a version of RetroDECK where save and state file sorting has changed!\n\nYour existing saves will be backed up to $save_backup_file\n\nYour existing states will be backed up to $state_backup_file\n\nIf a save or state cannot be sorted automatically it will remain in its original directory so you can sort it manually.\n\nIf you encounter any issues, a log of the sorting process is stored at $migration_logfile\n\nPLEASE BE PATIENT! This process can take several minutes if you have a large ROM library." allgames=($(find "$roms_folder" -maxdepth 2 -mindepth 2 ! -name "systeminfo.txt" ! -name "systems.txt" ! -name "*^*" | sed -e "s/ /\^/g")) # Build an array of all games and multi-disc-game-containing folders, adding whitespace placeholder From d671cfdbae0578721b4dd163ff0fa375775c77cf Mon Sep 17 00:00:00 2001 From: XargonWan <xargonwan@gmail.com> Date: Sat, 1 Oct 2022 21:25:19 +0200 Subject: [PATCH 121/124] Updated RetroArch to 1.11.0 and PCSX2-QT, updated metadata --- global.sh | 1 - net.retrodeck.retrodeck.appdata.xml | 9 +++++---- net.retrodeck.retrodeck.yml | 30 ++++++++++++++--------------- 3 files changed, 20 insertions(+), 20 deletions(-) diff --git a/global.sh b/global.sh index 9355d61a..29ad7ccb 100755 --- a/global.sh +++ b/global.sh @@ -48,7 +48,6 @@ conf_write() { then sed -i "s%sdcard=.*%sdcard=$sdcard%" "$rd_conf" fi - echo "DEBUG: New contents:" cat "$rd_conf" echo "" diff --git a/net.retrodeck.retrodeck.appdata.xml b/net.retrodeck.retrodeck.appdata.xml index c750ca63..c2b9104f 100644 --- a/net.retrodeck.retrodeck.appdata.xml +++ b/net.retrodeck.retrodeck.appdata.xml @@ -66,18 +66,19 @@ <url>https://github.com/XargonWan/RetroDECK/releases/tag/0.5.5b</url> <description> <ul> - <li>IMPORTANT: Started saves migration, the saves are being moved to retrodeck/saves/systemname/emulator, so if the emulator cannot load your saves you have to move them to the new path</li> + <li>IMPORTANT: Started saves migration, the saves are being moved to retrodeck/saves/systemname/emulator upon update, however if some emulators cannot load your saves you have to move them manually to the new path</li> <li>Theme revamp and more themes available such as the old one</li> - <li>Updated RetroArch and its cores from 1.10.2 to 1.10.3</li> + <li>Updated RetroArch and its cores from 1.10.2 to 1.11.0</li> <li>Updated all the standalone emulators to their latest releases</li> <li>Updated ES-DE to 1.2.6</li> - <li>Removed the unavailable emualtors from the ES-DE list to avoid confusion</li> + <li>Removed the unavailable emulators from the ES-DE list to avoid confusion</li> <li>Updated XEMU configurations and added its (free) assets</li> <li>Added free assets for RetroArch, PPSSPP and BlueMSX (libretro)</li> <li>New emulator: PCSX2-QT, it's now the default PS2 emulator. Former PCSX2 emulator is now called PCSX2 (Legacy).</li> <li>New emualtor: Duckstation for PSX.</li> + <li>Swanstation (Libretro) is the new PSX default emulator, so if you don't find your saves just switch back to Beetle</li> <li>New varialbes system: now some variables such as game folder location are saved in /var/config/retrodeck/retrodeck.cfg.</li> - <li>Solved an issue where Dolphin (Standalone) was not saving in the intended riectories.</li> + <li>Solved an issue where Dolphin (Standalone) was not saving in the intended directories.</li> </ul> </description> diff --git a/net.retrodeck.retrodeck.yml b/net.retrodeck.retrodeck.yml index d7510677..a8620a46 100644 --- a/net.retrodeck.retrodeck.yml +++ b/net.retrodeck.retrodeck.yml @@ -289,7 +289,7 @@ modules: sources: - type: git url: https://github.com/libretro/RetroArch.git - branch: 9b282aa742b6c3d2f2925ae5a12e2cd7c6b6ad38 + commit: 9586d679a8b143fbe1880dff7454fd0809262b55 - type: file path: rd-submodules/retroarch/retroarch.cfg post-install: @@ -322,7 +322,7 @@ modules: sources: - type: git url: https://github.com/libretro/RetroArch.git - branch: 9b282aa742b6c3d2f2925ae5a12e2cd7c6b6ad38 + commit: 9586d679a8b143fbe1880dff7454fd0809262b55 - name: retroarch-filers-audio subdir: libretro-common/audio/dsp_filters make-install-args: @@ -330,63 +330,63 @@ modules: sources: - type: git url: https://github.com/libretro/RetroArch.git - branch: 9b282aa742b6c3d2f2925ae5a12e2cd7c6b6ad38 + commit: 9586d679a8b143fbe1880dff7454fd0809262b55 - name: retroarch-assets make-install-args: - PREFIX=${FLATPAK_DEST} sources: - type: git url: https://github.com/libretro/retroarch-assets.git - commit: f45dd1351e6bfb9f01e12bee8d358ad22a2bb8f9 + commit: ee33f8ef693b42a8e23ca3fd48f43f345e7cd087 - name: libretro-database make-install-args: - PREFIX=${FLATPAK_DEST} sources: - type: git url: https://github.com/libretro/libretro-database.git - commit: f3b10ec262fcbd78da3473f46d244270d12a327e + commit: 772011a54392aab6be1302bf1bd8aa1cc0c0c6c2 - name: libretro-core-info make-install-args: - PREFIX=${FLATPAK_DEST} sources: - type: git url: https://github.com/libretro/libretro-core-info.git - commit: 06dac6318c067a6a40e2ea1e1260e74681ada844 + commit: 0cc4912691cd1adb87168ce87b6795bdf57b2fe5 - name: retroarch-joypad-autoconfig make-install-args: - PREFIX=${FLATPAK_DEST} sources: - type: git url: https://github.com/libretro/retroarch-joypad-autoconfig.git - commit: 760b057f1865a827762a54a8a32afda2cdd9e170 + commit: a3b5067b8954f15e8e87eeed71a4262f0ea7fd1c - name: common-shaders make-install-args: - PREFIX=${FLATPAK_DEST} sources: - type: git url: https://github.com/libretro/common-shaders.git - commit: 55e401834b732e62c34411321c4ffd82524345d4 + commit: 86cfa146a8dfddf6377ddb5dbcff552feae2e5bf - name: slang-shaders make-install-args: - PREFIX=${FLATPAK_DEST} sources: - type: git url: https://github.com/libretro/slang-shaders.git - commit: 148c57d9747f5db124135501ac280b5ca129a83f + commit: f8f99ee220edbf2c5df2714a73d46faea43e62e2 - name: glsl-shaders make-install-args: - PREFIX=${FLATPAK_DEST} sources: - type: git url: https://github.com/libretro/glsl-shaders.git - commit: 8f6b2649489760caea8f36ec6099998854059569 + commit: 46a00f15e09ffbd4fba46ab41f0653aeea918fd1 - name: common-overlays make-install-args: - PREFIX=${FLATPAK_DEST} sources: - type: git url: https://github.com/libretro/common-overlays.git - commit: db9744f4e58a740f0f10b04b62af347cd6f01928 + commit: e2ba730083769b45bac62d164115e7dc197c8b63 # RetroArch - END @@ -398,8 +398,8 @@ modules: - mv ./RetroArch-Linux-x86_64.AppImage.home/.config/retroarch/cores/* /app/share/libretro/cores/ sources: - type: archive - url: https://buildbot.libretro.com/stable/1.10.3/linux/x86_64/RetroArch_cores.7z - sha256: 33abf39839687f8faba202ed5dcf3a54c06266a49fad35f0521fa445523d009f + url: https://buildbot.libretro.com/stable/1.11.0/linux/x86_64/RetroArch_cores.7z + sha256: a443c18708b3eda12bdc3419e1aaf9d95370580a38f23d0abfa7868b84ff6fdc # PPSSPP - START # https://github.com/flathub/org.ppsspp.PPSSPP @@ -958,8 +958,8 @@ modules: - ln -s "${FLATPAK_DEST}/pcsx2-qt/usr/bin/pcsx2-qt" "${FLATPAK_DEST}/bin/pcsx2-qt" sources: - type: file - url: https://github.com/PCSX2/pcsx2/releases/download/v1.7.3325/pcsx2-v1.7.3325-linux-AppImage-64bit-AVX2-Qt.AppImage - sha256: 5fa89570fb68b8a729dc0589e568d3a09b2b9243d4d66a5b7086975fb02e95e4 + url: https://github.com/PCSX2/pcsx2/releases/download/v1.7.3357/pcsx2-v1.7.3357-linux-AppImage-64bit-AVX2-Qt.AppImage + sha256: 07f293c1aad832f0a908c18ff94c8b545db0cb56230b4f4574ba75071bd91441 # PCSX2 - END From a8915dda4af9cb4a0676c3168a9150abe4237609 Mon Sep 17 00:00:00 2001 From: XargonWan <xargonwan@gmail.com> Date: Sat, 1 Oct 2022 22:39:33 +0200 Subject: [PATCH 122/124] Added the new logo --- res/icon.svg | 35 +++--- res/logo.png | Bin 105309 -> 31533 bytes res/splash.svg | 319 +++++++------------------------------------------ 3 files changed, 62 insertions(+), 292 deletions(-) mode change 100755 => 100644 res/logo.png mode change 100755 => 100644 res/splash.svg diff --git a/res/icon.svg b/res/icon.svg index d00d28bd..98563325 100644 --- a/res/icon.svg +++ b/res/icon.svg @@ -1,19 +1,18 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 25.4.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<svg version="1.1" id="Capa_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - viewBox="0 0 37.22 37.22" style="enable-background:new 0 0 37.22 37.22;" xml:space="preserve"> -<style type="text/css"> - .st0{fill:#FFFFFF;} - .st1{fill:url(#SVGID_1_);} -</style> -<circle cx="18.61" cy="18.61" r="18.61"/> -<path class="st0" d="M18.56,3.51v5.43c5.39,0,9.75,4.37,9.75,9.75s-4.37,9.75-9.75,9.75v5.43c8.39,0,15.19-6.8,15.19-15.19 - S26.94,3.51,18.56,3.51z"/> -<linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="11.074" y1="18.2778" x2="25.5185" y2="18.2778"> - <stop offset="0" style="stop-color:#906DEC"/> - <stop offset="1" style="stop-color:#1D9EFE"/> -</linearGradient> -<path class="st1" d="M22.32,19.61c1.78-0.1,3.19-1.56,3.19-3.37c0-1.87-1.52-3.39-3.39-3.39h-9.8c-0.7,0-1.26,0.56-1.26,1.26v9.59 - h2.7v-4.07h5.11l3.03,4.07h3.38l-2.93-4.08L22.32,19.61z M21.69,17.3h-7.87v-2.19h7.87c0.6,0,1.09,0.49,1.09,1.09 - C22.78,16.81,22.29,17.3,21.69,17.3z"/> +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg width="100%" height="100%" viewBox="0 0 256 256" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2;"> + <g transform="matrix(1.88235,0,0,1.86861,-7.52941,-5.60584)"> + <path d="M140,37.25C140,18.347 124.765,3 106,3L38,3C19.235,3 4,18.347 4,37.25L4,105.75C4,124.653 19.235,140 38,140L106,140C124.765,140 140,124.653 140,105.75L140,37.25Z" style="fill:rgb(17,17,17);"/> + </g> + <g transform="matrix(2.02105,0,0,2.02105,-13.4737,-13.4737)"> + <g id="D" transform="matrix(-0.674885,8.26495e-17,-8.26495e-17,-0.674885,223.747,109.037)"> + <path d="M172.54,-2.511C175.786,-5.757 179.378,-8.24 183.315,-9.96C187.251,-11.68 191.533,-12.54 196.16,-12.54L271.855,-12.54L271.855,6.901L196.16,6.901C194.44,6.901 192.823,7.222 191.309,7.864C189.795,8.506 188.475,9.39 187.348,10.517C186.222,11.643 185.337,12.964 184.695,14.478C184.053,15.992 183.732,17.609 183.732,19.329L183.732,96.355C183.732,97.954 184.084,99.498 184.786,100.988C185.489,102.478 186.416,103.798 187.566,104.949C188.717,106.1 190.037,107.027 191.527,107.729C193.017,108.432 194.562,108.783 196.16,108.783L271.855,108.783L271.855,128.224L196.16,128.224C193.859,128.224 191.624,127.982 189.456,127.498C187.288,127.013 185.204,126.329 183.206,125.444C181.207,124.56 179.311,123.5 177.518,122.265C175.726,121.029 174.066,119.673 172.54,118.195C169.366,115.118 166.901,111.575 165.145,107.566C163.389,103.556 162.51,99.226 162.51,94.574L162.51,21.11C162.51,16.458 163.37,12.17 165.09,8.246C166.811,4.321 169.294,0.736 172.54,-2.511Z" style="fill:white;fill-rule:nonzero;"/> + </g> + <g id="Left-Symbol" serif:id="Left Symbol" transform="matrix(0.494792,-0,-0,0.494792,6.66667,6.66667)"> + <use xlink:href="#_Image1" x="39.093" y="89.764" width="103.568px" height="78.228px" transform="matrix(0.995844,0,0,0.990223,0,0)"/> + </g> + </g> + <defs> + <image id="_Image1" width="104px" height="79px" xlink:href=""/> + </defs> </svg> diff --git a/res/logo.png b/res/logo.png old mode 100755 new mode 100644 index 1150e7de6abf00addf2257c2274421f4fb85c495..d9fc05e5b3e7c158c41f35e0f358314e8d1ae149 GIT binary patch literal 31533 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 literal 105309 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 B8{7Z@ diff --git a/res/splash.svg b/res/splash.svg old mode 100755 new mode 100644 index f08a7ff3..0a2cfb46 --- a/res/splash.svg +++ b/res/splash.svg @@ -1,277 +1,48 @@ <?xml version="1.0" encoding="UTF-8" standalone="no"?> -<!-- Created with Inkscape (http://www.inkscape.org/) --> - -<svg - width="792.61493" - height="495.38437" - viewBox="0 0 209.7127 131.07045" - version="1.1" - id="svg5" - sodipodi:docname="splash.svg" - inkscape:version="1.1.2 (b8e25be833, 2022-02-05)" - xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" - xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" - xmlns:xlink="http://www.w3.org/1999/xlink" - xmlns="http://www.w3.org/2000/svg" - xmlns:svg="http://www.w3.org/2000/svg"> - <sodipodi:namedview - id="namedview7" - pagecolor="#505050" - bordercolor="#eeeeee" - borderopacity="1" - inkscape:pageshadow="0" - inkscape:pageopacity="0" - inkscape:pagecheckerboard="0" - inkscape:document-units="mm" - showgrid="false" - inkscape:zoom="0.50268269" - inkscape:cx="-233.74586" - inkscape:cy="329.23354" - inkscape:window-width="1920" - inkscape:window-height="991" - inkscape:window-x="-9" - inkscape:window-y="-9" - inkscape:window-maximized="1" - inkscape:current-layer="layer2" - units="px" - width="1920px" - height="1122.5196px" - fit-margin-top="0" - fit-margin-left="0" - fit-margin-right="0" - fit-margin-bottom="0" /> - <defs - id="defs2"> - <rect - x="22.877255" - y="497.33163" - width="668.41371" - height="146.2155" - id="rect89677" /> - <linearGradient - inkscape:collect="always" - id="linearGradient78351"> - <stop - style="stop-color:#946beb;stop-opacity:1" - offset="0" - id="stop78347" /> - <stop - style="stop-color:#1a9fff;stop-opacity:1" - offset="1" - id="stop78349" /> - </linearGradient> - <linearGradient - inkscape:collect="always" - xlink:href="#linearGradient78351" - id="linearGradient78353" - x1="10.00051" - y1="46.318153" - x2="196.06264" - y2="47.107666" - gradientUnits="userSpaceOnUse" /> - <linearGradient - inkscape:collect="always" - xlink:href="#linearGradient78351" - id="linearGradient104819" - x1="26.855909" - y1="512.25159" - x2="441.63049" - y2="514.24091" - gradientUnits="userSpaceOnUse" /> - <linearGradient - inkscape:collect="always" - xlink:href="#linearGradient78351" - id="linearGradient86391" - x1="60.585548" - y1="249.27652" - x2="369.62967" - y2="548.81158" - gradientUnits="userSpaceOnUse" /> - </defs> - <g - inkscape:groupmode="layer" - id="layer2" - inkscape:label="Livello 2" - style="display:inline"> - <g - aria-label="RETRO -" - id="text2352" - style="font-size:9.525px;line-height:1.25;fill:url(#linearGradient78353);stroke-width:0.264583"> - <path - d="m 13.27873,33.995418 h 23.783924 q 1.343025,0 2.447925,0.32385 1.114425,0.32385 2.00025,0.885825 0.89535,0.561975 1.552575,1.3335 0.66675,0.771525 1.1049,1.6764 0.43815,0.89535 0.657225,1.88595 0.219075,0.981075 0.20955,1.981199 0,1.019175 -0.219075,2.0193 -0.219075,1.000125 -0.657225,1.905 -0.43815,0.89535 -1.1049,1.65735 -0.657225,0.762 -1.54305,1.323975 -0.885825,0.55245 -2.00025,0.866775 -1.1049,0.314325 -2.447925,0.314325 h -0.104775 l 8.5725,10.49655 H 38.624754 L 30.052255,50.168867 H 15.79333 v 10.49655 h -5.562599 l -0.0095,-23.612474 q 0,-0.6858 0.219075,-1.247775 0.219075,-0.561975 0.619125,-0.962025 0.409575,-0.409575 0.971549,-0.62865 0.561975,-0.219075 1.247775,-0.219075 z m 23.679149,11.077574 q 0.619125,0 1.08585,-0.257175 0.466725,-0.257175 0.78105,-0.676275 0.314325,-0.4191 0.466725,-0.9525 0.161925,-0.542925 0.161925,-1.1049 0.0095,-0.561975 -0.142875,-1.095374 -0.1524,-0.542925 -0.466725,-0.962025 -0.3048,-0.4191 -0.78105,-0.676275 -0.466725,-0.257175 -1.1049,-0.257175 H 15.79333 v 5.981699 z" - style="font-family:DREAMS;-inkscape-font-specification:DREAMS;letter-spacing:0.264583px" - id="path110710" /> - <path - d="M 48.709617,57.607892 V 37.052943 q 0,-0.6858 0.219074,-1.247775 0.219075,-0.561975 0.619125,-0.962025 0.409575,-0.409575 0.97155,-0.62865 0.561975,-0.219075 1.247775,-0.219075 H 82.83769 v 5.095875 H 54.281741 v 5.400674 H 79.37059 v 5.095875 H 54.281741 v 5.9817 H 82.83769 v 5.095875 H 51.767141 q -0.6858,0 -1.247775,-0.219075 -0.561975,-0.219075 -0.97155,-0.619125 -0.40005,-0.409575 -0.619125,-0.97155 -0.219074,-0.561975 -0.219074,-1.247775 z" - style="font-family:DREAMS;-inkscape-font-specification:DREAMS;letter-spacing:0.264583px" - id="path110712" /> - <path - d="m 86.188378,39.091293 v -5.095875 h 34.137602 v 5.095875 H 106.048 v 21.574124 h -5.57212 V 39.091293 Z" - style="font-family:DREAMS;-inkscape-font-specification:DREAMS;letter-spacing:0.264583px" - id="path110714" /> - <path - d="m 127.41045,33.995418 h 23.78393 q 1.34302,0 2.44792,0.32385 1.11443,0.32385 2.00025,0.885825 0.89535,0.561975 1.55258,1.3335 0.66675,0.771525 1.1049,1.6764 0.43815,0.89535 0.65722,1.88595 0.21908,0.981075 0.20955,1.981199 0,1.019175 -0.21907,2.0193 -0.21908,1.000125 -0.65723,1.905 -0.43815,0.89535 -1.1049,1.65735 -0.65722,0.762 -1.54305,1.323975 -0.88582,0.55245 -2.00025,0.866775 -1.1049,0.314325 -2.44792,0.314325 h -0.10478 l 8.5725,10.49655 h -6.90562 l -8.5725,-10.49655 h -14.25893 v 10.49655 h -5.5626 l -0.01,-23.612474 q 0,-0.6858 0.21907,-1.247775 0.21908,-0.561975 0.61913,-0.962025 0.40957,-0.409575 0.97155,-0.62865 0.56197,-0.219075 1.24777,-0.219075 z m 23.67915,11.077574 q 0.61913,0 1.08585,-0.257175 0.46673,-0.257175 0.78105,-0.676275 0.31433,-0.4191 0.46673,-0.9525 0.16192,-0.542925 0.16192,-1.1049 0.01,-0.561975 -0.14287,-1.095374 -0.1524,-0.542925 -0.46673,-0.962025 -0.3048,-0.4191 -0.78105,-0.676275 -0.46672,-0.257175 -1.1049,-0.257175 h -21.16455 v 5.981699 z" - style="font-family:DREAMS;-inkscape-font-specification:DREAMS;letter-spacing:0.264583px" - id="path110716" /> - <path - d="m 165.47024,58.036517 q -1.24778,-1.209675 -1.9431,-2.7813 -0.6858,-1.58115 -0.6858,-3.40995 v -9.0297 q 0,-1.828799 0.67627,-3.371849 0.67628,-1.54305 1.95263,-2.8194 1.27635,-1.27635 2.8194,-1.952625 1.55257,-0.676275 3.37185,-0.676275 h 16.4973 q 1.81927,0 3.36232,0.676275 1.55258,0.676275 2.82893,1.952625 1.27635,1.27635 1.95262,2.8194 0.67628,1.54305 0.67628,3.371849 v 9.0297 q 0,1.8288 -0.69533,3.40995 -0.6858,1.571625 -1.93357,2.7813 -0.60008,0.581025 -1.30493,1.0668 -0.70485,0.485775 -1.49542,0.8382 -0.78105,0.3429 -1.6383,0.5334 -0.84773,0.1905 -1.7526,0.1905 h -16.4973 q -0.90488,0 -1.76213,-0.1905 -0.84772,-0.1905 -1.6383,-0.5334 -0.78105,-0.352425 -1.4859,-0.8382 -0.70485,-0.485775 -1.30492,-1.0668 z m 2.9337,-5.724525 q 0,0.62865 0.27622,1.2192 0.27623,0.581025 0.7239,1.038225 0.4572,0.447675 1.03823,0.7239 0.59055,0.276225 1.2192,0.276225 h 16.4973 q 0.62865,0 1.20967,-0.276225 0.59055,-0.276225 1.03823,-0.7239 0.4572,-0.4572 0.73342,-1.038225 0.27623,-0.59055 0.27623,-1.2192 v -9.96315 q 0,-0.676275 -0.25718,-1.266824 -0.24765,-0.600075 -0.69532,-1.038225 -0.43815,-0.447675 -1.03823,-0.695325 -0.59055,-0.257175 -1.26682,-0.257175 h -16.4973 q -0.67628,0 -1.27635,0.257175 -0.59055,0.24765 -1.03823,0.695325 -0.43815,0.43815 -0.69532,1.038225 -0.24765,0.590549 -0.24765,1.266824 z" - style="font-family:DREAMS;-inkscape-font-specification:DREAMS;letter-spacing:0.264583px" - id="path110718" /> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg width="100%" height="100%" viewBox="0 0 5368 2000" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2;"> + <g id="Logo" transform="matrix(4.50045,0,0,4.50045,-50,2.27374e-13)"> + <g id="DECK" transform="matrix(1,0,0,1,12.4872,24.461)"> + <g transform="matrix(59.9942,0,0,59.9942,717.904,355.467)"> + <g id="K"> + <g> + <path d="M0.233,-2.8L0.817,-2.8L0.817,-1.284L2.821,-2.801L3.694,-2.801L2.48,-1.882L3.818,0.001L3.099,-0.001L2.015,-1.529L0.817,-0.621L0.817,-0L0.233,-0L0.233,-2.8Z" style="fill:white;fill-rule:nonzero;"/> + </g> + </g> + </g> + <g transform="matrix(59.9942,0,0,59.9942,473.484,355.527)"> + <g id="C"> + <g> + <path d="M0.509,-2.524C0.598,-2.613 0.697,-2.682 0.806,-2.729C0.914,-2.776 1.032,-2.8 1.159,-2.8L3.827,-2.8L3.827,-2.265L1.159,-2.265C1.112,-2.265 1.067,-2.256 1.026,-2.239C0.984,-2.221 0.948,-2.197 0.917,-2.166C0.885,-2.135 0.861,-2.098 0.844,-2.057C0.826,-2.015 0.817,-1.97 0.817,-1.923L0.817,-0.877C0.817,-0.833 0.827,-0.791 0.846,-0.75C0.865,-0.709 0.891,-0.672 0.923,-0.641C0.954,-0.609 0.991,-0.583 1.032,-0.564C1.073,-0.545 1.115,-0.535 1.159,-0.535L3.827,-0.535L3.827,-0L1.159,-0C1.096,-0 1.034,-0.007 0.975,-0.02C0.915,-0.033 0.858,-0.052 0.803,-0.077C0.748,-0.101 0.695,-0.13 0.646,-0.164C0.597,-0.198 0.551,-0.235 0.509,-0.276C0.422,-0.361 0.354,-0.458 0.306,-0.569C0.257,-0.679 0.233,-0.798 0.233,-0.926L0.233,-1.874C0.233,-2.002 0.257,-2.12 0.304,-2.228C0.351,-2.336 0.42,-2.435 0.509,-2.524Z" style="fill:white;fill-rule:nonzero;"/> + </g> + </g> + </g> + <g transform="matrix(59.9942,0,0,59.9942,229.064,355.527)"> + <g id="E"> + <g> + <path d="M0.233,-0.321L0.233,-2.479C0.233,-2.527 0.241,-2.571 0.256,-2.61C0.271,-2.649 0.293,-2.683 0.322,-2.712C0.35,-2.74 0.384,-2.762 0.423,-2.777C0.462,-2.792 0.506,-2.8 0.554,-2.8L3.816,-2.8L3.816,-2.265L0.818,-2.265L0.818,-1.698L3.452,-1.698L3.452,-1.163L0.818,-1.163L0.818,-0.535L3.816,-0.535L3.816,-0L0.554,-0C0.506,-0 0.462,-0.008 0.423,-0.023C0.384,-0.038 0.35,-0.06 0.322,-0.089C0.293,-0.117 0.271,-0.151 0.256,-0.19C0.241,-0.229 0.233,-0.273 0.233,-0.321Z" style="fill:white;fill-rule:nonzero;"/> + </g> + </g> + </g> + <g transform="matrix(-1.65095,2.02183e-16,-2.02183e-16,-1.65095,482.537,399.236)"> + <g id="D---Gamepad" serif:id="D + Gamepad"> + <g> + <g id="Background" transform="matrix(-0.134589,-1.64824e-17,1.64824e-17,-0.134589,327.567,284.759)"> + <use xlink:href="#_Image1" x="255" y="1535" width="567px" height="302px"/> + </g> + <path d="M172.54,-2.511C175.786,-5.757 179.378,-8.24 183.315,-9.96C187.251,-11.68 191.533,-12.54 196.16,-12.54L271.855,-12.54L271.855,6.901L196.16,6.901C194.44,6.901 192.823,7.222 191.309,7.864C189.795,8.506 188.475,9.39 187.348,10.517C186.222,11.643 185.337,12.964 184.695,14.478C184.053,15.992 183.732,17.609 183.732,19.329L183.732,96.355C183.732,97.954 184.084,99.498 184.786,100.988C185.489,102.478 186.416,103.798 187.566,104.949C188.717,106.1 190.037,107.027 191.527,107.729C193.017,108.432 194.562,108.783 196.16,108.783L271.855,108.783L271.855,128.224L196.16,128.224C193.859,128.224 191.624,127.982 189.456,127.498C187.288,127.013 185.204,126.329 183.206,125.444C181.207,124.56 179.311,123.5 177.518,122.265C175.726,121.029 174.066,119.673 172.54,118.195C169.366,115.118 166.901,111.575 165.145,107.566C163.389,103.556 162.51,99.226 162.51,94.574L162.51,21.11C162.51,16.458 163.37,12.17 165.09,8.246C166.811,4.321 169.294,0.736 172.54,-2.511Z" style="fill:white;fill-rule:nonzero;"/> + </g> + </g> + </g> + </g> + <g transform="matrix(0.222187,0,0,0.2222,11.11,-5.05224e-14)"> + <g id="Rainbow"> + <use id="_Image2_" serif:id="_Image2" xlink:href="#_Image2" x="0" y="0" width="5368px" height="2000px"/> + </g> + </g> </g> - <g - aria-label="ECK" - id="text17644" - style="font-size:9.525px;line-height:1.25;letter-spacing:0.79375px;fill:#ffffff;stroke-width:0.264583"> - <path - d="M 48.818965,87.645493 V 67.090544 q 0,-0.6858 0.219075,-1.247775 0.219075,-0.561975 0.619125,-0.962025 0.409575,-0.409575 0.97155,-0.62865 0.561975,-0.219075 1.247775,-0.219075 h 31.070548 v 5.095875 H 54.39109 v 5.400675 h 25.088849 v 5.095875 H 54.39109 v 5.981699 h 28.555948 v 5.095875 H 51.87649 q -0.6858,0 -1.247775,-0.219075 -0.561975,-0.219075 -0.97155,-0.619125 -0.40005,-0.409575 -0.619125,-0.97155 -0.219075,-0.561975 -0.219075,-1.247775 z" - style="font-family:DREAMS;-inkscape-font-specification:DREAMS" - id="path110739" /> - <path - d="m 90.132069,66.661919 q 1.27635,-1.27635 2.8194,-1.952625 1.552575,-0.676275 3.37185,-0.676275 h 25.412701 v 5.095875 H 96.323319 q -0.676275,0 -1.27635,0.257175 -0.59055,0.24765 -1.038225,0.695325 -0.43815,0.43815 -0.695325,1.038225 -0.24765,0.59055 -0.24765,1.266825 v 9.96315 q 0,0.628649 0.276225,1.219199 0.276225,0.581025 0.7239,1.038225 0.4572,0.447675 1.038225,0.7239 0.59055,0.276225 1.2192,0.276225 h 25.412701 v 5.095875 H 96.323319 q -0.904875,0 -1.762125,-0.1905 -0.847725,-0.1905 -1.6383,-0.5334 -0.78105,-0.352425 -1.4859,-0.8382 -0.70485,-0.485775 -1.304925,-1.0668 -1.247775,-1.209675 -1.9431,-2.7813 -0.6858,-1.58115 -0.6858,-3.409949 v -9.0297 q 0,-1.8288 0.676275,-3.37185 0.676275,-1.54305 1.952625,-2.8194 z" - style="font-family:DREAMS;-inkscape-font-specification:DREAMS" - id="path110741" /> - <path - d="m 126.29215,64.033019 h 5.5626 v 14.4399 l 19.0881,-14.449425 h 8.31532 l -11.56335,8.753475 12.74445,17.935574 -6.84847,-0.01905 -10.3251,-14.554199 -11.41095,8.648699 v 5.915025 h -5.5626 z" - style="font-family:DREAMS;-inkscape-font-specification:DREAMS" - id="path110743" /> - </g> - <g - id="g38619" - transform="matrix(0.82704001,0,0,0.82704001,-148.41704,-223.88161)"> - <g - id="g38832" - transform="matrix(0.06692755,0,0,0.06692755,191.3323,337.17343)" - style="display:inline;fill:#ffffff"> - <path - d="M 200.25,600.27 C 89.51,600.27 0,510.89 0,400.32 0,289.75 89.51,200.37 200.25,200.37 c 110.74,0 200.26,89.38 200.26,199.95 0,110.57 -89.52,199.95 -200.26,199.95 z" - fill="url(#a)" - id="path38820" - style="fill:url(#linearGradient86391);fill-opacity:1" /> - <path - d="M 456.98,399.89 C 456.98,258.32 342.03,143.55 200.24,143.55 V 0 c 221.2,0 400.51,179.04 400.51,399.89 0,220.86 -179.31,399.9 -400.51,399.9 V 656.24 c 141.79,0 256.74,-114.77 256.74,-256.35 z" - fill="#1b1b1b" - id="path38822" - style="fill:#ffffff" /> - </g> - </g> - <g - aria-label="Powered by EmulationStation-DE" - transform="matrix(0.26458333,0,0,0.26458333,42.370582,-40.265212)" - id="text89675" - style="font-size:24px;line-height:1.25;white-space:pre;shape-inside:url(#rect89677);fill:url(#linearGradient104819)"> - <path - d="m 28.841797,515.39062 v 6.01172 h -3.867188 v -17.66015 h 6.679688 q 3.433594,0 5.214844,1.40625 1.78125,1.39453 1.78125,4.08984 0,2.8125 -1.96875,4.48828 -1.96875,1.66406 -5.132813,1.66406 z m -0.02344,-8.87109 v 6.07031 h 1.03125 q 2.90625,0 3.84375,-0.79687 0.949219,-0.8086 0.949219,-2.47266 0,-1.37109 -0.914062,-2.08594 -0.902344,-0.71484 -3.585938,-0.71484 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110764" /> - <path - d="m 46.572266,521.82422 q -3.304688,0 -5.132813,-1.89844 -1.828125,-1.91016 -1.828125,-5.29687 0,-3.39844 1.839844,-5.3086 1.851562,-1.91015 5.121094,-1.91015 3.292968,0 5.121093,1.91015 1.839844,1.91016 1.839844,5.3086 0,3.38671 -1.839844,5.29687 -1.828125,1.89844 -5.121093,1.89844 z m 0,-11.90625 q -3.199219,0 -3.199219,4.74609 0,4.65235 3.246094,4.65235 3.152343,0 3.152343,-4.65235 0,-4.74609 -3.199218,-4.74609 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110766" /> - <path - d="m 75.505859,507.83203 -4.125,13.57031 h -3.140625 l -3.128906,-9.6914 -3.128906,9.6914 h -3.164063 l -4.125,-13.57031 h 3.773438 l 2.34375,8.92969 2.847656,-8.92969 h 3.152344 l 2.777344,8.90625 2.285156,-8.90625 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110768" /> - <path - d="m 89.919922,515.17969 h -9.621094 q 0.234375,4.07812 4.628906,4.07812 2.296875,0 4.617188,-1.66406 h 0.128906 v 3.11719 q -2.753906,1.05468 -5.179687,1.05468 -3.820313,0 -5.824219,-1.8164 -2.003906,-1.81641 -2.003906,-5.23828 0,-3.39844 1.898437,-5.34375 1.898438,-1.95703 5.238281,-1.95703 6.117188,0 6.117188,6.5039 z m -3.597656,-2.03907 q -0.04687,-3.5039 -2.847657,-3.5039 -2.976562,0 -3.175781,3.5039 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110770" /> - <path - d="m 101.75586,511.5 h -0.11719 q -0.72656,-0.1875 -1.945311,-0.1875 -1.910156,0 -3.515625,0.60937 v 9.48047 h -3.597656 v -13.57031 h 3.597656 v 2.46094 q 1.652344,-1.48828 2.71875,-1.99219 1.066407,-0.51562 2.097656,-0.51562 0.26953,0 0.76172,0.0234 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110772" /> - <path - d="m 116.07617,515.17969 h -9.62109 q 0.23437,4.07812 4.6289,4.07812 2.29688,0 4.61719,-1.66406 h 0.12891 v 3.11719 q -2.75391,1.05468 -5.17969,1.05468 -3.82031,0 -5.82422,-1.8164 -2.0039,-1.81641 -2.0039,-5.23828 0,-3.39844 1.89843,-5.34375 1.89844,-1.95703 5.23828,-1.95703 6.11719,0 6.11719,6.5039 z m -3.59765,-2.03907 q -0.0469,-3.5039 -2.84766,-3.5039 -2.97656,0 -3.17578,3.5039 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110774" /> - <path - d="m 130.98242,521.40234 h -3.59765 v -1.78125 q -1.75782,1.42969 -2.64844,1.79297 -0.89063,0.36328 -1.91016,0.36328 -2.33203,0 -3.71484,-1.88672 -1.38281,-1.89843 -1.38281,-5.15625 0,-3.23437 1.67578,-5.25 1.67578,-2.02734 4.16015,-2.02734 0.89063,0 1.62891,0.19922 0.73828,0.19922 2.19141,0.96094 v -5.66016 h 3.59765 z m -3.59765,-3.48047 v -7.34765 q -1.17188,-0.50391 -2.17969,-0.50391 -3.75,0 -3.75,4.57031 0,2.3086 0.77344,3.33985 Q 123.00195,519 124.6543,519 q 1.24218,0 2.73047,-1.07813 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110776" /> - <path - d="m 146.28711,520.44141 -0.23438,0.96093 h -3.375 v -18.44531 h 3.59766 v 6.69141 q 1.57031,-1.32422 2.55469,-1.75782 0.99609,-0.43359 2.09765,-0.43359 2.39063,0 3.69141,1.83984 1.3125,1.83985 1.3125,5.16797 0,3.25782 -1.66406,5.28516 -1.66406,2.02734 -4.14844,2.02734 -1.78125,0 -3.83203,-1.33593 z m -0.0117,-9.2461 v 7.52344 q 1.19531,0.44531 2.19141,0.44531 3.73828,0 3.73828,-4.60547 0,-4.32422 -3.12891,-4.32422 -1.27734,0 -2.80078,0.96094 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110778" /> - <path - d="m 171.29492,507.83203 -7.4414,18.45703 h -3.79688 l 2.0625,-4.86328 -5.30859,-13.59375 h 3.90234 l 3.42188,9.69141 3.45703,-9.69141 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110780" /> - <path - d="m 193.73633,521.40234 h -12.30469 v -17.66015 h 12.30469 v 2.92968 h -8.46094 v 3.77344 h 7.86328 v 2.91797 h -7.86328 v 5.10938 h 8.46094 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110782" /> - <path - d="m 217.88867,521.40234 h -3.62109 v -6.80859 q 0,-1.35938 -0.12891,-2.37891 -0.11719,-1.03125 -0.71484,-1.40625 -0.58594,-0.375 -1.62891,-0.375 -0.92578,0 -2.61328,1.03125 v 9.9375 h -3.62109 v -6.80859 q 0,-1.42969 -0.14063,-2.41406 -0.14062,-0.9961 -0.73828,-1.3711 -0.58594,-0.375 -1.60547,-0.375 -0.97265,0 -2.60156,1.04297 v 9.92578 h -3.59766 v -13.57031 h 3.59766 v 1.89844 q 1.78125,-1.46485 2.69531,-1.86328 0.92578,-0.41016 1.91016,-0.41016 2.55469,0 3.77344,2.60156 1.72265,-1.5 2.8125,-2.05078 1.08984,-0.55078 2.13281,-0.55078 4.08984,0 4.08984,5.02734 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110784" /> - <path - d="m 234.10742,521.40234 h -3.59765 v -1.89843 q -1.64063,1.33593 -2.67188,1.80468 -1.03125,0.46875 -2.14453,0.46875 -4.28906,0 -4.28906,-5.02734 v -8.91797 h 3.62109 v 6.76172 q 0,2.83594 0.62109,3.52734 0.6211,0.69141 2.02735,0.69141 1.20703,0 2.83594,-1.05469 v -9.92578 h 3.59765 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110786" /> - <path - d="m 241.43164,521.40234 h -3.59766 v -18.44531 h 3.59766 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110788" /> - <path - d="m 256.66602,521.40234 h -3.57422 v -1.76953 q -1.65235,1.41797 -2.6836,1.76953 -1.01953,0.36328 -2.17968,0.36328 -1.78125,0 -2.95313,-1.14843 -1.17187,-1.16016 -1.17187,-2.97657 0,-2.29687 1.72265,-3.48046 1.73438,-1.1836 7.30078,-1.47657 v -0.36328 q 0,-1.27734 -0.8789,-1.85156 -0.87891,-0.57422 -2.90625,-0.57422 -1.38282,0 -3.96094,1.05469 h -0.12891 v -2.84766 q 2.71875,-0.65625 4.92188,-0.65625 3.43359,0 4.95703,1.11328 1.53516,1.10157 1.53516,3.51563 z m -3.57422,-3.30468 v -3.42188 q -3.53907,0.29297 -4.42969,0.91406 -0.89063,0.60938 -0.89063,1.69922 0,1.16016 0.6211,1.61719 0.62109,0.45703 1.94531,0.45703 1.39453,0 2.75391,-1.26562 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110790" /> - <path - d="m 268.2793,521.32031 q -1.44141,0.35156 -3.08203,0.35156 -2.42579,0 -3.55079,-1.03125 -1.125,-1.04296 -1.125,-3.36328 v -7.0664 h -1.78125 v -2.37891 h 1.79297 v -3.80859 h 3.58594 v 3.80859 h 4.16016 v 2.37891 h -4.16016 v 5.58984 q 0,2.15625 0.55078,2.8125 0.55078,0.65625 1.85156,0.65625 0.83204,0 1.65235,-0.41016 h 0.10547 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110792" /> - <path - d="m 274.2207,506.13281 h -3.85547 v -3.17578 h 3.85547 z m -0.1289,15.26953 h -3.59766 v -13.57031 h 3.59766 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110794" /> - <path - d="m 283.74805,521.82422 q -3.30469,0 -5.13282,-1.89844 -1.82812,-1.91016 -1.82812,-5.29687 0,-3.39844 1.83984,-5.3086 1.85157,-1.91015 5.1211,-1.91015 3.29297,0 5.12109,1.91015 1.83984,1.91016 1.83984,5.3086 0,3.38671 -1.83984,5.29687 -1.82812,1.89844 -5.12109,1.89844 z m 0,-11.90625 q -3.19922,0 -3.19922,4.74609 0,4.65235 3.24609,4.65235 3.15235,0 3.15235,-4.65235 0,-4.74609 -3.19922,-4.74609 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110796" /> - <path - d="m 306.10742,521.40234 h -3.62109 v -6.76172 q 0,-2.83593 -0.63281,-3.51562 -0.6211,-0.69141 -2.02735,-0.69141 -1.17187,0 -2.82422,1.04297 v 9.92578 h -3.59765 v -13.57031 h 3.59765 v 1.89844 q 1.6875,-1.38281 2.69532,-1.82813 1.01953,-0.44531 2.12109,-0.44531 4.28906,0 4.28906,5.02734 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110798" /> - <path - d="m 308.97852,520.34766 v -3.73829 h 0.39843 q 1.3125,1.07813 3.01172,1.71094 1.71094,0.63281 3.28125,0.63281 1.62891,0 2.625,-0.58593 0.9961,-0.58594 0.9961,-1.62891 0,-0.80859 -0.48047,-1.28906 -0.46875,-0.48047 -1.79297,-0.79688 -0.94922,-0.17578 -3.2461,-0.6914 -2.28515,-0.51563 -3.49218,-1.80469 -1.19532,-1.30078 -1.19532,-3.31641 0,-2.40234 2.05079,-3.90234 2.05078,-1.51172 5.27343,-1.51172 3.28125,0 6.16407,1.19531 v 3.57422 h -0.38672 q -2.46094,-1.99219 -5.64844,-1.99219 -1.51172,0 -2.49609,0.5625 -0.97266,0.5625 -0.97266,1.53516 0,0.83203 0.55078,1.32422 0.5625,0.49219 1.91016,0.80859 1.34765,0.2461 3,0.65625 1.66406,0.39844 2.47265,0.90235 0.82032,0.5039 1.30078,1.10156 0.49219,0.58594 0.72657,1.3125 0.24609,0.72656 0.24609,1.60547 0,2.57812 -2.10937,4.14844 -2.09766,1.57031 -5.56641,1.57031 -3.375,0 -6.62109,-1.38281 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110800" /> - <path - d="m 333.91602,521.32031 q -1.44141,0.35156 -3.08204,0.35156 -2.42578,0 -3.55078,-1.03125 -1.125,-1.04296 -1.125,-3.36328 v -7.0664 h -1.78125 v -2.37891 h 1.79297 v -3.80859 h 3.58594 v 3.80859 h 4.16016 v 2.37891 h -4.16016 v 5.58984 q 0,2.15625 0.55078,2.8125 0.55078,0.65625 1.85156,0.65625 0.83203,0 1.65235,-0.41016 h 0.10547 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110802" /> - <path - d="m 347.63867,521.40234 h -3.57422 v -1.76953 q -1.65234,1.41797 -2.68359,1.76953 -1.01953,0.36328 -2.17969,0.36328 -1.78125,0 -2.95312,-1.14843 -1.17188,-1.16016 -1.17188,-2.97657 0,-2.29687 1.72266,-3.48046 1.73437,-1.1836 7.30078,-1.47657 v -0.36328 q 0,-1.27734 -0.87891,-1.85156 -0.8789,-0.57422 -2.90625,-0.57422 -1.38281,0 -3.96093,1.05469 h -0.12891 v -2.84766 q 2.71875,-0.65625 4.92187,-0.65625 3.4336,0 4.95704,1.11328 1.53515,1.10157 1.53515,3.51563 z m -3.57422,-3.30468 v -3.42188 q -3.53906,0.29297 -4.42968,0.91406 -0.89063,0.60938 -0.89063,1.69922 0,1.16016 0.62109,1.61719 0.6211,0.45703 1.94532,0.45703 1.39453,0 2.7539,-1.26562 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110804" /> - <path - d="m 359.25195,521.32031 q -1.4414,0.35156 -3.08203,0.35156 -2.42578,0 -3.55078,-1.03125 -1.125,-1.04296 -1.125,-3.36328 v -7.0664 h -1.78125 v -2.37891 h 1.79297 v -3.80859 h 3.58594 v 3.80859 h 4.16015 v 2.37891 h -4.16015 v 5.58984 q 0,2.15625 0.55078,2.8125 0.55078,0.65625 1.85156,0.65625 0.83203,0 1.65234,-0.41016 h 0.10547 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110806" /> - <path - d="m 365.19336,506.13281 h -3.85547 v -3.17578 h 3.85547 z m -0.12891,15.26953 h -3.59765 v -13.57031 h 3.59765 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110808" /> - <path - d="m 374.7207,521.82422 q -3.30468,0 -5.13281,-1.89844 -1.82812,-1.91016 -1.82812,-5.29687 0,-3.39844 1.83984,-5.3086 1.85156,-1.91015 5.12109,-1.91015 3.29297,0 5.1211,1.91015 1.83984,1.91016 1.83984,5.3086 0,3.38671 -1.83984,5.29687 -1.82813,1.89844 -5.1211,1.89844 z m 0,-11.90625 q -3.19922,0 -3.19922,4.74609 0,4.65235 3.2461,4.65235 3.15234,0 3.15234,-4.65235 0,-4.74609 -3.19922,-4.74609 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110810" /> - <path - d="m 397.08008,521.40234 h -3.6211 v -6.76172 q 0,-2.83593 -0.63281,-3.51562 -0.62109,-0.69141 -2.02734,-0.69141 -1.17188,0 -2.82422,1.04297 v 9.92578 h -3.59766 v -13.57031 h 3.59766 v 1.89844 q 1.6875,-1.38281 2.69531,-1.82813 1.01953,-0.44531 2.1211,-0.44531 4.28906,0 4.28906,5.02734 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110812" /> - <path - d="m 408.7168,515.09766 h -8.53125 v -3.02344 h 8.53125 z" - style="font-weight:bold;font-family:Meiryo;-inkscape-font-specification:'Meiryo Bold'" - id="path110814" /> - <path - d="m 412.16211,521.40234 v -17.66015 h 5.51953 q 3.75,0 5.84766,0.96093 2.09765,0.96094 3.30468,2.95313 1.21875,1.99219 1.21875,4.93359 0,2.66016 -1.26562,4.78125 -1.25391,2.10938 -3.36328,3.07032 -2.10938,0.96093 -5.69531,0.96093 z m 3.86719,-14.88281 V 518.625 h 1.89843 q 6.08204,0 6.08204,-6.07031 0,-6.03516 -6.08204,-6.03516 z" - style="fill:#ffffff" - id="path110816" /> - <path - d="m 443.42773,521.40234 h -12.30468 v -17.66015 h 12.30468 v 2.92968 h -8.46093 v 3.77344 h 7.86328 v 2.91797 h -7.86328 v 5.10938 h 8.46093 z" - style="fill:#ffffff" - id="path110818" /> - </g> - </g> + <defs> + <image id="_Image1" width="567px" height="302px" xlink:href=""/> + <image id="_Image2" width="5368px" height="2000px" xlink:href=""/> + </defs> </svg> From e8a253db4fa6d3275f5ab4d05f2bd10673436cc2 Mon Sep 17 00:00:00 2001 From: icenine451 <benjamin.r.shelton@protonmail.com> Date: Sat, 1 Oct 2022 17:00:37 -0400 Subject: [PATCH 123/124] Changed order of operations in update --- retrodeck.sh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/retrodeck.sh b/retrodeck.sh index 54043997..8bbdc10a 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -260,10 +260,6 @@ post_update() { # Resetting es_systems, now we need it but in the future I should think a better solution, maybe with sed cp -fv /app/retrodeck/es_settings.xml /var/config/emulationstation/.emulationstation/es_settings.xml - ra_init - standalones_init - tools_init - # Perform save and state migration if needed versionwheresaveschanged="0.4.5b" # Hardcoded break point between unsorted and sorted saves @@ -379,6 +375,10 @@ post_update() { echo "Version" $version "is after the save and state organization was changed, no need to sort again" fi + ra_init + standalones_init + tools_init + create_lock } From 807dc4fbb132beb54d551d1a767fccd61b18f0e4 Mon Sep 17 00:00:00 2001 From: icenine451 <benjamin.r.shelton@protonmail.com> Date: Fri, 7 Oct 2022 09:28:27 -0400 Subject: [PATCH 124/124] Exclude SA emulator dirs from save migration --- retrodeck.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/retrodeck.sh b/retrodeck.sh index 747e59d4..6c437926 100644 --- a/retrodeck.sh +++ b/retrodeck.sh @@ -290,11 +290,11 @@ post_update() { --title "RetroDECK" \ --text="You are updating to a version of RetroDECK where save and state file sorting has changed!\n\nYour existing saves will be backed up to $save_backup_file\n\nYour existing states will be backed up to $state_backup_file\n\nIf a save or state cannot be sorted automatically it will remain in its original directory so you can sort it manually.\n\nIf you encounter any issues, a log of the sorting process is stored at $migration_logfile\n\nPLEASE BE PATIENT! This process can take several minutes if you have a large ROM library." - allgames=($(find "$roms_folder" -maxdepth 2 -mindepth 2 ! -name "systeminfo.txt" ! -name "systems.txt" ! -name "*^*" | sed -e "s/ /\^/g")) # Build an array of all games and multi-disc-game-containing folders, adding whitespace placeholder + allgames=($(find "$roms_folder" -maxdepth 2 -mindepth 2 ! -name "systeminfo.txt" ! -name "systems.txt" ! -name "gc" ! -name "n3ds" ! -name "nds" ! -name "wii" ! -name "xbox" ! -name "*^*" | sed -e "s/ /\^/g")) # Build an array of all games and multi-disc-game-containing folders, adding whitespace placeholder - allsaves=($(find "$saves_folder" -mindepth 1 -maxdepth 1 -name "*.*" | sed -e "s/ /\^/g")) # Build an array of all save files, ignoring standalone emulator sub-folders, adding whitespace placeholder + allsaves=($(find "$saves_folder" -mindepth 1 -maxdepth 1 -name "*.*" ! -name "gc" ! -name "n3ds" ! -name "nds" ! -name "wii" ! -name "xbox" | sed -e "s/ /\^/g")) # Build an array of all save files, ignoring standalone emulator sub-folders, adding whitespace placeholder - allstates=($(find "$states_folder" -mindepth 1 -maxdepth 1 -name "*.*" | sed -e "s/ /\^/g")) # Build an array of all state files, ignoring standalone emulator sub-folders, adding whitespace placeholder + allstates=($(find "$states_folder" -mindepth 1 -maxdepth 1 -name "*.*" ! -name "gc" ! -name "n3ds" ! -name "nds" ! -name "wii" ! -name "xbox" | sed -e "s/ /\^/g")) # Build an array of all state files, ignoring standalone emulator sub-folders, adding whitespace placeholder totalsaves=${#allsaves[@]} totalstates=${#allstates[@]}