PhoenixGenerator  2.0.4
Set of tools to generate code
Loading...
Searching...
No Matches
generator_class_cpp.cpp File Reference
#include "phoenix_color.h"
#include "openFileStream.h"
#include "header_generator.h"
#include "cmakelist_generator.h"
#include "generator_class_cpp.h"
+ Include dependency graph for generator_class_cpp.cpp:

Go to the source code of this file.

Functions

void class_checkClassConfig (bool &hasSource, bool &hasTemplate, const std::vector< PClassConfig > &vecClassConfig)
 Check if the configuration has source or template to determine if the .cpp or _impl.h files have to be generated.
 
PString class_getClassDeclTempalteDef (const PVecString &listTemplate)
 Get the template definition in the class declaration.
 
PString class_getClassDefTemplate (const PVecString &listTemplate)
 Get the template call in the class declaration.
 
bool class_getIsPointer (const PString &varType)
 Check if the given type is a pointer or not.
 
void class_saveClassConstructorImpl (std::ofstream &fs, const PClassConfig &classConfig, const PString &defTemplate, const PString &templateDeclaration)
 Saves constructor of the class.
 
void class_saveClassDestructorImpl (std::ofstream &fs, const PClassConfig &classConfig, const PString &defTemplate, const PString &templateDeclaration)
 Saves destructor of the class.
 
void class_saveClassInitialisationFunctionImpl (std::ofstream &fs, const PClassConfig &classConfig, const PString &defTemplate, const PString &templateDeclaration)
 Saves the copy function of a class.
 
bool generator_checkDefaultValueExist (const std::vector< PClassAttribute > &vecAttr)
 Check if the vector of PClassAttribute has default value.
 
bool generator_class_cpp (const PTraitBackendManager &manager, const std::vector< PClassConfig > &vecClassConfig, const PPath &outputSourceDir, const PPath &baseFileName, const GeneratorMode &mode, const PVecPath &vecInclude)
 Creates header and source files.
 
void generator_class_cpp_header (const PTraitBackendManager &manager, std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode)
 Create the declaration of the given class.
 
bool generator_class_cpp_headerFile (const PTraitBackendManager &manager, const PPath &headerFile, const std::vector< PClassConfig > &vecClassConfig, const GeneratorMode &mode, const PVecPath &vecInclude, const PString &includeTemplate)
 Create the declaration of the given class.
 
void generator_class_cpp_source (const PTraitBackendManager &manager, std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode)
 Create the implementation of the given class.
 
bool generator_class_cpp_sourceFile (const PTraitBackendManager &manager, const PPath &sourceFile, const PPath &headerFile, const std::vector< PClassConfig > &vecClassConfig, const GeneratorMode &mode, bool isTemplateImpl)
 Create the implementation of the given file.
 
bool generator_class_cpp_test (const PTraitBackendManager &manager, const PPath &outputTestDir, const std::vector< PClassConfig > &vecClassConfig, const PString &projectName, const PPath &baseFileName, const GeneratorMode &mode)
 Save the unit test of the generated PClassConfig.
 
bool generator_class_full (const PTraitBackendManager &manager, const ProjectParam &projectParam)
 Generate the full sources and related unit tests from configuration.
 
bool generator_class_test (const PTraitBackendManager &manager, const PPath &outputTestDir, const PClassConfig &classConfig, const PString &projectName, const PPath &baseFileName, const GeneratorMode &mode)
 Save the unit test of the generated PClassConfig.
 
bool generator_class_testCMakeLists (const PPath &outputCurrentTestDir, const PClassConfig &classConfig, const PString &projectName, const GeneratorMode &mode)
 Save the CMakeLists to be used to compile the unit test.
 
bool generator_class_testMain (const PTraitBackendManager &manager, const PPath &outputCurrentTestDir, const PClassConfig &classConfig, const PPath &baseFileName, const GeneratorMode &mode)
 Save the CMakeLists to be used to compile the unit test.
 
void generator_enum_cpp_header (const PTraitBackendManager &manager, std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode)
 Create the declaration of the given class.
 

Function Documentation

◆ class_checkClassConfig()

void class_checkClassConfig ( bool & hasSource,
bool & hasTemplate,
const std::vector< PClassConfig > & vecClassConfig )

Check if the configuration has source or template to determine if the .cpp or _impl.h files have to be generated.

Parameters
[out]hasSource: true if the configuration needs .cpp file
[out]hasTemplate: true if the configuration needs _impl.h file
vecClassConfig: class config we want to save

Definition at line 343 of file generator_class_cpp.cpp.

343 {
344 hasSource = false;
345 hasTemplate = false;
346 for(std::vector<PClassConfig>::const_iterator it(vecClassConfig.begin()); it != vecClassConfig.end(); ++it){
347 bool isTemplate = it->getListTemplate().size() != 0lu;
348 hasSource |= !isTemplate;
349 hasTemplate |= isTemplate;
350 }
351}

Referenced by generator_class_cpp().

+ Here is the caller graph for this function:

◆ class_getClassDeclTempalteDef()

