perf(kernel/for_each): delay initialization of visited set
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
e765105ea5
commit
2dd44bdf1a
1 changed files with 7 additions and 4 deletions
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue