mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2024-12-26 23:43:34 +00:00
bad3845d83
* Implement a server res directory * Only convert if neither exist * Remove unzip, Update RegEx * readme updates Run setup after setting working dir Address several docker issues Revert "Run setup after setting working dir" This reverts commit fd2fb9228e82a350204c1ef61f7ba059479bb12f. Fix docker * Remove extra submodules * Rework logic * Switch if block * Remove need to extract fdb from client * Change log name * Update FdbToSqlite.cpp
146 lines
3.8 KiB
C++
146 lines
3.8 KiB
C++
#ifndef __FDBTOSQLITE__H__
|
|
#define __FDBTOSQLITE__H__
|
|
|
|
#pragma once
|
|
|
|
#include <cstdint>
|
|
#include <iosfwd>
|
|
#include <map>
|
|
|
|
class AssetMemoryBuffer;
|
|
|
|
enum class eSqliteDataType : int32_t;
|
|
|
|
namespace FdbToSqlite {
|
|
class Convert {
|
|
public:
|
|
/**
|
|
* Create a new convert object with an input .fdb file and an output binary path.
|
|
*
|
|
* @param inputFile The file which ends in .fdb to be converted
|
|
* @param binaryPath The base path where the file will be saved
|
|
*/
|
|
Convert(std::string binaryOutPath);
|
|
|
|
/**
|
|
* Converts the input file to sqlite. Calling multiple times is safe.
|
|
*
|
|
* @return true if the database was converted properly, false otherwise.
|
|
*/
|
|
bool ConvertDatabase(AssetMemoryBuffer& buffer);
|
|
|
|
/**
|
|
* @brief Reads a 32 bit int from the fdb file.
|
|
*
|
|
* @return The read value
|
|
*/
|
|
int32_t ReadInt32(std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Reads a 64 bit integer from the fdb file.
|
|
*
|
|
* @return The read value
|
|
*/
|
|
int64_t ReadInt64(std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Reads a string from the fdb file.
|
|
*
|
|
* @return The read string
|
|
*
|
|
* TODO This needs to be translated to latin-1!
|
|
*/
|
|
std::string ReadString(std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Seeks to a pointer position.
|
|
*
|
|
* @return The previous position before the seek
|
|
*/
|
|
int32_t SeekPointer(std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Reads a column header from the fdb file and creates the table in the database
|
|
*
|
|
* @return The table name
|
|
*/
|
|
std::string ReadColumnHeader(std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Read the tables from the fdb file.
|
|
*
|
|
* @param numberOfTables The number of tables to read
|
|
*/
|
|
void ReadTables(int32_t& numberOfTables, std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Reads the columns from the fdb file.
|
|
*
|
|
* @param numberOfColumns The number of columns to read
|
|
* @return All columns of the table formatted for a sql query
|
|
*/
|
|
std::string ReadColumns(int32_t& numberOfColumns, std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Reads the row header from the fdb file.
|
|
*
|
|
* @param tableName The tables name
|
|
*/
|
|
void ReadRowHeader(std::string& tableName, std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Read the rows from the fdb file.,
|
|
*
|
|
* @param numberOfAllocatedRows The number of rows that were allocated. Always a power of 2!
|
|
* @param tableName The tables name.
|
|
*/
|
|
void ReadRows(int32_t& numberOfAllocatedRows, std::string& tableName, std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Reads a row from the fdb file.
|
|
*
|
|
* @param position The position to seek in the fdb to
|
|
* @param tableName The tables name
|
|
*/
|
|
void ReadRow(int32_t& position, std::string& tableName, std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Reads the row info from the fdb file.
|
|
*
|
|
* @param tableName The tables name
|
|
*/
|
|
void ReadRowInfo(std::string& tableName, std::istream& cdClientBuffer);
|
|
|
|
/**
|
|
* @brief Reads each row and its values from the fdb file and inserts them into the database
|
|
*
|
|
* @param numberOfColumns The number of columns to read in
|
|
* @param tableName The tables name
|
|
*/
|
|
void ReadRowValues(int32_t& numberOfColumns, std::string& tableName, std::istream& cdClientBuffer);
|
|
private:
|
|
|
|
/**
|
|
* Maps each sqlite data type to its string equivalent.
|
|
*/
|
|
static std::map<eSqliteDataType, std::string> m_SqliteType;
|
|
|
|
/**
|
|
* Base path of the folder containing the fdb file
|
|
*/
|
|
std::string m_BasePath{};
|
|
|
|
/**
|
|
* Whether or not a conversion was started. If one was started, do not attempt to convert the file again.
|
|
*/
|
|
bool m_ConversionStarted{};
|
|
|
|
/**
|
|
* The path where the CDServer will be stored
|
|
*/
|
|
std::string m_BinaryOutPath{};
|
|
}; //! class FdbToSqlite
|
|
}; //! namespace FdbToSqlite
|
|
|
|
#endif //!__FDBTOSQLITE__H__
|