CBMC
java_trace_validation.h
Go to the documentation of this file.
1 /*******************************************************************\
2 
3 Module: Java trace validation
4 
5 Author: Jeannie Moulton
6 
7 \*******************************************************************/
8 
9 #ifndef CPROVER_JAVA_BYTECODE_JAVA_TRACE_VALIDATION_H
10 #define CPROVER_JAVA_BYTECODE_JAVA_TRACE_VALIDATION_H
11 
12 #include <util/validation_mode.h>
13 
14 #include <optional>
15 
16 class goto_tracet;
17 class namespacet;
18 class exprt;
19 class address_of_exprt;
20 class constant_exprt;
21 class struct_exprt;
22 class symbol_exprt;
23 class member_exprt;
24 class messaget;
25 
26 // clang-format off
27 #define OPT_JAVA_TRACE_VALIDATION /*NOLINT*/ \
28  "(validate-trace)" \
29 
30 #define HELP_JAVA_TRACE_VALIDATION /*NOLINT*/ \
31  " {y--validate-trace} \t throw an error if the structure of the" \
32  " counterexample trace does not match certain assumptions (experimental," \
33  " currently java only)\n"
34 // clang-format on
35 
41  const goto_tracet &trace,
42  const namespacet &ns,
43  const messaget &log,
44  const bool run_check = false,
46 
49 bool check_symbol_structure(const exprt &expr);
50 
53 std::optional<symbol_exprt> get_inner_symbol_expr(exprt expr);
54 
57 bool check_member_structure(const member_exprt &expr);
58 
61 bool valid_lhs_expr_high_level(const exprt &lhs);
62 
65 bool valid_rhs_expr_high_level(const exprt &rhs);
66 
69 bool can_evaluate_to_constant(const exprt &expression);
70 
73 bool check_index_structure(const exprt &index_expr);
74 
76 bool check_struct_structure(const struct_exprt &expr);
77 
79 bool check_address_structure(const address_of_exprt &address);
80 
82 bool check_constant_structure(const constant_exprt &constant_expr);
83 
84 #endif // CPROVER_JAVA_BYTECODE_JAVA_TRACE_VALIDATION_H
Operator to return the address of an object.
Definition: pointer_expr.h:540
A constant literal expression.
Definition: std_expr.h:2987
Base class for all expressions.
Definition: expr.h:56
Trace of a GOTO program.
Definition: goto_trace.h:177
Extract member of struct or union.
Definition: std_expr.h:2841
Class that provides messages with a built-in verbosity 'level'.
Definition: message.h:155
A namespacet is essentially one or two symbol tables bound together, to allow for symbol lookups in t...
Definition: namespace.h:94
Struct constructor from list of elements.
Definition: std_expr.h:1872
Expression to hold a symbol (variable)
Definition: std_expr.h:131
bool valid_lhs_expr_high_level(const exprt &lhs)
bool check_address_structure(const address_of_exprt &address)
bool valid_rhs_expr_high_level(const exprt &rhs)
bool check_member_structure(const member_exprt &expr)
bool check_index_structure(const exprt &index_expr)
void check_trace_assumptions(const goto_tracet &trace, const namespacet &ns, const messaget &log, const bool run_check=false, const validation_modet vm=validation_modet::INVARIANT)
Checks that the structure of each step of the trace matches certain criteria.
bool check_symbol_structure(const exprt &expr)
bool check_constant_structure(const constant_exprt &constant_expr)
std::optional< symbol_exprt > get_inner_symbol_expr(exprt expr)
Recursively extracts the first operand of an expression until it reaches a symbol and returns it,...
bool can_evaluate_to_constant(const exprt &expression)
bool check_struct_structure(const struct_exprt &expr)
double log(double x)
Definition: math.c:2776
validation_modet