Skip to content

Commit 5dc0cda

Browse files
author
Daniel Kroening
committed
further support for union_tag and struct_tag
1 parent 00248e7 commit 5dc0cda

File tree

3 files changed

+28
-3
lines changed

3 files changed

+28
-3
lines changed

src/ansi-c/c_typecheck_type.cpp

+5
Original file line numberDiff line numberDiff line change
@@ -93,6 +93,11 @@ void c_typecheck_baset::typecheck_type(typet &type)
9393
typecheck_symbol_type(to_symbol_type(type));
9494
else if(type.id() == ID_typedef_type)
9595
typecheck_typedef_type(type);
96+
else if(type.id() == ID_struct_tag ||
97+
type.id() == ID_union_tag)
98+
{
99+
// nothing to do, these stay as is
100+
}
96101
else if(type.id()==ID_vector)
97102
typecheck_vector_type(to_vector_type(type));
98103
else if(type.id()==ID_custom_unsignedbv ||

src/cpp/cpp_typecheck_type.cpp

+6
Original file line numberDiff line numberDiff line change
@@ -189,6 +189,12 @@ void cpp_typecheckt::typecheck_type(typet &type)
189189
else if(type.id() == ID_symbol_type)
190190
{
191191
}
192+
else if(type.id() == ID_struct_tag)
193+
{
194+
}
195+
else if(type.id() == ID_union_tag)
196+
{
197+
}
192198
else if(type.id()==ID_constructor ||
193199
type.id()==ID_destructor)
194200
{

src/goto-symex/goto_symex_state.cpp

+17-3
Original file line numberDiff line numberDiff line change
@@ -760,7 +760,10 @@ void goto_symex_statet::rename_address(
760760

761761
// type might not have been renamed in case of nesting of
762762
// structs and pointers/arrays
763-
if(member_expr.struct_op().type().id() != ID_symbol_type)
763+
if(
764+
member_expr.struct_op().type().id() != ID_symbol_type &&
765+
member_expr.struct_op().type().id() != ID_struct_tag &&
766+
member_expr.struct_op().type().id() != ID_union_tag)
764767
{
765768
const struct_union_typet &su_type=
766769
to_struct_union_type(member_expr.struct_op().type());
@@ -845,8 +848,19 @@ void goto_symex_statet::rename(
845848
}
846849
else if(type.id() == ID_symbol_type)
847850
{
848-
const symbolt &symbol=
849-
ns.lookup(to_symbol_type(type).get_identifier());
851+
const symbolt &symbol = ns.lookup(to_symbol_type(type));
852+
type = symbol.type;
853+
rename(type, l1_identifier, ns, level);
854+
}
855+
else if(type.id() == ID_union_tag)
856+
{
857+
const symbolt &symbol = ns.lookup(to_union_tag_type(type));
858+
type = symbol.type;
859+
rename(type, l1_identifier, ns, level);
860+
}
861+
else if(type.id() == ID_struct_tag)
862+
{
863+
const symbolt &symbol = ns.lookup(to_struct_tag_type(type));
850864
type=symbol.type;
851865
rename(type, l1_identifier, ns, level);
852866
}

0 commit comments

Comments
 (0)