32 main_arguments.resize(parameters.size());
34 for(std::size_t param_number=0;
35 param_number<parameters.size();
48 object_factory_parameters,
52 return main_arguments;
60 bool has_return_value =
75 for(
const auto &p : parameters)
77 if(p.get_identifier().empty())
80 irep_idt identifier=p.get_identifier();
84 if(symbol.
type.
id()==ID_pointer)
86 codet output(ID_output);
97 init_code.
add(std::move(output));
122 for(
auto it = matches.begin(); it != matches.end();)
124 if((*it)->second.type.id() != ID_code || (*it)->second.is_property)
125 it = matches.erase(it);
133 message.
error() <<
"main symbol '" <<
config.
main.value() <<
"' not found"
138 if(matches.size()>=2)
146 main_symbol = matches.front()->first;
152 symbol_table_baset::symbolst::const_iterator s_it =
153 symbol_table.
symbols.find(main_symbol);
155 if(s_it==symbol_table.
symbols.end())
158 const symbolt &symbol=s_it->second;
172 symbol, symbol_table, message_handler, object_factory_parameters);
199 symbol_table_baset::symbolst::const_iterator init_it =
202 if(init_it==symbol_table.
symbols.end())
213 init_code.
add(std::move(call_init));
225 return_symbol.
mode=ID_C;
227 return_symbol.
name=
"return'";
231 symbol_table.
add(return_symbol);
238 if(symbol.
name==ID_main)
240 if(parameters.empty())
251 parameters.size() >= 2 && parameters[1].type().id() == ID_pointer &&
252 (parameters.size() == 2 ||
253 (parameters.size() == 3 && parameters[2].type().id() == ID_pointer)))
259 argc_symbol.base_name =
"argc'";
260 argc_symbol.is_static_lifetime =
true;
261 argc_symbol.is_lvalue =
true;
263 auto r = symbol_table.
insert(argc_symbol);
264 if(!
r.second &&
r.first != argc_symbol)
267 message.
error() <<
"argc already exists but is not usable"
283 symbolt argv_symbol{
"argv'", argv_type, ID_C};
284 argv_symbol.base_name =
"argv'";
285 argv_symbol.is_static_lifetime =
true;
286 argv_symbol.is_lvalue =
true;
288 auto r = symbol_table.
insert(argv_symbol);
289 if(!
r.second &&
r.first != argv_symbol)
292 message.
error() <<
"argv already exists but is not usable"
310 argc_symbol.
symbol_expr(), ID_ge, std::move(zero));
321 argc_symbol.
symbol_expr(), ID_le, std::move(bound_expr));
329 if(parameters.size()==3)
333 envp_size_symbol.base_name =
"envp_size'";
334 envp_size_symbol.is_static_lifetime =
true;
336 if(!symbol_table.
insert(std::move(envp_size_symbol)).second)
353 envp_symbol.base_name =
"envp'";
354 envp_symbol.is_static_lifetime =
true;
356 if(!symbol_table.
insert(std::move(envp_symbol)).second)
371 envp_size_symbol.
symbol_expr(), ID_le, std::move(max_minus_one));
409 init_code.
statements().back().add_source_location().add_pragma(
410 "disable:bounds-check");
413 if(parameters.size()==3)
432 init_code.
statements().back().add_source_location().add_pragma(
433 "disable:bounds-check");
439 if(parameters.size()==3)
444 exprt &op0=operands[0];
445 exprt &op1=operands[1];
465 if(parameters.size()==3)
485 const std::string main_signature =
type2c(symbol.
type, ns);
488 message.
error() <<
"'main' with signature '" << main_signature
490 <<
" but expecting one of:\n"
491 <<
" int main(void)\n"
492 <<
" int main(int argc, char *argv[])\n"
493 <<
" int main(int argc, char *argv[], char *envp[])\n"
494 <<
"If this is a non-standard main entry point please "
496 <<
"entry function and use --function instead"
505 parameters, init_code, symbol_table, object_factory_parameters);
508 init_code.
add(std::move(call_main));
516 for(
const auto &symbol_table_entry : symbol_table.
symbols)
518 const symbolt &symbol = symbol_table_entry.second;
520 if(symbol.
type.
id() != ID_code)
530 init_code.
add(std::move(destructor_call));
538 new_symbol.value.swap(init_code);
540 if(!symbol_table.
insert(std::move(new_symbol)).second)
@ AUTOMATIC_LOCAL
Allocate local objects with automatic lifetime.
bool generate_ansi_c_start_function(const symbolt &symbol, symbol_table_baset &symbol_table, message_handlert &message_handler, const c_object_factory_parameterst &object_factory_parameters)
Generate a _start function for a specific function.
exprt::operandst build_function_environment(const code_typet::parameterst ¶meters, code_blockt &init_code, symbol_table_baset &symbol_table, const c_object_factory_parameterst &object_factory_parameters)
void record_function_outputs(const symbolt &function, code_blockt &init_code, symbol_table_baset &symbol_table)
bool ansi_c_entry_point(symbol_table_baset &symbol_table, message_handlert &message_handler, const c_object_factory_parameterst &object_factory_parameters)
const integer_bitvector_typet & to_integer_bitvector_type(const typet &type)
Cast a typet to an integer_bitvector_typet.
symbol_exprt c_nondet_symbol_factory(code_blockt &init_code, symbol_table_baset &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.
signedbv_typet signed_int_type()
pointer_typet pointer_type(const typet &subtype)
bitvector_typet char_type()
Operator to return the address of an object.
typet index_type() const
The type of the index expressions into any instance of this type.
const typet & element_type() const
The type of the elements of the array.
Internally generated symbol table entryThis is a symbol generated as part of translation to or modifi...
A base class for relations, i.e., binary predicates whose two operands have the same type.
An assumption, which must hold in subsequent code.
A codet representing sequential composition of program statements.
void add(const codet &code)
code_operandst & statements()
A codet representing an assignment in the program.
goto_instruction_codet representation of a function call statement.
codet representation of a label for branch targets.
A goto_instruction_codet representing the declaration that an output of a particular description has ...
A codet representing a skip statement.
const irep_idt & get_base_name() const
std::vector< parametert > parameterst
const typet & return_type() const
const parameterst & parameters() const
Data structure for representing an arbitrary statement in a program.
std::optional< std::string > main
struct configt::ansi_ct ansi_c
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
Base class for all expressions.
std::vector< exprt > operandst
source_locationt & add_source_location()
const source_locationt & source_location() const
typet & type()
Return the type of the expression.
static irep_idt entry_point()
Get the identifier of the entry point to a goto model.
mp_integer largest() const
Return the largest value that can be represented using this type.
const irep_idt & id() const
source_locationt source_location
Class that provides messages with a built-in verbosity 'level'.
A namespacet is essentially one or two symbol tables bound together, to allow for symbol lookups in t...
bool lookup(const irep_idt &name, const symbolt *&symbol) const override
See documentation for namespace_baset::lookup().
The null pointer constant.
The plus expression Associativity is not specified.
The pointer type These are both 'bitvector_typet' (they have a width) and 'type_with_subtypet' (they ...
void add_pragma(const irep_idt &pragma)
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.
const symbolst & symbols
Read-only field, used to look up symbols given their names.
const symbolt & lookup_ref(const irep_idt &name) const
Find a symbol in the symbol table for read-only access.
std::list< symbolst::const_iterator > match_name_or_base_name(const irep_idt &id) const
Collect all symbols the name of which matches id or the base name of which matches id.
bool add(const symbolt &symbol)
Add a new symbol to the symbol table.
virtual std::pair< symbolt &, bool > insert(symbolt symbol)=0
Move or copy a new symbol to the symbol table.
irep_idt base_name
Base (non-scoped) name.
source_locationt location
Source code location of definition of symbol.
class symbol_exprt symbol_expr() const
Produces a symbol_exprt for a symbol.
typet type
Type of symbol.
irep_idt name
The unique identifier.
exprt value
Initial value of symbol.
irep_idt mode
Language mode.
static exprt conditional_cast(const exprt &expr, const typet &type)
std::string type2c(const typet &type, const namespacet &ns, const expr2c_configurationt &configuration)
Goto Programs with Functions.
const std::string & id2string(const irep_idt &d)
API to expression classes for Pointers.
const pointer_typet & to_pointer_type(const typet &type)
Cast a typet to a pointer_typet.
#define PRECONDITION(CONDITION)
static std::optional< codet > static_lifetime_init(const irep_idt &identifier, symbol_table_baset &symbol_table)
#define INITIALIZE_FUNCTION
const code_typet & to_code_type(const typet &type)
Cast a typet to a code_typet.
const array_typet & to_array_type(const typet &type)
Cast a typet to an array_typet.
std::string to_string(const string_not_contains_constraintt &expr)
Used for debug printing.
std::optional< mp_integer > max_argc
Maximum value of argc, which is operating-systems dependent: Windows limits the number of characters ...