Go to the documentation of this file.
24 #include <unordered_set>
28 if(type.
id() != ID_struct)
43 static const std::unordered_set<std::string> primitive_wrapper_type_names = {
46 "java.lang.Character",
52 return primitive_wrapper_type_names.count(type_name) > 0;
59 if(t.
id()==ID_pointer)
68 "all types constructed in java_types.cpp encode JVM types "
69 "with these bit widths");
71 return bitwidth == 64 ? 2u : 1u;
106 new_symbol.
type=class_type;
107 new_symbol.
mode=ID_java;
110 std::pair<symbolt &, bool> res=symbol_table.
insert(std::move(new_symbol));
116 "stub class symbol " <<
143 const std::string &friendly_name,
147 std::string qualified_name=
"java::"+friendly_name;
148 if(friendly_name.rfind(
':')==std::string::npos)
150 std::string prefix=qualified_name+
':';
151 std::set<irep_idt> matches;
153 for(
const auto &s : symbol_table.
symbols)
155 s.second.type.id()==ID_code)
156 matches.insert(s.first);
160 error=
"'"+friendly_name+
"' not found";
163 else if(matches.size()>1)
166 message <<
"'"+friendly_name+
"' is ambiguous between:";
169 for(
const auto &s : matches)
177 return *matches.begin();
182 auto findit=symbol_table.
symbols.find(qualified_name);
183 if(findit==symbol_table.
symbols.end())
185 error=
"'"+friendly_name+
"' not found";
188 else if(findit->second.type.id()!=ID_code)
190 error=
"'"+friendly_name+
"' not a function";
195 return findit->first;
216 result.
set(ID_java_member_access,
true);
234 const std::string &src,
243 size_t c_pos=open_pos+1;
244 const size_t end_pos=src.size()-1;
247 while(c_pos<=end_pos)
249 if(src[c_pos] == open_char)
251 else if(src[c_pos] == close_char)
260 depth<=(src.size()-open_pos),
262 "\' found in signature to parse.");
265 return std::string::npos;
281 components.end(), components_to_add.begin(), components_to_add.end());
299 func_symbol.
mode=ID_java;
300 func_symbol.
name=function_name;
301 func_symbol.
type=type;
302 symbol_table.
add(func_symbol);
321 std::vector<typet> argument_types;
322 for(
const auto &arg : arguments)
323 argument_types.push_back(arg.type());
340 const std::string to_strip_str=
id2string(to_strip);
341 const std::string prefix=
"java::";
344 return to_strip_str.substr(prefix.size(), std::string::npos);
354 std::string result(fqn_java_type);
355 const std::string java_cbmc_string(
"java::");
357 if(
has_prefix(fqn_java_type, java_cbmc_string))
358 result = fqn_java_type.substr(java_cbmc_string.length());
361 const std::string java_lang_string(
"java.lang.");
363 result = result.substr(java_lang_string.length());
383 bool include_interfaces)
386 const auto resolved_component =
387 component_resolver(component_class_id, component_name, include_interfaces);
393 if(resolved_component)
396 if(component_class_id == resolved_component->get_class_identifier())
397 return *resolved_component;
401 resolved_component->get_full_component_identifier());
405 access = component_symbol.
type.
get(ID_C_access);
407 if(access==ID_public || access==ID_protected)
410 return *resolved_component;
415 if(access==ID_default)
417 const std::string &class_package=
420 id2string(resolved_component->get_class_identifier()));
421 if(component_package == class_package)
422 return *resolved_component;
427 if(access==ID_private)
452 static const irep_idt in =
"java::java.lang.System.in";
453 static const irep_idt out =
"java::java.lang.System.out";
454 static const irep_idt err =
"java::java.lang.System.err";
455 return symbolid == in || symbolid == out || symbolid == err;
489 const std::string &basename_prefix,
495 const std::string name_prefix =
id2string(function_name);
497 type, name_prefix, basename_prefix, source_location, ID_java, symbol_table);
514 const auto signature_index = method_name.rfind(
":");
515 const auto method_index = method_name.rfind(
".", signature_index);
516 if(method_index == std::string::npos)
518 return method_name.substr(0, method_index);
Class that provides messages with a built-in verbosity 'level'.
#define UNREACHABLE
This should be used to mark dead code.
const componentst & components() const
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
const symbolt & lookup_ref(const irep_idt &name) const
Find a symbol in the symbol table for read-only access.
const typet & subtype() const
bool is_primitive_wrapper_type_name(const std::string &type_name)
Returns true iff the argument is the fully qualified name of a Java primitive wrapper type.
const struct_typet & to_struct_type(const typet &type)
Cast a typet to a struct_typet.
bool is_java_string_literal_id(const irep_idt &id)
void set_declaring_class(symbolt &symbol, const irep_idt &declaring_class)
Sets the identifier of the class which declared a given symbol to declaring_class.
The type of an expression, extends irept.
typet type
Type of symbol.
Operator to dereference a pointer.
dereference_exprt checked_dereference(const exprt &expr)
Dereference an expression and flag it for a null-pointer check.
exprt make_function_application(const irep_idt &function_name, const exprt::operandst &arguments, const typet &range, symbol_table_baset &symbol_table)
Create a (mathematical) function application expression.
const std::string java_class_to_package(const std::string &canonical_classname)
optionalt< irep_idt > declaring_class(const symbolt &symbol)
Gets the identifier of the class which declared a given symbol.
bool java_is_array_type(const typet &type)
void generate_class_stub(const irep_idt &class_name, symbol_table_baset &symbol_table, message_handlert &message_handler, const struct_union_typet::componentst &componentst)
Base class for all expressions.
std::vector< componentt > componentst
bool is_java_array_tag(const irep_idt &tag)
See above.
irep_idt base_name
Base (non-scoped) name.
A struct tag type, i.e., struct_typet with an identifier.
std::string to_string(const string_not_contains_constraintt &expr)
Used for debug printing.
Internally generated symbol table entry.
std::string trim_from_last_delimiter(const std::string &s, const char delim)
NODISCARD optionalt< std::string > class_name_from_method_name(const std::string &method_name)
Get JVM type name of the class in which method_name is defined.
irep_idt pretty_name
Language-specific display name.
irep_idt strip_java_namespace_prefix(const irep_idt &to_strip)
Strip java:: prefix from given identifier.
static const char * message(const static_verifier_resultt::statust &status)
Makes a status message string from a status.
size_t find_closing_delimiter(const std::string &src, size_t open_pos, char open_char, char close_char)
Finds the corresponding closing delimiter to the given opening delimiter.
irep_idt mode
Language mode.
bool is_java_string_type(const struct_typet &struct_type)
Returns true iff the argument represents a string type (CharSequence, StringBuilder,...
const std::string & id2string(const irep_idt &d)
void set_tag(const irep_idt &tag)
bool can_cast_type< struct_tag_typet >(const typet &type)
Check whether a reference to a typet is a struct_tag_typet.
#define PRECONDITION(CONDITION)
The symbol table base class interface.
void merge(const source_locationt &from)
Set all unset source-location fields in this object to their values in 'from'.
void java_add_components_to_class(symbolt &class_symbol, const struct_union_typet::componentst &components_to_add)
Add the components in components_to_add to the class denoted by class symbol.
irep_idt resolve_friendly_method_name(const std::string &friendly_name, const symbol_table_baset &symbol_table, std::string &error)
Resolves a user-friendly method name (like packagename.Class.method) into an internal name (like java...
bool is_non_null_library_global(const irep_idt &symbolid)
Check if a symbol is a well-known non-null global.
Application of (mathematical) function.
pointer_typet pointer_type(const typet &subtype)
static bool implements_java_char_sequence(const typet &type)
bool has_component(const irep_idt &component_name) const
const irep_idt & id() const
std::vector< exprt > operandst
unsigned java_local_variable_slots(const typet &t)
Returns the number of JVM local variables (slots) taken by a local variable that, when translated to ...
const std::unordered_set< std::string > cprover_methods_to_ignore
Methods belonging to the class org.cprover.CProver that should be ignored (not converted),...
const parameterst & parameters() const
pointer_typet pointer_to_replacement_type(const pointer_typet &given_pointer_type, const java_class_typet &replacement_class_type)
Given a pointer type to a Java class and a type representing a more specific Java class,...
symbolt & fresh_java_symbol(const typet &type, const std::string &basename_prefix, const source_locationt &source_location, const irep_idt &function_name, symbol_table_baset &symbol_table)
nonstd::optional< T > optionalt
optionalt< resolve_inherited_componentt::inherited_componentt > get_inherited_component(const irep_idt &component_class_id, const irep_idt &component_name, const symbol_tablet &symbol_table, bool include_interfaces)
Finds an inherited component (method or field), taking component visibility into account.
static auxiliary_symbolt declare_function(const irep_idt &function_name, const mathematical_function_typet &type, symbol_table_baset &symbol_table)
Declare a function with the given name and type.
std::size_t get_width() const
const irep_idt & get_name() const
Get the name of the struct, which can be used to look up its symbol in the symbol table.
void set_is_stub(bool is_stub)
bool add(const symbolt &symbol)
Add a new symbol to the symbol table.
void merge_source_location_rec(exprt &expr, const source_locationt &source_location)
Attaches a source location to an expression and all of its subexpressions.
Structure type, corresponds to C style structs.
unsigned java_method_parameter_slots(const java_method_typet &t)
Returns the the number of JVM local variables (slots) used by the JVM to pass, upon call,...
const irep_idt & get(const irep_namet &name) const
void set(const irep_namet &name, const irep_idt &value)
const symbolst & symbols
Read-only field, used to look up symbols given their names.
void set_name(const irep_idt &name)
Set the name of the struct, which can be used to look up its symbol in the symbol table.
virtual std::pair< symbolt &, bool > insert(symbolt symbol)=0
Move or copy a new symbol to the symbol table.
void java_root_class(symbolt &class_symbol)
Create components to an object of the root class (usually java.lang.Object) Specifically,...
bool has_prefix(const std::string &s, const std::string &prefix)
std::string pretty_print_java_type(const std::string &fqn_java_type)
Strip the package name from a java type, for the type to be pretty printed (java::java....
#define INVARIANT(CONDITION, REASON)
This macro uses the wrapper function 'invariant_violated_string'.
source_locationt & add_source_location()
The pointer type These are both 'bitvector_typet' (they have a width) and 'type_with_subtypet' (they ...
A type for mathematical functions (do not confuse with functions/methods in code)
symbolt & get_fresh_aux_symbol(const typet &type, const std::string &name_prefix, const std::string &basename_prefix, const source_locationt &source_location, const irep_idt &symbol_mode, const namespacet &ns, symbol_table_baset &symbol_table)
Installs a fresh-named symbol with respect to the given namespace ns with the requested name pattern ...
#define JAVA_STRING_LITERAL_PREFIX
irep_idt name
The unique identifier.
const bitvector_typet & to_bitvector_type(const typet &type)
Cast a typet to a bitvector_typet.
static irep_idt get_tag(const typet &type)