diff options
author | Andreas Stöckel <astoecke@techfak.uni-bielefeld.de> | 2015-01-30 18:18:02 +0100 |
---|---|---|
committer | Andreas Stöckel <andreas@somweyr.de> | 2015-01-30 18:18:02 +0100 |
commit | 0ed53efd407fb4e5462c3c1f606be90bb3f7241b (patch) | |
tree | efa7e55bdf1925fbf1ef5e2ad5155033d4d29713 /src | |
parent | 729ea17ed17cf81eb19847216406e40686df679d (diff) |
Added "Cardinality" type and AnyCardinality constant to RangeSet
Diffstat (limited to 'src')
-rw-r--r-- | src/core/RangeSet.cpp | 32 | ||||
-rw-r--r-- | src/core/RangeSet.hpp | 8 | ||||
-rw-r--r-- | src/core/common/Variant.hpp | 2 | ||||
-rw-r--r-- | src/core/model/Domain.hpp | 13 |
4 files changed, 41 insertions, 14 deletions
diff --git a/src/core/RangeSet.cpp b/src/core/RangeSet.cpp new file mode 100644 index 0000000..c07dc9b --- /dev/null +++ b/src/core/RangeSet.cpp @@ -0,0 +1,32 @@ +/* + Ousía + Copyright (C) 2014 Benjamin Paaßen, Andreas Stöckel + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +#include "RangeSet.hpp" + +namespace ousia { + +static Cardinality createAny() +{ + Cardinality any; + any.merge(Range<size_t>::typeRangeFrom(0)); + return std::move(any); +} + +const Cardinality AnyCardinality = createAny(); +} + diff --git a/src/core/RangeSet.hpp b/src/core/RangeSet.hpp index fc0070f..f5b56e2 100644 --- a/src/core/RangeSet.hpp +++ b/src/core/RangeSet.hpp @@ -19,6 +19,7 @@ #ifndef _OUSIA_RANGE_SET_HPP_ #define _OUSIA_RANGE_SET_HPP_ +#include <cstddef> #include <limits> #include <set> @@ -412,6 +413,13 @@ public: return !(lhs == rhs); } }; + +/** + * This is the default cardinality. + */ +using Cardinality = RangeSet<size_t>; +extern const Cardinality AnyCardinality; + } #endif /* _OUSIA_RANGE_SET_HPP_ */ diff --git a/src/core/common/Variant.hpp b/src/core/common/Variant.hpp index 103c0e7..3c78ccd 100644 --- a/src/core/common/Variant.hpp +++ b/src/core/common/Variant.hpp @@ -113,7 +113,7 @@ public: using arrayType = std::vector<Variant>; using mapType = std::map<std::string, Variant>; using objectType = Rooted<Managed>; - using cardinalityType = RangeSet<size_t>; + using cardinalityType = Cardinality; using rangeType = Range<size_t>; using functionType = std::shared_ptr<Function>; diff --git a/src/core/model/Domain.hpp b/src/core/model/Domain.hpp index cd649d5..7704d36 100644 --- a/src/core/model/Domain.hpp +++ b/src/core/model/Domain.hpp @@ -616,19 +616,6 @@ public: */ /** - * This is the default cardinality. - */ - -static Variant::cardinalityType createAny() -{ - Variant::cardinalityType any; - any.merge(Range<size_t>::typeRangeFrom(0)); - return std::move(any); -} - -static const Variant AnyCardinality = createAny(); - -/** * A StructuredClass specifies nodes in the StructureTree of a document that * implements this domain. For more information on the StructureTree please * consult the Header documentation above. |