summaryrefslogtreecommitdiff
path: root/src/core/model/Document.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/model/Document.hpp')
-rw-r--r--src/core/model/Document.hpp17
1 files changed, 16 insertions, 1 deletions
diff --git a/src/core/model/Document.hpp b/src/core/model/Document.hpp
index cb7f394..9410d17 100644
--- a/src/core/model/Document.hpp
+++ b/src/core/model/Document.hpp
@@ -161,7 +161,7 @@ protected:
fields[getFieldDescriptorIndex(fieldName, true)].push_back(s);
}
- bool validate(Logger &logger) const;
+ bool doValidate(Logger &logger) const;
public:
/**
@@ -512,6 +512,7 @@ class AnnotationEntity : public Node, public DocumentEntity {
private:
Owned<Anchor> start;
Owned<Anchor> end;
+
protected:
bool doValidate(Logger &logger) const override;
@@ -569,6 +570,9 @@ private:
void doResolve(ResolutionState &state) override;
+protected:
+ bool doValidate(Logger &logger) const override;
+
public:
Document(Manager &mgr, std::string name)
// TODO: Can a document have a parent?
@@ -622,6 +626,17 @@ public:
{
domains.insert(domains.end(), d.begin(), d.end());
}
+
+ /**
+ * Returns true if and only if the given StructureNode is part of this
+ * document, meaning that there is a path of parent references in the
+ * Structure Tree leading from the given StructureNode to this Document.
+ *
+ * @param s is some StructureNode.
+ * @return true if and only if the given StructureNode is part of this
+ * document.
+ */
+ bool hasChild(Handle<StructureNode> s) const;
};
}