#include #include #include #include #include #include #include #include enum PRODUCT { FUEL = 0, ORG = 1, EQUIP = 2 }; // Class 0 : Special // Class 9 : StarDock BBB // typedef std::array buysell; struct buysell { bool foe[3]; bool operator==(const buysell &rhs) const; friend std::ostream& operator<<(std::ostream& os, const buysell& bs); }; // ostream& operator<<(std::ostream& os, const buysell& bs); // typedef std::array buysell_text; struct buysell_text { char txt[3]; bool operator==(const buysell_text &rhs) const; friend std::ostream& operator<<(std::ostream& os, const buysell_text &bst); }; #define MAX_WARPS 6 typedef uint16_t sector_type; struct sector_warps { sector_type sector; // Yes, for debug // std::set warps; // possibly sector_type warps[MAX_WARPS]; // ports // planets // ctor that zeros everything out? sector_warps(); void add(sector_type sector); // add() that adds warp to end of warps? friend std::ostream& operator<<(std::ostream& os, const sector_warps& warps); }; /* 1 : "BBS", TTF 2 : "BSB", TFT 3 : "SBB", FTT 4 : "SSB", FFT 5 : "SBS", FTF 6 : "BSS", TFF 7 : "SSS", FFF 8 : "BBB", TTT 9 : "BBB", TTT */ /* convert type to buysell flag values, buy = true */ constexpr buysell get_buysell(uint8_t type) { switch (type) { case 1: // BBS TTF return {true, true, false}; case 2: // BSB TFT return {true, false, true}; case 3: // SBB FTT return {false, true, true}; case 4: // SSB FFT return {false, false, true}; case 5: // SBS FTF return {false, true, false}; case 6: // BSS TFF return {true, false, false}; case 7: // SSS FFF return {false, false, false}; case 8: // BBB TTT case 9: return {true, true, true}; default: throw std::invalid_argument("invalid buysell type"); } } constexpr buysell_text text_from_buysell(const buysell market) { buysell_text text{'?', '?', '?'}; for (int x = 0; x < 3; ++x) { text.txt[x] = market.foe[x] ? 'B' : 'S'; } return text; } constexpr buysell_text text_from_type(uint8_t type) { switch (type) { case 1: return buysell_text{'B', 'B', 'S'}; case 2: return buysell_text{'B', 'S', 'B'}; case 3: return buysell_text{'S', 'B', 'B'}; case 4: return buysell_text{'S', 'S', 'B'}; case 5: return buysell_text{'S', 'B', 'S'}; case 6: return buysell_text{'B', 'S', 'S'}; case 7: return buysell_text{'S', 'S', 'S'}; case 8: case 9: return buysell_text{'B', 'B', 'B'}; default: throw std::invalid_argument("invalid text_from_type type"); } } constexpr uint8_t type_from_buysell(const buysell market) { if (market.foe[0]) { if (market.foe[1]) { if (market.foe[2]) { return 8; // BBB TTT } else return 1; // BBS TTF } else { if (market.foe[2]) { return 2; // BSB TFT } else return 6; // BSS TFF } } else { if (market.foe[1]) { if (market.foe[2]) { return 3; // SBB FTT } else return 5; // SBS FTF } else { if (market.foe[2]) { return 4; // SSB FFT } else return 7; // SSS FFF } } } struct port { uint16_t sector; uint8_t type; uint16_t amount[3]; uint8_t percent[3]; friend std::ostream& operator<<(std::ostream& os, const port &p); }; struct port parse_portcim(const std::string line); // SPECIAL = 0 // STARDOCK = 9 class GameData { public: std::map config; // warps; // ports; };