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:
41  static const bool findAndReplaceString(std::string &paramString,
42  const std::string &searchString,
43  const std::string &replaceString);
45  bool open(const std::string &fileName, bool internal = false);
47  bool save(const std::string &fileName);
48  bool close();
50  bool substitute(const std::string &searchString, const std::string &replaceString);
52  bool insert(const std::string &atLine, const std::vector<std::string> &content);
54  bool insert(const std::string atLine, const L1GtVhdlTemplateFile &file);
56  void print() const;
58  void printParameterMap() const;
60  std::vector<std::string> returnLines() const;
62  std::map<std::string, std::string> returnParameterMap() const;
64  std::vector<std::string> getSubstitutionParametersFromTemplate() const;
67  bool extractParametersFromString(const std::string &str, std::vector<std::string> &parameters) const;
69  void append(const std::string &str);
71  void append(const L1GtVhdlTemplateFile &file);
75  bool removeEmptyLines();
77  bool isBlank(const char &chr) const;
79  bool split(const std::string &param, std::vector<std::string> &result) const;
81  void getConditionsFromAlgo(std::string condString, std::vector<std::string> &result) const;
83  std::string lines2String() const;
85  std::string getInternalParameter(const std::string &indentifier);
86 };
87 #endif /*L1GtConfigProducers_L1GtVhdlTemplateFile_h*/
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
std::string lines2String() const
returns a string with the content of vector lines
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 getConditionsFromAlgo(std::string condString, std::vector< std::string > &result) const
extracts all conditions from a algorithm
void replaceString(std::string &demangledName, std::string const &from, std::string const &to)
bool removeLineWithContent(const std::string &str)
removes all lines that contain the str
L1GtVhdlTemplateFile()
standard constructor
void print() const
prints the content of the VHDL File (only lines_)
std::vector< std::string > returnLines() const
returns a string vector with the current content of the VHDL File
void append(const std::string &str)
adds a line at the end of the the file with the content of str
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::map< std::string, std::string > returnParameterMap() const
returns parameter map
bool isBlank(const char &chr) const
checks weather a char is a blank
bool split(const std::string &param, std::vector< std::string > &result) const
seperates a string at all blanks and saves the elements in result
void printParameterMap() const
prints the parameter map
bool extractParametersFromString(const std::string &str, std::vector< std::string > &parameters) const
#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 ...