CBMC
is_threaded_domaint Class Reference
+ Inheritance diagram for is_threaded_domaint:
+ Collaboration diagram for is_threaded_domaint:

Public Member Functions

 is_threaded_domaint ()
 
bool merge (const is_threaded_domaint &src, trace_ptrt, trace_ptrt)
 
void transform (const irep_idt &, trace_ptrt trace_from, const irep_idt &, trace_ptrt, ai_baset &, const namespacet &) override
 how function calls are treated: a) there is an edge from each call site to the function head b) there is an edge from the last instruction (END_FUNCTION) of the function to the instruction following the call site (this also needs to set the LHS, if applicable) More...
 
void make_bottom () final override
 no states More...
 
void make_top () final override
 all states – the analysis doesn't use this directly (see make_entry) and domains may refuse to implement it. More...
 
void make_entry () final override
 Make this domain a reasonable entry-point state For most domains top is sufficient. More...
 
bool is_bottom () const override final
 
bool is_top () const override final
 
- Public Member Functions inherited from ai_domain_baset
virtual ~ai_domain_baset ()
 
virtual void output (std::ostream &, const ai_baset &, const namespacet &) const
 
virtual jsont output_json (const ai_baset &ai, const namespacet &ns) const
 
virtual xmlt output_xml (const ai_baset &ai, const namespacet &ns) const
 
virtual bool ai_simplify (exprt &condition, const namespacet &) const
 also add More...
 
virtual bool ai_simplify_lhs (exprt &condition, const namespacet &ns) const
 Simplifies the expression but keeps it as an l-value. More...
 
virtual exprt to_predicate (void) const
 Gives a Boolean condition that is true for all values represented by the domain. More...
 

Public Attributes

bool reachable
 
bool is_threaded
 

Additional Inherited Members

- Public Types inherited from ai_domain_baset
typedef goto_programt::const_targett locationt
 
typedef ai_history_baset::trace_ptrt trace_ptrt
 
- Protected Member Functions inherited from ai_domain_baset
 ai_domain_baset ()
 The constructor is expected to produce 'false' or 'bottom' A default constructor is not part of the domain interface. More...
 
 ai_domain_baset (const ai_domain_baset &old)
 A copy constructor is part of the domain interface. More...
 

Detailed Description

Definition at line 18 of file is_threaded.cpp.

Constructor & Destructor Documentation

◆ is_threaded_domaint()

is_threaded_domaint::is_threaded_domaint ( )
inline

Definition at line 24 of file is_threaded.cpp.

Member Function Documentation

◆ is_bottom()

bool is_threaded_domaint::is_bottom ( ) const
inlinefinaloverridevirtual

Implements ai_domain_baset.

Definition at line 81 of file is_threaded.cpp.

◆ is_top()

bool is_threaded_domaint::is_top ( ) const
inlinefinaloverridevirtual

Implements ai_domain_baset.

Definition at line 89 of file is_threaded.cpp.

◆ make_bottom()

void is_threaded_domaint::make_bottom ( )
inlinefinaloverridevirtual

no states

Implements ai_domain_baset.

Definition at line 63 of file is_threaded.cpp.

◆ make_entry()

void is_threaded_domaint::make_entry ( )
inlinefinaloverridevirtual

Make this domain a reasonable entry-point state For most domains top is sufficient.

Reimplemented from ai_domain_baset.

Definition at line 75 of file is_threaded.cpp.

◆ make_top()

void is_threaded_domaint::make_top ( )
inlinefinaloverridevirtual

all states – the analysis doesn't use this directly (see make_entry) and domains may refuse to implement it.

Implements ai_domain_baset.

Definition at line 69 of file is_threaded.cpp.

◆ merge()

bool is_threaded_domaint::merge ( const is_threaded_domaint src,
trace_ptrt  ,
trace_ptrt   
)
inline

Definition at line 31 of file is_threaded.cpp.

◆ transform()

void is_threaded_domaint::transform ( const irep_idt function_from,
trace_ptrt  from,
const irep_idt function_to,
trace_ptrt  to,
ai_baset ai,
const namespacet ns 
)
inlineoverridevirtual

how function calls are treated: a) there is an edge from each call site to the function head b) there is an edge from the last instruction (END_FUNCTION) of the function to the instruction following the call site (this also needs to set the LHS, if applicable)

in some cases, function calls are skipped, in which case: c) there is an edge from the call instruction to the instruction after

"this" is the domain before the instruction "from" "from" is the instruction to be interpreted "to" is the next instruction (for GOTO, FUNCTION_CALL, END_FUNCTION)

PRECONDITION(from.is_dereferenceable(), "Must not be _::end()") PRECONDITION(to.is_dereferenceable(), "Must not be _::end()") PRECONDITION(are_comparable(from,to) || (from->is_function_call() || from->is_end_function())

The history aware version is used by the abstract interpreter for backwards compatability it calls the older signature

Implements ai_domain_baset.

Definition at line 46 of file is_threaded.cpp.

Member Data Documentation

◆ is_threaded

bool is_threaded_domaint::is_threaded

Definition at line 22 of file is_threaded.cpp.

◆ reachable

bool is_threaded_domaint::reachable

Definition at line 21 of file is_threaded.cpp.


The documentation for this class was generated from the following file: