mirror of
https://github.com/nasa/trick.git
synced 2024-12-21 14:07:51 +00:00
ae07b26243
Added back the code that set the offset of variables with the offsetof function. This code is running by default. Any code that includes #ifndef TRICK_ICG in classes/structures will want this on. Added a flag to ICG that allows us to turn off writing of these lines. If the flag is present, ICG may write out io_src code for private/protected variables that it could not reach if an offsetof function was required. Code cannot have any #ifndef TRICK_ICG present in classes/structures for this to work.
138 lines
5.2 KiB
C++
138 lines
5.2 KiB
C++
|
|
#include <iostream>
|
|
#include <fstream>
|
|
#include <sys/stat.h>
|
|
#include <libgen.h>
|
|
#include <string.h>
|
|
#include <iomanip>
|
|
|
|
#include "llvm/Support/CommandLine.h"
|
|
|
|
#include "PrintFileContentsBase.hh"
|
|
#include "FieldDescription.hh"
|
|
#include "ClassValues.hh"
|
|
#include "EnumValues.hh"
|
|
|
|
extern llvm::cl::opt< bool > no_offset_of ;
|
|
|
|
PrintFileContentsBase::PrintFileContentsBase() {}
|
|
|
|
// provide empty default implementation of these routines.
|
|
void PrintFileContentsBase::printClassMapHeader(std::ofstream & out, std::string function_name ) {}
|
|
void PrintFileContentsBase::printClassMap(std::ofstream & out, ClassValues * cv) {}
|
|
void PrintFileContentsBase::printClassMapFooter(std::ofstream & out) {}
|
|
|
|
void PrintFileContentsBase::printEnumMapHeader(std::ofstream & out, std::string function_name ) {}
|
|
void PrintFileContentsBase::printEnumMap(std::ofstream & out, EnumValues * ev) {}
|
|
void PrintFileContentsBase::printEnumMapFooter(std::ofstream & out) {}
|
|
|
|
void PrintFileContentsBase::print_units_map(std::ofstream & outfile, ClassValues * cv ) {
|
|
ClassValues::FieldIterator fit ;
|
|
unsigned int ii ;
|
|
|
|
outfile << "struct UnitsMap" ;
|
|
printNamespaces( outfile, cv , "__" ) ;
|
|
printContainerClasses( outfile, cv , "__" ) ;
|
|
outfile << cv->getMangledTypeName() ;
|
|
outfile << " {\n" ;
|
|
outfile << " UnitsMap" ;
|
|
printNamespaces( outfile, cv , "__" ) ;
|
|
printContainerClasses( outfile, cv , "__" ) ;
|
|
outfile << cv->getMangledTypeName() ;
|
|
outfile << "() {\n" ;
|
|
|
|
outfile << " Trick::UnitsMap * units_map_ptr __attribute__((unused)) = Trick::UnitsMap::units_map() ;\n" ;
|
|
for ( fit = cv->field_begin() ; fit != cv->field_end() ; fit++ ) {
|
|
if ( determinePrintAttr(cv , *fit) and (*fit)->getUnits().compare("1")) {
|
|
FieldDescription * fdes = *fit ;
|
|
outfile << " units_map_ptr->add_param(\"" ;
|
|
printContainerClasses( outfile, cv , "__" ) ;
|
|
outfile << cv->getName() << "_" << fdes->getName() << "\", \"" << fdes->getUnits() << "\") ;\n" ;
|
|
}
|
|
}
|
|
outfile << " }\n" ;
|
|
outfile << "} ;\n\n" ;
|
|
|
|
outfile << "UnitsMap" ;
|
|
printNamespaces( outfile, cv , "__" ) ;
|
|
printContainerClasses( outfile, cv , "__" ) ;
|
|
outfile << cv->getMangledTypeName() ;
|
|
outfile << " um" ;
|
|
printNamespaces( outfile, cv , "__" ) ;
|
|
printContainerClasses( outfile, cv , "__" ) ;
|
|
outfile << cv->getMangledTypeName() ;
|
|
outfile << " ;\n\n" ;
|
|
}
|
|
|
|
/* Utility routines for printing */
|
|
void PrintFileContentsBase::print_open_extern_c(std::ofstream & outfile) {
|
|
outfile << "extern \"C\" {\n\n" ;
|
|
}
|
|
|
|
void PrintFileContentsBase::print_close_extern_c(std::ofstream & outfile) {
|
|
outfile << "\n} //extern \"C\"\n\n" ;
|
|
}
|
|
|
|
/* internal function determines if a particular field is printable based
|
|
on access to the field and the presense of init_attr friends.
|
|
*/
|
|
bool PrintFileContentsBase::determinePrintAttr( ClassValues * c , FieldDescription * fdes ) {
|
|
if ( fdes->getTypeName().compare("void") and fdes->getIO() != 0 and fdes->getEnumString().compare("TRICK_VOID")) {
|
|
if ( no_offset_of ) {
|
|
if ( fdes->isStatic() ) {
|
|
if ( fdes->isInherited() ) {
|
|
return ((c->getHasInitAttrFriend() && fdes->getAccess() == clang::AS_protected)
|
|
|| (fdes->getAccess() == clang::AS_public)) ;
|
|
} else {
|
|
return (c->getHasInitAttrFriend()
|
|
|| (fdes->getAccess() == clang::AS_public)) ;
|
|
}
|
|
} else {
|
|
return true ;
|
|
}
|
|
} else {
|
|
if ( fdes->isInherited() ) {
|
|
return ((c->getHasInitAttrFriend() && fdes->getAccess() == clang::AS_protected)
|
|
|| (fdes->getAccess() == clang::AS_public)) ;
|
|
} else {
|
|
return (c->getHasInitAttrFriend()
|
|
|| (fdes->getAccess() == clang::AS_public)) ;
|
|
}
|
|
}
|
|
}
|
|
return false ;
|
|
}
|
|
|
|
/** Prints namespace containers of a class delimited by delim */
|
|
void PrintFileContentsBase::printNamespaces( std::ofstream & outfile , ConstructValues * c , const char * delim ) {
|
|
ClassValues::NamespaceIterator nsi ;
|
|
for ( nsi = c->namespace_begin() ; nsi != c->namespace_end() ; nsi++ ) {
|
|
outfile << *nsi << delim ;
|
|
}
|
|
}
|
|
|
|
/** Prints namespace open block */
|
|
void PrintFileContentsBase::printOpenNamespaceBlocks( std::ofstream & outfile , ClassValues * c ) {
|
|
ClassValues::NamespaceIterator nsi ;
|
|
for ( nsi = c->namespace_begin() ; nsi != c->namespace_end() ; nsi++ ) {
|
|
outfile << "namespace " << *nsi << " {\n" ;
|
|
}
|
|
}
|
|
|
|
/** Prints namespace close block */
|
|
void PrintFileContentsBase::printCloseNamespaceBlocks( std::ofstream & outfile , ClassValues * c ) {
|
|
ClassValues::NamespaceIterator nsi ;
|
|
for ( nsi = c->namespace_begin() ; nsi != c->namespace_end() ; nsi++ ) {
|
|
outfile << "}\n" ;
|
|
}
|
|
}
|
|
|
|
/** Prints class containers of a class delimited by delim */
|
|
void PrintFileContentsBase::printContainerClasses( std::ofstream & outfile , ConstructValues * c , const char * delim ) {
|
|
ClassValues::ContainerClassIterator ci ;
|
|
for ( ci = c->container_class_begin() ; ci != c->container_class_end() ; ci++ ) {
|
|
outfile << *ci << delim ;
|
|
}
|
|
}
|
|
|