aboutsummaryrefslogtreecommitdiffhomepage
path: root/lib/Core/UserSearcher.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Core/UserSearcher.cpp')
-rw-r--r--lib/Core/UserSearcher.cpp17
1 files changed, 15 insertions, 2 deletions
diff --git a/lib/Core/UserSearcher.cpp b/lib/Core/UserSearcher.cpp
index 6158f722..f0b2f85a 100644
--- a/lib/Core/UserSearcher.cpp
+++ b/lib/Core/UserSearcher.cpp
@@ -13,6 +13,8 @@
#include "Executor.h"
#include "klee/Internal/Support/ErrorHandling.h"
+#include "klee/CommandLine.h"
+
#include "llvm/Support/CommandLine.h"
using namespace llvm;
@@ -58,8 +60,13 @@ namespace {
void klee::initializeSearchOptions() {
// default values
if (CoreSearch.empty()) {
- CoreSearch.push_back(Searcher::RandomPath);
- CoreSearch.push_back(Searcher::NURS_CovNew);
+ if (UseMerge){
+ CoreSearch.push_back(Searcher::NURS_CovNew);
+ klee_warning("--use-merge enabled. Using NURS_CovNew as default searcher.");
+ } else {
+ CoreSearch.push_back(Searcher::RandomPath);
+ CoreSearch.push_back(Searcher::NURS_CovNew);
+ }
}
}
@@ -104,6 +111,12 @@ Searcher *klee::constructUserSearcher(Executor &executor) {
searcher = new InterleavedSearcher(s);
}
+ if (UseMerge) {
+ if (std::find(CoreSearch.begin(), CoreSearch.end(), Searcher::RandomPath) != CoreSearch.end()){
+ klee_error("use-merge currently does not support random-path, please use another search strategy");
+ }
+ }
+
if (UseBatchingSearch) {
searcher = new BatchingSearcher(searcher, BatchTime, BatchInstructions);
}