#ifndef OPENMW_COMPONENTS_ESM_ESM3EXTERIORCELLREFID_HPP #define OPENMW_COMPONENTS_ESM_ESM3EXTERIORCELLREFID_HPP #include #include #include #include namespace ESM { class ESM3ExteriorCellRefId { public: constexpr ESM3ExteriorCellRefId() = default; constexpr explicit ESM3ExteriorCellRefId(int32_t x, int32_t y) noexcept : mX(x) , mY(y) { } std::string toString() const; std::string toDebugString() const; int32_t getX() const { return mX; } int32_t getY() const { return mY; } friend inline constexpr auto tie(const ESM3ExteriorCellRefId& value) noexcept { return std::tie(value.mX, value.mY); } constexpr bool operator==(ESM3ExteriorCellRefId rhs) const noexcept { return tie(*this) == tie(rhs); } constexpr bool operator<(ESM3ExteriorCellRefId rhs) const noexcept { return tie(*this) < tie(rhs); } friend std::ostream& operator<<(std::ostream& stream, ESM3ExteriorCellRefId value); friend struct std::hash; private: int32_t mX = 0; int32_t mY = 0; }; } namespace std { template <> struct hash { std::size_t operator()(ESM::ESM3ExteriorCellRefId value) const noexcept { return Misc::hash2dCoord(value.mX, value.mY); } }; } #endif