2013-12-30 23:09:58 +00:00
|
|
|
/*
|
2017-07-13 11:26:03 +03:00
|
|
|
* MapFormatJson.h, part of VCMI engine
|
2013-12-30 23:09:58 +00:00
|
|
|
*
|
|
|
|
* Authors: listed in file AUTHORS in main folder
|
|
|
|
*
|
|
|
|
* License: GNU General Public License v2.0 or later
|
|
|
|
* Full text of license available in license.txt file, in main folder
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "CMapService.h"
|
|
|
|
#include "../JsonNode.h"
|
|
|
|
|
2015-08-11 21:20:13 +03:00
|
|
|
#include "../filesystem/CZipSaver.h"
|
|
|
|
#include "../filesystem/CZipLoader.h"
|
2015-11-13 17:47:47 +03:00
|
|
|
#include "../GameConstants.h"
|
2015-08-11 21:20:13 +03:00
|
|
|
|
2016-11-13 13:38:42 +03:00
|
|
|
#include "../serializer/JsonSerializeFormat.h"
|
|
|
|
|
2022-07-26 16:07:42 +03:00
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2016-09-08 19:42:59 +03:00
|
|
|
struct TriggeredEvent;
|
2015-08-18 01:56:16 +03:00
|
|
|
struct TerrainTile;
|
2015-08-20 06:16:31 +03:00
|
|
|
struct PlayerInfo;
|
2015-11-13 17:47:47 +03:00
|
|
|
class CGObjectInstance;
|
|
|
|
class AObjectTypeHandler;
|
2016-02-14 14:22:46 +03:00
|
|
|
|
|
|
|
class JsonSerializeFormat;
|
2016-02-13 10:47:40 +03:00
|
|
|
class JsonDeserializer;
|
|
|
|
class JsonSerializer;
|
2013-12-30 23:09:58 +00:00
|
|
|
|
2015-08-07 22:33:44 +03:00
|
|
|
class DLL_LINKAGE CMapFormatJson
|
|
|
|
{
|
2015-11-13 17:47:47 +03:00
|
|
|
public:
|
2015-08-12 03:31:06 +03:00
|
|
|
static const int VERSION_MAJOR;
|
2015-11-13 17:47:47 +03:00
|
|
|
static const int VERSION_MINOR;
|
2015-08-07 22:33:44 +03:00
|
|
|
|
2015-11-13 17:47:47 +03:00
|
|
|
static const std::string HEADER_FILE_NAME;
|
|
|
|
static const std::string OBJECTS_FILE_NAME;
|
2016-02-22 23:43:57 +03:00
|
|
|
|
|
|
|
int fileVersionMajor;
|
|
|
|
int fileVersionMinor;
|
2015-08-07 22:33:44 +03:00
|
|
|
protected:
|
2016-11-13 13:38:42 +03:00
|
|
|
friend class MapObjectResolver;
|
|
|
|
std::unique_ptr<IInstanceResolver> mapObjectResolver;
|
2015-11-13 17:47:47 +03:00
|
|
|
|
2015-08-07 22:33:44 +03:00
|
|
|
/** ptr to the map object which gets filled by data from the buffer or written to buffer */
|
|
|
|
CMap * map;
|
|
|
|
|
|
|
|
/**
|
2015-08-14 05:22:24 +03:00
|
|
|
* ptr to the map header object which gets filled by data from the buffer.
|
2015-08-07 22:33:44 +03:00
|
|
|
* (when loading map and mapHeader point to the same object)
|
|
|
|
*/
|
2016-02-13 15:22:26 +03:00
|
|
|
CMapHeader * mapHeader;
|
2015-11-13 17:47:47 +03:00
|
|
|
|
2016-11-13 13:38:42 +03:00
|
|
|
CMapFormatJson();
|
|
|
|
|
2016-02-14 14:22:46 +03:00
|
|
|
void serializeAllowedFactions(JsonSerializeFormat & handler, std::set<TFaction> & value);
|
|
|
|
|
|
|
|
///common part of header saving/loading
|
|
|
|
void serializeHeader(JsonSerializeFormat & handler);
|
|
|
|
|
|
|
|
///player information saving/loading
|
|
|
|
void serializePlayerInfo(JsonSerializeFormat & handler);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads team settings to header
|
|
|
|
*/
|
|
|
|
void readTeams(JsonDeserializer & handler);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves team settings to header
|
|
|
|
*/
|
|
|
|
void writeTeams(JsonSerializer & handler);
|
|
|
|
|
2015-08-07 22:33:44 +03:00
|
|
|
/**
|
|
|
|
* Reads triggered events, including victory/loss conditions
|
|
|
|
*/
|
2016-02-13 15:22:26 +03:00
|
|
|
void readTriggeredEvents(JsonDeserializer & handler);
|
2015-08-07 22:33:44 +03:00
|
|
|
|
2015-08-14 05:22:24 +03:00
|
|
|
/**
|
|
|
|
* Writes triggered events, including victory/loss conditions
|
|
|
|
*/
|
2016-02-14 14:22:46 +03:00
|
|
|
void writeTriggeredEvents(JsonSerializer & handler);
|
2015-08-14 05:22:24 +03:00
|
|
|
|
2015-08-07 22:33:44 +03:00
|
|
|
/**
|
|
|
|
* Reads one of triggered events
|
|
|
|
*/
|
2015-08-14 05:22:24 +03:00
|
|
|
void readTriggeredEvent(TriggeredEvent & event, const JsonNode & source);
|
2015-11-13 17:47:47 +03:00
|
|
|
|
2015-08-14 05:22:24 +03:00
|
|
|
/**
|
|
|
|
* Writes one of triggered events
|
|
|
|
*/
|
2015-11-13 17:47:47 +03:00
|
|
|
void writeTriggeredEvent(const TriggeredEvent & event, JsonNode & dest);
|
2016-02-21 20:58:09 +03:00
|
|
|
|
2016-11-13 13:38:42 +03:00
|
|
|
void writeDisposedHeroes(JsonSerializeFormat & handler);
|
|
|
|
|
|
|
|
void readDisposedHeroes(JsonSerializeFormat & handler);
|
2016-02-21 20:58:09 +03:00
|
|
|
|
2016-11-13 13:38:42 +03:00
|
|
|
void serializePredefinedHeroes(JsonSerializeFormat & handler);
|
|
|
|
|
|
|
|
void serializeRumors(JsonSerializeFormat & handler);
|
2016-02-21 20:58:09 +03:00
|
|
|
|
|
|
|
///common part of map attributes saving/loading
|
|
|
|
void serializeOptions(JsonSerializeFormat & handler);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads map attributes except header ones
|
|
|
|
*/
|
|
|
|
void readOptions(JsonDeserializer & handler);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves map attributes except header ones
|
|
|
|
*/
|
|
|
|
void writeOptions(JsonSerializer & handler);
|
2015-08-07 22:33:44 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
class DLL_LINKAGE CMapPatcher : public CMapFormatJson, public IMapPatcher
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Default constructor.
|
|
|
|
*
|
|
|
|
* @param stream. A stream containing the map data.
|
|
|
|
*/
|
|
|
|
CMapPatcher(JsonNode stream);
|
2015-11-13 17:47:47 +03:00
|
|
|
|
2015-08-07 22:33:44 +03:00
|
|
|
public: //IMapPatcher
|
|
|
|
/**
|
|
|
|
* Modifies supplied map header using Json data
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void patchMapHeader(std::unique_ptr<CMapHeader> & header) override;
|
2015-11-13 17:47:47 +03:00
|
|
|
|
2015-08-07 22:33:44 +03:00
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* Reads subset of header that can be replaced by patching.
|
|
|
|
*/
|
|
|
|
void readPatchData();
|
|
|
|
|
2016-02-13 15:22:26 +03:00
|
|
|
JsonNode input;
|
2015-08-07 22:33:44 +03:00
|
|
|
};
|
|
|
|
|
2016-02-10 07:28:00 +03:00
|
|
|
class DLL_LINKAGE CMapLoaderJson : public CMapFormatJson, public IMapLoader
|
2013-12-30 23:09:58 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2015-11-13 17:47:47 +03:00
|
|
|
* Constructor.
|
2013-12-30 23:09:58 +00:00
|
|
|
*
|
|
|
|
* @param stream a stream containing the map data
|
|
|
|
*/
|
2016-02-10 07:28:00 +03:00
|
|
|
CMapLoaderJson(CInputStream * stream);
|
2013-12-30 23:09:58 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads the VCMI/Json map file.
|
|
|
|
*
|
|
|
|
* @return a unique ptr of the loaded map class
|
|
|
|
*/
|
2015-10-12 16:47:10 +03:00
|
|
|
std::unique_ptr<CMap> loadMap() override;
|
2013-12-30 23:09:58 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads the VCMI/Json map header.
|
|
|
|
*
|
|
|
|
* @return a unique ptr of the loaded map header class
|
|
|
|
*/
|
2015-10-12 16:47:10 +03:00
|
|
|
std::unique_ptr<CMapHeader> loadMapHeader() override;
|
2013-12-30 23:09:58 +00:00
|
|
|
|
2015-11-13 17:47:47 +03:00
|
|
|
struct MapObjectLoader
|
|
|
|
{
|
2016-02-22 02:37:19 +03:00
|
|
|
MapObjectLoader(CMapLoaderJson * _owner, JsonMap::value_type & json);
|
2015-11-13 17:47:47 +03:00
|
|
|
CMapLoaderJson * owner;
|
|
|
|
CGObjectInstance * instance;
|
|
|
|
ObjectInstanceID id;
|
|
|
|
std::string jsonKey;//full id defined by map creator
|
2016-02-22 02:37:19 +03:00
|
|
|
JsonNode & configuration;
|
2016-02-22 19:26:42 +03:00
|
|
|
|
2015-11-13 17:47:47 +03:00
|
|
|
///constructs object (without configuration)
|
|
|
|
void construct();
|
|
|
|
|
|
|
|
///configures object
|
|
|
|
void configure();
|
|
|
|
};
|
|
|
|
|
2013-12-30 23:09:58 +00:00
|
|
|
/**
|
|
|
|
* Reads the map header.
|
|
|
|
*/
|
2016-02-21 20:58:09 +03:00
|
|
|
void readHeader(const bool complete);
|
2013-12-30 23:09:58 +00:00
|
|
|
|
|
|
|
/**
|
2016-02-14 14:22:46 +03:00
|
|
|
* Reads complete map.
|
2015-11-13 17:47:47 +03:00
|
|
|
*/
|
2016-02-14 14:22:46 +03:00
|
|
|
void readMap();
|
2015-11-13 17:47:47 +03:00
|
|
|
|
2017-08-03 13:50:54 +03:00
|
|
|
static void readTerrainTile(const std::string & src, TerrainTile & tile);
|
2015-11-13 17:47:47 +03:00
|
|
|
|
|
|
|
void readTerrainLevel(const JsonNode & src, const int index);
|
|
|
|
|
2015-08-18 01:56:16 +03:00
|
|
|
void readTerrain();
|
2015-11-13 17:47:47 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads all map objects from zip archive
|
|
|
|
*/
|
|
|
|
void readObjects();
|
|
|
|
|
2016-02-22 02:37:19 +03:00
|
|
|
JsonNode getFromArchive(const std::string & archiveFilename);
|
2015-11-13 17:47:47 +03:00
|
|
|
|
2017-08-03 13:50:54 +03:00
|
|
|
private:
|
2016-02-10 07:28:00 +03:00
|
|
|
CInputStream * buffer;
|
|
|
|
std::shared_ptr<CIOApi> ioApi;
|
|
|
|
|
2015-11-13 17:47:47 +03:00
|
|
|
CZipLoader loader;///< object to handle zip archive operations
|
2013-12-30 23:09:58 +00:00
|
|
|
};
|
2015-08-08 17:30:19 +03:00
|
|
|
|
2016-02-10 07:28:00 +03:00
|
|
|
class DLL_LINKAGE CMapSaverJson : public CMapFormatJson, public IMapSaver
|
2015-08-08 17:30:19 +03:00
|
|
|
{
|
|
|
|
public:
|
2015-08-08 18:35:54 +03:00
|
|
|
/**
|
2015-11-13 17:47:47 +03:00
|
|
|
* Constructor.
|
2015-08-08 18:35:54 +03:00
|
|
|
*
|
2015-11-13 17:47:47 +03:00
|
|
|
* @param stream a stream to save the map to, will contain zip archive
|
2015-08-08 18:35:54 +03:00
|
|
|
*/
|
2015-11-13 17:47:47 +03:00
|
|
|
CMapSaverJson(CInputOutputStream * stream);
|
|
|
|
|
2015-08-11 21:20:13 +03:00
|
|
|
~CMapSaverJson();
|
2015-11-13 17:47:47 +03:00
|
|
|
|
2015-08-08 18:35:54 +03:00
|
|
|
/**
|
|
|
|
* Actually saves the VCMI/Json map into stream.
|
2015-11-13 17:47:47 +03:00
|
|
|
*/
|
|
|
|
void saveMap(const std::unique_ptr<CMap> & map) override;
|
|
|
|
|
2015-08-18 01:56:16 +03:00
|
|
|
/**
|
2015-11-13 17:47:47 +03:00
|
|
|
* Saves @data as json file with specified @filename
|
|
|
|
*/
|
2015-08-18 01:56:16 +03:00
|
|
|
void addToArchive(const JsonNode & data, const std::string & filename);
|
2015-11-13 17:47:47 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves header to zip archive
|
|
|
|
*/
|
2015-08-18 01:56:16 +03:00
|
|
|
void writeHeader();
|
2015-08-19 21:02:30 +03:00
|
|
|
|
2015-11-13 17:47:47 +03:00
|
|
|
/**
|
|
|
|
* Encodes one tile into string
|
|
|
|
* @param tile tile to serialize
|
|
|
|
*/
|
2017-08-03 13:50:54 +03:00
|
|
|
static std::string writeTerrainTile(const TerrainTile & tile);
|
2015-11-13 17:47:47 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves map level into json
|
|
|
|
* @param index z coordinate
|
|
|
|
*/
|
2015-08-18 01:56:16 +03:00
|
|
|
JsonNode writeTerrainLevel(const int index);
|
2015-11-13 17:47:47 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves all terrain into zip archive
|
|
|
|
*/
|
2015-08-18 01:56:16 +03:00
|
|
|
void writeTerrain();
|
2015-11-13 17:47:47 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves all map objects into zip archive
|
|
|
|
*/
|
|
|
|
void writeObjects();
|
|
|
|
|
2017-08-03 13:50:54 +03:00
|
|
|
private:
|
2016-02-10 07:28:00 +03:00
|
|
|
CInputOutputStream * buffer;
|
|
|
|
std::shared_ptr<CIOApi> ioApi;
|
2015-11-13 17:47:47 +03:00
|
|
|
CZipSaver saver;///< object to handle zip archive operations
|
2015-08-08 17:30:19 +03:00
|
|
|
};
|
2022-07-26 16:07:42 +03:00
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|