mirror of
https://github.com/nasa/trick.git
synced 2025-06-16 22:28:18 +00:00
Ignore privacy
Mostly working. This removes the use of offsetof from all I/O code. This was the only reason we needed friends. In it's place we put the offset value that clang has calculated for the field. Still need to work on virtually inherited classes and confirm bitfields. refs #218
This commit is contained in:
@ -22,7 +22,6 @@ FieldVisitor::FieldVisitor(clang::CompilerInstance & in_ci ,
|
||||
CommentSaver & in_cs ,
|
||||
PrintAttributes & in_pa ,
|
||||
std::string container_class ,
|
||||
bool in_access_spec_found ,
|
||||
bool in_inherited ,
|
||||
bool in_virtual_inherited ,
|
||||
unsigned int in_base_class_offset ) :
|
||||
@ -30,7 +29,7 @@ FieldVisitor::FieldVisitor(clang::CompilerInstance & in_ci ,
|
||||
hsd(in_hsd) ,
|
||||
cs(in_cs) ,
|
||||
pa(in_pa) {
|
||||
fdes = new FieldDescription(container_class, in_access_spec_found, in_inherited, in_virtual_inherited, in_base_class_offset) ;
|
||||
fdes = new FieldDescription(container_class, in_inherited, in_virtual_inherited, in_base_class_offset) ;
|
||||
}
|
||||
|
||||
bool FieldVisitor::VisitDecl(clang::Decl *d) {
|
||||
@ -206,6 +205,8 @@ bool FieldVisitor::VisitFieldDecl( clang::FieldDecl *field ) {
|
||||
fdes->setBitFieldStart( 32 - (field_offset_bits % 32) - fdes->getBitFieldWidth()) ;
|
||||
fdes->setBitFieldByteOffset((field_offset_bits / 32) * 4 ) ;
|
||||
}
|
||||
// set the offset to the field
|
||||
fdes->setFieldOffset(field->getASTContext().getFieldOffset(field) / 8 + fdes->getBaseClassOffset()) ;
|
||||
|
||||
// If the current type is not canonical because of typedefs or template parameter substitution,
|
||||
// traverse the canonical type
|
||||
@ -216,6 +217,10 @@ bool FieldVisitor::VisitFieldDecl( clang::FieldDecl *field ) {
|
||||
std::cout << " is_canonical = " << qt.isCanonical() << std::endl ;
|
||||
//field->dump() ;
|
||||
}
|
||||
|
||||
// set the offset to the field
|
||||
fdes->setFieldWidth(field->getASTContext().getTypeSize(qt) / 8) ;
|
||||
|
||||
if ( !qt.isCanonical() ) {
|
||||
fdes->setNonCanonicalTypeName(qt.getAsString()) ;
|
||||
clang::QualType ct = qt.getCanonicalType() ;
|
||||
|
Reference in New Issue
Block a user