2017-06-06 18:22:54 -07:00
|
|
|
/*
|
|
|
|
* =====================================================================================
|
|
|
|
*
|
|
|
|
* Filename: EntityConverter.hpp
|
|
|
|
*
|
|
|
|
* Description: Convert reflex entities to xonotic entities
|
2017-07-02 20:22:09 -07:00
|
|
|
* - Simple; operates on single entity at a time
|
|
|
|
* - Only context provided is information on what entities are related.
|
|
|
|
* (i.e. a teleport and it's destination) Can get this information
|
|
|
|
* through the pre-scan constructor of the .map file or by providing
|
|
|
|
* a queue of all the entities in the file.
|
|
|
|
* - Throws exceptions upon encountering malformed entities and when
|
|
|
|
* IO errors occur during object instantiation
|
2017-06-06 18:22:54 -07:00
|
|
|
*
|
|
|
|
* Version: 1.0
|
|
|
|
* Created: 05/27/2017 08:21:14 AM
|
|
|
|
* Revision: none
|
|
|
|
* Compiler: gcc
|
|
|
|
*
|
|
|
|
* Author: suhrke@teknik.io
|
|
|
|
*
|
|
|
|
* =====================================================================================
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ENTITY_CONVERTER_HPP
|
|
|
|
#define ENTITY_CONVERTER_HPP
|
|
|
|
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
#include <string>
|
2017-07-03 18:10:05 -07:00
|
|
|
#include <queue>
|
2017-06-06 18:22:54 -07:00
|
|
|
#include <vector>
|
|
|
|
|
2017-07-05 16:00:22 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2017-07-05 11:53:45 -07:00
|
|
|
|
2017-06-06 18:22:54 -07:00
|
|
|
class EntityConverter
|
|
|
|
{
|
|
|
|
public:
|
2017-07-02 20:22:09 -07:00
|
|
|
/*
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
* Class: EntityConverter
|
|
|
|
* Method: Constructor
|
|
|
|
* Description: Creates entity format mapping
|
|
|
|
* CAUTION: Requires matchRelated method to be called after this
|
|
|
|
* Requires: .ent filename for mapping entities from reflex format to xonotic format
|
|
|
|
* THROWS: runtime_error on .ent format error
|
|
|
|
* THROWS: std::ios::failure on IO failure
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
EntityConverter(std::string entityMapFile);
|
2017-07-03 17:04:06 -07:00
|
|
|
/* *--------------------------------------------------------------------------------------
|
2017-07-02 20:22:09 -07:00
|
|
|
* Class: EntityConverter
|
|
|
|
* Method: Constructor
|
|
|
|
* Description: Creates entity format mapping and pre-scans for related entities
|
|
|
|
* Parameter: string entityMapFile, file maps source to target entity formats
|
|
|
|
* Parameter: string reflexMapFile, for pre-scan
|
|
|
|
* THROWS: runtime_error on .ent format error
|
|
|
|
* THROWS: std::ios::failure on IO failure
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
2017-06-07 01:46:43 -07:00
|
|
|
EntityConverter(std::string entityMapFile, std::string reflexMapFile);
|
2017-07-02 20:22:09 -07:00
|
|
|
/*
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
* Class: EntityConverter
|
|
|
|
* Method: EntityConverter :: convert
|
|
|
|
* Description: Converts a single entity from reflex to xonotic format
|
2017-07-02 23:41:59 -07:00
|
|
|
* Parameter: vector of strings lines, lines that comprise a single entity
|
2017-07-02 20:22:09 -07:00
|
|
|
* Return: vector of strings, single entity in the converted format
|
2017-07-05 03:21:51 -07:00
|
|
|
* *IF entity is not supported, returns EMPTY vector
|
2017-07-02 20:22:09 -07:00
|
|
|
* THROWS: runtime_error on malformed .map file
|
2017-07-02 23:41:59 -07:00
|
|
|
* THROWS: runtime_error when called before related entities are matched
|
2017-07-02 20:22:09 -07:00
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
2017-06-06 18:22:54 -07:00
|
|
|
std::vector<std::string> convert(std::vector<std::string> lines);
|
2017-07-02 23:41:59 -07:00
|
|
|
/*
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
* Class: EntityConverter
|
|
|
|
* Method: EntityConverter :: matchRelated
|
|
|
|
* Description: Finds related entities (targets of teleports, etc), call after parsing
|
|
|
|
* the entire .map
|
|
|
|
* Parameter: queue of vector of string entities, ALL entities in a .map file
|
|
|
|
* THROWS: runtime_error when encountering malformed entity
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
void matchRelated(std::queue<std::vector<std::string>> entities);
|
2017-07-02 20:22:09 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
2017-06-06 18:22:54 -07:00
|
|
|
protected:
|
2017-07-05 05:10:31 -07:00
|
|
|
|
2017-07-05 16:00:22 -07:00
|
|
|
|
2017-07-05 05:10:31 -07:00
|
|
|
/*
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
* Class: EntityConverter
|
2017-07-05 16:00:22 -07:00
|
|
|
* Method: EntityConverter :: convert~EntityName~
|
|
|
|
* Description: Multiple methods to convert entity from reflex to xonotic format
|
|
|
|
* Parameter: vector of strings entity, multi-lined entity
|
|
|
|
* Return: vector of strings, the converted entity
|
2017-07-05 05:10:31 -07:00
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
2017-07-05 16:00:22 -07:00
|
|
|
std::vector<std::string> convertPickup(std::vector<std::string> &entity);
|
|
|
|
std::vector<std::string> convertPlayerSpawn(std::vector<std::string> &entity);
|
|
|
|
std::vector<std::string> convertJumpPad(std::vector<std::string> &entity);
|
|
|
|
std::vector<std::string> convertTeleporter(std::vector<std::string> &entity);
|
|
|
|
std::vector<std::string> convertTarget(std::vector<std::string> &entity);
|
|
|
|
std::vector<std::string> convertRaceStart(std::vector<std::string> &entity);
|
|
|
|
std::vector<std::string> convertRaceFinish(std::vector<std::string> &entity);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Related entities must be matched prior to entity conversion
|
|
|
|
bool areEntitiesMatched_;
|
|
|
|
// Map Reflex pickup IDs to Xonotic pickup identifiers
|
|
|
|
std::map<int, std::string> pickupMapping_;
|
|
|
|
// Map targets (by name) to their source type
|
|
|
|
std::map<std::string, std::string> targetMap_;
|
|
|
|
// Offsets for item/spawn height
|
|
|
|
const float OFFSET_PLAYER;
|
|
|
|
const float OFFSET_PICKUP;
|
2017-07-05 05:10:31 -07:00
|
|
|
|
2017-07-05 16:00:22 -07:00
|
|
|
|
|
|
|
|
|
|
|
private:
|
2017-07-02 20:22:09 -07:00
|
|
|
/*
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
* Class: EntityConverter
|
|
|
|
* Method: EntityConverter :: getAttributeType
|
|
|
|
* Description: Extracts the type from a line
|
|
|
|
* Parameter: string "line", entity keyword followed by the type
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
2017-06-06 18:22:54 -07:00
|
|
|
std::string getAttributeType(std::string line);
|
2017-07-02 20:22:09 -07:00
|
|
|
/*
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
* Class: EntityConverter
|
|
|
|
* Method: EntityConverter :: mapEntities
|
|
|
|
* Description: Prepare pickupMapping_
|
|
|
|
* Parameter: string mapFile, filename of pickup mapping
|
|
|
|
* Return: true if no error, false if error
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
void mapEntities(std::string mapFile);
|
2017-07-03 22:19:50 -07:00
|
|
|
/*
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
* Class: EntityConverter
|
|
|
|
* Method: EntityConverter :: addIfRelated
|
|
|
|
* Description: If the entity contains a related target/etc, add to map
|
|
|
|
* Paramater: string line, the previous line (contains entity type)
|
|
|
|
* Parameter: istream is, an ifstream or a stringstream containing a
|
|
|
|
* single entity
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
void addIfRelated(std::string &line, std::istream &is);
|
2017-07-02 20:22:09 -07:00
|
|
|
/*
|
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
* Class: EntityConverter
|
2017-07-05 16:00:22 -07:00
|
|
|
* Method: EntityConverter :: offset
|
|
|
|
* Description: Reflex coordinates place entities at the ground and Xonotic entities
|
|
|
|
* are at about center of player height. Offset accordingly.
|
|
|
|
* Paramater: string value, float value passed as string
|
|
|
|
* Parameter: float offset, amount to add to value
|
|
|
|
* Return: string, float value passed as string
|
2017-07-02 20:22:09 -07:00
|
|
|
*--------------------------------------------------------------------------------------
|
|
|
|
*/
|
2017-07-05 16:00:22 -07:00
|
|
|
std::string offset(std::string value, float offset);
|
|
|
|
|
2017-07-02 20:22:09 -07:00
|
|
|
|
2017-07-05 05:10:31 -07:00
|
|
|
|
2017-06-07 01:46:43 -07:00
|
|
|
void printMapping(); //DEBUG
|
|
|
|
void printTargetSources(); //DEBUG
|
|
|
|
|
2017-06-06 18:22:54 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif //ENTITY_CONVERTER_HPP
|
|
|
|
|