diff options
Diffstat (limited to 'lib/Expr')
-rw-r--r-- | lib/Expr/Expr.cpp | 16 | ||||
-rw-r--r-- | lib/Expr/ExprPPrinter.cpp | 48 |
2 files changed, 44 insertions, 20 deletions
diff --git a/lib/Expr/Expr.cpp b/lib/Expr/Expr.cpp index 65e858c3..e6385136 100644 --- a/lib/Expr/Expr.cpp +++ b/lib/Expr/Expr.cpp @@ -8,22 +8,28 @@ //===----------------------------------------------------------------------===// #include "klee/Expr.h" -#include "klee/Config/Version.h" -#include "llvm/ADT/Hashing.h" -#include "llvm/Support/CommandLine.h" -#include "llvm/Support/raw_ostream.h" +#include "klee/Config/Version.h" // FIXME: We shouldn't need this once fast constant support moves into // Core. If we need to do arithmetic, we probably want to use APInt. #include "klee/Internal/Support/IntEvaluation.h" - #include "klee/util/ExprPPrinter.h" +#include "llvm/ADT/Hashing.h" +#include "llvm/Support/CommandLine.h" +#include "llvm/Support/raw_ostream.h" + #include <sstream> using namespace klee; using namespace llvm; +namespace klee { +llvm::cl::OptionCategory + ExprCat("Expression building and printing options", + "These options impact the way expressions are build and printed."); +} + namespace { cl::opt<bool> ConstArrayOpt("const-array-opt", diff --git a/lib/Expr/ExprPPrinter.cpp b/lib/Expr/ExprPPrinter.cpp index 58b8de7c..114c46b4 100644 --- a/lib/Expr/ExprPPrinter.cpp +++ b/lib/Expr/ExprPPrinter.cpp @@ -7,10 +7,11 @@ // //===----------------------------------------------------------------------===// -#include "klee/util/PrintContext.h" #include "klee/util/ExprPPrinter.h" #include "klee/Constraints.h" +#include "klee/OptionCategories.h" +#include "klee/util/PrintContext.h" #include "llvm/Support/CommandLine.h" #include "llvm/Support/raw_ostream.h" @@ -21,21 +22,38 @@ using namespace klee; namespace { - llvm::cl::opt<bool> - PCWidthAsArg("pc-width-as-arg", llvm::cl::init(true)); - - llvm::cl::opt<bool> - PCAllWidths("pc-all-widths", llvm::cl::init(false)); - llvm::cl::opt<bool> - PCPrefixWidth("pc-prefix-width", llvm::cl::init(true)); - - llvm::cl::opt<bool> - PCMultibyteReads("pc-multibyte-reads", llvm::cl::init(true)); - - llvm::cl::opt<bool> - PCAllConstWidths("pc-all-const-widths", llvm::cl::init(false)); -} +llvm::cl::opt<bool> PCWidthAsArg( + "pc-width-as-arg", llvm::cl::init(true), + llvm::cl::desc( + "Print the width as a separate argument, as opposed to a prefix " + "to the operation (default=true)"), + llvm::cl::cat(klee::ExprCat)); + +llvm::cl::opt<bool> + PCAllWidths("pc-all-widths", llvm::cl::init(false), + llvm::cl::desc("Print the width of all operations, including " + "booleans (default=false)"), + llvm::cl::cat(klee::ExprCat)); + +llvm::cl::opt<bool> + PCPrefixWidth("pc-prefix-width", llvm::cl::init(true), + llvm::cl::desc("Print width with 'w' prefix (default=true)"), + llvm::cl::cat(klee::ExprCat)); + +llvm::cl::opt<bool> + PCMultibyteReads("pc-multibyte-reads", llvm::cl::init(true), + llvm::cl::desc("Print ReadLSB and ReadMSB expressions " + "when possible (default=true)"), + llvm::cl::cat(klee::ExprCat)); + +llvm::cl::opt<bool> PCAllConstWidths( + "pc-all-const-widths", llvm::cl::init(false), + llvm::cl::desc( + "Always print the width of constant expressions (default=false)"), + llvm::cl::cat(klee::ExprCat)); + +} // namespace class PPrinter : public ExprPPrinter { public: |