klee
|
#include <Searcher.h>
Public Member Functions | |
ExecutionState & | selectState () override |
void | update (ExecutionState *current, const std::vector< ExecutionState * > &addedStates, const std::vector< ExecutionState * > &removedStates) override |
bool | empty () override |
void | printName (llvm::raw_ostream &os) override |
Prints name of searcher as a klee_message() . More... | |
Public Member Functions inherited from klee::Searcher | |
virtual | ~Searcher ()=default |
virtual ExecutionState & | selectState ()=0 |
virtual void | update (ExecutionState *current, const std::vector< ExecutionState * > &addedStates, const std::vector< ExecutionState * > &removedStates)=0 |
virtual bool | empty ()=0 |
virtual void | printName (llvm::raw_ostream &os)=0 |
Prints name of searcher as a klee_message() . More... | |
Private Attributes | |
std::deque< ExecutionState * > | states |
Additional Inherited Members | |
Public Types inherited from klee::Searcher | |
enum | CoreSearchType : std::uint8_t { DFS , BFS , RandomState , RandomPath , NURS_CovNew , NURS_MD2U , NURS_Depth , NURS_RP , NURS_ICnt , NURS_CPICnt , NURS_QC } |
BFSSearcher implements breadth-first exploration. When KLEE branches multiple times for a single instruction, all new states have the same depth. Keep in mind that the process tree (PTree) is a binary tree and hence the depth of a state in that tree and its branch depth during BFS are different.
Definition at line 96 of file Searcher.h.
|
overridevirtual |
Implements klee::Searcher.
Definition at line 108 of file Searcher.cpp.
References states.
|
overridevirtual |
Prints name of searcher as a klee_message()
.
Implements klee::Searcher.
Definition at line 112 of file Searcher.cpp.
|
overridevirtual |
Selects a state for further exploration.
Implements klee::Searcher.
Definition at line 75 of file Searcher.cpp.
References states.
|
overridevirtual |
Notifies searcher about new or deleted states.
current | The currently selected state for exploration. |
addedStates | The newly branched states with current as common ancestor. |
removedStates | The states that will be terminated. |
Implements klee::Searcher.
Definition at line 79 of file Searcher.cpp.
References states.
|
private |
Definition at line 97 of file Searcher.h.
Referenced by empty(), selectState(), and update().