CBMC
renaming_level.h
Go to the documentation of this file.
1 /*******************************************************************\
2 
3 Module: Symbolic Execution
4 
5 Author: Romain Brenguier, romain.brenguier@diffblue.com
6 
7 \*******************************************************************/
8 
11 
12 #ifndef CPROVER_GOTO_SYMEX_RENAMING_LEVEL_H
13 #define CPROVER_GOTO_SYMEX_RENAMING_LEVEL_H
14 
15 #include <util/irep.h>
16 #include <util/sharing_map.h>
17 
18 #include "renamed.h"
19 
26 
34 symex_level0(ssa_exprt ssa_expr, const namespacet &ns, std::size_t thread_nr);
35 
40 {
42  void insert(const renamedt<ssa_exprt, L0> &ssa, std::size_t index);
43 
48  insert_or_replace(const renamedt<ssa_exprt, L0> &ssa, std::size_t index);
49 
51  bool has(const renamedt<ssa_exprt, L0> &ssa) const;
52 
57 
59  void restore_from(const symex_level1t &other);
60 
61 private:
63 };
64 
69 {
71 
75 
77  unsigned latest_index(const irep_idt &identifier) const;
78 
81  std::size_t increase_generation(
82  const irep_idt &l1_identifier,
83  const ssa_exprt &lhs,
84  std::function<std::size_t(const irep_idt &)> fresh_l2_name_provider);
85 };
86 
89 
92 
95 bool check_renaming(const exprt &expr);
96 
99 bool check_renaming_l1(const exprt &expr);
100 
103 bool check_renaming(const typet &type);
104 
105 #endif // CPROVER_GOTO_SYMEX_RENAMING_LEVEL_H
dstringt
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
Definition: dstring.h:36
symex_level0
renamedt< ssa_exprt, L0 > symex_level0(ssa_exprt ssa_expr, const namespacet &ns, std::size_t thread_nr)
Set the level 0 renaming of SSA expressions.
Definition: renaming_level.cpp:22
symex_level1t::restore_from
void restore_from(const symex_level1t &other)
Insert the content of other into this renaming.
Definition: renaming_level.cpp:109
symex_level2t::operator()
renamedt< ssa_exprt, L2 > operator()(renamedt< ssa_exprt, L1 > l1_expr) const
Set L2 tag to correspond to the current count of the identifier of l1_expr's.
Definition: renaming_level.cpp:101
sharing_mapt< irep_idt, std::pair< ssa_exprt, std::size_t > >
typet
The type of an expression, extends irept.
Definition: type.h:28
exprt
Base class for all expressions.
Definition: expr.h:55
symex_level2t::increase_generation
std::size_t increase_generation(const irep_idt &l1_identifier, const ssa_exprt &lhs, std::function< std::size_t(const irep_idt &)> fresh_l2_name_provider)
Allocates a fresh L2 name for the given L1 identifier, and makes it the latest generation on this pat...
Definition: renaming_level.cpp:136
renamed.h
ssa_exprt
Expression providing an SSA-renamed symbol of expressions.
Definition: ssa_expr.h:16
namespacet
A namespacet is essentially one or two symbol tables bound together, to allow for symbol lookups in t...
Definition: namespace.h:90
symex_level2t
Functor to set the level 2 renaming of SSA expressions.
Definition: renaming_level.h:68
check_renaming
bool check_renaming(const exprt &expr)
Check that expr is correctly renamed to level 2 and return true in case an error is detected.
Definition: renaming_level.cpp:239
check_renaming_l1
bool check_renaming_l1(const exprt &expr)
Check that expr is correctly renamed to level 1 and return true in case an error is detected.
Definition: renaming_level.cpp:214
get_original_name
exprt get_original_name(exprt expr)
Undo all levels of renaming.
Definition: renaming_level.cpp:157
symex_level1t::current_names
symex_renaming_levelt current_names
Definition: renaming_level.h:62
symex_level1t::insert
void insert(const renamedt< ssa_exprt, L0 > &ssa, std::size_t index)
Assume ssa is not already known.
Definition: renaming_level.cpp:47
optionalt
nonstd::optional< T > optionalt
Definition: optional.h:35
symex_level2t::current_names
symex_renaming_levelt current_names
Definition: renaming_level.h:70
symex_level1t
Functor to set the level 1 renaming of SSA expressions.
Definition: renaming_level.h:39
symex_level1t::has
bool has(const renamedt< ssa_exprt, L0 > &ssa) const
Definition: renaming_level.cpp:71
symex_level1t::operator()
renamedt< ssa_exprt, L1 > operator()(renamedt< ssa_exprt, L0 > l0_expr) const
Definition: renaming_level.cpp:77
symex_level2t::latest_index
unsigned latest_index(const irep_idt &identifier) const
Counter corresponding to an identifier.
Definition: renaming_level.cpp:130
sharing_map.h
renamedt
Wrapper for expressions or types which have been renamed up to a given level.
Definition: renamed.h:32
symex_level1t::insert_or_replace
optionalt< std::pair< ssa_exprt, std::size_t > > insert_or_replace(const renamedt< ssa_exprt, L0 > &ssa, std::size_t index)
Set the index for ssa to index.
Definition: renaming_level.cpp:55
irep.h