Go to the documentation of this file.
29 main_arguments.resize(parameters.size());
31 for(std::size_t param_number=0;
32 param_number<parameters.size();
45 object_factory_parameters,
49 return main_arguments;
57 bool has_return_value =
72 for(
const auto &p : parameters)
74 if(p.get_identifier().empty())
77 irep_idt identifier=p.get_identifier();
81 if(symbol.
type.
id()==ID_pointer)
83 codet output(ID_output);
94 init_code.
add(std::move(output));
117 std::list<irep_idt> matches;
123 symbol_tablet::symbolst::const_iterator s_it=
124 symbol_table.
symbols.find(it->second);
126 if(s_it==symbol_table.
symbols.end())
129 if(s_it->second.type.id()==ID_code)
130 matches.push_back(it->second);
141 if(matches.size()>=2)
149 main_symbol=matches.front();
155 symbol_tablet::symbolst::const_iterator s_it=
156 symbol_table.
symbols.find(main_symbol);
158 if(s_it==symbol_table.
symbols.end())
161 const symbolt &symbol=s_it->second;
175 symbol, symbol_table, message_handler, object_factory_parameters);
202 symbol_tablet::symbolst::const_iterator init_it=
205 if(init_it==symbol_table.
symbols.end())
216 init_code.
add(std::move(call_init));
228 return_symbol.
mode=ID_C;
230 return_symbol.
name=
"return'";
234 symbol_table.
add(return_symbol);
241 if(symbol.
name==ID_main)
243 if(parameters.empty())
247 else if(parameters.size()==2 || parameters.size()==3)
255 argc_symbol.
name =
"argc'";
259 argc_symbol.
mode = ID_C;
261 auto r = symbol_table.
insert(argc_symbol);
262 if(!
r.second &&
r.first != argc_symbol)
265 message.error() <<
"argc already exists but is not usable"
284 argv_symbol.
name =
"argv'";
285 argv_symbol.
type = argv_type;
288 argv_symbol.
mode = ID_C;
290 auto r = symbol_table.
insert(argv_symbol);
291 if(!
r.second &&
r.first != argv_symbol)
294 message.error() <<
"argv already exists but is not usable"
320 argc_symbol.
symbol_expr(), ID_le, std::move(bound_expr));
328 if(parameters.size()==3)
332 envp_size_symbol.
base_name =
"envp_size'";
333 envp_size_symbol.
name =
"envp_size'";
336 envp_size_symbol.
mode = ID_C;
338 if(!symbol_table.
insert(std::move(envp_size_symbol)).second)
352 envp_symbol.
name =
"envp'";
356 envp_symbol.
mode = ID_C;
358 if(!symbol_table.
insert(std::move(envp_symbol)).second)
373 envp_size_symbol.
symbol_expr(), ID_le, std::move(max_minus_one));
408 index_expr.set(
"bounds_check",
false);
413 if(parameters.size()==3)
424 index_expr.set(
"bounds_check",
false);
434 if(parameters.size()==3)
439 exprt &op0=operands[0];
440 exprt &op1=operands[1];
450 index_expr.
set(
"bounds_check",
false);
460 if(parameters.size()==3)
482 parameters, init_code, symbol_table, object_factory_parameters);
485 init_code.
add(std::move(call_main));
499 if(!symbol_table.
insert(std::move(new_symbol)).second)
Class that provides messages with a built-in verbosity 'level'.
#define UNREACHABLE
This should be used to mark dead code.
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
A codet representing sequential composition of program statements.
static exprt conditional_cast(const exprt &expr, const typet &type)
const symbolt & lookup_ref(const irep_idt &name) const
Find a symbol in the symbol table for read-only access.
const typet & subtype() const
const symbol_base_mapt & symbol_base_map
Read-only field, used to look up symbol names given their base names.
@ AUTOMATIC_LOCAL
Allocate local objects with automatic lifetime.
std::vector< parametert > parameterst
typet type
Type of symbol.
optionalt< std::string > main
The plus expression Associativity is not specified.
symbol_exprt c_nondet_symbol_factory(code_blockt &init_code, symbol_tablet &symbol_table, const irep_idt base_name, const typet &type, const source_locationt &loc, const c_object_factory_parameterst &object_factory_parameters, const lifetimet lifetime)
Creates a symbol and generates code so that it can vary over all possible values for its type.
Base class for all expressions.
irep_idt base_name
Base (non-scoped) name.
exprt::operandst build_function_environment(const code_typet::parameterst ¶meters, code_blockt &init_code, symbol_tablet &symbol_table, const c_object_factory_parameterst &object_factory_parameters)
std::string to_string(const string_not_contains_constraintt &expr)
Used for debug printing.
Internally generated symbol table entry.
struct configt::ansi_ct ansi_c
bitvector_typet index_type()
void record_function_outputs(const symbolt &function, code_blockt &init_code, symbol_tablet &symbol_table)
A namespacet is essentially one or two symbol tables bound together, to allow for symbol lookups in t...
A codet representing the declaration that an output of a particular description has a value which cor...
static const char * message(const static_verifier_resultt::statust &status)
Makes a status message string from a status.
typet & type()
Return the type of the expression.
bool lookup(const irep_idt &name, const symbolt *&symbol) const override
See documentation for namespace_baset::lookup().
codet representation of a function call statement.
const code_typet & to_code_type(const typet &type)
Cast a typet to a code_typet.
irep_idt mode
Language mode.
const irep_idt & get_base_name() const
signedbv_typet signed_int_type()
The null pointer constant.
const std::string & id2string(const irep_idt &d)
codet representation of a label for branch targets.
#define PRECONDITION(CONDITION)
An assumption, which must hold in subsequent code.
class symbol_exprt symbol_expr() const
Produces a symbol_exprt for a symbol.
#define INITIALIZE_FUNCTION
virtual std::pair< symbolt &, bool > insert(symbolt symbol) override
Author: Diffblue Ltd.
pointer_typet pointer_type(const typet &subtype)
const integer_bitvector_typet & to_integer_bitvector_type(const typet &type)
Cast a typet to an integer_bitvector_typet.
const irep_idt & id() const
std::vector< exprt > operandst
void add(const codet &code)
bool generate_ansi_c_start_function(const symbolt &symbol, symbol_tablet &symbol_table, message_handlert &message_handler, const c_object_factory_parameterst &object_factory_parameters)
Generate a _start function for a specific function.
const parameterst & parameters() const
const pointer_typet & to_pointer_type(const typet &type)
Cast a typet to a pointer_typet.
bool ansi_c_entry_point(symbol_tablet &symbol_table, message_handlert &message_handler, const c_object_factory_parameterst &object_factory_parameters)
bitvector_typet char_type()
bool add(const symbolt &symbol)
Add a new symbol to the symbol table.
exprt value
Initial value of symbol.
A codet representing a skip statement.
source_locationt location
Source code location of definition of symbol.
void set(const irep_namet &name, const irep_idt &value)
static optionalt< codet > static_lifetime_init(const irep_idt &identifier, symbol_tablet &symbol_table)
const symbolst & symbols
Read-only field, used to look up symbols given their names.
A base class for relations, i.e., binary predicates whose two operands have the same type.
#define forall_symbol_base_map(it, expr, base_name)
mp_integer largest() const
Return the largest value that can be represented using this type.
const symbolt * lookup(const irep_idt &name) const
Find a symbol in the symbol table for read-only access.
const typet & return_type() const
static irep_idt entry_point()
Get the identifier of the entry point to a goto model.
Operator to return the address of an object.
source_locationt & add_source_location()
The pointer type These are both 'bitvector_typet' (they have a width) and 'type_with_subtypet' (they ...
unsignedbv_typet size_type()
A codet representing an assignment in the program.
const source_locationt & source_location() const
irep_idt name
The unique identifier.
Data structure for representing an arbitrary statement in a program.