From 19d7218e90ba19bc145ec42983b150921e3ae2a9 Mon Sep 17 00:00:00 2001 From: estefan3112 Date: Mon, 18 Dec 2023 09:12:18 +0100 Subject: [PATCH 1/2] Minor tweaks of the first version based on developer feedback --- docs/guides/retroarch-cloud-sync.md | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/docs/guides/retroarch-cloud-sync.md b/docs/guides/retroarch-cloud-sync.md index 108289ad2d..79b7f788a0 100644 --- a/docs/guides/retroarch-cloud-sync.md +++ b/docs/guides/retroarch-cloud-sync.md @@ -1,22 +1,22 @@ # What is it? -RetroArch Cloud Sync enables a seamless synchronization of the most important system configuration and save data to a dedicated private webdav server, from where these data can be synchronized across Apple devices. The current functionality is limited to Apple devices (MacOS, iOS, tvOS) because it was developed here. It can be deployed to other RetroArch operating systems, if a developer is interested in this work. +RetroArch Cloud Sync is available in recent RetroArch Nighties and enables a seamless synchronization of the most important system configuration and save data to a dedicated private webdav server, from where these data can be synchronized across Apple devices. The current functionality is limited to Apple devices (MacOS, iOS, tvOS) because it was developed here. It can be deployed to other RetroArch operating systems, if a developer is interested in this work. RetroArch Cloud Sync currently syncs all data from the following directories: /"YourUser"/Documents/RetroArch/saves - original system saves /"YourUser"/Documents/RetroArch/states - RetroArch save states -/"YourUser"/Library/Application Support/RetroArch/config - the global retroarch.cfg and all core-specific configurations, core options and shader configurations +/"YourUser"/Library/Application Support/RetroArch/config - all core-specific configurations, core options and shader configurations, MAME/FBNeo hiscores, but not the global retroarch.cfg "YourUser" refers to your $HOME user in MacOS ## How to configure it -As with any sync solution, it is recommended to start with one device and ensure a proper functioning. Only then a second device should be added. +As with any sync solution, it is recommended to start with one device and ensure a proper functioning. Only then further devices should be added. ### Initial configuration with first device -In order to start with Cloud sync, you need an own webdav account that is accessible by MacOS via Connect to Server -> https://webdav.xxxxxx.xxx/. +In order to start with Cloud sync, you need an own webdav account that is accessible by MacOS via the Menu/Connect to Server -> https://webdav.xxxxxx.xxx/. !!! Tip It is obviously the best way to start with your leading RetroArch system, as this will bring the most important data into the webdav account first. In this account, create an own folder called RetroArch. @@ -29,13 +29,13 @@ Within RetroArch, go to Settings/Saving/Cloud Sync Username -> your webdav user Password -> your webdav password -Save this configuration and restart Retroarch. After this restart, the initial sync should start immediately (see progress indicator in the bottom left status line of RetroArch). Depending on your amount of sync data, this can take some time. When this is finished, you could do some testing. For example, launch a game and set a new hiscore, then close the game. Let the sync do its job, then look into the webdav accound, and the new hiscore should be there. +Save this configuration and restart Retroarch. After this restart, the initial sync should start immediately (see progress indicator in the bottom left status line of RetroArch). Depending on your amount of sync data, this can take some time. When this is finished, you could do some testing. For example, launch a game and set a new hiscore, then close the game. Let the sync do its job, then look into the webdav account, and the new hiscore should be there. -### Configuration of a second device +### Configuration of a second device and further devices -With the second device, so the identical steps in RetroArch as with the first device. From now on, the two devices should be in sync! +With any additional device, you do the identical steps in RetroArch as with the first device. From now on, these devices should be in sync! -!!! Important Note +!!! Tip Be very careful that these directory save settings are also identical on all sync devices: - Sort Saves into Folders by Core Name - ON/OFF - Sort Save States into Folders by Core Name - ON/OFF @@ -64,4 +64,8 @@ find . -name '.DS_Store' -type f -delete cd /"YourUser"/Library/Application\ Support/RetroArch find . -name '.DS_Store' -type f -delete -After deletion, the sync also deletes these .DS_Store files from the cloud repository. \ No newline at end of file +After deletion, the sync also deletes these .DS_Store files from the cloud repository. + +### Troubleshooting + +If the Cloud Sync returns an error, turn logging on and set the logging level to debug, log into a file. Cloud Sync logs reliably into the logfile, so the errors can be read easily. \ No newline at end of file From f596a997c281e67054b665e8d7f3f913789d2e34 Mon Sep 17 00:00:00 2001 From: estefan3112 Date: Mon, 18 Dec 2023 10:24:16 +0100 Subject: [PATCH 2/2] Update softwarelist-getting-started.md Update as RetroArch no longer provides the old cores. --- docs/guides/softwarelist-getting-started.md | 49 ++++++++++++++------- 1 file changed, 34 insertions(+), 15 deletions(-) diff --git a/docs/guides/softwarelist-getting-started.md b/docs/guides/softwarelist-getting-started.md index 0c216de09b..c6d84a8b35 100644 --- a/docs/guides/softwarelist-getting-started.md +++ b/docs/guides/softwarelist-getting-started.md @@ -2,29 +2,48 @@ In this chapter, the terms 'software' and 'software lists' are used to define non-arcade machines that are emulated by MAME/MESS. This kind of emulation requires a different planning approach than arcade machine emulation - it is more complicated to set up. +The basic principle is that software lists contained in the hash database are used to tell MAME/MESS how to start the game. This is an example entry from an Atari 7800 game also used further below (just for illustration purposes, no need to configure anything): + + + Asteroids (NTSC) + 1984 + Atari + + + + + + + + + + ## Understand the core variants The libretro core ecosystem currently includes many multi software emulators that support software emulation. Three families exist: MAME, MESS and UME. These emulators are in turn available in multiple versions to allow users to best match a core to their preference. -#### MAME -Arcade (MAME) & Arcade (MAME 2016) are currently the only MAME cores that support the emulation of both software & arcade systems. The Arcade (MAME) core is updated regularly and most inline with the official MAME project release. Arcade (MAME 2016) is an archived snapshot of MAME from the 0.174 release. +#### MAME current +Arcade (MAME) is currently the only MAME core for most host systems that supports the emulation of both software & arcade systems. The Arcade (MAME) core is updated regularly and most of the time in line with the official MAME project release. For an overview of the vast number of system that are emulated, have a look into the github directory of the hash files: https://github.com/mamedev/mame/tree/master/hash - every xml contains the readable metadata of one system, i.e. the games it supports. + +Arcade (MAME 2016) is an archived snapshot of MAME from the 0.174 release. Currently it is no longer built for RetroArch. -#### MESS -Multi (MESS 2015) is a snapshot of the MESS project from v0.160. The MESS project later merged with the MAME project in MAME v0.162, i.e. in May 2015. +#### MESS (no longer provided) +Currently there is no dedicated MESS core in Retroarch, except for Android ARM64. It is also still provided in RetroPie as MESS2016_libretro core. +Multi (MESS 2016) is a snapshot of the MESS project from v0.160. The MESS project later merged with the MAME project in MAME v0.162, i.e. in May 2015. The documentation of MESS is here: http://mess.redump.net/start - however some of its pages no longer work. -#### UME -Multi (UME 2015) is a snapshot of the Universal Machine Emulator. This was a precursor to the MAME/MESS merger, released by David Haywood (haze). The MAME and MESS project codebases co-existed in the MESS SVN development tree before they officially merged. This allowed haze to build and release the emulator with unmodified code from both projects under the name UME. +#### UME (no longer provided) +UME cores are no longer in RetroArch. Multi (UME 2015) was a snapshot of the Universal Machine Emulator. This was a precursor to the MAME/MESS merger, released by David Haywood (haze). The MAME and MESS project codebases co-existed in the MESS SVN development tree before they officially merged. This allowed haze to build and release the emulator with unmodified code from both projects under the name UME. ## Use the correct version of romset for the desired emulator -Arcade (MAME), Arcade (MAME 2016) will be the main focus of this guide but also the MULTI (MESS 2015) and MULTI (UME 2015) cores have this ability. As in MAME arcade emulation, each core requires its own distinct version of software list "romsets", which the emulator supports. +Arcade (MAME) will be the focus of this guide, but also the old Arcade (MAME 2016), the MULTI (MESS 2015) and MULTI (UME 2015) cores had this ability (so this information is also provided for documentation purposes). As in MAME arcade emulation, each core requires its own distinct version of software list "romsets", which the emulator supports. -| Emulator | Required ROM Version | -| :---: | :---: | -| MAME 2016 | MAME 0.174 | -| MAME (latest version) | MAME (latest version) | -| MESS 2015 | - | -| UME 2015 | - | +| Emulator | Required ROM Version | Notes | +| :---: | :---: | :---: | +| MAME (latest version) | MAME (latest version) | or same version if not in sync with MAME upstream | +| MAME 2016 | MAME 0.174 | RetroArch core no longer provided | +| MESS 2015 | MAME 0.160 | RetroArch core no longer provided | +| UME 2015 | MAME 0.160 | RetroArch core no longer provided | !!! tip For best results, start with a full software list ROM collection with a version that matches the emulator you are using. Individual romset zip files may not include BIOS ROMs, "Parent" romsets, necessary audio sample files, etc. @@ -82,7 +101,7 @@ You may also put or even extract the bios file to their own folder within the ga Now launch the game: In RetroArch, choose "Load Content" and browse to asteroid.zip and launch with MAME current. -(To Do: Add note about SoftList xml specifying the game names and crc and only supporting only those specific file names.) +(To Do: Add note about SoftList xml specifying the game names and crc and only supporting only those specific file names. Dummy files for CD-based games.) ### Method 2: RetroArch frontend friendly via Libretro CMD file launching @@ -93,7 +112,7 @@ Let's follow the above example and create a dedicated asteroid.cmd file for the a7800 -cart asteroid -rp "/"YourPath"/mame/roms/a7800" -To do: Other path definitions, e.g. under Windows? +To do: Other path definitions, e.g. under Windows? Maybe explain the different sources, e.g. cart, flop etc? Now launch the game: In RetroArch, choose "Load Content" and browse to asteroid.cmd, and it should launch with MAME current.