/****************************************************************************** * Top contributors (to current version): * Morgan Deters * * This file is part of the cvc5 project. * * Copyright (c) 2009-2021 by the authors listed in the file AUTHORS * in the top-level source directory and their institutional affiliations. * All rights reserved. See the file COPYING in the top-level source * directory for licensing information. * **************************************************************************** * * Path-compressing, backtrackable union-find using an undo * stack. Refactored from the UF union-find. */ #include #include "expr/node.h" #include "theory/arrays/union_find.h" using namespace std; namespace cvc5 { namespace theory { namespace arrays { template void UnionFind::notify() { Trace("arraysuf") << "arraysUF cancelling : " << d_offset << " < " << d_trace.size() << " ?" << endl; while(d_offset < d_trace.size()) { pair p = d_trace.back(); if(p.second.isNull()) { d_map.erase(p.first); Trace("arraysuf") << "arraysUF " << d_trace.size() << " erasing " << p.first << endl; } else { d_map[p.first] = p.second; Trace("arraysuf") << "arraysUF " << d_trace.size() << " replacing " << p << endl; } d_trace.pop_back(); } Trace("arraysuf") << "arraysUF cancelling finished." << endl; } // The following declarations allow us to put functions in the .cpp file // instead of the header, since we know which instantiations are needed. template void UnionFind>::notify(); template void UnionFind>::notify(); } // namespace arrays } // namespace theory } // namespace cvc5