Go to the documentation of this file.
24 #include <unordered_set>
37 static std::unordered_map<irep_idt, java_boxed_type_infot> type_info_by_name =
39 {
"java::java.lang.Boolean",
41 {
"java::java.lang.Byte",
43 {
"java::java.lang.Character",
45 {
"java::java.lang.Double",
47 {
"java::java.lang.Float",
49 {
"java::java.lang.Integer",
51 {
"java::java.lang.Long",
53 {
"java::java.lang.Short",
57 auto found = type_info_by_name.find(type_name);
58 return found == type_info_by_name.end() ? nullptr : &found->second;
64 static std::unordered_map<typet, java_primitive_type_infot, irep_hash>
65 type_info_by_primitive_type = {
67 {
"java::java.lang.Boolean",
68 "java::java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;",
69 "java::java.lang.Boolean.booleanValue:()Z"}},
71 {
"java::java.lang.Byte",
72 "java::java.lang.Byte.valueOf:(B)Ljava/lang/Byte;",
73 "java::java.lang.Number.byteValue:()B"}},
75 {
"java::java.lang.Character",
76 "java::java.lang.Character.valueOf:(C)"
77 "Ljava/lang/Character;",
78 "java::java.lang.Character.charValue:()C"}},
80 {
"java::java.lang.Double",
81 "java::java.lang.Double.valueOf:(D)"
83 "java::java.lang.Number.doubleValue:()D"}},
85 {
"java::java.lang.Float",
86 "java::java.lang.Float.valueOf:(F)"
88 "java::java.lang.Number.floatValue:()F"}},
90 {
"java::java.lang.Integer",
91 "java::java.lang.Integer.valueOf:(I)"
92 "Ljava/lang/Integer;",
93 "java::java.lang.Number.intValue:()I"}},
95 {
"java::java.lang.Long",
96 "java::java.lang.Long.valueOf:(J)Ljava/lang/Long;",
97 "java::java.lang.Number.longValue:()J"}},
99 {
"java::java.lang.Short",
100 "java::java.lang.Short.valueOf:(S)"
102 "java::java.lang.Number.shortValue:()S"}}};
104 auto found = type_info_by_primitive_type.find(maybe_primitive_type);
105 return found == type_info_by_primitive_type.end() ? nullptr : &found->second;
115 static const std::unordered_set<std::string> primitive_wrapper_type_names = {
118 "java.lang.Character",
124 return primitive_wrapper_type_names.count(type_name) > 0;
131 if(t.
id()==ID_pointer)
140 "all types constructed in java_types.cpp encode JVM types "
141 "with these bit widths");
143 return bitwidth == 64 ? 2u : 1u;
169 class_type.
set_tag(class_name);
178 new_symbol.
type=class_type;
179 new_symbol.
mode=ID_java;
182 std::pair<symbolt &, bool> res=symbol_table.
insert(std::move(new_symbol));
188 "stub class symbol " <<
215 const std::string &friendly_name,
219 std::string qualified_name=
"java::"+friendly_name;
220 if(friendly_name.rfind(
':')==std::string::npos)
222 std::string prefix=qualified_name+
':';
223 std::set<irep_idt> matches;
225 for(
const auto &s : symbol_table.
symbols)
227 s.second.type.id()==ID_code)
228 matches.insert(s.first);
232 error=
"'"+friendly_name+
"' not found";
235 else if(matches.size()>1)
237 std::ostringstream message;
238 message <<
"'"+friendly_name+
"' is ambiguous between:";
241 for(
const auto &s : matches)
242 message <<
"\n " <<
id2string(s).substr(6);
249 return *matches.begin();
254 auto findit=symbol_table.
symbols.find(qualified_name);
255 if(findit==symbol_table.
symbols.end())
257 error=
"'"+friendly_name+
"' not found";
260 else if(findit->second.type.id()!=ID_code)
262 error=
"'"+friendly_name+
"' not a function";
267 return findit->first;
288 result.
set(ID_java_member_access,
true);
306 const std::string &src,
315 size_t c_pos=open_pos+1;
316 const size_t end_pos=src.size()-1;
319 while(c_pos<=end_pos)
321 if(src[c_pos] == open_char)
323 else if(src[c_pos] == close_char)
332 depth<=(src.size()-open_pos),
334 "\' found in signature to parse.");
337 return std::string::npos;
353 components.end(), components_to_add.begin(), components_to_add.end());
371 func_symbol.
mode=ID_java;
372 func_symbol.
name=function_name;
373 func_symbol.
type=type;
374 symbol_table.
add(func_symbol);
393 std::vector<typet> argument_types;
394 for(
const auto &arg : arguments)
395 argument_types.push_back(arg.type());
412 const std::string to_strip_str=
id2string(to_strip);
413 const std::string prefix=
"java::";
416 return to_strip_str.substr(prefix.size(), std::string::npos);
426 std::string result(fqn_java_type);
427 const std::string java_cbmc_string(
"java::");
429 if(
has_prefix(fqn_java_type, java_cbmc_string))
430 result = fqn_java_type.substr(java_cbmc_string.length());
433 const std::string java_lang_string(
"java.lang.");
435 result = result.substr(java_lang_string.length());
455 bool include_interfaces)
458 const auto resolved_component =
459 component_resolver(component_class_id, component_name, include_interfaces);
465 if(resolved_component)
468 if(component_class_id == resolved_component->get_class_identifier())
469 return *resolved_component;
473 resolved_component->get_full_component_identifier());
477 access = component_symbol.
type.
get(ID_C_access);
479 if(access==ID_public || access==ID_protected)
482 return *resolved_component;
487 if(access==ID_default)
489 const std::string &class_package=
492 id2string(resolved_component->get_class_identifier()));
493 if(component_package == class_package)
494 return *resolved_component;
499 if(access==ID_private)
524 static const irep_idt in =
"java::java.lang.System.in";
525 static const irep_idt out =
"java::java.lang.System.out";
526 static const irep_idt err =
"java::java.lang.System.err";
527 return symbolid == in || symbolid == out || symbolid == err;
548 "getCurrentThreadId",
560 const std::string &basename_prefix,
566 const std::string name_prefix =
id2string(function_name);
568 type, name_prefix, basename_prefix, source_location, ID_java, symbol_table);
585 const auto signature_index = method_name.rfind(
":");
586 const auto method_index = method_name.rfind(
".", signature_index);
587 if(method_index == std::string::npos)
589 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.
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.
const symbolt & lookup_ref(const irep_idt &name) const
Find a symbol in the symbol table for read-only access.
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 (for examp...
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.
signedbv_typet java_long_type()
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.
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
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.
const bitvector_typet & to_bitvector_type(const typet &type)
Cast a typet to a bitvector_typet.
std::string trim_from_last_delimiter(const std::string &s, const char delim)
const irep_idt & get(const irep_idt &name) const
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.
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.
Return type for get_boxed_type_info_by_name.
irep_idt mode
Language mode.
bool has_prefix(const std::string &s, const std::string &prefix)
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.
void set(const irep_idt &name, const irep_idt &value)
#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),...
signedbv_typet java_int_type()
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.
Return type for get_java_primitive_type_info.
signedbv_typet java_short_type()
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.
signedbv_typet java_byte_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.
floatbv_typet java_double_type()
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 symbolst & symbols
Read-only field, used to look up symbols given their names.
unsignedbv_typet java_char_type()
const typet & base_type() const
The type of the data what we point to.
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.
c_bool_typet java_boolean_type()
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,...
const java_boxed_type_infot * get_boxed_type_info_by_name(const irep_idt &type_name)
If type_name is a Java boxed type tag, return information about it, otherwise return null.
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()
bool is_primitive_wrapper_type_id(const irep_idt &id)
Returns true iff the argument is the symbol-table identifier of a Java primitive wrapper type (for ex...
The pointer type These are both 'bitvector_typet' (they have a width) and 'type_with_subtypet' (they ...
mstreamt & warning() const
A type for mathematical functions (do not confuse with functions/methods in code)
const java_primitive_type_infot * get_java_primitive_type_info(const typet &maybe_primitive_type)
If primitive_type is a Java primitive type, return information about it, otherwise return null.
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.
floatbv_typet java_float_type()