• vithigar
    link
    fedilink
    English
    arrow-up
    14
    ·
    21 days ago

    Bold of you to assume the data in save files is packed binary and not something like JSON where { “x”: 13872, “y”: -17312, “z”: -20170 } requires 40 bytes of storage.

    • addie@feddit.uk
      link
      fedilink
      English
      arrow-up
      9
      ·
      21 days ago

      Agreed. JSON solves:

      • the ‘versioning’ problem, where the data fields change after an update. That’s a nightmare on packed binary; need to write so much code to handle it.
      • makes debugging persistence issues easy for developers
      • very fast libraries exist for reading and writing it
      • actually compresses pretty damn well; you can pass the compress + write to a background thread once you’ve done the fast serialisation, anyway.

      For saving games, JSON+gzip is such a good combination that I’d probably never consider anything else.

    • smeg@feddit.uk
      link
      fedilink
      English
      arrow-up
      2
      ·
      21 days ago

      That’s excusable in My First Game™ but surely professional AAAAA game would never cut corners and code something so lazily, eh?

      • vithigar
        link
        fedilink
        English
        arrow-up
        5
        ·
        21 days ago

        It’s not really laziness. Storing as JSON solves or prevents a lot of problems you could run into with something bespoke and “optimally packed”, you just have the tradeoff of needing more storage for it. Even then, the increased storage can be largely mitigated with compression. JSON compresses very well.

        The problem is usually what they’re storing, not how they’re storing it. For example, The Witcher (first one) has ~20MB save files. These are mostly a bespoke packed binary format, but contain things like raw strings of descriptions in multiple localisations for items being carried, and complete descriptors of game quests. Things that should just be ID values that point to that data in the game files. It also leads with like… 13KB of zero-padding for some reason.