|
| union_typet () |
| union_typet (componentst _components) |
std::optional< std::pair< struct_union_typet::componentt, mp_integer > > | find_widest_union_component (const namespacet &ns) const |
| Determine the member of maximum bit width in a union type.
|
| struct_union_typet (const irep_idt &_id) |
| struct_union_typet (const irep_idt &_id, componentst _components) |
const componentst & | components () const |
componentst & | components () |
bool | has_component (const irep_idt &component_name) const |
const componentt & | get_component (const irep_idt &component_name) const |
| Get the reference to a component with given name.
|
std::size_t | component_number (const irep_idt &component_name) const |
| Return the sequence number of the component with given name.
|
const typet & | component_type (const irep_idt &component_name) const |
irep_idt | get_tag () const |
void | set_tag (const irep_idt &tag) |
bool | is_class () const |
| A struct may be a class, where members may have access restrictions.
|
irep_idt | default_access () const |
| Return the access specification for members where access has not been modified.
|
bool | is_incomplete () const |
| A struct/union may be incomplete.
|
void | make_incomplete () |
| A struct/union may be incomplete.
|
| typet () |
| typet (const irep_idt &_id) |
| typet (irep_idt _id, typet _subtype) |
typet & | add_subtype () |
bool | has_subtypes () const |
bool | has_subtype () const |
void | remove_subtype () |
const source_locationt & | source_location () const |
source_locationt & | add_source_location () |
typet && | with_source_location (source_locationt location) && |
| This is a 'fluent style' method for creating a new type with an added-on source location.
|
typet & | with_source_location (source_locationt location) & |
| This is a 'fluent style' method for adding a source location.
|
typet && | with_source_location (const typet &type) && |
| This is a 'fluent style' method for creating a new type with an added-on source location.
|
typet & | with_source_location (const typet &type) & |
| This is a 'fluent style' method for adding a source location.
|
typet & | add_type (const irep_idt &name) |
const typet & | find_type (const irep_idt &name) const |
bool | is_nil () const |
bool | is_not_nil () const |
| irept (const irep_idt &_id) |
| irept (const irep_idt &_id, const named_subt &_named_sub, const subt &_sub) |
| irept ()=default |
const irep_idt & | id () const |
const std::string & | id_string () const |
void | id (const irep_idt &_data) |
const irept & | find (const irep_idt &name) const |
irept & | add (const irep_idt &name) |
irept & | add (const irep_idt &name, irept irep) |
const std::string & | get_string (const irep_idt &name) const |
const irep_idt & | get (const irep_idt &name) const |
bool | get_bool (const irep_idt &name) const |
signed int | get_int (const irep_idt &name) const |
std::size_t | get_size_t (const irep_idt &name) const |
long long | get_long_long (const irep_idt &name) const |
void | set (const irep_idt &name, const irep_idt &value) |
void | set (const irep_idt &name, irept irep) |
void | set (const irep_idt &name, const long long value) |
void | set_size_t (const irep_idt &name, const std::size_t value) |
void | remove (const irep_idt &name) |
void | move_to_sub (irept &irep) |
void | move_to_named_sub (const irep_idt &name, irept &irep) |
bool | operator== (const irept &other) const |
bool | operator!= (const irept &other) const |
void | swap (irept &irep) |
bool | operator< (const irept &other) const |
| defines ordering on the internal representation
|
bool | ordering (const irept &other) const |
| defines ordering on the internal representation
|
int | compare (const irept &i) const |
| defines ordering on the internal representation comments are ignored
|
void | clear () |
void | make_nil () |
subt & | get_sub () |
const subt & | get_sub () const |
named_subt & | get_named_sub () |
const named_subt & | get_named_sub () const |
std::size_t | hash () const |
std::size_t | full_hash () const |
bool | full_eq (const irept &other) const |
std::string | pretty (unsigned indent=0, unsigned max_indent=0) const |
| sharing_treet (irep_idt _id) |
sharing_treet & | operator= (const sharing_treet &irep) |
| ~sharing_treet () |
const dt & | read () const |
dt & | write () |
|
typedef std::vector< componentt > | componentst |
using | baset = tree_implementationt |
using | dt |
using | subt |
using | named_subt |
using | tree_implementationt |
| Used to refer to this class from derived classes.
|
static void | check (const typet &, const validation_modet=validation_modet::INVARIANT) |
| Check that the type is well-formed (shallow checks only, i.e., subtypes are not checked)
|
static void | validate (const typet &type, const namespacet &, const validation_modet vm=validation_modet::INVARIANT) |
| Check that the type is well-formed, assuming that its subtypes have already been checked for well-formedness.
|
static void | validate_full (const typet &type, const namespacet &ns, const validation_modet vm=validation_modet::INVARIANT) |
| Check that the type is well-formed (full check, including checks of subtypes)
|
static bool | is_comment (const irep_idt &name) |
static std::size_t | number_of_non_comments (const named_subt &) |
| count the number of named_sub elements that are not comments
|
void | detach () |
static void | remove_ref (dt *old_data) |
static void | nonrecursive_destructor (dt *old_data) |
| Does the same as remove_ref, but using an explicit stack instead of recursion.
|
dt * | data |
static dt | empty_d |
The union type.
For example, C union.
Definition at line 146 of file c_types.h.