perf(kernel/for_each): delay initialization of visited set

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2013-10-25 14:52:08 -07:00
parent e765105ea5
commit 2dd44bdf1a

View file

@ -5,6 +5,7 @@ Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura Author: Leonardo de Moura
*/ */
#pragma once #pragma once
#include <memory>
#include "kernel/expr.h" #include "kernel/expr.h"
#include "kernel/expr_sets.h" #include "kernel/expr_sets.h"
@ -19,17 +20,19 @@ namespace lean {
*/ */
template<typename F> template<typename F>
class for_each_fn { class for_each_fn {
expr_cell_offset_set m_visited; std::unique_ptr<expr_cell_offset_set> m_visited;
F m_f; F m_f;
static_assert(std::is_same<typename std::result_of<F(expr const &, unsigned)>::type, void>::value, static_assert(std::is_same<typename std::result_of<F(expr const &, unsigned)>::type, void>::value,
"for_each_fn: return type of m_f is not void"); "for_each_fn: return type of m_f is not void");
void apply(expr const & e, unsigned offset) { void apply(expr const & e, unsigned offset) {
if (is_shared(e)) { if (is_shared(e)) {
expr_cell_offset p(e.raw(), offset); expr_cell_offset p(e.raw(), offset);
if (m_visited.find(p) != m_visited.end()) if (!m_visited)
m_visited.reset(new expr_cell_offset_set());
if (m_visited->find(p) != m_visited->end())
return; return;
m_visited.insert(p); m_visited->insert(p);
} }
m_f(e, offset); m_f(e, offset);