PString class_getClassDeclTempalteDef ( const PVecString & listTemplate)

Get the template definition in the class declaration.

Parameters
listTemplate: list of template def
Returns
template definition in the class declaration (template< .... >)

Definition at line 44 of file generator_class_cpp.cpp.

44 {
45 if(listTemplate.size() == 0lu){return "";}
46 PString templateDef("template<");
47 PString comma("");
48 for(PVecString::const_iterator it(listTemplate.begin()); it != listTemplate.end(); ++it){
49 templateDef += comma;
50 templateDef += *it;
51 comma = ", ";
52 }
53 templateDef += ">\n";
54 return templateDef;
55}

Referenced by generator_class_cpp_header(), and generator_class_cpp_source().

+ Here is the caller graph for this function:

◆ class_getClassDefTemplate()

PString class_getClassDefTemplate ( const PVecString & listTemplate)

Get the template call in the class declaration.

Parameters
listTemplate: list of template def
Returns
template definition in the class declaration (< T, U, .... >)

Definition at line 26 of file generator_class_cpp.cpp.

26 {
27 if(listTemplate.size() == 0lu){return "";}
28 PString defTemplate("<"), comma("");
29 for(PVecString::const_iterator it(listTemplate.begin()); it != listTemplate.end(); ++it){
30 PVecString vecPart = it->split(' ');
31 if(vecPart.size() != 0lu){
32 defTemplate += comma + vecPart.back();
33 comma = ", ";
34 }
35 }
36 defTemplate += ">";
37 return defTemplate;
38}

Referenced by generator_class_cpp_header(), and generator_class_cpp_source().

+ Here is the caller graph for this function:

◆ class_getIsPointer()

bool class_getIsPointer ( const PString & varType)

Check if the given type is a pointer or not.

Parameters
varType: type to be checked
Returns
true if the given type is a pointer, false otherwise

Definition at line 17 of file generator_class_cpp.cpp.

17 {
18 if(varType.size() == 0lu){return false;}
19 return varType.find('*') && varType.back() == '*';
20}

Referenced by class_saveClassInitialisationFunctionImpl().

+ Here is the caller graph for this function:

◆ class_saveClassConstructorImpl()

void class_saveClassConstructorImpl ( std::ofstream & fs,
const PClassConfig & classConfig,
const PString & defTemplate,
const PString & templateDeclaration )

Saves constructor of the class.

Parameters
[out]fs: header file name
classConfig: PClassConfig we vant to save
defTemplate: extra template definition for the class name space
templateDeclaration: basic template declaration before each method (template< ... >)

Definition at line 63 of file generator_class_cpp.cpp.

63 {
64 PString name(classConfig.getName());
65 fs << "///Constructor of class " << name << std::endl;
66 fs << templateDeclaration;
67 fs << name << defTemplate << "::" << name << "()";
68 if(classConfig.getListParentClass().size() != 0lu){
69 PVecString::const_iterator it(classConfig.getListParentClass().begin());
70 fs << std::endl << "\t: " << *it << "()";
71 if(classConfig.getListParentClass().size() > 1lu){
72 while(it != classConfig.getListParentClass().end()){
73 fs << ", " << *it << "()";
74 ++it;
75 }
76 }
77 fs << std::endl;
78 }
79 fs << "{" << std::endl;
80 fs << "\tinitialisation" << name << "();" << std::endl;
81 fs << "}" << std::endl << std::endl;
82}
const PString & getName() const
Returns the class name.
const PVecString & getListParentClass() const
Returns the list of the parents of the class.

References PClassConfig::getListParentClass(), and PClassConfig::getName().

Referenced by generator_class_cpp_source().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ class_saveClassDestructorImpl()

void class_saveClassDestructorImpl ( std::ofstream & fs,
const PClassConfig & classConfig,
const PString & defTemplate,
const PString & templateDeclaration )

Saves destructor of the class.

Parameters
[out]fs: header file name
classConfig: PClassConfig we vant to save
defTemplate: extra template definition for the class name space
templateDeclaration: basic template declaration before each method (template< ... >)

Definition at line 91 of file generator_class_cpp.cpp.

91 {
92 PString name(classConfig.getName());
93 fs << "///Destructor of class " << name << std::endl;
94 fs << templateDeclaration;
95 fs << name << defTemplate << "::~" << name << "(){" << std::endl;
96 fs << "\t" << std::endl;
97 fs << "}" << std::endl << std::endl;
98}

References PClassConfig::getName().

Referenced by generator_class_cpp_source().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ class_saveClassInitialisationFunctionImpl()

void class_saveClassInitialisationFunctionImpl ( std::ofstream & fs,
const PClassConfig & classConfig,
const PString & defTemplate,
const PString & templateDeclaration )

Saves the copy function of a class.

Parameters
[out]fs: header file name
classConfig: PClassConfig we vant to save
defTemplate: extra template definition for the class name space
templateDeclaration: basic template declaration before each method (template< ... >)

Definition at line 106 of file generator_class_cpp.cpp.

