1
0
This repository has been archived on 2025-03-06. You can view files and clone it, but cannot push or open issues or pull requests.
Jip J. Dekker 9b7e65e00b Squashed 'software/minizinc/' content from commit 5a577826
git-subtree-dir: software/minizinc
git-subtree-split: 5a577826da4d7cf6195f28b5604d8d20a01fbc6e
2021-06-18 09:34:50 +10:00

53 lines
1.6 KiB
C++

/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
/*
* Main authors:
* Jip J. Dekker <jip.dekker@monash.edu>
* Guido Tack <guido.tack@monash.edu>
*/
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#pragma once
#include <minizinc/ast.hh>
#include <minizinc/aststring.hh>
#include <unordered_map>
#include <unordered_set>
namespace MiniZinc {
/// Hash map from strings to \a T
/// Note: This map is only safe to use if the keys are guaranteed to be
/// marked alive. (For example if they are used in a Model object)
template <typename T>
using ASTStringMap = std::unordered_map<ASTString, T>;
/// Hash set of strings
/// Note: This set is only safe to use if the keys are guaranteed to be
/// marked alive. (For example if they are used in a Model object)
using ASTStringSet = std::unordered_set<ASTString>;
/// Hash map from strings to \a T
/// Note: This map will ensure its keys stay alive while it still exists
/// Specialisations for Expression* and VarDeclI* exist to ensure the
/// stored values are kept alive as well.
template <typename T>
class ManagedASTStringMap : public GCMarker, public std::unordered_map<ASTString, T> {
protected:
void mark(MINIZINC_GC_STAT_ARGS) override {
for (auto& it : *this) {
it.first.mark();
}
}
};
template <>
void ManagedASTStringMap<Expression*>::mark(MINIZINC_GC_STAT_ARGS);
template <>
void ManagedASTStringMap<VarDeclI*>::mark(MINIZINC_GC_STAT_ARGS);
} // namespace MiniZinc