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!% &#45;&#45;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
zcmeFZWmHvN+c3H*K~MoD1d)~wC8ZlgN=mxfba$tKfV6<p-JQ}PDka^y>F(}*Cf@f`
z=Y79({+vH&jAsuR?6u}x*SzM{F&Dw_WF;P=6QV;PkcX0QL=_+q6z~;^6b%vlIl5FW
z0yh**l~f&6Wu&<ctSy=J46XH{OfHr-U>pMB6>zc9Gcbobkm^H?O|AII_ZnKrNlgv;
z$W_>7Udq^rKut{FxY<D!-DH&v+{_KQ49Nxf(Rp3C0RT&=gC41irG=F}w+kQnAGqA$
z``vA3a?(Fj9L)L1Rb}3hidfr0N!gj$nO>6fqm%O585(gbh>HLHFu39)H*s*V;bvxb
zc6MfRW@WOrGiH9p#l^+^l7*Rtg%QkPw0E^~&~st5vZuHM@fQqHsJ(%msf~lFwH4_d
zOg(*TM+ZJ~axhN%H*iCPf5NtLw6pjF+0cL)Y5}!`S~=J=zhZjD{O|LjE~fv&#>)P0
zask3I-;IFjFaKk@gQ?N~Vfx+3|CnxLV(nmUZ(?opPo(~1iGL3Nj|Ty{|My2+^lbjO
z$uctk&(kd}|6?2W4q{G#aDOx5KXCfT0`^L-Hc(~-sJ*qLodHzL2~dyX58>|U!u`(F
z1!|!xY6^&I54gcc{)*-G%m3T3+P@9Ie)(^sBGwkxc8Wj_q2Rec58V-uThda`7^-4w
z=wR}1;Qlot4Ye}98~O*RKO=YeSvcMagtC<>*b&RWz^VRgjE|g)gZbZ9Qu|+r{>csQ
zKM2ZL8v^`T{{Z~gkfeynJ3DJ5QwuO=uOJ~zDk&zy@rsLsgOP>luN466xWTigMy{fI
z4qz6`OCZs&UNXLXrSyuGoAo6(%PYp0oZNpC<j-uNL56w`djD_p@AQC_*U*65!PLP5
z`seB|y%4f+`0MJgOAFIGW#G2Zvohu*cVRSy8tFM&IFR$(Slc^5?O1r3?{vq)^lt!v
zuKodmm-#=y^8)l_WVqj$+B;a=x&GUVics7CT=9<zl9K)rEN(r6JC5*?+t^tfIvPL?
z|IiTN{@19zwUL9fo*h)k7|0YKxsZ{ODd3$e>AO2+Aq5Khl8OC4pKvyT0%-qdLNfpR
zR{nt+FZ2IE{;!??n-u}i{dEsmCt&87|7qvI#Xl`2)C!nKJ75Q|Gi=x)5CmUSAOrt{
z_Yeq8lw(wb6p|2DPzz-UVJwZhsw#5u``~k*v@kJ0aUsTNwC056!^elOcOQ#dpiKMt
znJg6!v<Pansbk@YVM&$0uNt)Jdm$|Pn}O$Q$J#h>R;?^>_^o*9GaqS=QWPZqwd?O0
zl?wzsc-*GBv>EH0(kA56GFRVXRLh@5s1-WRw2TpjZlS9Z26W&k_h87O%ayJw$J7S!
z#41rzdC+Z-E&F}1%^@z{5AEtg_x@TG;O|vdbDt-s<@IG~?B_V_xcH^+ER61c&)@M?
zKPv6X)Z7i7GM`ZTU{Wi7TI%Q_&0K79d77c)G}1{zv(_ISqbb(dO-M*jDH+wlXeLz9
z0hRek93N%WyA6jmZw4=<zdgYt84)1(rNPW*A(U_OG&Lwto*QwRLesGDq7Lb)D}Iye
zsOHuDgimEp0p6_dk<7Z=I|}tIhDk&9C-+_We8*7Mzumi1$Tk*OBZ7&zXf<!5JDsJ;
zEk5soVSh4i5qIdy0S@iH%^Nj)2;|X^yI+J@`bW<o5K@SwsF0FN()O&ehZ1z|*MWVG
z(U7~(Kq8jlhKx`G204029*rO1&QEPTRjnR6^CfKL5oH8irFWXR@>!DdrhYiD6p+%9
zg{QJ)dDdL@{3BT;jr#al*Umi4QypL1>%gU{x-?mHJ8f-kAOCTy>3yVbf4)Gf1QG7t
zeOpIFd3yIZ4FgB_?ynEiJ0FC*FZKVO@LxLoS04VW7yq>ncjoZ_r*`s-C}tXVW!n(d
z>Y|~BS>uaWV+mNMA#uwgwMz8gWSD9X0;ZK5N;hle>A$9z(D$&{#e1|du8bAT@{aQ9
z<5MX$Rb<fpWO5HKEc*dvww;vH49I43FCR`(Nl@NoI@HfgGiLij*r7v2GWc?ckOVgl
z%PNeud+p}>-ujc@R}2@mmIWmBMsj6@4-{|Y+!$4w=gkX_wUxb2s#Dh@p#7^kdox$z
z_&p=i{Z<hlf~ZwkBb)^`*ynN*V7hCO^m92=xtf;o#SR90nN3=gSJbLu6?6$Do77)w
z>D@1?RjPtB&yR1z;Q6P`UgSN2AG2z(gNqp!Bv(ID+PnBMq@D>0*OgWc1<j)NPj4!p
zl&ReAk8hl5hk5zC!jTIHd1HC?y|4W@ZE@(JPI79#3h(D>>Gwb5(qyCTX0WC#R%(l;
zyHzm$`Z6%{WkTsuXjE}j#S7sY@wa1WlO}PSw?WlZa<fx6wD-{p3b;ckjmtM_;)s40
zWWMR;DKR2Z+EI(%?2QjF`{05Q&e3sFDo`c$JsZEn8IyIY@d8)vfaDV)uI`@7>87&O
zg@DRvsiwTZ!D_!Ud#SwH{zqk)T!E*W$3jmgdc5)r_QL%);&UnOt_`e*r-oC*TErbF
zrb54s!Z&Bm3qm(fOp|ALeiPA3@_YN;ER<S{I_|lhAKrJGtI*DNKR_N{q@KM>?I66#
za);YUvR{Z_mv2Y?uD+#d?M-|b9BL_VdTCwY_M^|+=lTk{kZRVs=e>iJBg#aoT-i}v
zG1W~(m?s=Vr=UyDO-x6{c2{TzqpZzDvVOhb!z$8Zf|k{NIbP?K7Nuk9{WiJ!2>9XH
zHLloBs%~s9yu4f>Rd+O7XWy}IhgwSRTFFV@crrK{O6^1oMZquf4Ix+}Ow>4i#kpbi
z#>`aO%=F`%$gKL?EEPAYUhN0&XCcA`tNG6ald`)fMa)jgUK~-c%->r%w~{>gm_kbv
zV1W?M((%c{ZF>KgfyFPI!OGSML&*}7(MB(&Bkiytsp#eRGaWlEImXs=Nf)k0LiOt#
zn?KA#zBP`1L$KT}`<jV#IsOXrfyRGOv$Q=-#(kCqZ`KFap5BWyOUhC&WH_DPa+Axt
zW;0pNcskqjHryh^K=VzFxcbzinyPJctI3Y1<L9-{E(i{ILVE|&nnu!^4x$&LDf6LD
zD+6cUZDA>V^dmEw89^9S>1sYf9E}SlW0=#@*cqt4W1sFR#!NWL=ubbi^6ap^y6x@Y
zpH8|E^V%>Sv>#Pn`_*2ucWwCL#rtDYNSb2#!-m@D96fl$s>h^Qt<eKB(F42%!zRvp
z?-zEV0S$4lD^7!n=^&l=q>iN8>%(iDzNxcJi^^p>+o@KS&te%gkgYDj-#_wPo4fQi
zJ~NKaR6W)d5)2OweZuF@{Pn@Aq-D-S%hv_py`lK)=vMa+wbBZ;-balbvkG`PJ51Ir
z(c`eA&HZ5S{H6Dtm~djX#NPUN?a6i{^o5ge3CCp;v`LFA(#iMMV&yr$g@OtvtSk^f
zm|E@Em_Sj#6Pp(eg4P~uhZr>{O(Wq38klbHIc`t5gcwuqZzF2iUXnaR9bp<6En<)g
zFY*N2!Ljhxp{>*@(_4=zj#`M9d9cO*>*@4<t;Y3bjP?d2Hw>j-z3*{<Nxx>Hj(jC%
zF!75t0?V2KSNJcZ2j0zF)A3Z8$7Wj?UULOgRrj8a8$wHK7~pH&@kmN7wik%oR|Isk
z6&c=ny%lx}qM3d9-dkffCcYFrh5KdWQfRttU#K-XO5H1?lr5LfjD;PYkM>yG8hFlE
zgz~!N>i0-K95RP`a<!9atWHN<yR9E37`kMOG}zXZxiA~&-NO7%RAd-AO0N6VdC{7$
zBujg%v}bZNWHhtuI-HpDB()hki&6QeuPY=BC+CAu(*p%I_`Rq`fX0MzoZjLFFvp+R
zEn(cI2lgb8$9&f~4c&Dr%%Tfdbf^5O6?28k>fbeHDgArGx!BbIq2A!!T%i>JFriw~
zHO8Jm7D><>IPxe*$~vCn@yPGw=t8AqK?FJnCVxt)L;oH4EK^O)x)4^{rWkueLq}2m
zO?-{y?hCiLw_31`RMV5{a~mYcyL54_U6YXur$I$hK>|zLV1M}N@@?;+mQ~clbXU@a
zI)-9Ys+n4*%X*auQIZ+PzT*$56jSeynF=Ia!YIBLW#rx$O;_}>Hsep1>xPNS`3jD+
zm9+cEGrG)ITs$<G`k0d4D5WvuU>cezDu)2M#Dy(ayhlpG;X^@8rmYt`{P;C&cNS~#
z^zC5fd1$`2`pk2wB`bL6=b`t<40#W^7^XZ<hV>$>UpWzxb&(wr)LMUdgJAW1*2<#C
zT};k5ZIGkxtm-!Pff-jxpnL6=yn<oO77rhp8#-iwIrBxv?5I6-lEw`S8C6QZ=aQ3I
zy7?6TATF|g{v#P3m)r914_D3ARh!Iicq6eyunCsa=Ubm+19N6Y`yUGmXF*_7hbgV5
zENJNB{u_azxw5-_%z}MYyss@Q<WYGP5d>S!MqID!;xAAdu}3dfM}lFh!b=7UYT@fV
zTpLk4HCDB6?LImnzlk<985-q=W<$4mDi}$%kJ0hb<#ubzpEtZX#pOfs8~S;2DZsUV
z^gdYYXLuCRXpu&Y`Hwyb#LcKelzo?9@)!s0ZCuvaLu#)lvzD6g_Dtv!+x4y8Sk2ZI
z?Myt=!UPC-!pr7b-pZPhxnUg$r$Zvly1VG!xtG^`4!Uf17Nd{q&p^PRB|Cag5BWGe
zAD!5%=fUBp9xXGLWv(qva8hqk1(?L~K)&nX2|q@|vihKZYs+#L-q@82f%?Xce|wsD
zuO)|SJ*6g{8#*$l8i%I$fq_cRR~jm<=;_ftYDz-Le&P>2f6)k^H2lehsn3Jfs9LBT
zoF=I@{dD%3Ou+i#8EO=r?2#n8%~H8xMfo*DYD0Gn*#m=95Yu%<8&E$u%wN7L*0<=I
zT0?|*8B~e>;MitzL;v9Sk;C7=5Gg2Ii$K6O;1!kfG3h{Ln<4Q@i0cpgXzhOfC&wt?
zSV`dDodE<6+IZ6>G{|ce%}nizHU{wc$9>(6)(WD@v$<~?u$43&PnMHple!}$E(Y~u
zQbc4=1S`Bz^<y+NT8b$?n-wwdah7r+i&m|urx1r1EVPue3!y&P=g(C+)bu6#Lh28@
z()exhH#;Yc(oULV?SvHv{Y@CxF>H!nXagAR6jK5d<!!hLKgHBsA0hd?(Y!(9$DcE@
zxt`z1$j$p=QSl=}M}Lb2tc)cmTi59ZHxu#nY`XvS80B>!;sb%F<BsC`q7;@D<i+==
zkP#qshL6_HUV1R+oc;J%qY{#`h*&{nKU)~LO5_y)>%u;W<Kd5_a6IPM9l)Pgl}cL2
z#`3dR&AZR1%}!7?;Yu4V=Yt?fgMsq&Hj2%zhPI@9owo0Z>xE~HY$j0AR`L$cnor(x
zENWty8BuA>t$0YeK7l%H;pW~qKj8zUo%$7~k%*AIPrk7BeM}Kmhi)0`t{g$Gr>~1<
z%kl(gUp><&NH{5*d8tU<@d4En;ofzwPN)WV?jvkIQ1eH7KQ<D6;17S{hAtURY40Dp
zWR*k>B!|ghJW={4_hX7Ms63?6aXMb-j{aByDYqb_*jeN7(7b**>(k7wpAj0AiIbBE
z%CB@zK9sjBXXNhlpuc<<yIz(>Hl>Yw9|HM+qbB?GvZys#3R=l{J9ZW}cp~=DCylHp
zPGgQO3*D>b7mTJ=kiEpjQ^LcgV4W7MP=;<kMNcj>fNEYr<}_ly8u<KY7R9=%MH~-a
z&me8a+CBwX;$cjioz_*57%)>1Kh^8V+z&|)=?@QSYaX>%_lxaE8$46})xu2hDFgKY
zA53p52`e#68BjaM0fimauZx5dXG521bOzF9Bdro_kHpYkvTf*ZdR4B|UI!pPaDl2$
zyNgDE#KKS20!CY*HoWC5j+w%=wYpfc&o~@A{K7m7%=7~@vn{)!T~RWB;St-0_iRw_
zgOP1q;B(7laZ|h?EDDJiUr|4-Do4?@`qW->kTAL-Lwp4CGEjZAMbEy8WKyby6JJ(|
ztD(u~c%5~Ylev(qqQ9Iko|BPK|D-9134x46vsY)bSI68Fs;NpJGiqW(6Q*Ge`WhsQ
z&-Y<Z-Uq>Y^7r5@A?A}m+|(cBvp#eFU{NKibCK1en1=eRgp*Ksmr$K*5DD2=-+4i!
z<u-TI(yVsxGv}E?wg6M2c1%z1xNeGl+=*4nRNkhx-N|%kG+8$xiE$ymv6Si4S#H`4
z`Qn^?U;bVRZ)d~&ykm7mWoTE8DK1<QrB?Y&DF%g4xi2+c{OoYJqPnl(Sg-W3y!5JF
zTh(JIl-<mtrzV~uF3)WB;KaI&(A#;rdsn&Fa1{Bb+@h9W?(6Rb_U8rSO3ITptApJ}
zudSs@$LPIlrv$b~J?+iw?8JKNi2}44@Y2FPu97M#C8Etvmq_nl_Gt9P7EXzmEVeZ2
z)FrqpA5IiRQ%Y5kF-+lT!H8yCiD18{(nN}fJV-Oz9l7Xl^FOa%y~<d#%=ut+s{woV
zc2MoCi!bD+O2I{)mbaKYq^U8}C)ets&V#E&i>f#BU3N+pM9KPZ%*b*zDV>Oq_Kk_`
zOQS{vT`WBO5jFXOaxF#=pc%QXdxnx$Uk5gZevO})xWxWkhQ%l1n>`-qAB&6DaZ_KK
z;Z}IzxU~=gJYS^adZ$W;1Xij2UOpktJjE6Np*iyPrp4vq(Dj2s#d+tr537UEtv_uz
zWYX6A{u-?4(l?(hb?Jv+S2dII%Fbs;@J^y83zXVyUv($fi74=9{6c#HtQv?Ne>sUf
zU}TOlL~!3DRM#}K5E!XkliJC=`Jk1CZKx#47g=f0*0&K+dO5vYWL-^?rq$Fu6$H9`
zBzCJr{0*xY?eK95=V789fvJjW;`NrFnM^I?x}hhq%h&@$lByO?ro9#IpE`Uy{Pkg{
zTl8kKf$r^F;jR?j+Utx30SQ4jQg6;qV+JnXrg5S`Co8?ae6v||s9hXk;bhE?h_i)2
zTIG~#DXtQ8!<$%Vv}}ZXG&Kr+y$YUG3_hM)!SgQCM9F@gyB~vks9pEF?yTqClsv~k
zUhWys8f^0myC_$U$dU<Hen7gIb(qLa5aK7&oVS~SpR$i?=5q6<ntCQURuud#Mi?GJ
zAm_>(gS}smN{?_-M;Qj6el^S=?<1ktU?w#A`0=cxJJvS!lFR!vt)h5OGDM?Cb5?<+
zhT90!5nd*^q^VdtP)A6E@>FOqSJ8ZJ?@NJNQZLacFWE?6AS%Qsh08vINXNxLV?k}~
zx(eSxbS?3^+yYAE-rSkWGZGV@52c}u7(O`=DUl-{v=gvjdeQ#E9M}LaF$8g%^V<pd
z7_oMin&$N99=0At$oX>~OW|lDHFr7h(?}!Rnz$Q}<{UC|vZ7v?N3#XA+li@~xn9K4
z&E3uTJi4I1#eMo>?)lUU_3vT$nBz=+sWh!<*r~f$Ey5Bd9BTQm{Q4z;jqoVhU+aJS
z$a;jTM}b);+T2B~Xmesphk}5u{(C5oy~JS0nN&fB3=!S(<Vl@7lzrUngiJAhi@oQN
z9{r`TXmHQ%K|ix;j52dUHir<fz&r(Rt3BQ(l^XeNc*YOp_IDD-@Cdc?gv*U_85)%x
zd8&d%a5Z6#>ytMD9BP59O_VXpi3~01mxx98exMX$V|jI6ODAIb#!x&<e1P}R57a5+
zk|wW0F^k5idXlz>pLZMjSJ#QJZB%<7`T!+NWKa@O)+CuL#51qJ&+0NW84?R66~MSe
zd~n^B`Hj=qt3)W0;h924f*BSv1j6>dYzfKI&qKqfm)7#Zf_f5s((&AVt(34y0%Dy9
zbvi4EukK>0dJs_PtKfsJ(9BaKotSnxxQ+4<B8Wye*D|FTohuaiqOKZKrLtxq?<<by
z3ENs22HWl)OrD(!zcvc-0dm3<l&j|{3J?9jqUON6LfCTLl0af?hGqEna3yhLjEc|m
zn>sY9rNrs^bcqm_*{>a&(xFAA*MT`&>^y@B@ONNkCCOeU?i``WUZQLv&}kn?q30Cw
z#}QHegsH;%qI!S9ES7fq=IcG$Je2+v=IYn9wS&ObpSp*n%KKoORY+A$ApI~ykCO65
zg1k<r>b6~ZK1%vi_h8oi{-o~PeQ$*KxNFR?b3T;n47@eEAWm~E!-3^uyp{|I#fZt#
z{jyP<lD}6y`*@GGVh_Cx#AF;7H<vginHsT+MBce+W4r?1*+L=G2=@@f-lswoL2Cg`
zhR_qy;zSLBgW7CRGAYP=fE1-Vhv-(@9|!#<mQ6)yHBGDDT`xlTGre4BQ<tIC2g)9P
zweBwiBh*_;GUdjmk$&om7**%@2p;?2ik9K%en@CkVDvg?6i0svfuu{?;?YA<Ze^n$
zQcdcfb}2OTrM`!L&R`|XN*f#bZoydc4m!NpwW@OW+?O)LhYCpvnie38Fp=Y!uFCry
zBB89wuhtb5^h8CdJar7<miujVvGVp&lxOW$GfkV0Pu*kAzWB$JO8%c&RHE+Pg%j>^
z=SGBCG~vQJP2ndC3qO?K-N5r-Zx;N3!zg6tEDs9jnOj>gHcb_MX8&v~Ml8nuEiIVN
znB7a=>amUU;2O@i_(Yd<fYMySN9qFkDZ~d0Dm$>qCJ@qYT>65It`*WCh=lMaQ_hFB
z6@tZbu8FZ$NojI$zihJ|(c-wbtIB7S;Ku8xsdpxXBJ0b8)gSwTgvjL>Y=9o!MUn{b
zyFF^a1#srr3WOb5T@`r!o7?1!B^(cc+)*XA7tva>quH$y50at?ask48mP*vjl^LMD
z60-cGS{YN1SXC*&l$6O*A#@)*U?QHs&n$M&)FVWuEm)J554?A$)CM3;9HZ)VTvY*&
zC50k>8W?Qos^*Bnvz|1<ht}if{+T5;_PJ``DBd(?rF->>t{~*jK2)(U)K{Tab#>Dj
z!i@pz!!6!4Uy4~~d>-PJJ5aN%fF#kcW0V!Nt)yT-5U=*8oFOWf!9#^0L9pEPxx;GM
zcXMRoj(&TUw4k72AEP{tq|A3-GI!@}eqZ^`-?-L14#c5sy2UWEjqY6bP<zAcG&MXQ
zdq9n2?okr9=A#yH)0OC|vepa$-522hILsp@92#g4|FlRx;YA#=YT@1ducDZc5y^<a
zcB?&>cG73;QoJ@!g*}QnYDscW4VU<k1S09&g3rbo?NH#Q*Bsv0?#f%A8?vwUN9PLb
zk3-@ZYkOVcv?|S=0fWj+TPNK3Gj?tM?>6wYXWK!qu6Jy<)cq9-q*X&N|GA=dg7v32
z0}S%EI9x1~i4U;+5kKkT>ID<ncg4&;)6TZtZ7z}_q`nlb%qod?M)`J$u0D;Z+1q5e
zH{{)r-G}mR5q;AWA+Bix)L_h%edsm0YUc+~IFTS`k{n+aujb+h_Q)o6hwM0gDnz!F
zBc$2|A>Qc_igU`qT<xjldM_F4kVjG@{5NaE&#Ev1?f4DRLW7&nrzWgw)f9)S<c#6Q
zf~4p+C%^C6Pfy4yTiY*C%Qi0-o>9<i<@OC<dJ0QML%C*%l6B1^v7)9JYD5yVh?~Ps
zwXM3khELlQIuId#+J;S`z1Wh`N=pVJ9xn#8<xSwRguglLEhrQ%M9hc8u<^CX5{tZ^
zr4weOjs=I@6GSM{{>*jyGbOaI>1P8USK-WRtwtm4l|n%mQ+)G`$VrlSNn1(Q=ytl>
z9Am797VaMU)-Wf&*+S4KsHQ6h<Q;~kMC0yC+avFT1D&~qmW=(=>TcJb_c6B}znZ<p
z$dnI0YVBtT&(Mcdv?tD7eEq(NFuTMs;8Tk;dNdpLA|n@s>O#MpSDp`2K<dR2?lo3#
zEhjV%F$^jK-=n)i%c~WATMd#6E#Ops&*csL4r~uCfT2OK9F(+W1StZh=T@%!eN=^X
zd=M;?n0ODjzV`kFQ|e%%wuRaaO>hsy?<!-&nw=Y^K$nVfcW!<g2!O2VZb0y)0v*#c
zzU|KtW4@K~T!Ar22z)?#px0Hh#v7vXSK5K=!8xAXF&Y6mxJ!9Xjf!E;Zkd0jJcl^R
zv=jSx`OlljC{ObeGTiv*ZW{lLVf9?Cs{NFw1Z9$FQG|O1HM;}uY5{*|KCw$b<N|mE
z9`m92z~p^=-$Ga6hb>Lap((&;A=Ceq|I%dWmqnL>itr~dD`!y|Ow`Ev#`|c{|Bf)R
zP22n`eb|6X=TZasx=g+30&3?=OOs*}f8{gEZJ5@0@J3C5ejiBRpY8{-qvCJ#9)#T?
zraoWnaPCiW)G<?<iU-y|1e<b2?X$Xa=nwrvytZydm&;=b=X~Pabs@-S350un_Ve2{
zlQ0<@dZs@Jq%GH^a$k(uIN#cW>pUOHV~8MRGPUWXdXM_`Og2Cpu(iulz;$!Soa+D=
ztBj_#b#JJWv;V>>V_4)0$bR(#(`#EWs#Qk-X1}9Fe@QACecbbPZ`DiS>nR2VV%CxD
zeZ71QCTI#HqM6|6t|!yw(+}yu^<frbCm&M)4CL&^<Jiem*@Mr^!Nkad>@=+d?Cz73
zwKW1sUaK5cL81RR3xN6;(phdvT=c1Q6W4KBc4CaAXvn}9D@)?>A^8pW=W_PKZokah
z-j#+Sq%?JQk5X^fnL6_M0Cw}mz|#o!#@2;2zwx#_X$vSQ_-lPKW!i~b?Y{0@9EqrP
zdB_L^<>}?(;p;IXx4o?!IHS{QC_od7biy8&U9sxyXoj6N$rv*Ppc*Fcla3#<Ir*jB
z!S!<HdT2Pq_>N-v%k%X~%KcojyN~(MeAGcia2#6~T1x`IEWEK!qFw9;QB>M0j@&_;
z^$|xOQ}4O<F%4w%1LCL175N!=S?h_Ui;EJ)EzJ~`!KIH`1>G~%1_hIOhcR6jX5)f;
zWBIpPP6a9&uH_$@U8=+Jhuyg3Y)xyNpCLj#G8v9KzR!~2@80}Y{H@07`%Vx+JWpP!
zKYb=ygC*Wt;6NE0_3~{rrDQ=Cao-#j5NU{CAnTRNRSFz;_x49@BAFW=q*)X}d_YmD
z|NfQlr|Tw(qf_E8nEUr;*oy5(V(<X+6BR4*$u2D@wYOc;gtC)agu;7LH*$!V5JE|c
z#0e42gvJTS+D<c#j!jR%bW$aBbo$!yt3h3eWr4~@({e%0#ZhW|ul&P|1ox;VeCY1t
zZ@=TmDtf^U|7fC#-8IpAQZy1A8%byL_xO?!AikyR$Nk+Xd;RZ^IA^a^a1<`^ajV_M
zY{^Co$LU64<dPMJF9SK(*Tr&LJ`=;`?;2H;-d8%HZM9fNpY7yqTeCExEoYk2ItekM
z0={w+E`^Wt+MZ;NcM3*}&}Z^eW{17SQkau$1J7UrK4iStb1U?Q8v=1W>&bPFT{Q-E
zn6gWxTxuP+(!Ar0n?k#>7IM1hf<7-l5<}YBGQa7}I>9D~VuXhtR@f?>sdZt81!N&X
zAgP_|SB*EVbn+XLNW>8qtfETXJ`f><z}oG;nfO}i$JLd#AGj{(QtaEMv4w{aAcC{`
z1#1%(lHrx8q7MgjmwC<Yp2=@O5D`$GvfGTL@LP9eW(+B2s?Uy|h^ehgVnFt3NB4ph
z7vzY8ZaO8Fcpo)HI{3fHSm@m&XkYq}g@lIeaDU|Ym?Dhf$}v3eSoQ=p+=PC6f(!zA
z=Nz6SA`veesU-HMo~uOCU*5VaFiimSk<U~*B=c9?PHN@N=Q1Rhl4cWy+7WuOY$S+J
zJw0#L?nptdXto5~UJRS4DmSE@rZw-CvhwPV2g7i)&IrWW;p^aQ4jCmty1a&MlDW?5
zYEdOO&He^`ZWth#k06fji1^or<(1-?kfaOYA;w>2w0vvg8czVS5QxsZ2xjkZ%Re5;
zAJD3_=$g-H0YLI#iR|s@rBbUFIe9+ep(V=`>a#DFEMM*@>{G8e8=grL=8T(+7tQpn
zH$M~qi@pLF!FmC>OlP|)u6LR|d$>EdCYoLQcHQpi1^n|1wGrU0(!w<Z)FcFma@~@I
zhr+Of^EsK>zE}b#{0Witi}@>DX65xz_ciB^e|hyvguX=u(x76ezjn}1f)h*p9=_;C
zaVr<?e|6(9y7ZV2(LrQjTA3ecPI6v!y-h!B%jzwSnNK2fikCb&>OKU5_2bZqx%XBt
zCGR-z(fBVNycv8orR1L(5<c2_;c4C#@;>q^RzFWRYiPN$b3bG~GhE6du6)w|3|$f|
z%pX;~`SrWVmS{Hh!vs9rL6~Uv_;Zw}-uv+82ROQd(Uc7o#;appvT|P|kKagbH#M!Q
z$t>InR9nPR@W<SOl;085+;*6u!SO4X<1JQ_W{gx#eZbg(yyS(jKhB7xXk*J0C7Bcp
zkTVBb8{%xcALZs}3_TOCZLaLWsQ7(E0G!ndZI8fZo9a(_8p>JSFzKchzD&mVZ`_`n
zf@Fs*{P`|oBA4{3Hv))S=b01biq5ZFpJfd3aDH1%;E4H4e(aO@Y_?;9Gx%dTJ2(pk
zHf1JtA4hBBzcux}NBe6+{4NJsR%I;N$TmAPJOY`qhpFjhAy37J=dJcKiSG4mPZ{W*
zgMysag72tWA)JwpuMyhvqvb|X$*s7~KHMZyU)loXTxPwI1ET&oCq-#XI37WW4|Eii
zp>yF9vN*&z?5)qW;KMIh$$?Tq(snCa+!?+5S>!itoA$zYT{82Ir)*RCvV=macXWf>
zdlA2+-@JRMFk-<72!o3#r!T9Ct@?IWtkfb|X}bbLvi7Ov*>MuSY4DS1Pyq1|;ybuN
z%BJ>yjGM}Gy;3Hw1(@X5;q}(>;zlzo@XO_@5#LR+pE^rISp0)=Qi)#vG@%fk0AQe7
zxfDGtPHV1kM=2=zUh$sn5?6i_a)E%l!g<&t6VK(K3$S024wELPFWu5<>zgBwr{3W@
zhvV_&1UeGsgAKP$6hsh3r3ppa1<LvOhFmAz+$=W1v17gD_0JNSQmFn=ExE_*a3ZKS
zpEy3!LDA6eW)Q>B{!8Ssx{a~9Eku3d#W(?*sahWG64cogd&w#9qN5t^kQ)8v^-5y<
zp5<$*ZAi*(ul4RUL+7J;;N#ZlxSDU44<$sigR-68)~(`7#)&<AM-iT>!S*JqJ%jxA
z6!W3qJBnW%NS{pAlhEFGO;FM5pB@~O0f=I;BNq*~jxSXv5O@u^`6ubh3-cWAOp+^)
zK<DJOj{Jsvye7%`m6iMk`{L^=`9xBUi1M7vovJQBl}|=T`)gIfheRXmrgvHDd6b6j
zEo{vFuv->GlC$%dB%cxW2Tm-&5H!4k?)&UW>SLU6I_^dxCAURb3Ys;$pi=#rrtuI+
zz!{?rMMgg2Q_9vnekmOfW6Z4@qmtqx-KHK4qG{bPMeLaTszKF&6BKz&V}8A?ZC^~4
z82Jayg2g^fw|G`g5$Q&YJn#0zxF2!)Lru8_37%*cR#Oy*gnHv<zv@0&-uqJOCY<@w
zIM~i2NL=k!6d@4yybE?UCaag5Wrj0+TEoO@Nc;K^Iq?rauaex@6fH8~MO&eTmU#Cx
z1eTeQZOqvd4ebtdX_WF<H0=&BJi?7uWUBa-TsrylD_>A^JaY2qzFH72eaGyG_ja9U
zl;6-&40>Ssgy_!V_@Hz3T_;?0%|@r)j4}o@ZiTstusjXOa?f{w#jB^V@f;?s744J`
zF+5u7w0&6Y>_r+NW*WDCv7y*oaZR_5@iJ%!IW)WF_l%=kQ{FMQ>6v4Zz`MUJ`*$6c
z6g5r}B{$J6-~0ZEm*k;uZLQQUIj2?#J`Eb+O<c;N$31}tJr;>68ABcGyf0H7>JaDR
z<XxhbB!J?HAYS%PslSnggkRY~6!;7$cUt!P*uO+z@|h0f`2{ObNzdKj`eiryjX9dh
zgY+EN3L@9hVR;JUx8k8Wb(colyhGd<7+frpJ@5KU;F6DCb&#GDp*)?UwZ-k5v2zYC
zeD|h)6o<cVyzz}x(H-07kqX=nE3bMgPD8roh+hpSOvx*`RTEu}n>aA7+kbF;_Jk7}
zRwqUhX7BhW+}woVss{So`$dfMlF8W^CY$Ur3HnR6Smn>JjIWRi3eY6wLQL4wuiymB
zKKwqwKr0E^#t~iV7HJ$MoIRT~EcQMUR#Xa!JT}WGR_W?{F}0SkSsnIu-}JZ`BkVw?
zN^Tq_w3qF?ysV>^kVm`F^IJkpI?=7rm8L*CM8w>^&*IVs7Md|MO?6hku-Ngp@x)E)
zyf$f!qxRsAr>*yD0{Yu4;CG}jm@}>%q4=gM`$pL|!YZ`RTut@tRYjQRu1A|LOAUc8
z0bj>ysl(BH2PIH<+8J}5SY%I+6->=`LPQTw8==f~j(842CQ47i(DJV+8!)H`Ii(hw
zT66<P@%fGLNm5wjT5sLjNCNZLN;i8${Ps=7it)+hOMKA3hqDwmkCPzb;HLKRUT77^
zA^5Z^*je=C<3@0PyM&T$=!Ml&Y8@?pmD|H;9WHl6myNT~z!|h}{NggHYc)AOQ((Oe
zYOO5JZif-{7u28qV$8laeeX3t-M=|l``s{3R?Wq(Lh8W-jS&maXYSzmyri%)^2koq
zZ^Ct?aVfnDUI{b`t01cnz7c#G)tk_v#bD_3>UnA(9j^zCac-o;PFIDVLqC32h*z<W
zst@zEzx=JXT`Z_Nh@I*u+Se5E-&~8UEO6j5YCx-wB^+XV-r@>qY8P#bA>7_zoZT)&
zn;nLo8%$DsH3wxSVez?$y`b!>&@Hcq$m4ZcPOeI?KKSiJvJGW=O#%AG>8Fz>cw8R_
zEzG9cDNkOX)lA(6U;CeVdq7Kd<ll^59|XAfN=pv#qj-I18o+ALeyu(0Cg-IF?0ROK
zgLD7*qUFh5K!f;z+09>hteZL{0?l2A*|t-$1}{GJZK)qM+@<UEXGX3d&ATJH`r5!L
z`(VTedWSuIzo*<HG_a526sp({cD3yp#Q$NXIvhPVl1r|oUmaAW&xOI+J2;=jXlH+S
zWK~wlU#G=7)}%LnV->Vc>+uQkLDZv_9XI2(CmBPDKWd(hufSHE-9cv7)~*=szU{Ap
zYa9#$OU9bHFJ}+NXuy{DagxeP6Try<WX_dNBe_n`YkJ_x-cMT6c6!ENw3K4@;m6Ju
zFDUyn*Gv5|89W^uI<g+zYD)Dl@*NLP>|b!rYb)V<p5<(f^n*<e9DYlZB1X%O5rEUq
zd%aH=k@E5~-6Ob*zovKFLbuNFV}Xm^EZL98orIw`bn1&HwjCfL?U9FuG|Ug9BJT5!
zqM`3PR*np}grt0DrfJ3M&vaY0a-Vk?lqcJ$po9(HtX#@7{)sYEJGJ2<o-jLLW8z^X
zlX@TWj=Nv8I^)3i;{aJaMz%#tl=Vwq<shKHL=-OXx!sJDgzoACanAWD*|Zj*k?|+A
zCwUhelPXKg(<G<lby!_l^zer!tQ`HcG}SJ7h62z9x3>LacPF|~`k3fe7(qPkwVI2`
z+-Z>L^O0nt$>ow=)`u1HcNs<=&rh|ai?-Ktk}1H&6TRPy3;5MZNwyIyuLZ3OwNmUx
z7sd2TTev>gTM?ycF$JI?ld&f|9ReT$;bUB>h<Z+p{f9PvvCiA)619aP8gJ@pso0^%
z9+M{6(b@!ZyMxy+Vn8E%etzyc#dwQ+Q1Kie<*6_9r*AC>3BD7gKkfaJJIDQRNG`x<
zoV{gf7HHB>$U82hntf85Le}N$81=J4=RIC=A}!b!_sS2e@d{9$Sa8PCMaENBfK77o
zQRqylU0Ls3OIMytiGoZ4d7iC~jM{qIuW@HD<ZZ+zH&uPdPR0<ufzFA?Mqf7I_q>9A
z_-k0BkR6XG=HeYBqTF1IvA8a$4mGk3D*qKA$ok)-*`<__cXCib+kmG@->hq}H)H5Y
z5Wl(koP?6wPo)>|7+Ppc5e^?JVwAc~_p3ei>itjaLRDDDD5@h|G4m>Q*=m)wGfVF^
zg@+8jNAK>kk6TokJyBWj9Hl~oKyKdgl{_JtU7&kSMm47^O>h&()g1ig_-!7s%I)HG
za!|_?J~YHo^`s@28+G=xFY7{Vk3j_{eN%V0&)J!emafV4`lkW60ELt~QL6!S52%Gh
zAWgRTseH{YMT>N}(N<+Yvu6%d+6ZYWn^+2_qpo%t`yS|}hEWXUy>RX06wl8+3ndoi
z0edeAlMqmId;_8(KEjBnBW8{FgaV-YPN(-Eq|33;9lnzd9Qlp7&m5BD{ZY%UZcU(L
zY6ojBF?9c!x`99UPWEQ;3)efYTX1@b4OdklQjm*eH@Teo3RQk%+|h-N@#h}ueiFm^
zC=45%(~Y}X>$e}nxYM9%`lWlwGh%qkwUxS)H>b=wZ$l)G8L)nV{$)o|8|X9wT8blx
z3xY~Oqve?~zA?IFJhWYl@0R&RMZS)rSJ%|~_z41Jpl;id87JEtgyS{vcI=(N;J2lp
z3-G+*M!P(mG}#v!626dKYi%2*r_@{_qL}2MxZ+#V`4zso+VFh$G1&%({YciF^~7)a
z+tAm_WvT6;39?V2%vEO*z4WO}t0cN4)jWS(R>=*Q2z7j|k)xAwH_8{%r?B>YT2rSV
zq_4*``k>i^48nVtrH&x6>|9ayhRiEze~aVc%Yv+1k4+5$MqoQAB^8LoIt0FrDke}<
zYH>^}{Ax7*^ad+hn_W&;yf2CD5mQ7KrkQq*!6_CvJ12%o4$6RSdTaUYskes(dB>+G
zmyfLBY49<f#M_#Jan1$MPYR^xTw0Fi5qo}O7Gn9?W0<F6kb$zvtRVB{-mFIG7&?yv
z;ncfFo_lxPDVI1V^#dh!wm3Mq_4IvU*shCDv}T{_Eam=`!zZ5e+Qzs;GcTOZ4PugY
zzW-}j2M+QY)yla8l^YEuH+H4$^~5zh7~w|W6tx@9d5XIF{G~<x(#h5cITQb5L=@GP
zh&b)M=*zx{2om~pu@Q&?H@rbo(_Mh^_N3n)CzkaUB4l32RRh)sBilw79GvZtaBPtQ
zAy5+Pcxv(}?6&LX?E(QfBr1VZd)H!KtN%9MAImE{IE?%Ol+6a71m!xMu1W@kYm#jk
zWjgBbxxUhqyjA6GpjnDZ?!PpELLmG2%6vB~2H71o!QFCCPdxzg8AFA+E^lj_yib2x
z{WRBB(1K><3MIRoGB97sF^|J@3V!Nq^P*Crzx0!q?dsyv*gc`KBHI9mvF<l%vl1}e
zs(K8!{S+Y5-i(MvfV8G6)gCPe)q>Nq0a-ow6o=L?a=wWR4>e_RhlalI?R3p|--sZo
zXn?*{2!}6!Vg1eJU6kPY=9mEibgt(s1&pt*8dC6L=XleHdy`Y6Uresi7e?1RbSP@#
zftP%|?eU?hs=Ts}JRtjSUy8AI)v5V_A$gXPJD=sb!N*mJ`Wn;nF&{=__G+pFQ^NWe
zt~XrAP3vliIG}ND>iJ8;9FrLUFWl(7E&c`QQM>42u=K&PrFkdf=N<0dvb)`v$NWH(
z-AscibYcu)EvdWqyD{#EuzC)7%XsY0rP2!N5G2RY!k)3N)IyxIKSIjEJxs?MoKlC3
z457N;&XU%zhy~9EWJNTdAH<-b4)vek7PE_;Tw9NSTDrIrcXA`2dAxK4l(N-&+dWQg
zEBoi!S8__ejGNICFU-|aceOWey?F&k^Y_-;9tQ5eHt&e4u`>Ad@Y+%R-N<M4&pVT+
zQSMvhC&#53#`hn2fUXLtN7~m)b7|NKzo{4En43Hr&FZA`Qun?Z>`%R|fUCIcFgoI1
z(t={QVX14g3mjCs%KeEk<(|>eHQ{}ZZXDW!b$eFp>`FC-G=Eu@)+w%kD~6dZRZw8K
z>rm?T^VQmBMebBXvy0#979T%?I2OI#YVVxK*+`E-1)=3sZjgpP)oIGvV*RsjO|e_m
zmJ#Liljd;_B9Bu0B|S@UvO9LB#|-`0KL8x0VhLGW?r`S(x*y9`9vgZ6L*BkpyJg5#
zeL|Voyd%aljqOTsBZt#4=I2OOL-s{>;Af7U&!L}!87ckcj~&t_8DD1`Wz**l$7Tx9
zU5yw1<jSB%e-HW*<Iv(V!Xj-ek2$VwI<D2l??*GZbvFvu^G`Z3ygWU(Ze|s|z0ZzI
ztzjfE9cx+5JU3fNU%=M2lhl>lO^q?r8F^OR+a#34M@&-=Hc^ARR?#++!lIdP%smWM
zg+H+O(WIUoX|$=hwT&xJs@UHCTG@L)+C-PDU8eeQS9yoy5T#a0yu`&nWLMz^-)o^p
zyLfw)Gvm@&@4~%{-RoP0{i&-h=E$!>{~npuk8~V)lSeHX)L*(0w7g>6k9kx~=jv+D
zmpN7I;K$!W%wIiYOZz-2$57AS3=<i(QoGr^4)KataWCCJRpIH+Lfz<!Q?4C$G>O^j
zuQViJ{PklsXZgLIOOat1i)!X_8O<c&i?0j{vpV-(;2pK^VIKw4-9{?NyX5oYa3!Gu
z1)1-9yWUlLDfet=P-9@*X=)~|6M#w^Fbq85|9zeAju8JJzBT9vdNo3%w6vx_LvS;4
z2SPLce7=AG4!b=Y$yeO?^C2K0u&UKKcKF^|G1KgM<#lt(ZaPHy>d%Latj%z74WGTz
zbT|i<*hTOd$4jqTJ(1mfEJG|5k5Qcs%%r2EBftAB*1`?g2*ohbQe6*z;>R<nEl#uJ
zGpdhNo2$S|T+_9i+*VdsFL}hQ4b^V1U~qoRsVc#%#4pLoH)k#In;;S|EYJrzMBIuO
z(`6wHV^pug;tQDLO78PV#oV21x|+6b(W<r5a&oF!4`v%G)~E$HJX?JbBqhNaYM}uh
zhxN#HY!C6c6{Fq+EvHGS=hf-XRJD1gc$lFY9v@B>){`eoN9;?Bi)`o5dlX03GBPub
z`%^qmMpZ(Ivl{nW;J1A|d%wH8@47MQAXp$`z>`wH`%KAj&QeMarSQ3rfmQ8Rx_c8j
z3k&GnxLejo@`nX(4<dy8?}45a8YxwbDL|+_2y<_`*4oUhVBHpiX5aN9{&%WC3m{+y
zDy{YE@2~v=@WvEp4J1TRiV(^d33~LL+u;ifw0ogF2%lN|x($^iiQDn*@jHG4j>J^g
z)vx!TP<_0EZfa_pDG|}U5cq838R7t!TAX#mPR&}1d!Jc#NXiPYtE=l1YFW){vslo_
zQwoUDCHuy1J?C+Gyy1SjeX*Vyaqq!XQa2)!H`3CYH5LRr_~(l7+nezswL9K+#ZV7>
zAtZ->`s8uc%c<jau_9>R0yfcdeb{5#A~+AuMBqGq5J+G0ZE-0=;C4AiZfIyoG(yoG
zP`~hfasBa-lo%!=@&^vfDF&_j;}|*qjgkDAbv4Mx__(+ltJ(S}3W*RvX4j+DhtD{+
z&kvUF8i9P^+`?Oc1gFKs{$^n*6*YBeO7<@Xyq@m?7>R7A<Zf7kjagY)Us;W<rm9Tm
zTYW+23=7MuZY6HCPz80$RdUDaYNFgAS0-`Qfm^H}v6UViydd;%v)L-H-JK|3ijp8M
zpR~y6$oB<gDgoRE9Z%%SNefKA<ALz!Jio%88Nb|@K=(1MoYZ#Tsh+Gf4hjee2DEH&
z+Swd0g&nT+fL*2CbFuUtz#%5SjqtuU08+&{>!A3qF>n{Om3C@j;8?XFC0KJQjMHkm
z1_-q&Ha2!f2S8N4+N|2`WHZsaS?!o~rRnB$S|sp6S7+y)oG0A((}#?x-&~%o^(8j|
zk!8}V2WQ3!0dc>rV?&}86ctrUG`Xzj8t*+M1Pw^Rv~RbUTjRwV<29BVgZ@dm-@cs#
zdG%P1k|25%1PDFy6yzOy(Naum<@!IryfP5QRLJM|1l%8%IL7gLsny^Fek|u(<WU4!
z-xr?5s%X0cPPezWi}l;309`rRgLzL@K=0Th1^TaklNKpJ%RdpY{x+&ySEI8T*K!Uf
zM!+%}$&=UdI6xWaMBL9^?M?IsKx${564!;g-QhQ9s1FGp_UDD}`ow^_4u;=9+?R@H
z3X6!q=j(L+ZDil#bpzg6K+}EsG)FG=_SZ9O<f#*01T+Vrg{2y`B|sT6P`TtxO*gV6
zV{)XwD!hMB1$vE+!U%!Q$2-%`C!3=Pj%@PdC0Y~|6rlTU!bnc8-{yyc$$y>(q#hYP
z^ylG>eLth-x0iHuZ;u()CR@DWt-eSC*ZU#>r+tvEJLCd!hXE-cNEZ>qJmlfO4S2*3
z<gc)_nUKQ*WN;AV5b-d=V%2i}#UH_UD!Vb1jfDD0T22n14-EoKgNQ@`V>jph$7HF-
zK?f_}0E2+fhnSXMqSa8MR+$5+3CM^=6Zn9j0$9_&WS&ssW!^_YOSe~hsjqGIZEec|
z!_Gee<LvWNF;`YbM#gi$4OLkg_qDjbenzW<pn+Ds!^L)GzXb;%ECd<IEH7ZC`(Bd@
z5Txh)9xm7C2SBT_0YW615RvgaNv@rSpOkvv-)>F1#=DG4NT_!?(4S)Vfw7qk%mXpq
z9n1^@Ou7P4?+B}^3f|#>G<Pr!3^V|^XTGS!Sg!?zh5f+ltP2YZq4><J&q*LH8?YAm
z<;fOO@lCyENe8j}_UW{B?hRsk2sjRJ3Z%=a;ikBD?r}8nmw2js9zD7*8-bYmI%z$D
z2tN(`B|+lJCfN7Gw&eHk-_uqNmO$3;TI>=Yh!5UGQ{JozzybW0by}ZDcE?SnzKaKf
z(OJvO%g~-UzQaxm-!ZQi0Ii3)CFvC71Mi<x1C%|7-ta3};KOI2wT>nPtox!{3&`6x
zhjaS@6|Rmqn$#FU#pJL53qau(dE~;I;(dFRT03J0%0<n0ga=Krb1e^#Yd;i>qW6XC
zLOzj0)#l@Bl}6z02_M~i{tM|r#Fxjza!5O(kX+ehAQlrzT=qY-A0zr0fwK)d+|Ik#
zzghb~rXZp{2i8op$^?6l9)UYPGP2CDD;kIw!2{ouZu{N@b|49}70^(?Llf#UuZIZV
zXI<Bl{qH>lCqb~#AKYsP7$EKp6GI5M1~WUrp8lBV$RnDNL%^mvm!&Z9e{z7$O9Lk+
z-pxrdH~nyY>s$Yf-AoA(5{SRxQ?<Cgy0w&*p7`-n9UUO=T=uKKKVnm8yRP7h$&2<Q
z3Yvo#0~!Hg1TNPzf%WrC>@{*<45kK3DEQ^uw{O6S^W7W|i)YH;Da$uo16Z>sr{xqS
zkPVP9`=U#y@NzLS${gbeVkPpr+NF7}A_=l4^ElrEF$j7<Ko01eS8%x)%B<}?>uB7U
zgw2Nm(E~?JP^77b0pEyB;%Sim#O&-2Z_Z%M;2;5FX9cg`_YbAbmj&{f;u*$Va<a00
zC*wNs>!W^mUgE(@2o|VVDiujY5ChW)j>}_x&XGyPBPIq`7NQ;+9-boLeftli)K>}I
z35ZxqG-_qRNsb?x5TsbQ?edOutfzVTRaI3QR&`?FP)yZWx=0XUu(o|K`<*_I6{!Ii
zE#SEM`HybJtRwgd%F4<{5c7%3rDKR^zM`e2WoNGjP93=W=EH9K%!~}=zTqbKv%9r)
zTD0dM@Gl&=xSj1Xx}kqmQBYXiLsN@O^*mK8kH2J~p;4_i8)a^}wgaxdsHkXrdwXa|
z!S|@OwxY69EW+o|P>q<!X&dYTaVG<IadF`c^E~U0r3a3N)aRW~;hJ6DBcj)&Zs<*K
z<mBK-aE;<I;C1zvJEK&z9AmpESL-e(3?eKi%7m1a$u^oZ3h4UvObqUPWBBv3=^dcA
zx4@NhSkG<S)qVI4S$`)g`h&i-k;QC;X3+n0twBfl!BU5@k<s1B6kR=h6J(~K_HvJl
zLvZ(Och((PSYe}e;0b}?e-K4#Gua%;p9<n83J15GH%Cmt<ugvJtQ*7xAm_axzCtRy
zX$DFPEO+(|;x{Z1(#+4d`E$<Lw1;udeTj-n_q^=ogcW(xV11gZwT6`&NQ8;pMHRqS
z@?R{+fT)E~0*RZ`?RXuqsK#vc?J?;ZEdv7)r_~IIP?KeIfyN?}gWUgDfpQ_xk21aX
zdtvqx;Y0)`sO;eXvmCDv5>od8hd1-hmRdGx;5GgLS7I**u#P|%KK$*@o%eQuJIB}Y
z0Pk}_e8H(o-RRU*0ke_301SLH0>URx>{nt{%)X)_Q&dhCtyo27XJ;?{3Uglwz{e3A
zWWe#Elw{PX0il&LBxT$4_WA;Zr2KZvAMfOc4gKY9OVd?&bOHYas+Y0zB#NdWt)HJz
zn`q`jZe!e2b|LH$tgsLv1IZu4*z!@LBPKNE?|$G5p&&nDpLi?<p;$ME(4Jc1#0p~J
zW`&H*LY<Ahys^Uc)4#F8zSgDoAGo}CTII*=@ZV*%Uz;ORR8yM-WK6WGr;SNhJ8yCA
z<N)EL3D~?*g+l(w#ail~3~^^8@Hzc}CM`Fo7+T9199A<EKzw1>tDLyFxakd$$vz0x
zS(ZY6n?I^t((6|S!5~tmXJqVEC0fpqp1VGpGB5SKKImY@Llu=*Qcz&=IN#^l{brDx
z?1VnMf-wh-SY`zOB`}ldTF9Lb@4e)r{VILBIl2X+iY{qQdHKNzuj9<$hC)nlDIebj
z$gD9Z`|X$!L|iPaYOO}@yLD?Iiu3|-0+=eY@7&K9gK*nI0o`eW*5!i3!$TeT<v0+t
z-_kR3UWYNik%gGdMhixF8}?Fs(}0+qZjCdKTlYS!Tlw%r)@3t4_tEQlp8>Jvw8qA3
zV2hg17ejlxyM>(*?1B-bA8Aw=O8(-1kW}tmON#&8bvf$m{rZd5#MxammK+d8U2c`a
zk5b{9AT$}!YSsnZ1qA(eHs>yak6;&pAZ_)G&&|Qe>d_1^M8HHFk)qkj8_7ng);nwf
zx0>QhN*a;@G9lj62?Km>7rk|I4Y%`!AP_qXIPcC3i1{QLLSm*tjs)Vk&%SA*<hJv^
zsCPgHg;1Y=_WfLL(7`>9&9VfPI+@Gf$mrI@x<Mw9<78*L*8OaEYrGV57Nt`ekk}fi
z-dC;{6^>hD1aEwk6crRIfIl`QT`%t-?h!=)0mv>7VrdeWd0&wJyl{wTb^(M92YhST
zt?yBW_*l0?sMhY{)5GO10<<YWcGgHlF5`Z_Gil1l8?s+Ht>=J08cIfdb(a)K#!#JX
z3{yKqG4cV|A@SUCWUI7=xE?L?=z;EGTRWyek}nR@(`E&LuyisvI}$CH@!cfwWW`R6
zcWi7dFjvYTPy;{D>M<fQLxk~t2={?od#|MQ`Sa&2_Mfx^`>`NIj`jUKuI<hU0LTRd
z1jOIv9`QOUzLi`xJs>A^0kZOcwfCj*RPAlpTS9|4QAskKG8CZ<DH%h_kd&d!6%ipa
zBx4f?r^t{LcEmAd2$`pfGGr`dR*`MoGSB<H)_LCV@AH0tKK8TrTL0nx-}iN2*R@vV
zNEh+Jq@@ohDhKb6j*bdwK21Df6(T=>;Lss0_br1lPeqNd@mT@AVqtdMwkFo9u*!eU
zGOxH{T%jZPTNP;jwfW0yh^@ftV2<Py`<|$O%`lefJs5gRLsL^SGzaOAIZ>%+uT$0b
zT<azW44Jae{G6$&{LO*N+(y}Y?~1#7tV!WQ5{La>9q78A94isJp-4c|SFDttSvvjY
z%YmGFG4v~~nI)5Zit9Ou4ycM<XD{lsL^LzDPep-VEAAqiSH|<q7K=HbOX*85fAGg6
zwWMx*yE*>t4I*xnsimgmwa-Ys!$CVmPIAyqKXv!JeBx`mp|}e}jchb$rIPmX*=7~%
zhUby?V=~cNEIe|Hd0)=v`rOTvz=gM&c9(x9Z>`xGsG4AyWk!G`qOvrb=1W=CMQ}Nm
zz9}x2b=l6>#95im9TencOUfS{rG&D(;S{37G(r9DT%zT$pFI{2NE&ZUT52LOl4@?*
zcjw0*xq9lU_-7PsY5OiIm#xG-NF)!DC+a3Q-!b6ohR>oU6_0Q@9`nc-zpT_rR@$?q
z!%R~0Ni)pq<E1Tr!fbbPa0E=|Xg^k1rtrw$dEh`dC`rGY#K*cez@+#LjY_Q$d2eye
zJm+DHO2A~^VusKHW($&EX_z{{&s@5>JZc5XF-xyi3GNiaC6nnk(M1GBEip=7913pv
zJF_)U_G@ZroOJJ0?x(FUFfs4`1NR{l_mO+kq_Cp(;^+i$9jobJ_h`$j)9AcU7LcYx
z>6l5OtY;P1&?_ZVbDI?6gTMX_w3>k<K&-<@;tBRhJ3Pmo2a!~94%v$}A6-YBrRct5
z3sj}-Q!+ca#gwF80(vD<#L(YCc^i>H#LH$|n??P`TZ>)Ca0W%hvtqn@oIb@O|M@O|
zArpHXK*#*%+_?dl5U+vQKP<Kik-esIPei2($C)S`IG@It<1@b+wj#~4`v_tj@&W<^
zsI_Zf$m<cG#$<vL!otE(x`!usX577T6>k2)XE+UKqa~7z3moEuEl<8UYM)uYJc@D1
zT_*k<b~aYFA?A24_7#6VOYJM`erv~pWnv|ksplNJ`7y+Coabb!d4&%}Ecz%)Gq%<r
zJ0?f$7?YG^-zwFY=9y(yc9LWBRdjz`N3J}uqubCQMy%w7tPABZV5kbqaekL4p=afO
zS4lR>Ng`|th_LBQPf4LXx651_GpCJi95@i<&%)h>1;POLUc&$_Q_&2sO*s0FA%!BD
z8lh_q?ZE|)vF8REM#`;s<t&KnULgQ5k(s~tKi-5IhvJ8h4vpYIl4ca+!RCDXZuDLZ
zfsE6B#HdWSY~8vtH?~l-KZM|{kR2};IS-{K$6>V1*fX=+-yg=?qQ_i7p<<0>8I&UC
z8jNcPLCBN>1?El!eL}7@K{koIGn(2!JBCRjikPk=L_a>}?tZC!pKnCztR%FloNA%~
zg16vt{i+)ueB(Ocn<8zgi9q2^v>$If%vRcs9T`TxfJGxpdAHeqQVtp8{KHIH`CU?!
znXJe3AlBjG<TL|9qL$M-=7>%6%e1sK(Q<v1SDb{Ppdh|#bRs>NE?<k%qy!$j!R}l3
zcOY#=i%LI`d?;rFsL0nlGJDyP2VGfj568MMFHp&~8f16S75O(hCG=!NgOQqR@^;Nt
zl(@gT@1B}#x7MZ2^|kkHUg2fEbI&wXYY%7$u+f(G1)UE(z$tJ(kn+V*E%ktgny$q5
zB(^}Eif^kTfmuuK$>xp<M*B2Q>CTdW3LT|s2;=%H>yR_JPJ^GF=5bNt$zSW;LQhs_
zkCEGh6AowyCRpzKJ;Fgd?kv3g!_j(%x-T-VuQ2V-L~Ghx&2YOY1D~n$a{*aQYld_r
zRoxxjUQ_Sf`#h|198@?uTfzG<vFt4b3U&1P#_itI0+0_*=h{DQ!ytzokyM4^ZvTkt
zk7ZocaN?|7k&;~;=#|a0chmaWDj!B}{MrzFWND;M+oyQ9;#y>t^@q9K=wgqXK9eKH
zaw5N_bwa|-FJ=ceDX!)2cl2qGTDkFic5rxpCTiL1i(@h+xFR-9XP054cj<J-r!<=M
z2@L@in#cyfZ)f<~<UQy2O4*##)pc7_&qoaQm3ivK$$1#_#Aqa;X+XQB18{q+x4L{h
zKymfERg|e4HshMYo*K2zIrDCpZ&@wz*5mFT>84%$ir#h+4O`qC%)F|W)J~h7TWjgj
z4%wFGvr^mqh{ShlkCe^LdeMTIo9{Ox%0|ev)nT-QE5zySCg)tK4kEx1(y5Mlx??j6
zBB$iFQc!g`Lp@<lWI6}kuH`fpN2>2)Z-%=AlA3|YH~Weo4!#FRq>Elw-vv@sI<)s@
zB^?S=&HFjeg<f}F_a3M2w>~mN6S=<lN%5aotp+=H?II3mUY?Y?Y^d?H8;Q4QrOAJ7
z@q2#BI#NK4ZuY_xfhYxCm&GDvY$XLvel`SRA7b(icsYN>II!M0I$$h?ftgwP)zcKP
z4i)QjS<mg?KAH!i^QVgc#z01AO&*p3)rezuWQC}=+-B)7ag0qaTug5lcSv&`eWa_r
zPUd1IMH?C!$@;7=5_Bq2bEX-nr88$i+wmfR9B+l@<m7;l)Hg6_*Gr#p{uON<hXbaZ
zaCdK*BYh#C?ro3m?G-k?@-9#I8n{#~3H0**9aQQ?B1vBdn0|puh}N5kKYCU<<eLC=
zpx!GgWxqdi0mMucC^kOkJaR>Kmzfq<jquV@zmmzB7av}5a}}#KiY%Iy{1BsY6*G_q
zLy!?~0f`Y64Y>>GP^@S$ELg1A25pD5E0I>3o=d0y^ElrWTYT7U{M(I^D2Y)0X<L%J
zjZa;zr|Y)feL6dMoKLm1l&KV;yb<XkENoo1#1?cI_X)RBtnB$zy=^>4|AWlI$fmx#
z>QJ)(@v#JVN5x8#xri_0)WV*;A{*M>c;mrHBO&HP--ap8q9niPGEP6L<|n!<fRaa!
zErtnbilLIZ?Da4<0bS0-L;1L?(y*RP=k<LdOH4RrXR(^knH@Xad4AoyND9>v77;<B
zbzff^2BRnDeGrWTrEH<^Mfp$P`>2mjKR>nsd?8YXrY%Xd!cM1tyMb#J(&8<Nt}T}<
zSbFi51WtmD|NV*A_Y=4K*YWF3<|Aq8nMQ>-FBe}ZZ|(D>diT0^AhYL~C@>EssOol5
z=QsE6bKJ?@Auc?>N0>BNntCCb$h@E#Y_I)j&ob{v_XFVgxynA?t|K#6)^!WpHp^VE
z-IWt=V|kvv)CUev3fSh{L}kZghy~y_G&Nm=M6nLI+Bo$#)eM*v5XMU4_YA1Pw!G_K
z&W$L!)dkRbRb_IYG_1MxkSS(&@di@%{ila6P3Mx=#`C)!>MJquqgSf_8YcTH%oOSF
z0Lyq2-6{ja($r6}a~GV~mrqqQyk)g@QKjti$h2ruVNZH=Va(89>^)0bW~KvZ3d*jp
zete3h8;;w9X#>0gv!I`{L0?}VDJDkV(+!HiuP?;<0#Sib5S(ejsFvtf6(9NNoxkWA
z;LCp~-DJUODMxQ#<lhN;5h?oV4)<f-LK0N94L(268|q35l$~R*9$7NiOn7NQ`<X^&
zy(N0Oyi8Ac=ji^6qz7SIf=sMDa+rgq1ZRFNij~hwcR#Z1QT1g%I(ihSIiif6Vam~N
zWF5$V#M1pnsL_0Gx-4s(QRy`^;pO*UnHSR6xA&hY`M@f6){>?jdA>GMoaWI`N)s`j
zzSH(mUw5Bwj}5h}gtvKMYO=b)ZgJlIVZVGGiP6slJa*7lu|kXa@y__*)lc_X6_E2k
zUC@!2o@uGBuKxKc#1U*22!vl>?%oKW;SI7m?^(coyS+rjeD~3@an_E~lIrD02`R6g
zClvekc=zXe+a;LpiOe!OOq~o@jBy?+Uiy-LG&2aLDCua%YDbq0&$302j-t=>vYx)$
zwvPgCePxUxjHJXSuzx<QKY6X2aJvJM8f)_f6>ESA_Y<il)N*jc%!sBJF}#(JG~9ac
zTKBGvQZJ-B%5qa4EhIM@%UYk-Ofv1P^DUDv|FFzzwm9l2ly2Cxr)a#%TD5=CvqvnD
zQ2{RjAGcVX`kox)TnE*GNHEW(?e5HvbB-D@_LjI)G4)UzzVs?5Qr1E9H#gQijlI8B
zM9CNIf7mJ>`P$^zNP?wRr;Ot3@&4Qng%jofoMfK^o~yCt^<8y}5;Juu{O<p{Z1Mw<
zcfi;OXjEY5(6X=zbJwsPSM+liyPj93bE(MbcfQ<>Ie+^*7k_!r_B`9hTlPjY#AL0C
zH%-AzPcpUIHKA+H_SZR*k~Tq(fc^nlnAfb9e}&Q<Pn@<;ilFxMzxPNBKdC9Qi`^i7
zaG2?)?iHrYpKrB?`@EKZzPt1z+#|&C=l%=&FY1PyQc`<VFFR>-Zy}{97xdj33lxeg
zyzTU~+>Pb|+&YTNd8yOjtfgl7PxP^<1KY6Bfmmp#@U+aH?AZo;-_?IuKa|#NAz4;p
zy&4r(#@E+Y3=ItYCv!4(9lCh4P2cdL20<cMER<0nYB1fC^t+|inYNTVs@=W5sLi`3
z>1{>w^D{$Ud-Yh>wl3lz>SzJ_A)=jEPCzs9F@)Fr{CPHh?oExP#v|29+6803AI`ZC
z9@Ql&J>^pL@d8n{OEfJ$*xS-TIFg{DbFAv`B^F%&@(Vm13){Ah1@ycx8w99ctJ7QS
z{}DB-I2^5UDv;)t;;u4OZ0|8y5mj+>_`<O7{P6+3eQCz6*&gBfG-?R|>-{p@i+Tl@
z&)k<6ZuiQ56e8~6V_~#HB5@L^LQ|~B5&}hhu$KrSz)ij1$_r|PZv>ex4l3N|XvzDD
z^mIcrr1FJWT5R6HWA5^&ZN)i5)Tj0ytYsavwE~X5r5R3cs<3G9nlVR@a#90p*F2p`
z&Zl?RMFFo{jUCI{(DX2D-St51JUsz<k6is|0+_7a`sr`ZTM(XnKoJ2-oSUBCLE(tf
zCKp<G$z~3gIybCVD0-_s;&tnmc69ep)}65Tu#9b=u%-5j^?H;1K0iBr`Q)d^+%s3#
z9Oi+5E>HFpDJMWvc0**Ah_F>@_puCc@~(?|Gnp^8d>K1>NW1@c#ia@Vj0MVJi*#0z
z6w`{9)K>|red{8OIjSk$(Mqo)A|t_Ej<srvi;9c0_9hAH>*=|SwPz$G>{DOfEEIFI
z{gO2*#>v`l*V*-A-=w+4dPNVRj8C*{B|I)?bN7p_`#Txy`4*Tqm8PdCXV2u_UHq1P
zS%tDCbQmI+`{yH{<fba=<AW2cp*qW3RJNOU>V%{GL)w%Dg!b?_;U^N_?UePB`&^m)
z!oD<*z<a+YvigQgKiSH34%hd;_HDl8X(Cs0Hl5eHoZ}A_wDTZ4Kvx`^9k|cRbL;aF
zYAO44<bn$#Y8Cb6o@z(x1#7T+;F7n5u~?cZm~RxJPULxZdy9Let%fhi_{@I%nB=(Y
z>-BRv-E`F@1qV|~Zb<}%nJ?t&2^TG|X>0cV6{N9c{@CHP3hxE|4c|^)W4swIsQpxI
z+k7YcCKTcyK_Z#NP6+GIbV$_-r|OL+1dH8S9!ZA25V16i{s}Z273^4(msF?+<IPOX
z9n>7_4Ac471+=E{zymu4!UD6(rVP`(CW=$<*Y!V(5MCLqXv*q;-Tr-e7ta?V;n^;s
z?ER>|<hv1AM6SxJI_SD+pO%|^*Ckz^FkdS7TB-&q3z~xA3?y?ZYFHcuZ*)<DLlXy^
z83JeH4n?WY{I)ZxE*%j$z4y}mYA@NmLU%_}yIAk+;y}=g6M|8tJJYyAzo0V&k%Y%s
z^D*R9ft|cF+j9DoH6m>BXGlK?OXURiz$#=>E-9No__=EmOSvmcsCm{#A^j=J>3KXA
z*X)-EB15POukJL2WqB$&|K@t}F($&OV8}a!F5eccAg6jK2o+Ff?|>a4utfe}NtGf-
zX98s*dP%1)>a9)7kAGe`I2-cUcp@ZN?Yk7bnH+m8sQz;cTK&K64AOFL%-!cus~ydd
zyYb;uq;HW_-GUA$owS%_0sq=klW*MJ9h=5b=@v(Hd}SSa3QK9t)Q*E9A_!$;D=Vwe
zSrEJKBdr4JQlUrifDrqodRph4(8w|8Ga0SyA$xh$j?ZlPUVQv&n!$}P!KrPx$SFQ{
zw#6$X4?#)Cj`4zipT3QP74pBU*a@-@x&T|Tx<yvS`kl%#-EF)IrBL4DTkkU0bkoKB
z#b(GO_iL4Rb)D%EtKG$tkw$?>TsPL!-F~+Ih%Fe}r1nr?&Q>PXF!{_#vafWn2bs1s
zDef6FTQ&KJW?sC~@iORPx071H;D#t)QhpN@4#``YztC_$zq_NR6kzNwJyV=(`=xZl
zES6pYk)Ata8Q|Vn*i4O#?yO7{aO^D7Iy9K!wf-|!eaGH{;b`s!SxKV%w3!)t5*|n~
zPd6{|`6XVkJiBJ>BKPyJ7l=qswN%v~xyeH8fhMw|2P4x~r{3E8-k!d1_@#rPMl)5<
zwy)HKiP!69@%={mg&r_G6F|kC%PN1m6O3KyOd~-|pX8|BS8JIA3JvZ3W@r60aEW;U
z8Xx?()#D)0d91J;exdJZ5_!lxcOpbbl=aroX1-)XMB`Myj`n+}p~;iGd^OLK<L;y(
zLfWZOqGqLqI%I|TR)|8=1S^7sVZeAZPULlW%F9ME)FIU`)TAut&@2F|$mo~AJe5Ls
zYgsYin$SO?1VhnRqljGsv3VxmVXMi-i^mWdFctuKwbqdu-2+vfg6Rv^zBBY+e^D-`
zRDK83khs;>4hmrV{!=?RIIQ`$wpzmigxKLZdgG$&oWW$vAGhED7y=2*!C#DBhcjU_
z+qOh~;5hBt>E@j|rf1Uk7p%Qw@T4t{l}D!aTx56klhZRWm<PdrO>m6pT&KQ&=uHpr
znS&OZXV>8Xy(>O=&~I+6V}a7L|7-n5>lmkx1g*!vN1cqKoi1$PK)o;;CDr#dpe?;j
zo3-92>GbUDw%L{L>6-WSK4yiE0a>dCX<qhusjp9Y(s>AkD>gt@>nyu7S9fvm*O!<~
z40<&f3bvW@TbF|6hmOY@sQ`S6gCC&5)cWTz)6}P(^#uzDwcWa2nVtENp)h{pQU1@*
z-)}rUAlx@JdqnqgMuyyLvv8w|!h_4jGWzX{=F(HzJa;JZS|8WGv-&Q!W%)$bsxCe?
z$TIUrGBk%T1b{ofWbhe5)Lb2Yb|W6jAY?SrLx-5dSQ1sRV){ef@?eH#Cz#gCm+1Ph
zyC}V&uDS&5v3g}xGSN?2J-vl%V#$^Dz_*#^uwWj|@voFIo=~F|U8Co8OIN<Xf7m1!
zUc?nB#1;sb3}Hm^IV@o4GWvA{i^tr%PYBPSqqJOwAgbINa_q-nfJID!jQ>vdv=#4o
zWiAV?@t`&Lv6qP{jfOr8D<!;bb3#|QuzAd>=>IlTwC%BW>m{4$WzP&Z4xZuP;?`TT
zm^h|+NAc-5SE}RfJI-whd4?OEdq5nKzgM9NrGWg~?3{e=o0*8A!$Ls*;%9^j^fQCL
zGIcV163dnJGlNx1FAuofbsT%RGxuzNdN+&Q?-T=Tp04S{1w{`}{m#>=2O@(K^!Dkd
zr!-EMj2GOx9;~-dqy2VAGuzwIi1i!iddb@ewg-7O)#&Zk=LKilQprIHgYB7u;a=Ur
z?Ue>v&!uplF1wC;&DjNCcLs5aCR7tPlwKU(pZAJGKdnzkRk)0Q`yFxNY^|3IXffD|
zKxP&=z1n*3WMlo3yWeo^cL5TKy@~ig0){g^Cc?FOso!qdaZJqiehk>V982cKfK`m*
zTyEBfubT&7<(mAOaE<F){Jq#c9bL)Zy6GR--xf?Tx<?MRQP1k!I><MiVP3HgTT!i-
z1FQ$9{@#5Az6`X=C-(1|))$UkZgBL;z5V+K-v}Wc19sk5rI!`~1{RL=@~OUnKD%ht
zJ-K9~RJN!?`O+^-iO-v*0H8f6@d16Xq;LVIzr4@lOy;jqBxt{f9A?inlI|svZ#5oQ
zT<L7Ohr1mZ*17vQfs&eZ;jw+oahG5(gEd>f0+$qJ;EDaG{@&DkZ|WC{1PGA4Q->~Q
z4}iUtLvs4^e0tk+;6mhB7}=n~9J-VPvw{HhVlj~!Hna8H0Cd-y;<$?$-T^yWgRsQR
zHitpxtbr!eY5JNkdFTVl$F(h&wz^oo#>Iom;iDnuk-q#kFy447gP$!BqZD%4`hKN?
zwo>83N>ID3ynUc2@7=4k-W?ecF%I4n(QWu`&)34DTf=)QkH}cogc3@kA3aNrmkUxX
zVQGUC>Va$<!{WU2`VLCN`Z4N1%{!+J+OFPDh@jQccM}8$XSvYfKSYQY0d)}_VCXFF
zQVi1oc$_^?gy<K0rD-v_vw_W`)90Mm$43ij+re;OWn|^qJ8FG_kL6brnO4%jCZ<QU
zvGe`Dv~wes1rb8@$AS`^s4S+Y-&s7R59;S%`=U~@xpza2Jgkm;pt4eSDJhh!OqLL)
z5dPxALc)dvh|Chk;-$GH>1P-zUb5cS7g?)~JQ!^0I`m-XLj7>SB;8;l2p!Nz-H;PJ
zL?Sgz?~EkXM~SnBl~c=Cp!OeDmzokCY9e7@dv*E>=Ni@#DS>shYw7(?RC5a^0FHTR
zabJ5i{EmUPwj!AKBzI8vNJA*s+)oXOk#hzM^)EGMM+6`BKA}%5Oto!)22#D}--JDo
z@I@&`o2=jsUNpYdv23m#ecA&JCO56}ZP+M5(b6&hD9<Q;`%R|&GWz;AijzHuBF0n}
zNYn4ILPUFnTX`J?$#jml&<4tfXh9EX?|X^#Cj?oUZthSM7xf)Yv-T;v@pA=}fA+O2
zX=j03nosqbrr&c2lPy>#(6Rwy8wNALToVMGp5DeYis-VMPEbqvS}GscHqq@>YhfDu
zwGivt>P=mxeynpv+P$Z3rLV&x&g*3}?M-bXNsj;>QTobCSn26UBtd^88Kc9SEFPQh
zv?gO4=j*zO`}{LH9XRvJTz2i-L0Wmb1m`c;cYDv7UYhIa9g<nq8T!hV5HuIxP4ch-
z3rEyG?6NhuH-g{`r9e{wO@)Zvc!nw8P=R%zq1}FYFs{IV_Sv0pH5_7bGw-Uly=Z^n
z5V7<8(3r5fXX1FA1J^Ru^!I>O>f8F0G8?8lQ5>m-KObY+N+Y!d;j5Sfp~ZB@5w3|g
zLvwEaJ>SgK;<s9=tGRY+^2#r@p4QpLzr{Vh!!}A5?7KtP%f`$kfk$i%5C5gwg}1Be
zM)a(z?bA>TY^Yf5bXQzkd0N4vrYjs27I;8|UtwXOii14YFP?DV$!ZgauJCpNMfvvt
zaIgV^lMie#PfP%LpHLMQ<gHKf^*x~*p_LTIWvHKJYE<TS-5H$w&`g5uf>z^}c!m6p
z(GeO+nGikT{35$`T?Y@mbRF_)l!<dKk}o@d8G`Q%^l%8)p)MBP)m9{5!RR!z(s}dX
zj&%{2?TaC>BvC<v#TzSi353_8V!;RMHv09T3kRQ~cC^G0w0wo(m|OP}LpUXWL6l*h
z6O+n*G)>!KQ{zk=4O2Ra#I&?g*n-FsRvJ*)`ihrF(>V@Z{DZ$3PA!>!uiTP-%1<Tz
z{>-+j_aeR6otl!e2>+WrtO^j_SM#ueM3m|4Gn`TU{(!wvcI-8x?5G5OfR^J3G}RPK
z36BrkWMUvH3=Iuojvf>ws1o>VPbRT)%jQ8-#No;yegR=HAd^I=6?5!2+6nX0+fEn}
zPw~)G<2aw?5xy4J(XX5`4kj5!Z*d}wtw<^s$g6QOj%Jiye^f$yZGm%$paG%3_UjoM
znxl&b54kO@4_y}AJ^R$9vLW$5Sb$5{Ka+I%^~E<o62s3vM|XzjlrMp65-%CgIX42S
zp!0hGFOM+yA|tMs0Wk~%8pPDgH@fmt0Wu9uoYYc++eu5Kj=n41=BSW-ErF_6aO$`1
zk=lejMNhx`y)l|fSQmJT88(J%B!S@Yg<(MlB0e@JYj&)|u_ZxGIl(y3#_5Z;Opyqi
zB^UkfocHzxy|Cw`HH-2kF3k*+0o{dSU0N}@?U46{kcT_qP6kiNUv_J_5vUb#(u<q;
z;b>brbh92n{$@44Z1{-aUnvK^=JlS{rHCmhU@<s0^m$_AzQbk19LeGpO~>4M1<Gf|
zN-y<ff!|bE?I7s(oA5}2jl7Lx8b3xl?uhH5u$~X4z>18nyeuW<fV%9I72{#cCxlrA
z*a6XJa6m+)1nfMkEafF=od>es+iO@66<||0xt0+|0Rr5kY=|S2f?<h))ZjAF)mCDb
zjexHwh;Mq9V-`~b@8UBp=?Cw^FvM6YLxn}br{>Q9WKe}BlK*Q-$aPm?NI(kOX1Xz_
z`bTxJOa+%$>lvXn#N^zT?b-B`ptK<<GX#qLYi=?Ds70)htw}0JpPz7_Bshw?gUJM_
zjW1EkR~HONrJlrMf!rY^RAArI`7XP7O}gXzBQ@X-k@?CnZ<K%II4UUOdU#1y!7^1(
zSQ<?Wj>iNZ1_KFZwstvy+rY$RZ!yOMP*VRSlM%1U<Z|2!nu`~3$K=d$qJ)|LQF9)x
z7@jy>707<SCvM?y$;R8$wL<VzJzKIFki@dS)f1lk1vfKf0e~NLH}hzr+M!pYmcYo6
zjUGI{`^i;>)u|87J8k>W@+E6U!`L3tK)ZPETs9i6HfT^V=Jh3;_)3%IVEU8x`3x2X
z{-nZ>tR)Z8IwYUCXMY6dEvVGeHqEfssP22?u~|rAZppl7b*{sEVXS;{e5~p5)X;|w
zbW71B=TjaYOQ01v#7uS<Z?ep?lqdrJg3Tj9?4(#U@)Ko?rJk(WDLUteO;C+Ve{5yM
z7Y<2p2nqTB@sAq;s8r26@xCj!CFz6PfA}DLE0smUua-Sfbszmf;#PxV^v~qp%ru^`
z=CcAq=TygcFIwM`1a$!Hr05U!;hh%09xIqfz)wD%{Hw064g!=5@hP<HS4iQkun#cy
z(V6Ah=t@Mx%R(ZB3NjvEf+u2884=PNE8)Ao>T()ak6gvovM?>)jQ}NQNxVp^&QAZ#
z>n2DzYrg6ekk&)LFk3kH0b;pU(lJ@`)xfvl7jumiK0~B(=0r4agqx9*`0pcIt4M+c
zZ^2P=R4l47-ZS(1t+t@F;Xjvuz?fhp!W0>EfCyvn?tq=v8@K)jcbPA!FiSx@9M0&?
z#C`bR)Qgoom?WL}A*8re3tJG{(`R>IV~&Uh)ObrieBMi)ok|K1hu6myy5F^HYo~Oj
zJf<zjI7lStSURoA<Kx*MczjoXYsHn`gooVv(7!*Sf427)4wTMwsZ`{0PEAA=t2YVn
z;7u#(QZ{5~7$HA3NO#1bK5;gB!&DVkYw52-NAe@AI`lB@-tL5+2!je76P%AT)6$9o
zwj}mqi4*VBY0Y=xkA(IQsR%D%jKfKzEZYN~2%agkP#Y5I<+Y-1t?h02GtybSan(s>
zWn}^&07Jv$gnpAST5*;%&KSa>Faa-D9+IOUzC7di{0H|yhF$Z^cfd$&#SC=Jyb3+b
z46w3%7jB+vBVL*TIET!HkzOTzFyuOR(?U&6jj{`0tb26C@4HATxZH3d9YP5srJP|r
z?Dfztvq&&f<DmmW>nlI~?)+I4OhU&6oP;p>ndC2iG51;n{0FeJ;A3iWbj&n;Q`26Y
zYcNTCE_kK)<uA_4DRaVH1#l0+5Igst<WDOECZ!gSW&S%Fmm_|E1|<-H2(RN%|8r3d
z$)D2e-Y<`%nx2*h#|nN}LlT_C=DL35w0><`a+J6|Um3H-m5iL6=?<v21gB7pcc(+$
z7!Usj_7R7)X-)S2&xP!S59~0i1*+~ad~Txu{#=FG;)e~YPQ~hwIM~46W;LwNXQwSv
zZ)PCDxlx+m5ery&#4j)kcQ3$>AT7dsNFvopB`dLWfGU9l77Bu$aO9R=9F0wtB*9&T
z?Gb$#w$NV;Yq{~~4x8zI!c>DJV_bpbf2)s9kSuyBXOQqaqPm3FT2jQY4Hh_p*U^mt
zWz0}oUj4^QNFwFjqthxsBN)yusI^<}_7tJhxMM+b{-V<|i#}>^ghSKsvoi7T;9nER
z6`mBxRjzm&1qRjqE{JzNO}NnTZL?v*oaMVVW{%gS*oqPFp=~%|I#yOgaCuAFwZHa-
z-jr23twGEOYgt1F2O#_(wpgT@;U+RF#&~Bgfg>Jq$@q(5#)G@*Z;#d0*CT%WnnizH
zL9B9t>w&BBS49?HW&nc;Rn-Tjk7A1{I%tl=v=)B?k)YJI^8sc}B1QifNfDR*H@WkF
rm;Kje=6_4|zoq*BKqdbR7aDKYoRY7}9@_=11?i01S=G#w7We)SIqvKS

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[@]}