106 {
107 PString name(classConfig.getName());
108 fs << "///Initialisation Function of class " << name << std::endl;
109 fs << templateDeclaration;
110 fs << "void " << name << defTemplate << "::initialisation" << name << "(){" << std::endl;
111 const std::vector<PClassAttribute> & listAttr(classConfig.getListAttribute());
112 for(std::vector<PClassAttribute>::const_iterator it(listAttr.begin()); it != listAttr.end(); ++it){
113 if(it->getDefaultValue() != ""){
114 fs << "\tp_" << it->getName() << " = "<<it->getDefaultValue()<<";" << std::endl;
115 }else{
116 PString varType(it->getType());
117 bool isSimpleType = getIsSimpleType(varType);
118 bool isPtr(class_getIsPointer(varType));
119 if(isPtr){
120 fs << "\tp_" << it->getName() << " = NULL;" << std::endl;
121 }else if(isSimpleType){
122 PString defaultValue(getDefaultValueTypeInCpp(varType));
123 if(defaultValue != ""){
124 fs << "\tp_" << it->getName() << " = "<<defaultValue<<";" << std::endl;
125 }
126 }else if(varType == "PString"){
127 fs << "\tp_" << it->getName() << " = \"\";" << std::endl;
128 }
129 }
130 }
131 fs << "}" << std::endl << std::endl;
132}
const std::vector< PClassAttribute > & getListAttribute() const
Returns the list of attributes of the class.
bool class_getIsPointer(const PString &varType)
Check if the given type is a pointer or not.
PString getDefaultValueTypeInCpp(const PString &type)
Get the default value of a type in C++.
bool getIsSimpleType(const PString &varType)
Check if the given type is a simple type.

References class_getIsPointer(), getDefaultValueTypeInCpp(), getIsSimpleType(), PClassConfig::getListAttribute(), and PClassConfig::getName().

Referenced by generator_class_cpp_source().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_checkDefaultValueExist()

bool generator_checkDefaultValueExist ( const std::vector< PClassAttribute > & vecAttr)

Check if the vector of PClassAttribute has default value.

Parameters
vecAttr: vector of attribute to be checked
Returns
true if there is at least one default value, false if there is none

Definition at line 138 of file generator_class_cpp.cpp.

138 {
139 bool hasDefaultValue = false;
140 for(std::vector<PClassAttribute>::const_iterator it(vecAttr.begin()); it != vecAttr.end() && !hasDefaultValue; ++it){
141 hasDefaultValue |= it->getDefaultValue() != "";
142 }
143 return hasDefaultValue;
144}

Referenced by generator_enum_cpp_header().

+ Here is the caller graph for this function:

◆ generator_class_cpp()

bool generator_class_cpp ( const PTraitBackendManager & manager,
const std::vector< PClassConfig > & vecClassConfig,
const PPath & outputSourceDir,
const PPath & baseFileName,
const GeneratorMode & mode,
const PVecPath & vecInclude )

Creates header and source files.

Parameters
manager: PTraitBackendManager which handles all trait backend
vecClassConfig: vector of class config we want to save
baseFileName: base file name for header or source file
outputSourceDir: output directory where to save sources
mode: all modes of the generator (data/check/type/config stream)
Returns
true on success, false otherwise

Definition at line 361 of file generator_class_cpp.cpp.

361 {
362 if(baseFileName == ""){
363 std::cerr << termRed() << "generator_class_cpp : baseFileName is empty" << termDefault() << std::endl;
364 return false;
365 }
366 bool hasSource(false), hasTemplate(false);
367 class_checkClassConfig(hasSource, hasTemplate, vecClassConfig);
368 PString includeTemplate("");
369 if(hasTemplate){
370 includeTemplate = PString(baseFileName.getFileName() + "_impl.h");
371 }
372 PPath headerFile = outputSourceDir / PPath(baseFileName + ".h");
373 if(!generator_class_cpp_headerFile(manager, headerFile, vecClassConfig, mode, vecInclude, includeTemplate)){
374 std::cerr << termRed() << "generator_class_cpp : cannot generate header file '"<<headerFile<<"'" << termDefault() << std::endl;
375 return false;
376 }
377 if(hasSource){
378 PPath sourceFile = outputSourceDir / PPath(baseFileName + PString(".cpp"));
379 if(!generator_class_cpp_sourceFile(manager, sourceFile, PPath(baseFileName + PString(".h")), vecClassConfig, mode, false)){
380 std::cerr << termRed() << "generator_class_cpp : cannot generate source file '"<<sourceFile<<"'" << termDefault() << std::endl;
381 return false;
382 }
383 }
384 if(hasTemplate){
385 PPath implFile = outputSourceDir / PPath(baseFileName + PString("_impl.h"));
386 if(!generator_class_cpp_sourceFile(manager, implFile, PPath(baseFileName + PString(".h")), vecClassConfig, mode, true)){
387 std::cerr << termRed() << "generator_class_cpp : cannot generate impl file '"<<implFile<<"'" << termDefault() << std::endl;
388 return false;
389 }
390 }
391 return true;
392}
bool generator_class_cpp_sourceFile(const PTraitBackendManager &manager, const PPath &sourceFile, const PPath &headerFile, const std::vector< PClassConfig > &vecClassConfig, const GeneratorMode &mode, bool isTemplateImpl)
Create the implementation of the given file.
void class_checkClassConfig(bool &hasSource, bool &hasTemplate, const std::vector< PClassConfig > &vecClassConfig)
Check if the configuration has source or template to determine if the .cpp or _impl....
bool generator_class_cpp_headerFile(const PTraitBackendManager &manager, const PPath &headerFile, const std::vector< PClassConfig > &vecClassConfig, const GeneratorMode &mode, const PVecPath &vecInclude, const PString &includeTemplate)
Create the declaration of the given class.

