Go to the documentation of this file.
57 bool did_initialize_values =
false;
58 auto struct_type_it = struct_type_def.
components().begin();
60 ++param_it, ++struct_type_it)
63 struct_type_it->get_name(),
65 did_initialize_values =
true;
68 if(did_initialize_values)
101 return value.value();
106 member_expr.
type(), ns,
true,
false);
114 const std::stack<exprt> &stack,
117 bool merging_write)
const
126 return std::make_shared<full_struct_abstract_objectt>(
131 std::dynamic_pointer_cast<full_struct_abstract_objectt>(
mutable_clone());
137 auto const old_value =
map.
find(c);
138 if(!old_value.has_value())
141 member_expr.
type(), ns,
true,
false);
143 c, environment.
write(starting_value, value, stack, ns, merging_write));
149 environment.
write(old_value.value(), value, stack, ns, merging_write));
152 result->set_not_top();
153 DATA_INVARIANT(result->verify(),
"Structural invariants maintained");
159 std::cout <<
"Setting component" << std::endl;
163 auto const old_value = result->map.find(c);
169 DATA_INVARIANT(result->verify(),
"Structural invariants maintained");
173 INVARIANT(!result->map.empty(),
"If not top, map cannot be empty");
175 if(!old_value.has_value())
177 DATA_INVARIANT(result->verify(),
"Structural invariants maintained");
188 if(old_value.has_value())
190 result->map.replace(c, value);
194 result->map.insert(c, value);
196 result->set_not_top();
197 INVARIANT(!result->is_bottom(),
"top != bottom");
200 DATA_INVARIANT(result->verify(),
"Structural invariants maintained");
219 for(
const auto &field : type_decl.
components())
221 auto value =
map.
find(field.get_name());
222 if(value.has_value())
228 out <<
'.' << field.get_name() <<
'=';
249 std::dynamic_pointer_cast<const full_struct_abstract_objectt>(other);
261 return std::make_shared<full_struct_abstract_objectt>(*other);
264 std::dynamic_pointer_cast<full_struct_abstract_objectt>(
mutable_clone());
271 return shared_from_this();
275 INVARIANT(!result->is_top(),
"Merge of maps will not generate top");
276 INVARIANT(!result->is_bottom(),
"Merge of maps will not generate bottom");
277 DATA_INVARIANT(result->verify(),
"Structural invariants maintained");
298 std::dynamic_pointer_cast<full_struct_abstract_objectt>(
mutable_clone());
300 bool is_modified =
visit_map(result->map, visitor);
302 return is_modified ? result : shared_from_this();
306 const exprt &name)
const
314 member_exprt(name, compound_type.get_component(field.first));
315 auto field_expr = field.second->to_predicate(field_name);
317 if(!field_expr.is_true())
318 all_predicates.push_back(field_expr);
321 if(all_predicates.empty())
323 if(all_predicates.size() == 1)
324 return all_predicates.front();
336 for(
auto const &
object : view)
338 if(visited.find(
object.second) == visited.end())
340 object.second->get_statistics(
statistics, visited, env, ns);
const componentst & components() const
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
sharing_ptrt< class abstract_objectt > abstract_object_pointert
virtual bool is_top() const
Find out if the abstract object is top.
abstract_object_pointert visit_sub_elements(const abstract_object_visitort &visitor) const override
Apply a visitor operation to all sub elements of this abstract_object.
goto_programt::const_targett locationt
static bool merge_shared_maps(const sharing_mapt< keyt, abstract_object_pointert, false, hash > &map1, const sharing_mapt< keyt, abstract_object_pointert, false, hash > &map2, sharing_mapt< keyt, abstract_object_pointert, false, hash > &out_map, const widen_modet &widen_mode)
const struct_typet & to_struct_type(const typet &type)
Cast a typet to a struct_typet.
bool visit_map(mapt &map, const visitort &visitor)
virtual abstract_object_pointert write(const abstract_object_pointert &lhs, const abstract_object_pointert &rhs, std::stack< exprt > remaining_stack, const namespacet &ns, bool merge_write)
Used within assign to do the actual dispatch.
const struct_union_typet & to_struct_union_type(const typet &type)
Cast a typet to a struct_union_typet.
sharing_ptrt< full_struct_abstract_objectt > constant_struct_pointert
The type of an expression, extends irept.
void get_view(V &view) const
Get a view of the elements in the map A view is a list of pairs with the components being const refer...
Base type for structs and unions.
abstract_object_pointert merge_constant_structs(constant_struct_pointert other, const widen_modet &widen_mode) const
Performs an element wise merge of the map for each struct.
virtual const typet & type() const
Get the real type of the variable this abstract object is representing.
sorted_viewt get_sorted_view() const
Convenience function to get a sorted view of the map elements.
abstract_object_pointert read_component(const abstract_environmentt &environment, const exprt &expr, const namespacet &ns) const override
A helper function to evaluate the abstract object contained within a struct.
Base class for all expressions.
abstract_object_pointert write_location_context(const locationt &location) const override
Update the location context for an abstract object.
full_struct_abstract_objectt(const full_struct_abstract_objectt &ao)
Explicit copy-constructor to make it clear that the shared_map used to store the values of fields is ...
A namespacet is essentially one or two symbol tables bound together, to allow for symbol lookups in t...
typet & type()
Return the type of the expression.
std::vector< view_itemt > viewt
View of the key-value pairs in the map.
static combine_result merge(const abstract_object_pointert &op1, const abstract_object_pointert &op2, const locationt &merge_location, const widen_modet &widen_mode)
void statistics(abstract_object_statisticst &statistics, abstract_object_visitedt &visited, const abstract_environmentt &env, const namespacet &ns) const override
#define DATA_INVARIANT(CONDITION, REASON)
This condition should be used to document that assumptions that are made on goto_functions,...
const exprt & compound() const
virtual abstract_object_pointert abstract_object_factory(const typet &type, const namespacet &ns, bool top, bool bottom) const
Look at the configuration for the sensitivity and create an appropriate abstract_object.
void output(std::ostream &out, const class ai_baset &ai, const class namespacet &ns) const override
To provide a human readable string to the out representing the current known value about this object.
#define PRECONDITION(CONDITION)
void insert_or_replace(const key_type &k, valueU &&m)
bool empty() const
Check if map is empty.
internal_abstract_object_pointert mutable_clone() const override
const irep_idt & id() const
std::vector< exprt > operandst
abstract_object_pointert merge(const abstract_object_pointert &other, const widen_modet &widen_mode) const override
To merge an abstract object into this abstract object.
std::set< abstract_object_pointert > abstract_object_visitedt
Pure virtual interface required of a client that can apply a copy-on-write operation to a given abstr...
Extract member of struct or union.
Structure type, corresponds to C style structs.
const typet & follow(const typet &) const
Resolve type symbol to the type it points to.
abstract_object_pointert merge_location_context(const locationt &location) const override
Update the merge location context for an abstract object.
This is the basic interface of the abstract interpreter with default implementations of the core func...
abstract_object_pointert write_component(abstract_environmentt &environment, const namespacet &ns, const std::stack< exprt > &stack, const exprt &expr, const abstract_object_pointert &value, bool merging_write) const override
A helper function to evaluate writing to a component of a struct.
const member_exprt & to_member_expr(const exprt &expr)
Cast an exprt to a member_exprt.
irep_idt get_component_name() const
virtual bool is_bottom() const
Find out if the abstract object is bottom.
abstract_object_pointert object
exprt to_predicate_internal(const exprt &name) const override
to_predicate implementation - derived classes will override
The Boolean constant true.
bool verify() const override
Function: full_struct_abstract_objectt::verify.
static memory_sizet from_bytes(std::size_t bytes)
typet t
To enforce copy-on-write these are private and have read-only accessors.
optionalt< std::reference_wrapper< const mapped_type > > find(const key_type &k) const
Find element.