/* * AsciiReader.hh * * Created on: 5 août 2013 * Author: CS */ #ifndef ASCIIREADER_HH_ #define ASCIIREADER_HH_ #include "AbstractReader.hh" #include <memory> namespace TimeTableCatalog { /** * Reads a TimeTable from an ASCII formated file. * Something like : * #Time Table generated by AMDA @ CDPP; * #Name: testTable_M_lll; * #Description: ; * #Historic: Union between testTable lll ; * #Creation Date : 2012-09-05T19:15:47; * # * 2001-02-07T18:39:11 2001-02-07T18:59:11 * 2001-02-07T19:49:11 2001-02-07T19:59:11 * 2001-02-08T02:29:11 2001-02-08T03:04:11 */ class AsciiReader: public AbstractReader { public: static const std::string FORMAT; AsciiReader(const std::string& ppath); virtual ~AsciiReader(); /** * Reads a TimeTable from an ASCII formated file. */ void read(TimeTable& ptt); /** * Checks the TT format to know if the reader is the good one. */ bool canRead(const std::string& pPath); /** * Creates an instance of this. */ std::unique_ptr<AbstractReader> createInstance(const std::string& pPath); ParameterDescription::ParameterType getTypeFromString(std::string type); private: /** * Reads an interval from ASCII formated file and creates a TimeInterval. */ std::unique_ptr<TimeInterval> readInterval(const std::string& pline, TimeTable& pTT, int pcrtIndex); /** * Reads metadata as name, description etc. from ASCII formated file. */ void readMetadata(const std::string& pline, TimeTable& ptimeTable); /** * Adds a line to TT description. */ void addDescription(const std::string & pline, TimeTable& ptt); /** * Adds a parameter description to a time table. */ void addParameter(const std::string & pline, TimeTable& ptt); int timeSize; }; } /* namespace TimeTableCatalog */ #endif /* ASCIIREADER_HH_ */