31 std::vector<codet> statements;
32 for(
auto sub_expression_it = function_value.
depth_begin();
33 sub_expression_it != function_value.
depth_end();
36 if(sub_expression_it->id() == ID_code)
38 statements.push_back(
to_code(*sub_expression_it));
47 const std::vector<codet>
52 const symbolt *entry_point_function =
54 REQUIRE(entry_point_function !=
nullptr);
72 const std::vector<codet> &statements,
74 const std::optional<irep_idt> &superclass_name,
80 for(
const auto &assignment : statements)
82 if(assignment.get_statement() == ID_assign)
86 if(code_assign.
lhs().
id() == ID_member)
90 if(superclass_name.has_value())
104 const irep_idt supercomponent_name =
105 "@" +
id2string(superclass_name.value());
109 ode.
build(superclass_expr, ns);
119 locations.null_assignment = code_assign;
123 locations.non_null_assignments.push_back(code_assign);
137 ode.
build(member_expr, ns);
147 locations.null_assignment = code_assign;
151 locations.non_null_assignments.push_back(code_assign);
169 const std::vector<codet> &statements,
174 for(
const auto &assignment : statements)
176 if(assignment.get_statement() == ID_assign)
180 if(code_assign.
lhs().
id() == ID_member)
185 member_expr.
op().
id() == ID_dereference)
189 pointer.id() == ID_symbol &&
221 const std::vector<codet> &instructions)
223 INFO(
"Looking for symbol: " << pointer_name);
224 std::regex special_chars{R
"([-[\]{}()*+?.,\^$|#\s])"};
225 std::string sanitized =
226 std::regex_replace(id2string(pointer_name), special_chars, R"(\$&)");
228 std::regex(
"^" + sanitized +
"$"), instructions);
233 const std::regex &pointer_name_match,
234 const std::vector<codet> &instructions)
237 bool found_assignment =
false;
238 std::vector<irep_idt> all_symbols;
239 for(
const codet &statement : instructions)
241 if(statement.get_statement() == ID_assign)
244 if(code_assign.
lhs().
id() == ID_symbol)
262 found_assignment =
true;
268 std::ostringstream found_symbols;
269 for(
const auto &entry : all_symbols)
271 found_symbols << entry << std::endl;
273 INFO(
"Symbols: " << found_symbols.str());
274 REQUIRE(found_assignment);
287 const std::vector<codet> &entry_point_instructions)
289 for(
const auto &statement : entry_point_instructions)
291 if(statement.get_statement() == ID_decl)
295 if(decl_statement.get_identifier() == variable_name)
297 return decl_statement;
310 const std::vector<codet> &entry_point_instructions,
314 symbol_identifier, entry_point_instructions)
316 REQUIRE(assignments.size() == 1);
317 return assignments[0].rhs();
329 const std::vector<codet> &entry_point_instructions,
333 entry_point_instructions, symbol_identifier);
335 return expr_try_dynamic_cast<symbol_exprt>(
skip_typecast(expr));
354 const std::vector<codet> &entry_point_instructions,
355 const irep_idt &input_symbol_identifier)
359 entry_point_instructions, input_symbol_identifier);
361 if(symbol_assigned_to_input_symbol)
364 entry_point_instructions,
368 return input_symbol_identifier;
386 const std::optional<irep_idt> &superclass_name,
388 const irep_idt &component_type_name,
389 const std::optional<irep_idt> &typecast_name,
390 const std::vector<codet> &entry_point_instructions,
397 const auto &component_assignments =
399 entry_point_instructions,
405 "looking for component assignment " << component_name <<
" in "
407 REQUIRE(component_assignments.non_null_assignments.size() == 1);
412 const symbol_exprt *rhs_symbol_expr = expr_try_dynamic_cast<symbol_exprt>(
413 skip_typecast(component_assignments.non_null_assignments[0].rhs()));
414 REQUIRE(rhs_symbol_expr);
423 const auto &component_declaration =
425 symbol_identifier, entry_point_instructions);
426 const typet &component_type =
428 REQUIRE(component_type.
id() == ID_struct_tag);
429 const auto &component_struct =
431 REQUIRE(component_struct.get(ID_name) == component_type_name);
433 return symbol_identifier;
448 const std::optional<irep_idt> &superclass_name,
449 const irep_idt &array_component_name,
451 const std::vector<codet> &entry_point_instructions,
456 const auto &component_assignments =
458 entry_point_instructions,
461 array_component_name,
463 REQUIRE(component_assignments.non_null_assignments.size() == 1);
468 const exprt &component_assignment_rhs_expr =
469 component_assignments.non_null_assignments[0].rhs();
474 const auto &component_assignment_rhs =
476 const auto &component_reference_tmp_name =
480 REQUIRE(component_assignment_rhs.type().id() == ID_pointer);
484 .
get(ID_identifier) == array_type_name);
488 const auto &component_reference_assignments =
490 component_reference_tmp_name, entry_point_instructions);
491 REQUIRE(component_reference_assignments.non_null_assignments.size() == 1);
492 const exprt &component_reference_assignment_rhs_expr =
493 component_reference_assignments.non_null_assignments[0].rhs();
496 PRECONDITION(component_reference_assignment_rhs_expr.
id() == ID_side_effect);
497 const auto &array_component_reference_assignment_rhs =
502 array_component_reference_assignment_rhs.type().id() == ID_pointer);
507 REQUIRE(array.
get(ID_identifier) == array_type_name);
509 return component_reference_tmp_name;
519 const std::vector<codet> &entry_point_statements)
527 entry_point_statements);
536 const auto &argument_assignment =
550 const std::vector<codet> &statements,
551 const irep_idt &function_call_identifier)
553 std::vector<code_function_callt> function_calls;
554 for(
const codet &statement : statements)
556 if(statement.get_statement() == ID_function_call)
561 if(function_call.
function().
id() == ID_symbol)
565 function_call_identifier)
567 function_calls.push_back(function_call);
572 return function_calls;
A goto_instruction_codet representing an assignment in the program.
A goto_instruction_codet representing the declaration of a local variable.
goto_instruction_codet representation of a function call statement.
Data structure for representing an arbitrary statement in a program.
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
const char * c_str() const
Base class for all expressions.
depth_iteratort depth_end()
depth_iteratort depth_begin()
typet & type()
Return the type of the expression.
static irep_idt entry_point()
Get the identifier of the entry point to a goto model.
const irep_idt & get(const irep_idt &name) const
const irep_idt & id() const
Extract member of struct or union.
const exprt & compound() const
irep_idt get_component_name() const
const union_typet & follow_tag(const union_tag_typet &) const
Follow type tag of union type.
A namespacet is essentially one or two symbol tables bound together, to allow for symbol lookups in t...
The null pointer constant.
Split an expression into a base object and a (byte) offset.
void build(const exprt &expr, const namespacet &ns)
Given an expression expr, attempt to find the underlying object it represents by skipping over type c...
static const exprt & root_object(const exprt &expr)
const typet & base_type() const
The type of the data what we point to.
Expression to hold a symbol (variable)
const irep_idt & get_identifier() const
The symbol table base class interface.
const symbolt * lookup(const irep_idt &name) const
Find a symbol in the symbol table for read-only access.
exprt value
Initial value of symbol.
The type of an expression, extends irept.
Forward depth-first search iterators These iterators' copy operations are expensive,...
const exprt & skip_typecast(const exprt &expr)
find the expression nested inside typecasts, if any
Deprecated expression utility functions.
Goto Programs with Functions.
const code_assignt & to_code_assign(const goto_instruction_codet &code)
const code_function_callt & to_code_function_call(const goto_instruction_codet &code)
const code_declt & to_code_decl(const goto_instruction_codet &code)
const std::string & id2string(const irep_idt &d)
bool is_java_array_tag(const irep_idt &tag)
See above.
irep_idt require_entry_point_argument_assignment(const irep_idt &argument_name, const std::vector< codet > &entry_point_statements)
Checks that the input argument (of method under test) with given name is assigned a single non-null o...
std::vector< code_function_callt > find_function_calls(const std::vector< codet > &statements, const irep_idt &function_call_identifier)
Verify that a collection of statements contains a function call to a function whose symbol identifier...
std::vector< codet > get_all_statements(const exprt &function_value)
Expand value of a function to include all child codets.
pointer_assignment_locationt find_struct_component_assignments(const std::vector< codet > &statements, const irep_idt &structure_name, const std::optional< irep_idt > &superclass_name, const irep_idt &component_name, const symbol_table_baset &symbol_table)
Find assignment statements of the form:
pointer_assignment_locationt find_pointer_assignments(const irep_idt &pointer_name, const std::vector< codet > &instructions)
For a given variable name, gets the assignments to it in the provided instructions.
const std::vector< codet > require_entry_point_statements(const symbol_table_baset &symbol_table)
pointer_assignment_locationt find_this_component_assignment(const std::vector< codet > &statements, const irep_idt &component_name)
Find assignment statements that set this->{component_name}.
irep_idt require_struct_component_assignment(const irep_idt &structure_name, const std::optional< irep_idt > &superclass_name, const irep_idt &component_name, const irep_idt &component_type_name, const std::optional< irep_idt > &typecast_name, const std::vector< codet > &entry_point_instructions, const symbol_table_baset &symbol_table)
Checks that the component of the structure (possibly inherited from the superclass) is assigned an ob...
const code_declt & require_declaration_of_name(const irep_idt &variable_name, const std::vector< codet > &entry_point_instructions)
Find the declaration of the specific variable.
const irep_idt & require_struct_array_component_assignment(const irep_idt &structure_name, const std::optional< irep_idt > &superclass_name, const irep_idt &array_component_name, const irep_idt &array_type_name, const std::vector< codet > &entry_point_instructions, const symbol_table_baset &symbol_table)
Checks that the array component of the structure (possibly inherited from the superclass) is assigned...
API to expression classes for Pointers.
const dereference_exprt & to_dereference_expr(const exprt &expr)
Cast an exprt to a dereference_exprt.
const pointer_typet & to_pointer_type(const typet &type)
Cast a typet to a pointer_typet.
const symbol_exprt * try_get_unique_symbol_assigned_to_symbol(const std::vector< codet > &entry_point_instructions, const irep_idt &symbol_identifier)
Get the unique symbol assigned to a symbol, if one exists.
static const irep_idt & get_ultimate_source_symbol(const std::vector< codet > &entry_point_instructions, const irep_idt &input_symbol_identifier)
Follow the chain of non-null assignments until we find a symbol that hasn't ever had another symbol a...
const exprt & get_unique_non_null_expression_assigned_to_symbol(const std::vector< codet > &entry_point_instructions, const irep_idt &symbol_identifier)
Get the unique non-null expression assigned to a symbol.
Utilties for inspecting goto functions.
#define PRECONDITION(CONDITION)
side_effect_exprt & to_side_effect_expr(exprt &expr)
const codet & to_code(const exprt &expr)
const symbol_exprt & to_symbol_expr(const exprt &expr)
Cast an exprt to a symbol_exprt.
const typecast_exprt & to_typecast_expr(const exprt &expr)
Cast an exprt to a typecast_exprt.
const member_exprt & to_member_expr(const exprt &expr)
Cast an exprt to a member_exprt.
const struct_tag_typet & to_struct_tag_type(const typet &type)
Cast a typet to a struct_tag_typet.
std::vector< code_assignt > non_null_assignments
std::optional< code_assignt > null_assignment
bool has_suffix(const std::string &s, const std::string &suffix)