File tree Expand file tree Collapse file tree 4 files changed +14
-41
lines changed
java_bytecode_convert_method Expand file tree Collapse file tree 4 files changed +14
-41
lines changed Original file line number Diff line number Diff line change @@ -284,16 +284,21 @@ class java_method_typet : public code_typet
284284 }
285285};
286286
287+ template <>
288+ inline bool can_cast_type<java_method_typet>(const typet &type)
289+ {
290+ return type.id () == ID_code && type.get_bool (ID_C_java_method_type);
291+ }
292+
287293inline const java_method_typet &to_java_method_type (const typet &type)
288294{
289- PRECONDITION (type. id () == ID_code );
295+ PRECONDITION (can_cast_type<java_method_typet>(type) );
290296 return static_cast <const java_method_typet &>(type);
291297}
292298
293299inline java_method_typet &to_java_method_type (typet &type)
294300{
295- PRECONDITION (type.id () == ID_code);
296- type.set (ID_C_java_method_type, true );
301+ PRECONDITION (can_cast_type<java_method_typet>(type));
297302 return static_cast <java_method_typet &>(type);
298303}
299304
Original file line number Diff line number Diff line change @@ -21,7 +21,6 @@ SRC += java_bytecode/goto-programs/class_hierarchy_output.cpp \
2121 java_bytecode/java_types/erase_type_arguments.cpp \
2222 java_bytecode/java_types/generic_type_index.cpp \
2323 java_bytecode/java_types/java_generic_symbol_type.cpp \
24- java_bytecode/java_types/java_method_type.cpp \
2524 java_bytecode/java_types/java_type_from_string.cpp \
2625 java_bytecode/java_utils_test.cpp \
2726 java_bytecode/load_method_by_regex.cpp \
Original file line number Diff line number Diff line change @@ -30,8 +30,12 @@ SCENARIO(
3030 symbol_table.lookup_ref (method_name + " :(Ljava/lang/Object;)I" );
3131
3232 const java_method_typet &function_type =
33- require_type::require_code (function_symbol.type );
34- THEN (" The method should be marked as a bridge method" )
33+ require_type::require_java_method (function_symbol.type );
34+ THEN (" The method symbol should be of java_method_typet" )
35+ {
36+ REQUIRE (function_type.get_bool (ID_C_java_method_type));
37+ }
38+ THEN (" And the method should be marked as a bridge method" )
3539 {
3640 REQUIRE (function_type.get_bool (ID_is_bridge_method));
3741 }
Load Diff This file was deleted.
You can’t perform that action at this time.
0 commit comments