2015-11-18 20:59:53 +00:00
|
|
|
/*
|
|
|
|
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
*/
|
2015-12-09 03:37:06 +00:00
|
|
|
#include "library/trace.h"
|
2015-11-19 22:58:25 +00:00
|
|
|
#include "library/io_state_stream.h"
|
2015-11-18 20:59:53 +00:00
|
|
|
#include "library/blast/blast.h"
|
|
|
|
#include "library/blast/choice_point.h"
|
|
|
|
#include "library/blast/trace.h"
|
|
|
|
#include "library/blast/options.h"
|
|
|
|
|
|
|
|
namespace lean {
|
|
|
|
namespace blast {
|
2015-12-09 15:34:15 +00:00
|
|
|
MK_THREAD_LOCAL_GET_DEF(expr, get_last_target);
|
|
|
|
|
|
|
|
void trace_target() {
|
|
|
|
if (lean_is_trace_enabled(name({"blast", "search"})) &&
|
|
|
|
curr_state().get_target() != get_last_target()) {
|
|
|
|
lean_trace(name({"blast", "search"}), tout() << "target " << ppb(curr_state().get_target()) << "\n";);
|
|
|
|
get_last_target() = curr_state().get_target();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-19 03:12:29 +00:00
|
|
|
void trace_curr_state() {
|
2015-12-09 03:52:32 +00:00
|
|
|
lean_trace(name({"blast", "state"}), tout() << "\n"; curr_state().display(tout()););
|
2015-11-18 20:59:53 +00:00
|
|
|
}
|
|
|
|
|
2015-12-09 03:37:06 +00:00
|
|
|
void trace_search(char const * msg) {
|
|
|
|
lean_trace(name({"blast", "search"}), tout() << msg << "\n";);
|
2015-11-18 20:59:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void trace_action(char const * a) {
|
2015-12-09 03:37:06 +00:00
|
|
|
lean_trace(name({"blast", "action"}), tout() << a << "\n";);
|
2015-11-18 20:59:53 +00:00
|
|
|
}
|
|
|
|
|
2015-11-19 03:12:29 +00:00
|
|
|
void trace_curr_state_if(action_result r) {
|
2015-12-09 03:37:06 +00:00
|
|
|
if (!failed(r) && !solved(r))
|
2015-11-19 03:12:29 +00:00
|
|
|
trace_curr_state();
|
2015-11-18 20:59:53 +00:00
|
|
|
}
|
|
|
|
|
2015-11-20 16:55:44 +00:00
|
|
|
io_state_stream const & operator<<(io_state_stream const & out, ppb const & e) {
|
2015-11-19 22:58:25 +00:00
|
|
|
expr tmp = curr_state().to_kernel_expr(e.m_expr);
|
|
|
|
out << tmp;
|
|
|
|
return out;
|
|
|
|
}
|
2015-11-18 20:59:53 +00:00
|
|
|
}}
|