fix(*): static variable initialization problems

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2014-06-06 18:44:12 -07:00
parent 3562c76161
commit 89a7898054
2 changed files with 5 additions and 11 deletions

View file

@ -267,14 +267,12 @@ expr_macro::~expr_macro() {
// Constructors // Constructors
#ifdef LEAN_CACHE_EXPRS #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; 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) { inline expr cache(expr const & e) {
if (g_expr_cache_enabled) { if (g_expr_cache_enabled) {
if (!g_expr_cache) static expr_cache LEAN_THREAD_LOCAL g_expr_cache(LEAN_INITIAL_EXPR_CACHE_CAPACITY);
g_expr_cache.reset(new expr_cache(LEAN_INITIAL_EXPR_CACHE_CAPACITY)); if (auto r = g_expr_cache.insert(e))
if (auto r = g_expr_cache->insert(e))
return *r; return *r;
} }
return e; return e;

View file

@ -32,13 +32,9 @@ std::ostream & operator<<(std::ostream & out, option_kind k) {
return out; 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() { option_declarations & get_option_declarations_core() {
if (!g_option_declarations) static option_declarations g_option_declarations;
g_option_declarations.reset(new option_declarations()); return g_option_declarations;
return *g_option_declarations;
} }
option_declarations const & get_option_declarations() { option_declarations const & get_option_declarations() {