I’m making an RPG in C++ and the items (loot/gear) will have immutable base versions, but then the player can get instantiations of them which can change with use and modification. These mutable instantiations will be saved in the DB. But I’m wondering if the base versions should be defined in JSON, or a separate DB (with the same schema), or maybe the same DB (seems dangerous), or if I should just hardcode them in C++ in the ItemFactory.

How have you approached this problem in your games? How do game engines do it? I’m using SDL2 so I’m doing most of these systems from scratch.

  • Sentient LoomOP
    link
    fedilink
    English
    31 month ago

    I never considered CSV but that would be the simplest way to store basic definitions.

    There will be complicated behavior. And a bit of hierarchical data (each item will belong to a specific map). Plus I want inheritance so they can perform different functions on different screens. But the basic data is fairly simple.

    Is there a good CSV library you use to read the data into C++?

    • @[email protected]
      link
      fedilink
      61 month ago

      Honestly I’d just hand write a CSV parser, they aren’t that complicated ESPECIALLY if you don’t care about having commas in your data because then you don’t need to quote wrap the entries but that’s just me.

      • @[email protected]
        link
        fedilink
        31 month ago

        Same. I already have one I wrote myself that’s good enough for my needs – which means it doesn’t handle quoting or alternate line endings or other quirks. (I can just change the separator to \t if I really need commas in values, and since I control the data format, I can just say “it will always have Unix line endings” to keep it simple.)

        There’s probably thousands of open source CSV parsers out there though if you don’t want to roll your own, but I don’t have a specific recommendation.

        • @[email protected]
          link
          fedilink
          31 month ago

          Yeah, I had the same thought LOL. If you need commas in your data just use a TSV and call it good. I have yet to need the commas though