3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2026-02-25 01:31:18 +00:00
z3/src/util/trace.cpp
Nikolaj Bjorner 5478955199 disable cancelation during propagation at base level
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
2019-03-26 16:19:50 -07:00

66 lines
1.1 KiB
C++

/*++
Copyright (c) 2006 Microsoft Corporation
Module Name:
trace.cpp
Abstract:
Trace message support.
Author:
Leonardo de Moura (leonardo) 2006-09-13.
Revision History:
--*/
#include "util/trace.h"
#include "util/str_hashtable.h"
#ifdef _TRACE
std::ofstream tout(".z3-trace");
static bool g_enable_all_trace_tags = false;
static str_hashtable* g_enabled_trace_tags = nullptr;
static str_hashtable& get_enabled_trace_tags() {
if (!g_enabled_trace_tags) {
g_enabled_trace_tags = alloc(str_hashtable);
}
return *g_enabled_trace_tags;
}
void finalize_trace() {
dealloc(g_enabled_trace_tags);
g_enabled_trace_tags = nullptr;
}
void enable_trace(const char * tag) {
get_enabled_trace_tags().insert(tag);
}
void enable_all_trace(bool flag) {
g_enable_all_trace_tags = flag;
}
void disable_trace(const char * tag) {
get_enabled_trace_tags().erase(tag);
}
bool is_trace_enabled(const char * tag) {
return g_enable_all_trace_tags ||
(g_enabled_trace_tags && get_enabled_trace_tags().contains(tag));
}
void close_trace() {
tout.close();
}
void open_trace() {
tout.open(".z3-trace");
}
#endif