fix(*): static variable initialization problems
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
3562c76161
commit
89a7898054
2 changed files with 5 additions and 11 deletions
|
@ -267,14 +267,12 @@ expr_macro::~expr_macro() {
|
|||
// Constructors
|
||||
|
||||
#ifdef LEAN_CACHE_EXPRS
|
||||
typedef lru_cache<expr, expr_hash, is_bi_equal_proc> expr_cache;
|
||||
static std::unique_ptr<expr_cache> LEAN_THREAD_LOCAL g_expr_cache;
|
||||
static bool LEAN_THREAD_LOCAL g_expr_cache_enabled = true;
|
||||
typedef lru_cache<expr, expr_hash, is_bi_equal_proc> expr_cache;
|
||||
inline expr cache(expr const & e) {
|
||||
if (g_expr_cache_enabled) {
|
||||
if (!g_expr_cache)
|
||||
g_expr_cache.reset(new expr_cache(LEAN_INITIAL_EXPR_CACHE_CAPACITY));
|
||||
if (auto r = g_expr_cache->insert(e))
|
||||
static expr_cache LEAN_THREAD_LOCAL g_expr_cache(LEAN_INITIAL_EXPR_CACHE_CAPACITY);
|
||||
if (auto r = g_expr_cache.insert(e))
|
||||
return *r;
|
||||
}
|
||||
return e;
|
||||
|
|
|
@ -32,13 +32,9 @@ std::ostream & operator<<(std::ostream & out, option_kind k) {
|
|||
return out;
|
||||
}
|
||||
|
||||
// Replace with std::unique_ptr after bug in clang++ is fixed
|
||||
static std::shared_ptr<option_declarations> g_option_declarations;
|
||||
|
||||
option_declarations & get_option_declarations_core() {
|
||||
if (!g_option_declarations)
|
||||
g_option_declarations.reset(new option_declarations());
|
||||
return *g_option_declarations;
|
||||
static option_declarations g_option_declarations;
|
||||
return g_option_declarations;
|
||||
}
|
||||
|
||||
option_declarations const & get_option_declarations() {
|
||||
|
|
Loading…
Reference in a new issue