diff options
author | Benjamin Paassen <bpaassen@techfak.uni-bielefeld.de> | 2015-02-12 22:36:38 +0100 |
---|---|---|
committer | Benjamin Paassen <bpaassen@techfak.uni-bielefeld.de> | 2015-02-12 22:36:38 +0100 |
commit | 3ed124aeed2cb65b05f61224115366601ee3b05f (patch) | |
tree | ac25a6f524d6361d64b69926238623b972cea0fa /src/core/model/Domain.cpp | |
parent | 37a691eb6a5ed31dfc28e15db9d076322ab5fdde (diff) |
added Descriptor::getPermittedChildren.
Diffstat (limited to 'src/core/model/Domain.cpp')
-rw-r--r-- | src/core/model/Domain.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/core/model/Domain.cpp b/src/core/model/Domain.cpp index 6f33ebd..3cc9755 100644 --- a/src/core/model/Domain.cpp +++ b/src/core/model/Domain.cpp @@ -471,6 +471,19 @@ NodeVector<FieldDescriptor> Descriptor::getDefaultFields() const return res; } +NodeVector<StructuredClass> Descriptor::getPermittedChildren() const +{ + // TODO: In principle a cast would be nicer here, but for now we copy. + NodeVector<Node> nodes = collect(this, [](Handle<Node> n) { + return n->isa(&RttiTypes::StructuredClass); + }); + NodeVector<StructuredClass> res; + for (auto n : nodes) { + res.push_back(n.cast<StructuredClass>()); + } + return res; +} + static ssize_t getFieldDescriptorIndex(const NodeVector<FieldDescriptor> &fds, const std::string &name) { |