#ifndef OPENMW_COMPONENTS_DETOURNAVIGATOR_NAVMESHDB_H #define OPENMW_COMPONENTS_DETOURNAVIGATOR_NAVMESHDB_H #include "tileposition.hpp" #include "tilespositionsrange.hpp" #include #include #include #include #include #include #include #include #include #include #include struct sqlite3; struct sqlite3_stmt; namespace DetourNavigator { using TileId = Misc::StrongTypedef; using TileRevision = Misc::StrongTypedef; using TileVersion = Misc::StrongTypedef; using ShapeId = Misc::StrongTypedef; struct Tile { TileId mTileId; TileVersion mVersion; }; struct TileData { TileId mTileId; TileVersion mVersion; std::vector mData; }; enum class ShapeType { Collision = 1, Avoid = 2, }; std::ostream& operator<<(std::ostream& stream, ShapeType value); namespace DbQueries { struct GetMaxTileId { static std::string_view text() noexcept; static void bind(sqlite3&, sqlite3_stmt&) {} }; struct FindTile { static std::string_view text() noexcept; static void bind(sqlite3& db, sqlite3_stmt& statement, std::string_view worldspace, const TilePosition& tilePosition, const std::vector& input); }; struct GetTileData { static std::string_view text() noexcept; static void bind(sqlite3& db, sqlite3_stmt& statement, std::string_view worldspace, const TilePosition& tilePosition, const std::vector& input); }; struct InsertTile { static std::string_view text() noexcept; static void bind(sqlite3& db, sqlite3_stmt& statement, TileId tileId, std::string_view worldspace, const TilePosition& tilePosition, TileVersion version, const std::vector& input, const std::vector& data); }; struct UpdateTile { static std::string_view text() noexcept; static void bind(sqlite3& db, sqlite3_stmt& statement, TileId tileId, TileVersion version, const std::vector& data); }; struct DeleteTilesAt { static std::string_view text() noexcept; static void bind( sqlite3& db, sqlite3_stmt& statement, std::string_view worldspace, const TilePosition& tilePosition); }; struct DeleteTilesAtExcept { static std::string_view text() noexcept; static void bind(sqlite3& db, sqlite3_stmt& statement, std::string_view worldspace, const TilePosition& tilePosition, TileId excludeTileId); }; struct DeleteTilesOutsideRange { static std::string_view text() noexcept; static void bind( sqlite3& db, sqlite3_stmt& statement, std::string_view worldspace, const TilesPositionsRange& range); }; struct GetMaxShapeId { static std::string_view text() noexcept; static void bind(sqlite3&, sqlite3_stmt&) {} }; struct FindShapeId { static std::string_view text() noexcept; static void bind(sqlite3& db, sqlite3_stmt& statement, std::string_view name, ShapeType type, const Sqlite3::ConstBlob& hash); }; struct InsertShape { static std::string_view text() noexcept; static void bind(sqlite3& db, sqlite3_stmt& statement, ShapeId shapeId, std::string_view name, ShapeType type, const Sqlite3::ConstBlob& hash); }; struct Vacuum { static std::string_view text() noexcept; static void bind(sqlite3&, sqlite3_stmt&) {} }; } class NavMeshDb { public: explicit NavMeshDb(std::string_view path, std::uint64_t maxFileSize); Sqlite3::Transaction startTransaction(Sqlite3::TransactionMode mode = Sqlite3::TransactionMode::Default); TileId getMaxTileId(); std::optional findTile( ESM::RefId worldspace, const TilePosition& tilePosition, const std::vector& input); std::optional getTileData( ESM::RefId worldspace, const TilePosition& tilePosition, const std::vector& input); int insertTile(TileId tileId, ESM::RefId worldspace, const TilePosition& tilePosition, TileVersion version, const std::vector& input, const std::vector& data); int updateTile(TileId tileId, TileVersion version, const std::vector& data); int deleteTilesAt(ESM::RefId worldspace, const TilePosition& tilePosition); int deleteTilesAtExcept(ESM::RefId worldspace, const TilePosition& tilePosition, TileId excludeTileId); int deleteTilesOutsideRange(ESM::RefId worldspace, const TilesPositionsRange& range); ShapeId getMaxShapeId(); std::optional findShapeId(std::string_view name, ShapeType type, const Sqlite3::ConstBlob& hash); int insertShape(ShapeId shapeId, std::string_view name, ShapeType type, const Sqlite3::ConstBlob& hash); void vacuum(); private: Sqlite3::Db mDb; Sqlite3::Statement mGetMaxTileId; Sqlite3::Statement mFindTile; Sqlite3::Statement mGetTileData; Sqlite3::Statement mInsertTile; Sqlite3::Statement mUpdateTile; Sqlite3::Statement mDeleteTilesAt; Sqlite3::Statement mDeleteTilesAtExcept; Sqlite3::Statement mDeleteTilesOutsideRange; Sqlite3::Statement mGetMaxShapeId; Sqlite3::Statement mFindShapeId; Sqlite3::Statement mInsertShape; Sqlite3::Statement mVacuum; }; } #endif