feat(library/blast): add 'blast.trace_preprocessor'
This commit is contained in:
parent
2d007c7c23
commit
964bb140be
3 changed files with 15 additions and 2 deletions
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
}}
|
}}
|
||||||
|
|
Loading…
Reference in a new issue