Releases: mtkennerly/ludusavi
v0.8.0 (2020-08-10)
- Added:
- If you create a file called
ludusavi.portable
in the same location as the executable, then Ludusavi will store its config file and the manifest there as well.
- If you create a file called
- Fixed:
- Read-only files could only be backed up once, since the original backup could not be replaced by a newer copy, and you could not restore a backup if the original file was read-only. Now, Ludusavi will try to unset the read-only flag on backups before replacing them with newer backups, and it will try to unset the flag on target files before restoring a backup.
- Invalid paths like
C:\Users\Foo\Documents\C:\Users\Foo
would be shortened to justC:\Users\Foo
, which could cause irrelevant files to be backed up. Now, the extraneousC:
will be converted toC_
so that it simply won't match any files or directories. - When some games were deselected, the disk space display only showed units for the total space, not the used space, which could lead to it showing "1.42 of 1.56 GiB", where 1.42 was actually MiB and not GiB. Units are now shown for both sides.
- Changed:
- When backing up or restoring a file, if it already exists with the correct content, then Ludusavi won't re-copy it.
- In GUI mode, Ludusavi now tries to be smarter about when a full scan is needed. Previously, every backup and backup preview would trigger a full scan. Now, Ludusavi will remember which games it found and only re-scan those games (until you change your roots, change the "other" settings, or reopen the program).
- In CLI mode,
--try-update
will use a default, empty manifest if there is no local copy of the manifest and it cannot be downloaded.
(See also: experimental variant with OpenGL)
v0.8.0 with OpenGL (2020-08-10)
This is an experimental variant of v0.8.0 with OpenGL support. If the standard version doesn't work for you, then give this a try.
v0.7.0 (2020-08-01)
The backup structure has changed! Read below for more detail.
- Added:
- Backup option to exclude save locations that are only confirmed for another operating system.
- Backup option to exclude store screenshots.
--try-update
flag for backups via CLI.
- Fixed:
- When starting the GUI, if Ludusavi could not check for a manifest update (e.g., because your Internet is down), then it would default to an empty manifest even if you already had a local copy that was downloaded before. Now, it will use the local copy even if it can't check for updates.
- Changed:
- Backup structure is now human-readable.
- App window now has a minimum size, 640x480. (Note: For now, the crates.io release will not have a minimum size.)
- File size units are now adjusted based on the size, rather than always using MiB. (contributed by wtjones)
(See also: experimental variant with OpenGL)
New backup structure
Click to expand full details
Previously, Ludusavi used Base64 to encode game names and original paths when organizing backups. There were some technical advantages of that approach, but it was not easy to understand, and there was a technical flaw because Base64 output can include /
, which isn't safe for folder or file names.
Therefore, Ludusavi now organizes backups like this, in a way that is easier to read and understand:
C:/somewhere/the-backup-folder/
Game 1 Name/
mapping.yaml
registry.yaml
drive-C/ # drive-0 on Linux and Mac
Users/
...
Program Files/
Steam/
...
The name of each game's folder is as close to the real title as possible, except for replacing some special characters with _
. Ultimately, Ludusavi doesn't care much about the folder name and mainly looks for mapping.yaml
, which contains some metadata that Ludusavi needs. If a game has any Windows registry data to back up, then there will also be a registry.yaml
file. Within each drive folder, everything is simply organized exactly like it already is on your computer.
If you need to restore a previous backup, then please use Ludusavi v0.6.0 to do the restoration first, then migrate to Ludusavi v0.7.0 and create a new backup.
You can read more here about the background of this change. Be assured that this sort of disruptive change is not taken lightly, but may happen in some cases until Ludusavi reaches version 1.0.0.
v0.7.0 with OpenGL (2020-08-01)
This is an experimental variant of v0.7.0 with OpenGL support. If the standard version doesn't work for you, then give this a try.
v0.6.0 (2020-07-29)
- Added:
- Option to merge into an existing backup directory.
--api
flag in CLI mode.--by-steam-id
flag in CLI mode.
- Fixed:
- Registry values of type
EXPAND_SZ
andMULTI_SZ
were converted toSZ
when restored.
- Registry values of type
- Changed:
- On Windows, the program icon is now embedded in the executable so that you can see it in the file browser as well.
(See also: experimental variant with OpenGL)
v0.6.0 with OpenGL (2020-07-29)
This is an experimental variant of v0.6.0 with OpenGL support. If the standard version doesn't work for you, then give this a try.
v0.5.0 (2020-07-25)
- Added:
- Support for custom games.
- Icons for several buttons.
- An icon for Ludusavi itself. (Note: For now, the crates.io release will not show this icon.)
- Support for cutting in text fields. (Note: For now, the crates.io release will copy text instead of cutting it.)
- More buttons for browsing folders.
- Support for
~
(user home directory) in redirects. - Support for
.
and..
path segments when the path does not exist.
- Fixed:
- On Windows, long paths can now be backed up without issue.
- When backing up files, the Base64-encoded name now preserves the original file's actual capitalization, rather than the expected capitalization from the manifest.
- There was a rare issue related to the above point where some files could be backed up twice, once with the original capitalization and once with the expected capitalization.
- The CLI required the backup
--path
to already exist. - Keyboard shortcuts didn't work in redirect fields.
- Registry keys were not backed up if the parent key had no values.
- CLI mode would panic when restoring if a non-Base64-encoded file were present in the source folder. Now, such files will be reported as an error.
- Changed:
- The configuration auto-save is now more predictable. All config changes are now saved immediately.
- When a game has registry data to back up, registry.yaml no longer includes unnecessary fields and is now sorted alphabetically. This means that identical registry content will produce an identical registry.yaml across backups.
- The progress bar is now shown on all screens.
(See also: experimental variant with OpenGL)
v0.5.0 with OpenGL (2020-07-25)
This is an experimental variant of v0.5.0 with OpenGL support. If the standard version doesn't work for you, then give this a try.
v0.4.0 (2020-07-21)
- Added the ability to select and deselect specific games.
- Added the ability to restore to different folders via redirects.
- Added indicators for how much disk space is used by the files.
- Added indicators in the GUI when files fail to process.
- Added a browse button for folders.
- Replaced the "=> Restore" and "=> Backup" buttons with a navigation bar.
- Redesigned the confirmation and error screens so that the buttons are shown below the text, which helps to prevent any accidental clicks before reading.
- Narrowed how Steam IDs are substituted in paths to avoid false positives.
- Fixed an issue where restore mode in the GUI would get stuck showing an "in progress" state if the source path had no subdirectories.
(See also: experimental variant with OpenGL)
v0.4.0 with OpenGL (2020-07-21)
This is an experimental variant of v0.4.0 with OpenGL support. If the standard version doesn't work for you, then give this a try.