References class_checkClassConfig(), generator_class_cpp_headerFile(), and generator_class_cpp_sourceFile().

Referenced by generator_class_full().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_cpp_header()

void generator_class_cpp_header ( const PTraitBackendManager & manager,
std::ofstream & fs,
const PClassConfig & classConfig,
const GeneratorMode & mode )

Create the declaration of the given class.

Parameters
manager: PTraitBackendManager which handles all trait backend
[out]fs: file to be completed
classConfig: configuration of the class to be used
mode: mode of the generator

Definition at line 186 of file generator_class_cpp.cpp.

186 {
187 if(classConfig.getClassDocumentation() != "") fs << classConfig.getClassDocumentation() << std::endl;
188 PString name(classConfig.getName());
189 GeneratorMode classMode(mode);
190 const PVecString & listTemplate = classConfig.getListTemplate();
191 PString defTemplate(class_getClassDefTemplate(listTemplate));
192 PString templateDeclaration(class_getClassDeclTempalteDef(listTemplate));
193 classMode.defTemplate = defTemplate;
194 classMode.templateDeclaration = templateDeclaration;
195
196 fs << classMode.templateDeclaration;
197 fs << "class " << name;
198 if(classConfig.getListParentClass().size() != 0lu){
199 PVecString::const_iterator it(classConfig.getListParentClass().begin());
200 fs << " : public " << *it;
201 if(classConfig.getListParentClass().size() > 1lu){
202 while(it != classConfig.getListParentClass().end()){
203 fs << ", " << *it;
204 ++it;
205 }
206 }
207 }
208 fs << "{" << std::endl;
209 fs << "\tpublic:" << std::endl;
210 fs << "\t\t" << name << "();" << std::endl;
211 fs << "\t\tvirtual ~" << name << "();" << std::endl;
212
213 manager.publicMethodDeclaration(fs, classConfig, classMode);
214 fs << "\tprotected:" << std::endl;
215 manager.protectedMethodDeclaration(fs, classConfig, classMode);
216
217 fs << "\tprivate:" << std::endl;
218 fs << "\t\tvoid initialisation" << name << "();" << std::endl;
219 manager.privateMethodDeclaration(fs, classConfig, classMode);
220 const std::vector<PClassAttribute> & listAttr(classConfig.getListAttribute());
221 for(std::vector<PClassAttribute>::const_iterator it(listAttr.begin()); it != listAttr.end(); ++it){
222 if(it->getDocumentation() != "") fs << "\t\t" << it->getDocumentation() << std::endl;
223
224 fs << "\t\t" << it->getType() << " p_" << it->getName() << ";" << std::endl;
225 }
226 fs << "};" << std::endl << std::endl;
227 manager.classExtraFunctionDeclaration(fs, classConfig, classMode);
228 fs << std::endl << std::endl;
229}
const PString & getClassDocumentation() const
Returns the class documentation.
const PVecString & getListTemplate() const
Returns the list of the template of the class.
void protectedMethodDeclaration(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Declaration of protected methods.
void classExtraFunctionDeclaration(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Declaration of extra functions.
void privateMethodDeclaration(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Declaration of private methods.
void publicMethodDeclaration(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Declaration of public methods.
PString class_getClassDefTemplate(const PVecString &listTemplate)
Get the template call in the class declaration.
PString class_getClassDeclTempalteDef(const PVecString &listTemplate)
Get the template definition in the class declaration.
All the genertor modes.

References class_getClassDeclTempalteDef(), class_getClassDefTemplate(), PTraitBackendManager::classExtraFunctionDeclaration(), GeneratorMode::defTemplate, PClassConfig::getClassDocumentation(), PClassConfig::getListAttribute(), PClassConfig::getListParentClass(), PClassConfig::getListTemplate(), PClassConfig::getName(), PTraitBackendManager::privateMethodDeclaration(), PTraitBackendManager::protectedMethodDeclaration(), PTraitBackendManager::publicMethodDeclaration(), and GeneratorMode::templateDeclaration.

Referenced by generator_class_cpp_headerFile().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_cpp_headerFile()

bool generator_class_cpp_headerFile ( const PTraitBackendManager & manager,
const PPath & headerFile,
const std::vector< PClassConfig > & vecClassConfig,
const GeneratorMode & mode,
const PVecPath & vecInclude,
const PString & includeTemplate )

Create the declaration of the given class.

Parameters
manager: PTraitBackendManager which handles all trait backend
headerFile: file to be saved
vecClassConfig: configuration of the class to be used
mode: mode of the generator
vecInclude: vector of include files to be added into the header
includeTemplate: extra include for the template implementation
Returns
true on success, false otherwise

Definition at line 240 of file generator_class_cpp.cpp.

242{
243 if(headerFile == "") return false;
244 std::ofstream fs;
245 if(!openFileStream(fs, headerFile)){return false;}
246 licenceSave(fs);
247 PString macroDef(makeMultiIncludeDefineMacro(headerFile.getFileName()));
248 fs << "#ifndef " << macroDef << std::endl;
249 fs << "#define " << macroDef << std::endl << std::endl;
250 fs << "#include <string>" << std::endl;
251 if(vecInclude.size() != 0lu){
252 for(PVecPath::const_iterator it(vecInclude.begin()); it != vecInclude.end(); ++it){
253 fs << "#include " << *it << std::endl;
254 }
255 fs << std::endl;
256 }
257 manager.headerExtraInclude(fs, mode);
258 fs << std::endl;
259 for(std::vector<PClassConfig>::const_iterator it(vecClassConfig.begin()); it != vecClassConfig.end(); ++it){
260 if(it->getIsEnum()){
261 generator_enum_cpp_header(manager, fs, *it, mode);
262// saveEnumDecl(fs, *it, mode);
263 }else{
264 generator_class_cpp_header(manager, fs, *it, mode);
265 }
266 }
267
268 if(includeTemplate != ""){
269 fs << "#include \""<<includeTemplate<<"\"" << std::endl << std::endl;
270 }
271
272 fs << std::endl << std::endl << "#endif" << std::endl << std::endl;
273 fs.close();
274 return true;
275}
void headerExtraInclude(std::ofstream &fs, const GeneratorMode &mode) const
Add extra include on the header.
void generator_class_cpp_header(const PTraitBackendManager &manager, std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode)
Create the declaration of the given class.
void generator_enum_cpp_header(const PTraitBackendManager &manager, std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode)
Create the declaration of the given class.
PString makeMultiIncludeDefineMacro(const PString &fileName)
Create the macro of multi inclusion file name.
void licenceSave(std::ofstream &fs)
Saves the policy.

References generator_class_cpp_header(), generator_enum_cpp_header(), PTraitBackendManager::headerExtraInclude(), licenceSave(), and makeMultiIncludeDefineMacro().

Referenced by generator_class_cpp().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_cpp_source()

void generator_class_cpp_source ( const PTraitBackendManager & manager,
std::ofstream & fs,
const PClassConfig & classConfig,
const GeneratorMode & mode )

Create the implementation of the given class.

Parameters
manager: PTraitBackendManager which handles all trait backend
[out]fs: file to be completed
classConfig: configuration of the class to be used
mode: mode of the generator

Definition at line 283 of file generator_class_cpp.cpp.

283 {
284 manager.classExtraFunctionImplementation(fs, classConfig, mode);
285 GeneratorMode classMode(mode);
286 const PVecString & listTemplate = classConfig.getListTemplate();
287 PString defTemplate(class_getClassDefTemplate(listTemplate));
288 PString templateDeclaration(class_getClassDeclTempalteDef(listTemplate));
289 classMode.defTemplate = defTemplate;
290 classMode.templateDeclaration = templateDeclaration;
291 if(!classConfig.getIsEnum()){
292 class_saveClassConstructorImpl(fs, classConfig, defTemplate, templateDeclaration);
293 class_saveClassDestructorImpl(fs, classConfig, defTemplate, templateDeclaration);
294 }
295 manager.publicMethodImplementation(fs, classConfig, classMode);
296 manager.protectedMethodImplementation(fs, classConfig, classMode);
297 manager.privateMethodImplementation(fs, classConfig, classMode);
298 if(!classConfig.getIsEnum()){
299 class_saveClassInitialisationFunctionImpl(fs, classConfig, defTemplate, templateDeclaration);
300 }
301}
bool getIsEnum() const
Say if the current PClassConfig is an enum.
void classExtraFunctionImplementation(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Implementation of extra functions.
void protectedMethodImplementation(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Implementation of protected methods.
void privateMethodImplementation(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Implementation of private methods.
void publicMethodImplementation(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Implementation of public methods.
void class_saveClassDestructorImpl(std::ofstream &fs, const PClassConfig &classConfig, const PString &defTemplate, const PString &templateDeclaration)
Saves destructor of the class.
void class_saveClassConstructorImpl(std::ofstream &fs, const PClassConfig &classConfig, const PString &defTemplate, const PString &templateDeclaration)
Saves constructor of the class.
void class_saveClassInitialisationFunctionImpl(std::ofstream &fs, const PClassConfig &classConfig, const PString &defTemplate, const PString &templateDeclaration)
Saves the copy function of a class.

References class_getClassDeclTempalteDef(), class_getClassDefTemplate(), class_saveClassConstructorImpl(), class_saveClassDestructorImpl(), class_saveClassInitialisationFunctionImpl(), PTraitBackendManager::classExtraFunctionImplementation(), GeneratorMode::defTemplate, PClassConfig::getIsEnum(), PClassConfig::getListTemplate(), PTraitBackendManager::privateMethodImplementation(), PTraitBackendManager::protectedMethodImplementation(), PTraitBackendManager::publicMethodImplementation(), and GeneratorMode::templateDeclaration.

Referenced by generator_class_cpp_sourceFile().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_cpp_sourceFile()

bool generator_class_cpp_sourceFile ( const PTraitBackendManager & manager,
const PPath & sourceFile,
const PPath & headerFile,
const std::vector< PClassConfig > & vecClassConfig,
const GeneratorMode & mode,
bool isTemplateImpl )

Create the implementation of the given file.

Parameters
manager: PTraitBackendManager which handles all trait backend
sourceFile: source file to be saved
headerFile: header to be used with this source file
vecClassConfig: vector of configuration of the classes to be used
mode: mode of the generator
isTemplateImpl: true to activate
Returns
true on success, false otherwise

Definition at line 312 of file generator_class_cpp.cpp.

314{
315 if(sourceFile == "" || headerFile == "") return false;
316 std::ofstream fs;
317 if(!openFileStream(fs, sourceFile)){return false;}
318 licenceSave(fs);
319 if(isTemplateImpl){
320 PString macroDef(makeMultiIncludeDefineMacro(headerFile.getFileName() + "_IMPL"));
321 fs << "#ifndef " << macroDef << std::endl;
322 fs << "#define " << macroDef << std::endl << std::endl;
323 }
324 fs << std::endl << "#include \"" << headerFile.getFileName() << "\"" << std::endl << std::endl;
325 for(std::vector<PClassConfig>::const_iterator it(vecClassConfig.begin()); it != vecClassConfig.end(); ++it){
326 generator_class_cpp_source(manager, fs, *it, mode);
327 }
328 if(isTemplateImpl){
329 fs << "#endif" << std::endl << std::endl;
330 }
331 fs.close();
332
333 return true;
334}
void generator_class_cpp_source(const PTraitBackendManager &manager, std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode)
Create the implementation of the given class.

References generator_class_cpp_source(), licenceSave(), and makeMultiIncludeDefineMacro().

Referenced by generator_class_cpp().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_cpp_test()

bool generator_class_cpp_test ( const PTraitBackendManager & manager,
const PPath & outputTestDir,
const std::vector< PClassConfig > & vecClassConfig,
const PString & projectName,
const PPath & baseFileName,
const GeneratorMode & mode )

Save the unit test of the generated PClassConfig.

Parameters
manager: PTraitBackendManager which handles all trait backend
outputTestDir: output directory where to put the generated test (typically ../TESTS if the program is called from ./src)
vecClassConfig: vector of class configuration to be used
projectName: configuration of the project
baseFileName: base of output file name of the generated sources
mode: all modes of the generator (data/check/type/config stream)
Returns
true on success, false oterhwise

Definition at line 471 of file generator_class_cpp.cpp.

471 {
472 PString cmakeListBody;
473 cmakeListBody += getCMakeListsHeader();
474 bool b(true);
475 cmakeListBody += "#Generating tests for " + PString::toString(vecClassConfig.size()) + "\n";
476 for(std::vector<PClassConfig>::const_iterator it(vecClassConfig.begin()); it != vecClassConfig.end(); ++it){
477 cmakeListBody += "add_subdirectory(TEST_" + it->getName().toUpper() + ")\n";
478 b &= generator_class_test(manager, outputTestDir, *it, projectName, baseFileName, mode);
479 }
480 cmakeListBody += "\n\n";
481 PPath cmakelist(outputTestDir / PPath("CMakeLists.txt"));
482 b &= cmakelist.saveFileContent(cmakeListBody);
483 return b;
484}
PString getCMakeListsHeader()
Get the CMakeLists.txt header.
bool generator_class_test(const PTraitBackendManager &manager, const PPath &outputTestDir, const PClassConfig &classConfig, const PString &projectName, const PPath &baseFileName, const GeneratorMode &mode)
Save the unit test of the generated PClassConfig.

References generator_class_test(), and getCMakeListsHeader().

Referenced by generator_class_full().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_full()

bool generator_class_full ( const PTraitBackendManager & manager,
const ProjectParam & projectParam )

Generate the full sources and related unit tests from configuration.

Parameters
manager: PTraitBackendManager which handles all trait backend
projectParam: description of classes and how and where to generate sources and test
Returns
true on success, false otherwise

Definition at line 491 of file generator_class_cpp.cpp.

491 {
492 bool b(true);
493 b &= projectParam.outputSourceDir.createDirectory();
494 b &= projectParam.outputTestDir.createDirectory();
495 PString cmakeListBody;
496 cmakeListBody += getCMakeListsHeader();
497 const PVecDataConfig & vecDataConfig = projectParam.vecDataConfig;
498 for(const PDataConfig & config : vecDataConfig){
499 PPath baseFileName = config.getFileName().getFileName().eraseExtension();
500 if(!generator_class_cpp(manager, config.getVecClassConfig(), projectParam.outputSourceDir, baseFileName, projectParam.mode, config.getVecInclude())){
501 std::cerr << termRed() << "generator_class_full : cannot generate C++ sources at '"<<projectParam.outputSourceDir<<"'" << termDefault() << std::endl;
502 b = false; //best effort strategy
503 }
504 PPath outputCurrentTestDir = projectParam.outputTestDir / PPath("TEST_" + config.getFileName().getFileName().eraseExtension().toUpper());
505 cmakeListBody += "add_subdirectory(" + outputCurrentTestDir.getFileName() + ")\n";
506 if(!generator_class_cpp_test(manager, outputCurrentTestDir, config.getVecClassConfig(), projectParam.name, baseFileName, projectParam.mode)){
507 std::cerr << termRed() << "generator_class_full : cannot generate C++ tests at '"<<projectParam.outputTestDir<<"'" << termDefault() << std::endl;
508 b = false; //best effort strategy
509 }
510 }
511 cmakeListBody += "\n\n";
512 PPath cmakelist(projectParam.outputTestDir / PPath("CMakeLists.txt"));
513 b &= cmakelist.saveFileContent(cmakeListBody);
514 return b;
515}
std::vector< PDataConfig > PVecDataConfig
Definition PDataConfig.h:48
Class to describe a basic class.
Definition PDataConfig.h:17
bool generator_class_cpp(const PTraitBackendManager &manager, const std::vector< PClassConfig > &vecClassConfig, const PPath &outputSourceDir, const PPath &baseFileName, const GeneratorMode &mode, const PVecPath &vecInclude)
Creates header and source files.
bool generator_class_cpp_test(const PTraitBackendManager &manager, const PPath &outputTestDir, const std::vector< PClassConfig > &vecClassConfig, const PString &projectName, const PPath &baseFileName, const GeneratorMode &mode)
Save the unit test of the generated PClassConfig.
GeneratorMode mode
Mode to be used to generate the project.
PPath outputTestDir
Output path of the unit tests.
PVecDataConfig vecDataConfig
Configuration of classes to be generated.
PString name
Name of the project.
PPath outputSourceDir
Output path of the sources.

References generator_class_cpp(), generator_class_cpp_test(), getCMakeListsHeader(), ProjectParam::mode, ProjectParam::name, ProjectParam::outputSourceDir, ProjectParam::outputTestDir, and ProjectParam::vecDataConfig.

Referenced by simple_project_generate_source().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_test()

bool generator_class_test ( const PTraitBackendManager & manager,
const PPath & outputTestDir,
const PClassConfig & classConfig,
const PString & projectName,
const PPath & baseFileName,
const GeneratorMode & mode )

Save the unit test of the generated PClassConfig.

Parameters
manager: PTraitBackendManager which handles all trait backend
outputTestDir: output directory where to put the genreated test (typically ../TESTS if the program is called from ./src)
classConfig: class configuration to be used
projectName: configuration of the project
baseFileName: base of output file name of the generated sources
mode: all modes of the generator (data/check/type/config stream)
Returns
true on success, false oterhwise

Definition at line 451 of file generator_class_cpp.cpp.

451 {
452 PString name(classConfig.getName());
453 PPath outputCurrentTestDir(outputTestDir + PString("/TEST_") + name.toUpper());
454 if(!outputCurrentTestDir.createDirectory()){std::cerr << "generator_class_test : cannot create TEST directory '"<<outputCurrentTestDir<<"'" << std::endl;return false;}
455
456 bool b(true);
457 b &= generator_class_testCMakeLists(outputCurrentTestDir, classConfig, projectName, mode);
458 b &= generator_class_testMain(manager, outputCurrentTestDir, classConfig, baseFileName, mode);
459 return b;
460}
bool generator_class_testMain(const PTraitBackendManager &manager, const PPath &outputCurrentTestDir, const PClassConfig &classConfig, const PPath &baseFileName, const GeneratorMode &mode)
Save the CMakeLists to be used to compile the unit test.
bool generator_class_testCMakeLists(const PPath &outputCurrentTestDir, const PClassConfig &classConfig, const PString &projectName, const GeneratorMode &mode)
Save the CMakeLists to be used to compile the unit test.

References generator_class_testCMakeLists(), generator_class_testMain(), and PClassConfig::getName().

Referenced by generator_class_cpp_test().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_testCMakeLists()

bool generator_class_testCMakeLists ( const PPath & outputCurrentTestDir,
const PClassConfig & classConfig,
const PString & projectName,
const GeneratorMode & mode )

Save the CMakeLists to be used to compile the unit test.

Parameters
outputCurrentTestDir: current test directory in which to create the CMakeLists.txt
classConfig: class configuration to be used
projectName: configuration of the project
mode: all modes of the generator (data/check/type/config stream)
Returns
true on success, false oterhwise

Definition at line 429 of file generator_class_cpp.cpp.

429 {
430 PString body(""), testName("test_class_" + classConfig.getName().toLowerUnderscore());
431 body += getCMakeListsHeader();
432 body += "add_executable("+testName+" main.cpp)\n";
433 body += "target_link_libraries("+testName+" ${"+projectName.toUpper()+"_TEST_DEPENDENCIES})\n";
434 body += "\n";
435 body += "add_test(NAME "+testName.firstToUpper()+"\n";
436 body += "\tCOMMAND ${CMAKE_CURRENT_BINARY_DIR}/"+testName+"\n";
437 body += "\tWORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}\n";
438 body += ")\n\n\n";
439 return PPath(outputCurrentTestDir + PString("/CMakeLists.txt")).saveFileContent(body);
440}

References getCMakeListsHeader(), and PClassConfig::getName().

Referenced by generator_class_test().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_class_testMain()

bool generator_class_testMain ( const PTraitBackendManager & manager,
const PPath & outputCurrentTestDir,
const PClassConfig & classConfig,
const PPath & baseFileName,
const GeneratorMode & mode )

Save the CMakeLists to be used to compile the unit test.

Parameters
manager: PTraitBackendManager which handles all trait backend
outputCurrentTestDir: current test directoru in which to create the CMakeLists.txt
classConfig: class configuration to be used
baseFileName: base of output file name of the generated sources
mode: all modes of the generator (data/check/type/config stream)
Returns
true on success, false oterhwise

Definition at line 403 of file generator_class_cpp.cpp.

403 {
404 std::ofstream fs;
405 if(!openFileStream(fs, PPath(outputCurrentTestDir + PString("/main.cpp")))){return false;}
406 licenceSave(fs);
407// body += licenceSaveStr() + "\n";
408 if(mode.assertInclude != ""){
409 fs << "#include \"" + mode.assertInclude + "\"\n\n";
410 }
411 fs << "#include \"" + baseFileName + ".h\"\n\n";
412 manager.testFunction(fs, classConfig, mode);
413 fs << "int main(int argc, char ** argv){\n";
414 //Do other test if the enableDataStream is true
415 manager.testCallFunction(fs, classConfig, mode);
416 fs << "\treturn 0;\n";
417 fs << "}\n";
418 fs.close();
419 return true;
420}
void testCallFunction(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Call of the test function.
void testFunction(std::ofstream &fs, const PClassConfig &classConfig, const GeneratorMode &mode) const
Implementation of test function.
PString assertInclude
Include of the assert to be used.

References GeneratorMode::assertInclude, licenceSave(), PTraitBackendManager::testCallFunction(), and PTraitBackendManager::testFunction().

Referenced by generator_class_test().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ generator_enum_cpp_header()

void generator_enum_cpp_header ( const PTraitBackendManager & manager,
std::ofstream & fs,
const PClassConfig & classConfig,
const GeneratorMode & mode )

Create the declaration of the given class.

Parameters
manager: PTraitBackendManager which handles all trait backend
[out]fs: file to be completed
classConfig: configuration of the class to be used
mode: mode of the generator

Definition at line 152 of file generator_class_cpp.cpp.

152 {
153 if(classConfig.getClassDocumentation() != "") fs << classConfig.getClassDocumentation() << std::endl;
154 PString name(classConfig.getName());
155 fs << "namespace " << name << " {\n";
156 if(classConfig.getClassDocumentation() != ""){fs << "\t"<< classConfig.getClassDocumentation() << std::endl;}
157 fs << "\tenum " << name << " {\n\t\t";
158 const std::vector<PClassAttribute> & vecAttr(classConfig.getListAttribute());
159 bool isDefaultCounterActivated = !generator_checkDefaultValueExist(vecAttr);
160 PString comma("");
161 size_t i(0lu);
162 for(std::vector<PClassAttribute>::const_iterator it(vecAttr.begin()); it != vecAttr.end(); ++it){
163 if(it->getDocumentation() != "") fs << "\t\t" << it->getDocumentation() << std::endl;
164 fs << comma << it->getName();
165 if(isDefaultCounterActivated){
166 fs << " = " << i;
167 }else if(it->getDefaultValue() != ""){
168 fs << " = " << it->getDefaultValue();
169 }
170 comma = ",\n\t\t";
171 ++i;
172 }
173 fs << "\n\t};" << std::endl;
174 fs << "}" << std::endl << std::endl;
175 manager.classExtraFunctionDeclaration(fs, classConfig, mode);
176 fs << std::endl << std::endl;
177}
bool generator_checkDefaultValueExist(const std::vector< PClassAttribute > &vecAttr)
Check if the vector of PClassAttribute has default value.

References PTraitBackendManager::classExtraFunctionDeclaration(), generator_checkDefaultValueExist(), PClassConfig::getClassDocumentation(), PClassConfig::getListAttribute(), and PClassConfig::getName().

Referenced by generator_class_cpp_headerFile().

+ Here is the call graph for this function:
+ Here is the caller graph for this function: