3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-15 05:18:44 +00:00
z3/src/util/uint_map.h
Nikolaj Bjorner d0e20e44ff booyah
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
2020-07-04 15:56:30 -07:00

64 lines
1,013 B
C++

/*++
Copyright (c) 2006 Microsoft Corporation
Module Name:
uint_map.h
Abstract:
<abstract>
Author:
Leonardo de Moura (leonardo) 2010-07-01.
Revision History:
--*/
#pragma once
#include "util/vector.h"
/**
\brief Implement a map from unsigned to T * using vectors
*/
template<typename T>
class uint_map {
ptr_vector<T> m_map;
public:
bool contains(unsigned k) const { return m_map.get(k, 0) != 0; }
bool find(unsigned k, T * & v) const {
if (k >= m_map.size())
return false;
else {
v = m_map[k];
return v != 0;
}
}
T * find(unsigned k) const {
SASSERT(k < m_map.size() && m_map[k] != 0);
return m_map[k];
}
void insert(unsigned k, T * v) {
m_map.reserve(k+1);
m_map[k] = v;
SASSERT(contains(k));
}
void erase(unsigned k) {
if (k < m_map.size())
m_map[k] = 0;
}
void reset() {
m_map.reset();
}
};