2013-02-04 13:29:59 +03:00
|
|
|
/*
|
|
|
|
* MapFormatH3M.h, part of VCMI engine
|
|
|
|
*
|
|
|
|
* 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"
|
2023-04-02 18:56:10 +02:00
|
|
|
#include "MapFeaturesH3M.h"
|
2013-02-07 20:02:15 +03:00
|
|
|
|
2022-07-26 15:07:42 +02:00
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2013-02-04 13:29:59 +03:00
|
|
|
class CGHeroInstance;
|
2023-04-02 18:56:10 +02:00
|
|
|
class MapReaderH3M;
|
2023-09-27 23:11:11 +02:00
|
|
|
class MetaString;
|
2013-02-04 13:29:59 +03:00
|
|
|
class CArtifactInstance;
|
|
|
|
class CGObjectInstance;
|
|
|
|
class CGSeerHut;
|
|
|
|
class IQuestObject;
|
|
|
|
class CGTownInstance;
|
|
|
|
class CCreatureSet;
|
|
|
|
class CInputStream;
|
2023-02-25 17:44:15 +02:00
|
|
|
class TextIdentifier;
|
2023-04-03 21:41:05 +02:00
|
|
|
class CGPandoraBox;
|
2013-02-04 13:29:59 +03:00
|
|
|
|
2023-04-02 18:56:10 +02:00
|
|
|
class ObjectInstanceID;
|
|
|
|
class BuildingID;
|
|
|
|
class ObjectTemplate;
|
|
|
|
class SpellID;
|
2023-04-11 16:45:22 +02:00
|
|
|
class PlayerColor;
|
2023-04-02 18:56:10 +02:00
|
|
|
class int3;
|
2013-02-04 13:29:59 +03:00
|
|
|
|
|
|
|
class DLL_LINKAGE CMapLoaderH3M : public IMapLoader
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Default constructor.
|
|
|
|
*
|
|
|
|
* @param stream a stream containing the map data
|
|
|
|
*/
|
2023-02-25 17:44:15 +02:00
|
|
|
CMapLoaderH3M(const std::string & mapName, const std::string & modName, const std::string & encodingName, CInputStream * stream);
|
2013-02-04 13:29:59 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Destructor.
|
|
|
|
*/
|
|
|
|
~CMapLoaderH3M();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads the VCMI/H3 map file.
|
|
|
|
*
|
|
|
|
* @return a unique ptr of the loaded map class
|
|
|
|
*/
|
2015-10-12 15:47:10 +02:00
|
|
|
std::unique_ptr<CMap> loadMap() override;
|
2013-02-04 13:29:59 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads the VCMI/H3 map header.
|
|
|
|
*
|
|
|
|
* @return a unique ptr of the loaded map header class
|
|
|
|
*/
|
2015-10-12 15:47:10 +02:00
|
|
|
std::unique_ptr<CMapHeader> loadMapHeader() override;
|
2013-02-04 13:29:59 +03:00
|
|
|
|
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* Initializes the map object from parsing the input buffer.
|
|
|
|
*/
|
|
|
|
void init();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads the map header.
|
|
|
|
*/
|
|
|
|
void readHeader();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads player information.
|
|
|
|
*/
|
|
|
|
void readPlayerInfo();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads victory/loss conditions.
|
|
|
|
*/
|
|
|
|
void readVictoryLossConditions();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads team information.
|
|
|
|
*/
|
|
|
|
void readTeamInfo();
|
|
|
|
|
2023-04-03 19:51:02 +02:00
|
|
|
/**
|
|
|
|
* Reads the list of map flags.
|
|
|
|
*/
|
|
|
|
void readMapOptions();
|
|
|
|
|
2013-02-04 13:29:59 +03:00
|
|
|
/**
|
|
|
|
* Reads the list of allowed heroes.
|
|
|
|
*/
|
|
|
|
void readAllowedHeroes();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads the list of disposed heroes.
|
|
|
|
*/
|
|
|
|
void readDisposedHeroes();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads the list of allowed artifacts.
|
|
|
|
*/
|
|
|
|
void readAllowedArtifacts();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads the list of allowed spells and abilities.
|
|
|
|
*/
|
|
|
|
void readAllowedSpellsAbilities();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads artifacts of a hero.
|
|
|
|
*
|
|
|
|
* @param hero the hero which should hold those artifacts
|
|
|
|
*/
|
|
|
|
void loadArtifactsOfHero(CGHeroInstance * hero);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads an artifact to the given slot of the specified hero.
|
|
|
|
*
|
|
|
|
* @param hero the hero which should hold that artifact
|
|
|
|
* @param slot the artifact slot where to place that artifact
|
|
|
|
* @return true if it loaded an artifact
|
|
|
|
*/
|
|
|
|
bool loadArtifactToSlot(CGHeroInstance * hero, int slot);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Read rumors.
|
|
|
|
*/
|
|
|
|
void readRumors();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads predefined heroes.
|
|
|
|
*/
|
|
|
|
void readPredefinedHeroes();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads terrain data.
|
|
|
|
*/
|
|
|
|
void readTerrain();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads custom(map) def information.
|
|
|
|
*/
|
2023-05-24 00:14:06 +02:00
|
|
|
void readObjectTemplates();
|
2013-02-04 13:29:59 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads objects(towns, mines,...).
|
|
|
|
*/
|
|
|
|
void readObjects();
|
|
|
|
|
2023-04-03 21:41:05 +02:00
|
|
|
/// Reads single object from input stream based on template
|
|
|
|
CGObjectInstance * readObject(std::shared_ptr<const ObjectTemplate> objectTemplate, const int3 & objectPosition, const ObjectInstanceID & idToBeGiven);
|
|
|
|
|
2023-09-17 15:06:49 +02:00
|
|
|
CGObjectInstance * readEvent(const int3 & objectPosition, const ObjectInstanceID & idToBeGiven);
|
2023-04-03 21:41:05 +02:00
|
|
|
CGObjectInstance * readMonster(const int3 & objectPosition, const ObjectInstanceID & idToBeGiven);
|
|
|
|
CGObjectInstance * readHero(const int3 & initialPos, const ObjectInstanceID & idToBeGiven);
|
2023-09-17 15:06:49 +02:00
|
|
|
CGObjectInstance * readSeerHut(const int3 & initialPos, const ObjectInstanceID & idToBeGiven);
|
2023-04-03 21:41:05 +02:00
|
|
|
CGObjectInstance * readTown(const int3 & position, std::shared_ptr<const ObjectTemplate> objTempl);
|
|
|
|
CGObjectInstance * readSign(const int3 & position);
|
2023-09-30 17:47:47 +02:00
|
|
|
CGObjectInstance * readWitchHut(const int3 & position, std::shared_ptr<const ObjectTemplate> objectTemplate);
|
2023-10-04 18:32:16 +02:00
|
|
|
CGObjectInstance * readScholar(const int3 & position, std::shared_ptr<const ObjectTemplate> objectTemplate);
|
2023-04-11 16:45:22 +02:00
|
|
|
CGObjectInstance * readGarrison(const int3 & mapPosition);
|
2023-04-03 21:41:05 +02:00
|
|
|
CGObjectInstance * readArtifact(const int3 & position, std::shared_ptr<const ObjectTemplate> objTempl);
|
|
|
|
CGObjectInstance * readResource(const int3 & position, std::shared_ptr<const ObjectTemplate> objTempl);
|
|
|
|
CGObjectInstance * readMine(const int3 & position, std::shared_ptr<const ObjectTemplate> objTempl);
|
2023-09-17 15:06:49 +02:00
|
|
|
CGObjectInstance * readPandora(const int3 & position, const ObjectInstanceID & idToBeGiven);
|
2023-04-03 21:41:05 +02:00
|
|
|
CGObjectInstance * readDwelling(const int3 & position);
|
|
|
|
CGObjectInstance * readDwellingRandom(const int3 & position, std::shared_ptr<const ObjectTemplate> objTempl);
|
2023-10-04 15:49:17 +02:00
|
|
|
CGObjectInstance * readShrine(const int3 & position, std::shared_ptr<const ObjectTemplate> objectTemplate);
|
2023-04-03 21:41:05 +02:00
|
|
|
CGObjectInstance * readHeroPlaceholder(const int3 & position);
|
2023-04-12 00:02:01 +02:00
|
|
|
CGObjectInstance * readGrail(const int3 & position, std::shared_ptr<const ObjectTemplate> objectTemplate);
|
2023-04-03 21:41:05 +02:00
|
|
|
CGObjectInstance * readPyramid(const int3 & position, std::shared_ptr<const ObjectTemplate> objTempl);
|
|
|
|
CGObjectInstance * readQuestGuard(const int3 & position);
|
2023-06-07 23:04:13 +02:00
|
|
|
CGObjectInstance * readShipyard(const int3 & mapPosition, std::shared_ptr<const ObjectTemplate> objectTemplate);
|
2023-04-11 16:45:22 +02:00
|
|
|
CGObjectInstance * readLighthouse(const int3 & mapPosition);
|
2023-04-05 13:08:41 +02:00
|
|
|
CGObjectInstance * readGeneric(const int3 & position, std::shared_ptr<const ObjectTemplate> objectTemplate);
|
2023-04-04 12:45:31 +02:00
|
|
|
CGObjectInstance * readBank(const int3 & position, std::shared_ptr<const ObjectTemplate> objectTemplate);
|
2023-04-03 21:41:05 +02:00
|
|
|
|
2013-02-04 13:29:59 +03:00
|
|
|
/**
|
|
|
|
* Reads a creature set.
|
|
|
|
*
|
|
|
|
* @param out the loaded creature set
|
|
|
|
* @param number the count of creatures to read
|
|
|
|
*/
|
2013-02-05 00:58:42 +03:00
|
|
|
void readCreatureSet(CCreatureSet * out, int number);
|
2013-02-04 13:29:59 +03:00
|
|
|
|
|
|
|
/**
|
2023-04-03 21:41:05 +02:00
|
|
|
* Reads a quest for the given quest guard.
|
2013-02-04 13:29:59 +03:00
|
|
|
*
|
2023-04-03 21:41:05 +02:00
|
|
|
* @param guard the quest guard where that quest should be applied to
|
2013-02-04 13:29:59 +03:00
|
|
|
*/
|
2023-09-17 15:06:49 +02:00
|
|
|
void readBoxContent(CGPandoraBox * object, const int3 & position, const ObjectInstanceID & idToBeGiven);
|
2013-02-04 13:29:59 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads a quest for the given quest guard.
|
|
|
|
*
|
|
|
|
* @param guard the quest guard where that quest should be applied to
|
|
|
|
*/
|
2023-10-09 19:15:34 +02:00
|
|
|
int readQuest(IQuestObject * guard, const int3 & position);
|
2013-02-04 13:29:59 +03:00
|
|
|
|
2023-09-17 15:06:49 +02:00
|
|
|
void readSeerHutQuest(CGSeerHut * hut, const int3 & position, const ObjectInstanceID & idToBeGiven);
|
2023-04-05 00:08:24 +02:00
|
|
|
|
2013-02-04 13:29:59 +03:00
|
|
|
/**
|
|
|
|
* Reads events.
|
|
|
|
*/
|
|
|
|
void readEvents();
|
|
|
|
|
2013-02-07 20:02:15 +03:00
|
|
|
/**
|
|
|
|
* read optional message and optional guards
|
|
|
|
*/
|
2023-09-27 23:11:11 +02:00
|
|
|
void readMessageAndGuards(MetaString & message, CCreatureSet * guards, const int3 & position);
|
2013-02-07 20:02:15 +03:00
|
|
|
|
2023-02-24 16:15:45 +02:00
|
|
|
/// reads string from input stream and converts it to unicode
|
2023-02-25 17:44:15 +02:00
|
|
|
std::string readBasicString();
|
|
|
|
|
|
|
|
/// reads string from input stream, converts it to unicode and attempts to translate it
|
|
|
|
std::string readLocalizedString(const TextIdentifier & identifier);
|
2013-02-04 13:29:59 +03:00
|
|
|
|
2023-04-11 16:45:22 +02:00
|
|
|
void setOwnerAndValidate(const int3 & mapPosition, CGObjectInstance * object, const PlayerColor & owner);
|
2023-04-02 18:56:10 +02:00
|
|
|
|
2016-11-13 12:38:42 +02:00
|
|
|
void afterRead();
|
|
|
|
|
2023-04-02 18:56:10 +02:00
|
|
|
MapFormatFeaturesH3M features;
|
|
|
|
|
2014-01-03 02:48:38 +03:00
|
|
|
/** List of templates loaded from the map, used on later stage to create
|
|
|
|
* objects but not needed for fully functional CMap */
|
2022-09-11 15:12:35 +02:00
|
|
|
std::vector<std::shared_ptr<const ObjectTemplate>> templates;
|
2014-01-03 02:48:38 +03:00
|
|
|
|
2013-02-04 13:29:59 +03:00
|
|
|
/** ptr to the map object which gets filled by data from the buffer */
|
|
|
|
CMap * map;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ptr to the map header object which gets filled by data from the buffer.
|
|
|
|
* (when loading a map then the mapHeader ptr points to the same object)
|
|
|
|
*/
|
|
|
|
std::unique_ptr<CMapHeader> mapHeader;
|
2023-04-02 18:56:10 +02:00
|
|
|
std::unique_ptr<MapReaderH3M> reader;
|
2013-02-07 20:02:15 +03:00
|
|
|
CInputStream * inputStream;
|
2013-02-04 13:29:59 +03:00
|
|
|
|
2023-02-25 01:18:15 +02:00
|
|
|
std::string mapName;
|
2023-02-25 17:44:15 +02:00
|
|
|
std::string modName;
|
2023-02-25 01:18:15 +02:00
|
|
|
std::string fileEncoding;
|
|
|
|
|
2014-01-03 02:48:38 +03:00
|
|
|
};
|
2022-07-26 15:07:42 +02:00
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|