-
Notifications
You must be signed in to change notification settings - Fork 281
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Early Discussion: New save format to reduce save size and number of files #5771
Comments
…nteam#5771) Signed-off-by: David Li <jiawei.davidli@gmail.com>
The reason for multiple save files is that we're semi-often modifying the files separately. |
How about simple zip files? Would allow any user to have easy access. |
@thedyze Performance penalty for packing/unpacking and very tiny benefit (slightly beter organization) |
@Coolthulhu The current thinking is that files like The emphasis is really on the map tile & visibility data (files in
@thedyze I decided against zip as the API is a little weirder and we'd lose the ability to attach extra metadata if needed. SQL just provides a bunch more flexibility. SQLite also gives some nice bonuses around ACID transactions so we'll finally be able to fix the crashed-during-save corruption. |
I am very late but I hope anything we do is going to allow migrations of save files to the new format. This doesn't need to be in the main release, if it's not difficult to supply a migration change for saves it could be a separate tool. We can still gut out all the old data and make users upgrade to the new format, we would just ideally supply a tool for it. Users right now can pretty much load a save from early DDA and use each stable version of DDA and then BN to upgrade one version at a time, which is a side effect of DDA/BN's intent on maintaining migration and lack of major overhauls to the save data for years. I am not worried about disrupting saves older than a few months however. |
Is your feature request related to a problem? Please describe.
Context and Motivation
CBN currently stores saves as loose uncompressed JSON files. Each map chunk is a separate file. Each player-chunk tuple is another file.
With very little exploration, CBN saves balloon to over a GB spread out over many hundred thousand individual files. This slows down saving/loading and makes filesystem operations on saves particularly slow (i.e. backups, syncing across machines, etc).
Describe the solution you'd like
Proposal
Migrate to a new save format where map tiles are stored as compressed JSON blobs in a SQLite3 database.
The planned save format will contain one sqlite db for the game world, plus one for each character. Specifically:
map.db
replaces:maps/
directory (map tile info)0.*
files (overmap info)<player_id>.db
replaces:<player_id>.seen.*
files (player overmap visibility data)<player_id>.mm1/
directory (player map tile memory)All other files will remain unchanged. This should cover all the worst offenders while leaving the more manual-edit-friendly files untouched.
Each database will consist of a single table:
Proposed Migration Path
Phase 1. [#5774] Backend cleanup of the world save/load codebase to make it easier to support multiple save formats. Keep the format unchanged at this stage.
Phase 2. Implement the new format under an experimental feature flag/option. There should be a migration path for old saves.
Phase 3. Roll the format out as the default format. Keep backwards compatibilty for a long/indefinite period of time.
Phase 4. (Optional) deprecate the old format, and keep around a script to upgrade from the old format
Additional context
No response
The text was updated successfully, but these errors were encountered: