feat(library/blast): add 'blast.trace_preprocessor'

This commit is contained in:
Leonardo de Moura 2015-12-07 08:38:11 -08:00
parent 2d007c7c23
commit 964bb140be
3 changed files with 15 additions and 2 deletions

View file

@ -20,6 +20,9 @@ Author: Leonardo de Moura
#ifndef LEAN_DEFAULT_BLAST_TRACE #ifndef LEAN_DEFAULT_BLAST_TRACE
#define LEAN_DEFAULT_BLAST_TRACE false #define LEAN_DEFAULT_BLAST_TRACE false
#endif #endif
#ifndef LEAN_DEFAULT_BLAST_TRACE_PREPROCESSOR
#define LEAN_DEFAULT_BLAST_TRACE_PREPROCESSOR false
#endif
#ifndef LEAN_DEFAULT_BLAST_SHOW_FAILURE #ifndef LEAN_DEFAULT_BLAST_SHOW_FAILURE
#define LEAN_DEFAULT_BLAST_SHOW_FAILURE true #define LEAN_DEFAULT_BLAST_SHOW_FAILURE true
#endif #endif
@ -58,6 +61,7 @@ static name * g_blast_max_depth = nullptr;
static name * g_blast_init_depth = nullptr; static name * g_blast_init_depth = nullptr;
static name * g_blast_inc_depth = nullptr; static name * g_blast_inc_depth = nullptr;
static name * g_blast_trace = nullptr; static name * g_blast_trace = nullptr;
static name * g_blast_trace_pre = nullptr;
static name * g_blast_subst = nullptr; static name * g_blast_subst = nullptr;
static name * g_blast_simp = nullptr; static name * g_blast_simp = nullptr;
static name * g_blast_cc = nullptr; static name * g_blast_cc = nullptr;
@ -81,6 +85,9 @@ unsigned get_blast_inc_depth(options const & o) {
bool get_blast_trace(options const & o) { bool get_blast_trace(options const & o) {
return o.get_bool(*g_blast_trace, LEAN_DEFAULT_BLAST_TRACE); return o.get_bool(*g_blast_trace, LEAN_DEFAULT_BLAST_TRACE);
} }
bool get_blast_trace_pre(options const & o) {
return o.get_bool(*g_blast_trace_pre, LEAN_DEFAULT_BLAST_TRACE_PREPROCESSOR);
}
bool get_blast_subst(options const & o) { bool get_blast_subst(options const & o) {
return o.get_bool(*g_blast_subst, LEAN_DEFAULT_BLAST_SUBST); return o.get_bool(*g_blast_subst, LEAN_DEFAULT_BLAST_SUBST);
} }
@ -117,6 +124,7 @@ config::config(options const & o) {
m_init_depth = get_blast_init_depth(o); m_init_depth = get_blast_init_depth(o);
m_inc_depth = get_blast_inc_depth(o); m_inc_depth = get_blast_inc_depth(o);
m_trace = get_blast_trace(o); m_trace = get_blast_trace(o);
m_trace_pre = get_blast_trace_pre(o);
m_subst = get_blast_subst(o); m_subst = get_blast_subst(o);
m_simp = get_blast_simp(o); m_simp = get_blast_simp(o);
m_cc = get_blast_cc(o); m_cc = get_blast_cc(o);
@ -151,6 +159,7 @@ void initialize_options() {
g_blast_init_depth = new name{"blast", "init_depth"}; g_blast_init_depth = new name{"blast", "init_depth"};
g_blast_inc_depth = new name{"blast", "inc_depth"}; g_blast_inc_depth = new name{"blast", "inc_depth"};
g_blast_trace = new name{"blast", "trace"}; g_blast_trace = new name{"blast", "trace"};
g_blast_trace_pre = new name{"blast", "trace_preprocessor"};
g_blast_subst = new name{"blast", "subst"}; g_blast_subst = new name{"blast", "subst"};
g_blast_simp = new name{"blast", "simp"}; g_blast_simp = new name{"blast", "simp"};
g_blast_cc = new name{"blast", "cc"}; g_blast_cc = new name{"blast", "cc"};
@ -170,6 +179,8 @@ void initialize_options() {
"(blast) search depth increment for blast (remark: blast uses iteration deepening)"); "(blast) search depth increment for blast (remark: blast uses iteration deepening)");
register_bool_option(*blast::g_blast_trace, LEAN_DEFAULT_BLAST_TRACE, register_bool_option(*blast::g_blast_trace, LEAN_DEFAULT_BLAST_TRACE,
"(blast) trace"); "(blast) trace");
register_bool_option(*blast::g_blast_trace_pre, LEAN_DEFAULT_BLAST_TRACE_PREPROCESSOR,
"(blast) trace preprocessor");
register_bool_option(*blast::g_blast_subst, LEAN_DEFAULT_BLAST_SUBST, register_bool_option(*blast::g_blast_subst, LEAN_DEFAULT_BLAST_SUBST,
"(blast) enable subst action"); "(blast) enable subst action");
register_bool_option(*blast::g_blast_simp, LEAN_DEFAULT_BLAST_SIMP, register_bool_option(*blast::g_blast_simp, LEAN_DEFAULT_BLAST_SIMP,
@ -198,6 +209,7 @@ void finalize_options() {
delete g_blast_init_depth; delete g_blast_init_depth;
delete g_blast_inc_depth; delete g_blast_inc_depth;
delete g_blast_trace; delete g_blast_trace;
delete g_blast_trace_pre;
delete g_blast_subst; delete g_blast_subst;
delete g_blast_simp; delete g_blast_simp;
delete g_blast_cc; delete g_blast_cc;

View file

@ -15,6 +15,7 @@ struct config {
unsigned m_init_depth; unsigned m_init_depth;
unsigned m_inc_depth; unsigned m_inc_depth;
bool m_trace; bool m_trace;
bool m_trace_pre;
bool m_subst; bool m_subst;
bool m_simp; bool m_simp;
bool m_recursor; bool m_recursor;

View file

@ -67,10 +67,10 @@ public:
}; };
strategy preprocess_and_then(strategy const & S) { strategy preprocess_and_then(strategy const & S) {
return [=]() { scope_trace s(false); return preprocess_strategy_fn(S, false)(); }; // NOLINT return [=]() { scope_trace s(get_config().m_trace_pre); return preprocess_strategy_fn(S, false)(); }; // NOLINT
} }
strategy basic_preprocess_and_then(strategy const & S) { strategy basic_preprocess_and_then(strategy const & S) {
return [=]() { scope_trace s(false); return preprocess_strategy_fn(S, true)(); }; // NOLINT return [=]() { scope_trace s(get_config().m_trace_pre); return preprocess_strategy_fn(S, true)(); }; // NOLINT
} }
}} }}