3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-05-06 07:15:47 +00:00
z3/src/util/scoped_numeral_vector.h
Nuno Lopes 9b54b4e784 fix vector<> to support non-POD types
adjust code to std::move and avoid unnecessary/illegal
2017-10-16 00:54:29 +01:00

70 lines
1.6 KiB
C++

/*++
Copyright (c) 2011 Microsoft Corporation
Module Name:
scoped_numeral_vector.h
Abstract:
Wrapper for easying the pain when using vectors of numerals.
Author:
Leonardo de Moura (leonardo) 2011-12-03
Revision History:
--*/
#ifndef SCOPED_NUMERAL_VECTOR_H_
#define SCOPED_NUMERAL_VECTOR_H_
#include "util/vector.h"
template<typename Manager>
class _scoped_numeral_vector : public svector<typename Manager::numeral> {
Manager & m_manager;
_scoped_numeral_vector(_scoped_numeral_vector const & v);
public:
_scoped_numeral_vector(Manager & m):m_manager(m) {}
~_scoped_numeral_vector() {
reset();
}
void reset() {
unsigned sz = this->size();
for (unsigned i = 0; i < sz; i++) {
m().del(this->operator[](i));
}
svector<typename Manager::numeral>::reset();
}
Manager & m() const { return m_manager; }
void push_back(typename Manager::numeral const & v) {
svector<typename Manager::numeral>::push_back(typename Manager::numeral());
m_manager.set(this->back(), v);
}
void pop_back() {
shrink(this->size()-1);
}
void shrink(unsigned sz) {
unsigned old_sz = this->size();
if (old_sz == sz)
return;
for (unsigned i = sz; i < old_sz; i++)
m().del(this->operator[](i));
svector<typename Manager::numeral>::shrink(sz);
}
void resize(unsigned sz) {
unsigned old_sz = this->size();
if (sz <= old_sz)
shrink(sz);
svector<typename Manager::numeral>::resize(sz, 0);
}
};
#endif