refactor(util): explicit initialization/finalization
This commit is contained in:
parent
4437a65d0b
commit
79cfb32ec7
13 changed files with 127 additions and 71 deletions
|
@ -10,6 +10,7 @@ Author: Leonardo de Moura
|
||||||
#include "util/name.h"
|
#include "util/name.h"
|
||||||
#include "util/name_generator.h"
|
#include "util/name_generator.h"
|
||||||
#include "util/name_set.h"
|
#include "util/name_set.h"
|
||||||
|
#include "util/init_module.h"
|
||||||
using namespace lean;
|
using namespace lean;
|
||||||
|
|
||||||
static void tst1() {
|
static void tst1() {
|
||||||
|
@ -172,6 +173,8 @@ static void tst13() {
|
||||||
}
|
}
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
|
save_stack_info();
|
||||||
|
initialize_util_module();
|
||||||
tst1();
|
tst1();
|
||||||
tst2();
|
tst2();
|
||||||
tst3();
|
tst3();
|
||||||
|
@ -185,5 +188,6 @@ int main() {
|
||||||
tst11();
|
tst11();
|
||||||
tst12();
|
tst12();
|
||||||
tst13();
|
tst13();
|
||||||
|
finalize_util_module();
|
||||||
return has_violations() ? 1 : 0;
|
return has_violations() ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,16 +1,9 @@
|
||||||
if (("${BOOST}" MATCHES "ON") AND ("${MULTI_THREAD}" MATCHES "ON"))
|
|
||||||
set(THREAD_CPP "thread.cpp")
|
|
||||||
else()
|
|
||||||
set(THREAD_CPP "")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_library(util trace.cpp debug.cpp name.cpp name_set.cpp
|
add_library(util trace.cpp debug.cpp name.cpp name_set.cpp
|
||||||
name_generator.cpp exception.cpp interrupt.cpp hash.cpp escaped.cpp
|
name_generator.cpp exception.cpp interrupt.cpp hash.cpp escaped.cpp
|
||||||
bit_tricks.cpp safe_arith.cpp ascii.cpp memory.cpp shared_mutex.cpp
|
bit_tricks.cpp safe_arith.cpp ascii.cpp memory.cpp shared_mutex.cpp
|
||||||
realpath.cpp script_state.cpp script_exception.cpp rb_map.cpp
|
realpath.cpp script_state.cpp script_exception.cpp rb_map.cpp
|
||||||
lua.cpp luaref.cpp lua_named_param.cpp stackinfo.cpp lean_path.cpp
|
lua.cpp luaref.cpp lua_named_param.cpp stackinfo.cpp lean_path.cpp
|
||||||
serializer.cpp lbool.cpp thread_script_state.cpp bitap_fuzzy_search.cpp
|
serializer.cpp lbool.cpp thread_script_state.cpp bitap_fuzzy_search.cpp
|
||||||
init_module.cpp
|
init_module.cpp thread.cpp)
|
||||||
${THREAD_CPP})
|
|
||||||
|
|
||||||
target_link_libraries(util ${LEAN_LIBS})
|
target_link_libraries(util ${LEAN_LIBS})
|
||||||
|
|
|
@ -7,27 +7,24 @@ Author: Leonardo de Moura
|
||||||
#include <initializer_list>
|
#include <initializer_list>
|
||||||
namespace lean {
|
namespace lean {
|
||||||
static char g_safe_ascii[256];
|
static char g_safe_ascii[256];
|
||||||
/**
|
|
||||||
\brief Initializer for the \c g_safe_ascii table of "safe" ASCII characters.
|
|
||||||
*/
|
|
||||||
class init_safe_ascii {
|
|
||||||
void set(int i, bool v) { g_safe_ascii[static_cast<unsigned char>(i)] = v; }
|
|
||||||
public:
|
|
||||||
init_safe_ascii() {
|
|
||||||
for (int i = 0; i <= 255; i++)
|
|
||||||
set(i, false);
|
|
||||||
// digits and characters are safe
|
|
||||||
for (int i = '0'; i <= '9'; i++) set(i, true);
|
|
||||||
for (int i = 'a'; i <= 'z'; i++) set(i, true);
|
|
||||||
for (int i = 'A'; i <= 'Z'; i++) set(i, true);
|
|
||||||
// the following characters are also safe
|
|
||||||
for (unsigned char b : {'_', ' ', '\t', '\r', '\n', '(', ')', '{', '}', ':', '.', ',', '\"', '\'', '`', '!', '#',
|
|
||||||
'=', '<', '>', '@', '^', '|', '&', '~', '+', '-', '*', '/', '\\', '$', '%', '?', ';', '[', ']'})
|
|
||||||
set(b, true);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
static init_safe_ascii g_init_safe_ascii;
|
static void set(int i, bool v) { g_safe_ascii[static_cast<unsigned char>(i)] = v; }
|
||||||
|
|
||||||
|
void initialize_ascii() {
|
||||||
|
for (int i = 0; i <= 255; i++)
|
||||||
|
set(i, false);
|
||||||
|
// digits and characters are safe
|
||||||
|
for (int i = '0'; i <= '9'; i++) set(i, true);
|
||||||
|
for (int i = 'a'; i <= 'z'; i++) set(i, true);
|
||||||
|
for (int i = 'A'; i <= 'Z'; i++) set(i, true);
|
||||||
|
// the following characters are also safe
|
||||||
|
for (unsigned char b : {'_', ' ', '\t', '\r', '\n', '(', ')', '{', '}', ':', '.', ',', '\"', '\'', '`', '!', '#',
|
||||||
|
'=', '<', '>', '@', '^', '|', '&', '~', '+', '-', '*', '/', '\\', '$', '%', '?', ';', '[', ']'})
|
||||||
|
set(b, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void finalize_ascii() {
|
||||||
|
}
|
||||||
|
|
||||||
bool is_safe_ascii(char c) {
|
bool is_safe_ascii(char c) {
|
||||||
return g_safe_ascii[static_cast<unsigned char>(c)];
|
return g_safe_ascii[static_cast<unsigned char>(c)];
|
||||||
|
|
|
@ -16,4 +16,7 @@ bool is_safe_ascii(char c);
|
||||||
ASCII character.
|
ASCII character.
|
||||||
*/
|
*/
|
||||||
bool is_safe_ascii(char const * str);
|
bool is_safe_ascii(char const * str);
|
||||||
|
|
||||||
|
void initialize_ascii();
|
||||||
|
void finalize_ascii();
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,9 +17,18 @@ Author: Leonardo de Moura
|
||||||
#include "util/debug.h"
|
#include "util/debug.h"
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
static volatile bool g_has_violations = false;
|
static volatile bool g_has_violations = false;
|
||||||
static volatile bool g_enable_assertions = true;
|
static volatile bool g_enable_assertions = true;
|
||||||
static std::unique_ptr<std::set<std::string>> g_enabled_debug_tags;
|
static std::set<std::string> * g_enabled_debug_tags = nullptr;
|
||||||
|
|
||||||
|
void initialize_debug() {
|
||||||
|
// lazy initialization
|
||||||
|
}
|
||||||
|
|
||||||
|
void finalize_debug() {
|
||||||
|
if (g_enabled_debug_tags)
|
||||||
|
delete g_enabled_debug_tags;
|
||||||
|
}
|
||||||
|
|
||||||
bool has_violations() {
|
bool has_violations() {
|
||||||
return g_has_violations;
|
return g_has_violations;
|
||||||
|
@ -43,7 +52,7 @@ void notify_assertion_violation(const char * fileName, int line, const char * co
|
||||||
|
|
||||||
void enable_debug(char const * tag) {
|
void enable_debug(char const * tag) {
|
||||||
if (!g_enabled_debug_tags)
|
if (!g_enabled_debug_tags)
|
||||||
g_enabled_debug_tags.reset(new std::set<std::string>());
|
g_enabled_debug_tags = new std::set<std::string>();
|
||||||
g_enabled_debug_tags->insert(tag);
|
g_enabled_debug_tags->insert(tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -93,6 +93,8 @@ Author: Leonardo de Moura
|
||||||
#define lean_assert_le(A, B) lean_assert(A <= B, A, B)
|
#define lean_assert_le(A, B) lean_assert(A <= B, A, B)
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
|
void initialize_debug();
|
||||||
|
void finalize_debug();
|
||||||
void notify_assertion_violation(char const * file_name, int line, char const * condition);
|
void notify_assertion_violation(char const * file_name, int line, char const * condition);
|
||||||
void enable_debug(char const * tag);
|
void enable_debug(char const * tag);
|
||||||
void disable_debug(char const * tag);
|
void disable_debug(char const * tag);
|
||||||
|
|
|
@ -4,16 +4,31 @@ Released under Apache 2.0 license as described in the file LICENSE.
|
||||||
|
|
||||||
Author: Leonardo de Moura
|
Author: Leonardo de Moura
|
||||||
*/
|
*/
|
||||||
|
#include "util/ascii.h"
|
||||||
|
#include "util/debug.h"
|
||||||
|
#include "util/trace.h"
|
||||||
#include "util/serializer.h"
|
#include "util/serializer.h"
|
||||||
#include "util/name.h"
|
#include "util/name.h"
|
||||||
|
#include "util/lean_path.h"
|
||||||
|
#include "util/thread.h"
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
void initialize_util_module() {
|
void initialize_util_module() {
|
||||||
|
initialize_debug();
|
||||||
|
initialize_trace();
|
||||||
|
initialize_thread();
|
||||||
|
initialize_ascii();
|
||||||
|
initialize_lean_path();
|
||||||
initialize_serializer();
|
initialize_serializer();
|
||||||
initialize_name();
|
initialize_name();
|
||||||
}
|
}
|
||||||
void finalize_util_module() {
|
void finalize_util_module() {
|
||||||
finalize_name();
|
finalize_name();
|
||||||
finalize_serializer();
|
finalize_serializer();
|
||||||
|
finalize_lean_path();
|
||||||
|
finalize_ascii();
|
||||||
|
finalize_thread();
|
||||||
|
finalize_trace();
|
||||||
|
finalize_debug();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ file_not_found_exception::file_not_found_exception(std::string const & fname):
|
||||||
exception(sstream() << "file '" << fname << "' not found in the LEAN_PATH"),
|
exception(sstream() << "file '" << fname << "' not found in the LEAN_PATH"),
|
||||||
m_fname(fname) {}
|
m_fname(fname) {}
|
||||||
|
|
||||||
static std::string g_default_file_name(LEAN_DEFAULT_MODULE_FILE_NAME);
|
static std::string * g_default_file_name = nullptr;
|
||||||
|
|
||||||
bool is_directory(char const * pathname) {
|
bool is_directory(char const * pathname) {
|
||||||
struct stat info;
|
struct stat info;
|
||||||
|
@ -115,39 +115,51 @@ std::string get_path(std::string f) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::string g_lean_path;
|
static std::string * g_lean_path = nullptr;
|
||||||
static std::vector<std::string> g_lean_path_vector;
|
static std::vector<std::string> * g_lean_path_vector = nullptr;
|
||||||
|
|
||||||
void init_lean_path() {
|
void init_lean_path() {
|
||||||
char * r = getenv("LEAN_PATH");
|
char * r = getenv("LEAN_PATH");
|
||||||
if (r == nullptr) {
|
if (r == nullptr) {
|
||||||
g_lean_path = ".";
|
*g_lean_path = ".";
|
||||||
std::string exe_path = get_path(get_exe_location());
|
std::string exe_path = get_path(get_exe_location());
|
||||||
g_lean_path += g_path_sep;
|
*g_lean_path += g_path_sep;
|
||||||
g_lean_path += exe_path + g_sep + ".." + g_sep + "library";
|
*g_lean_path += exe_path + g_sep + ".." + g_sep + "library";
|
||||||
} else {
|
} else {
|
||||||
g_lean_path = r;
|
*g_lean_path = r;
|
||||||
}
|
}
|
||||||
g_lean_path_vector.clear();
|
g_lean_path_vector->clear();
|
||||||
g_lean_path = normalize_path(g_lean_path);
|
*g_lean_path = normalize_path(*g_lean_path);
|
||||||
unsigned i = 0;
|
unsigned i = 0;
|
||||||
unsigned j = 0;
|
unsigned j = 0;
|
||||||
unsigned sz = g_lean_path.size();
|
unsigned sz = g_lean_path->size();
|
||||||
for (; j < sz; j++) {
|
for (; j < sz; j++) {
|
||||||
if (is_path_sep(g_lean_path[j])) {
|
if (is_path_sep((*g_lean_path)[j])) {
|
||||||
if (j > i)
|
if (j > i)
|
||||||
g_lean_path_vector.push_back(g_lean_path.substr(i, j - i));
|
g_lean_path_vector->push_back(g_lean_path->substr(i, j - i));
|
||||||
i = j + 1;
|
i = j + 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (j > i)
|
if (j > i)
|
||||||
g_lean_path_vector.push_back(g_lean_path.substr(i, j - i));
|
g_lean_path_vector->push_back(g_lean_path->substr(i, j - i));
|
||||||
}
|
}
|
||||||
|
|
||||||
struct init_lean_path_fn {
|
static char g_sep_str[2];
|
||||||
init_lean_path_fn() { init_lean_path(); }
|
|
||||||
};
|
void initialize_lean_path() {
|
||||||
static init_lean_path_fn g_init_lean_path_fn;
|
g_default_file_name = new std::string(LEAN_DEFAULT_MODULE_FILE_NAME);
|
||||||
static std::string g_sep_str(1, g_sep);
|
g_lean_path = new std::string();
|
||||||
|
g_lean_path_vector = new std::vector<std::string>();
|
||||||
|
g_sep_str[0] = g_sep;
|
||||||
|
g_sep_str[1] = 0;
|
||||||
|
init_lean_path();
|
||||||
|
}
|
||||||
|
|
||||||
|
void finalize_lean_path() {
|
||||||
|
delete g_lean_path_vector;
|
||||||
|
delete g_lean_path;
|
||||||
|
delete g_default_file_name;
|
||||||
|
}
|
||||||
|
|
||||||
bool has_file_ext(std::string const & fname, char const * ext) {
|
bool has_file_ext(std::string const & fname, char const * ext) {
|
||||||
unsigned ext_len = strlen(ext);
|
unsigned ext_len = strlen(ext);
|
||||||
|
@ -183,7 +195,7 @@ optional<std::string> check_file_core(std::string file, char const * ext) {
|
||||||
optional<std::string> check_file(std::string const & path, std::string const & fname, char const * ext = nullptr) {
|
optional<std::string> check_file(std::string const & path, std::string const & fname, char const * ext = nullptr) {
|
||||||
std::string file = path + g_sep + fname;
|
std::string file = path + g_sep + fname;
|
||||||
if (is_directory(file.c_str())) {
|
if (is_directory(file.c_str())) {
|
||||||
std::string default_file = file + g_sep + g_default_file_name;
|
std::string default_file = file + g_sep + *g_default_file_name;
|
||||||
if (auto r1 = check_file_core(default_file, ext)) {
|
if (auto r1 = check_file_core(default_file, ext)) {
|
||||||
if (auto r2 = check_file_core(file, ext))
|
if (auto r2 = check_file_core(file, ext))
|
||||||
throw exception(sstream() << "ambiguous import, it can be '" << *r1 << "' or '" << *r2 << "'");
|
throw exception(sstream() << "ambiguous import, it can be '" << *r1 << "' or '" << *r2 << "'");
|
||||||
|
@ -194,13 +206,13 @@ optional<std::string> check_file(std::string const & path, std::string const & f
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string name_to_file(name const & fname) {
|
std::string name_to_file(name const & fname) {
|
||||||
return fname.to_string(g_sep_str.c_str());
|
return fname.to_string(g_sep_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string find_file(std::string fname, std::initializer_list<char const *> const & extensions) {
|
std::string find_file(std::string fname, std::initializer_list<char const *> const & extensions) {
|
||||||
bool is_known = is_known_file_ext(fname);
|
bool is_known = is_known_file_ext(fname);
|
||||||
fname = normalize_path(fname);
|
fname = normalize_path(fname);
|
||||||
for (auto path : g_lean_path_vector) {
|
for (auto path : *g_lean_path_vector) {
|
||||||
if (is_known) {
|
if (is_known) {
|
||||||
if (auto r = check_file(path, fname))
|
if (auto r = check_file(path, fname))
|
||||||
return *r;
|
return *r;
|
||||||
|
@ -217,7 +229,7 @@ std::string find_file(std::string fname, std::initializer_list<char const *> con
|
||||||
std::string find_file(std::string const & base, optional<unsigned> const & rel, name const & fname,
|
std::string find_file(std::string const & base, optional<unsigned> const & rel, name const & fname,
|
||||||
std::initializer_list<char const *> const & extensions) {
|
std::initializer_list<char const *> const & extensions) {
|
||||||
if (!rel) {
|
if (!rel) {
|
||||||
return find_file(fname.to_string(g_sep_str.c_str()), extensions);
|
return find_file(fname.to_string(g_sep_str), extensions);
|
||||||
} else {
|
} else {
|
||||||
auto path = base;
|
auto path = base;
|
||||||
for (unsigned i = 0; i < *rel; i++) {
|
for (unsigned i = 0; i < *rel; i++) {
|
||||||
|
@ -225,7 +237,7 @@ std::string find_file(std::string const & base, optional<unsigned> const & rel,
|
||||||
path += "..";
|
path += "..";
|
||||||
}
|
}
|
||||||
for (auto ext : extensions) {
|
for (auto ext : extensions) {
|
||||||
if (auto r = check_file(path, fname.to_string(g_sep_str.c_str()), ext))
|
if (auto r = check_file(path, fname.to_string(g_sep_str), ext))
|
||||||
return *r;
|
return *r;
|
||||||
}
|
}
|
||||||
throw file_not_found_exception(fname.to_string());
|
throw file_not_found_exception(fname.to_string());
|
||||||
|
@ -241,15 +253,15 @@ std::string find_file(std::string fname) {
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string find_file(name const & fname) {
|
std::string find_file(name const & fname) {
|
||||||
return find_file(fname.to_string(g_sep_str.c_str()));
|
return find_file(fname.to_string(g_sep_str));
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string find_file(name const & fname, std::initializer_list<char const *> const & exts) {
|
std::string find_file(name const & fname, std::initializer_list<char const *> const & exts) {
|
||||||
return find_file(fname.to_string(g_sep_str.c_str()), exts);
|
return find_file(fname.to_string(g_sep_str), exts);
|
||||||
}
|
}
|
||||||
|
|
||||||
char const * get_lean_path() {
|
char const * get_lean_path() {
|
||||||
return g_lean_path.c_str();
|
return g_lean_path->c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void display_path(std::ostream & out, std::string const & fname) {
|
void display_path(std::ostream & out, std::string const & fname) {
|
||||||
|
|
|
@ -54,4 +54,7 @@ void display_path(std::ostream & out, std::string const & fname);
|
||||||
|
|
||||||
std::string dirname(char const * fname);
|
std::string dirname(char const * fname);
|
||||||
std::string path_append(char const * path1, char const * path2);
|
std::string path_append(char const * path1, char const * path2);
|
||||||
|
|
||||||
|
void initialize_lean_path();
|
||||||
|
void finalize_lean_path();
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,20 +8,22 @@ Author: Leonardo de Moura
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
#if defined(LEAN_USE_BOOST)
|
#if defined(LEAN_USE_BOOST)
|
||||||
static boost::thread::attributes g_thread_attributes;
|
static boost::thread::attributes * g_thread_attributes = nullptr;
|
||||||
class init_thread_attributes {
|
void initialize_thread() {
|
||||||
public:
|
g_thread_attributes = new boost::thread::attributes();
|
||||||
init_thread_attributes() {
|
g_thread_attributes->set_stack_size(8192*1024); // 8Mb
|
||||||
g_thread_attributes.set_stack_size(8192*1024); // 8Mb
|
}
|
||||||
}
|
void finalize_thread() {
|
||||||
};
|
delete g_thread_attributes;
|
||||||
static init_thread_attributes g_init_thread_attributes;
|
}
|
||||||
void set_thread_stack_size(size_t sz) {
|
void set_thread_stack_size(size_t sz) {
|
||||||
g_thread_attributes.set_stack_size(sz);
|
g_thread_attributes->set_stack_size(sz);
|
||||||
}
|
}
|
||||||
boost::thread::attributes const & get_thread_attributes() {
|
boost::thread::attributes const & get_thread_attributes() {
|
||||||
return g_thread_attributes;
|
return *g_thread_attributes;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
void initialize_thread() {}
|
||||||
|
void finalize_thread() {}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -203,3 +203,8 @@ static T & GETTER_NAME() { \
|
||||||
#define MK_THREAD_LOCAL_GET(T, GETTER_NAME, DEF_VALUE) static T & GETTER_NAME() { static T LEAN_THREAD_LOCAL r(DEF_VALUE); return r; }
|
#define MK_THREAD_LOCAL_GET(T, GETTER_NAME, DEF_VALUE) static T & GETTER_NAME() { static T LEAN_THREAD_LOCAL r(DEF_VALUE); return r; }
|
||||||
#define MK_THREAD_LOCAL_GET_DEF(T, GETTER_NAME) static T & GETTER_NAME() { static T LEAN_THREAD_LOCAL r; return r; }
|
#define MK_THREAD_LOCAL_GET_DEF(T, GETTER_NAME) static T & GETTER_NAME() { static T LEAN_THREAD_LOCAL r; return r; }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
namespace lean {
|
||||||
|
void initialize_thread();
|
||||||
|
void finalize_thread();
|
||||||
|
}
|
||||||
|
|
|
@ -21,11 +21,20 @@ std::ofstream tout(LEAN_TRACE_OUT);
|
||||||
mutex trace_mutex;
|
mutex trace_mutex;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static std::unique_ptr<std::set<std::string>> g_enabled_trace_tags;
|
static std::set<std::string> * g_enabled_trace_tags = nullptr;
|
||||||
|
|
||||||
|
void initialize_trace() {
|
||||||
|
// lazy initialization
|
||||||
|
}
|
||||||
|
|
||||||
|
void finalize_trace() {
|
||||||
|
if (g_enabled_trace_tags)
|
||||||
|
delete g_enabled_trace_tags;
|
||||||
|
}
|
||||||
|
|
||||||
void enable_trace(char const * tag) {
|
void enable_trace(char const * tag) {
|
||||||
if (!g_enabled_trace_tags)
|
if (!g_enabled_trace_tags)
|
||||||
g_enabled_trace_tags.reset(new std::set<std::string>());
|
g_enabled_trace_tags = new std::set<std::string>();
|
||||||
g_enabled_trace_tags->insert(tag);
|
g_enabled_trace_tags->insert(tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -28,4 +28,6 @@ namespace lean {
|
||||||
void enable_trace(char const * tag);
|
void enable_trace(char const * tag);
|
||||||
void disable_trace(char const * tag);
|
void disable_trace(char const * tag);
|
||||||
bool is_trace_enabled(char const * tag);
|
bool is_trace_enabled(char const * tag);
|
||||||
|
void initialize_trace();
|
||||||
|
void finalize_trace();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue