CMS 3D CMS Logo

L1GtVhdlTemplateFile.h
Go to the documentation of this file.
1 #ifndef L1GtConfigProducers_L1GtVhdlTemplateFile_h
2 #define L1GtConfigProducers_L1GtVhdlTemplateFile_h
3 
19 // system include files
20 
21 #include <map>
22 #include <string>
23 #include <vector>
24 
26 private:
29  bool intern_;
31  std::vector<std::string> lines_;
33  std::map<std::string, std::string> parameterMap_;
34 
35 public:
45  static const bool findAndReplaceString(std::string &paramString,
46  const std::string &searchString,
47  const std::string &replaceString);
49  bool open(const std::string &fileName, bool internal = false);
51  bool save(const std::string &fileName);
52  bool close();
54  bool substitute(const std::string &searchString, const std::string &replaceString);
56  bool insert(const std::string &atLine, const std::vector<std::string> &content);
58  bool insert(const std::string atLine, const L1GtVhdlTemplateFile &file);
60  void print() const;
62  void printParameterMap() const;
64  std::vector<std::string> returnLines() const;
66  std::map<std::string, std::string> returnParameterMap() const;
68  std::vector<std::string> getSubstitutionParametersFromTemplate() const;
71  bool extractParametersFromString(const std::string &str, std::vector<std::string> &parameters) const;
73  void append(const std::string &str);
75  void append(const L1GtVhdlTemplateFile &file);
79  bool removeEmptyLines();
81  bool isBlank(const char &chr) const;
83  bool split(const std::string &param, std::vector<std::string> &result) const;
85  void getConditionsFromAlgo(std::string condString, std::vector<std::string> &result) const;
87  std::string lines2String() const;
89  std::string getInternalParameter(const std::string &indentifier);
90 };
91 #endif /*L1GtConfigProducers_L1GtVhdlTemplateFile_h*/
bool split(const std::string &param, std::vector< std::string > &result) const
seperates a string at all blanks and saves the elements in result
std::string lines2String() const
returns a string with the content of vector lines
bool extractParametersFromString(const std::string &str, std::vector< std::string > &parameters) const
std::map< std::string, std::string > parameterMap_
containing the header information of internal files
static const bool findAndReplaceString(std::string &paramString, const std::string &searchString, const std::string &replaceString)
replaces searchString with replaceString at it&#39;s first occurance in string
bool substitute(const std::string &searchString, const std::string &replaceString)
replaces searchString with replaceString
void printParameterMap() const
prints the parameter map
bool save(const std::string &fileName)
saves the content of the template file to a local file (the content of parameterMap_ will not be save...
std::vector< std::string > getSubstitutionParametersFromTemplate() const
returns a vector with all substitution parameters that are found in the template file ...
void replaceString(std::string &demangledName, std::string const &from, std::string const &to)
~L1GtVhdlTemplateFile()
destructor
bool removeLineWithContent(const std::string &str)
removes all lines that contain the str
L1GtVhdlTemplateFile()
standard constructor
void append(const std::string &str)
adds a line at the end of the the file with the content of str
bool isBlank(const char &chr) const
checks weather a char is a blank
std::string getInternalParameter(const std::string &indentifier)
returns a parameter of a internal template file
bool insert(const std::string &atLine, const std::vector< std::string > &content)
replaces the whole line containing atLine and inserts content instead of it
std::vector< std::string > lines_
containing the content of the VHDL file
std::vector< std::string > returnLines() const
returns a string vector with the current content of the VHDL File
#define str(s)
bool removeEmptyLines()
deletes all empty lines in a template file
bool open(const std::string &fileName, bool internal=false)
opens a template file. If the header information shall be parsed intern has to be set to true ...
std::map< std::string, std::string > returnParameterMap() const
returns parameter map
void getConditionsFromAlgo(std::string condString, std::vector< std::string > &result) const
extracts all conditions from a algorithm
void print() const
prints the content of the VHDL File (only lines_)