XPATH Datamodel For YangUtils
Change-Id: I39449323a6d43ad293ac7ae986dc983d35eb944b
diff --git a/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangAtomicPath.java b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangAtomicPath.java
new file mode 100644
index 0000000..6df33bb
--- /dev/null
+++ b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangAtomicPath.java
@@ -0,0 +1,78 @@
+/*
+ * Copyright 2016-present Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onosproject.yangutils.datamodel;
+
+import java.io.Serializable;
+import java.util.List;
+
+/**
+ * Representation of data model node to maintain absolute path defined in YANG path-arg.
+ */
+public class YangAtomicPath implements Serializable {
+
+ private static final long serialVersionUID = 806201688L;
+
+ // YANG node identifier.
+ private YangNodeIdentifier nodeIdentifier;
+
+ // List of path predicates expression.
+ private List<YangPathPredicate> pathPredicatesList;
+
+ /**
+ * Returns the node identifier.
+ *
+ * @return the node identifier
+ */
+ public YangNodeIdentifier getNodeIdentifier() {
+ return nodeIdentifier;
+ }
+
+ /**
+ * Sets the node identifier.
+ *
+ * @param nodeIdentifier Sets the node identifier
+ */
+ public void setNodeIdentifier(YangNodeIdentifier nodeIdentifier) {
+ this.nodeIdentifier = nodeIdentifier;
+ }
+
+ /**
+ * Returns the path predicate expression.
+ *
+ * @return the path predicate expression
+ */
+ public List<YangPathPredicate> getPathPredicatesList() {
+ return pathPredicatesList;
+ }
+
+ /**
+ * Sets the path predicate expression.
+ *
+ * @param pathPredicatesList Sets the path predicate expression
+ */
+ public void setPathPredicatesList(List<YangPathPredicate> pathPredicatesList) {
+ this.pathPredicatesList = pathPredicatesList;
+ }
+
+ /**
+ * Adds predicate expression in data holder.
+ *
+ * @param predicatesExp the predicate expression to be added
+ */
+ public void addLeavesPredicate(YangPathPredicate predicatesExp) {
+ getPathPredicatesList().add(predicatesExp);
+ }
+}
diff --git a/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathArgType.java b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathArgType.java
new file mode 100644
index 0000000..5939829
--- /dev/null
+++ b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathArgType.java
@@ -0,0 +1,29 @@
+/*
+ * Copyright 2016-present Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onosproject.yangutils.datamodel;
+
+/**
+ * Represents path argument type in data model tree.
+ */
+public enum YangPathArgType {
+
+ // Absolute path.
+ ABSOLUTE_PATH,
+
+ // Relative path.
+ RELATIVE_PATH
+
+}
diff --git a/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathOperator.java b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathOperator.java
new file mode 100644
index 0000000..718c30c
--- /dev/null
+++ b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathOperator.java
@@ -0,0 +1,25 @@
+/*
+ * Copyright 2016-present Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onosproject.yangutils.datamodel;
+
+/**
+ * Represents path-expr in data model tree.
+ */
+public enum YangPathOperator {
+
+ // Path expression contains equal to.
+ EQUALTO
+}
diff --git a/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathPredicate.java b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathPredicate.java
new file mode 100644
index 0000000..cf45349
--- /dev/null
+++ b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangPathPredicate.java
@@ -0,0 +1,132 @@
+/*
+ * Copyright 2016-present Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onosproject.yangutils.datamodel;
+
+import java.io.Serializable;
+
+/**
+ * Representation of data model node to maintain path predicate in YANG absolute-path or relative-path.
+ */
+public class YangPathPredicate<T> implements Serializable {
+
+ private static final long serialVersionUID = 806201689L;
+
+ // YANG node identifier.
+ private YangNodeIdentifier nodeIdentifier;
+
+ // Left axis node will represent the nodeidentifier before equality sign in path predicate.
+ private T leftAxisNode;
+
+ // YANG path operator.
+ private YangPathOperator pathOperator;
+
+ // YANG relative path.
+ private YangRelativePath rightRelativePath;
+
+ // Right axis node will represent the nodeidentifier after equality sign in path predicate.
+ private T rightAxisNode;
+
+ /**
+ * Returns the path expression operator.
+ *
+ * @return the path expression operator
+ */
+ public YangPathOperator getPathOperator() {
+ return pathOperator;
+ }
+
+ /**
+ * Sets the path expression operator.
+ *
+ * @param pathOperator Sets the path expression operator
+ */
+ public void setPathOperator(YangPathOperator pathOperator) {
+ this.pathOperator = pathOperator;
+ }
+
+ /**
+ * Returns the right relative path expression.
+ *
+ * @return the right relative path expression
+ */
+ public YangRelativePath getRightRelativePath() {
+ return rightRelativePath;
+ }
+
+ /**
+ * Sets the right relative path expression.
+ *
+ * @param rightRelativePath Sets the right relative path expression
+ */
+ public void setRightRelativePath(YangRelativePath rightRelativePath) {
+ this.rightRelativePath = rightRelativePath;
+ }
+
+ /**
+ * Returns the nodeidentifier.
+ *
+ * @return the nodeidentifier
+ */
+ public YangNodeIdentifier getNodeIdentifier() {
+ return nodeIdentifier;
+ }
+
+ /**
+ * Sets the YANG node identifier.
+ *
+ * @param nodeIdentifier Sets the node identifier
+ *
+ */
+ public void setNodeIdentifier(YangNodeIdentifier nodeIdentifier) {
+ this.nodeIdentifier = nodeIdentifier;
+ }
+
+ /**
+ * Returns the left axis node.
+ *
+ * @return the left axis node
+ */
+ public T getLeftAxisNode() {
+ return leftAxisNode;
+ }
+
+ /**
+ * Sets the left axis node.
+ *
+ * @param leftAxisNode Sets the left axis node
+ */
+ public void setLeftAxisNode(T leftAxisNode) {
+ this.leftAxisNode = leftAxisNode;
+ }
+
+ /**
+ * Returns the right axis node.
+ *
+ * @return the right axis node
+ */
+ public T getRightAxisNode() {
+ return rightAxisNode;
+ }
+
+ /**
+ * Sets the right axis node.
+ *
+ * @param rightAxisNode Sets the right axis node
+ */
+ public void setRightAxisNode(T rightAxisNode) {
+ this.rightAxisNode = rightAxisNode;
+ }
+}
diff --git a/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangRelativePath.java b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangRelativePath.java
new file mode 100644
index 0000000..a7af2a2
--- /dev/null
+++ b/datamodel/src/main/java/org/onosproject/yangutils/datamodel/YangRelativePath.java
@@ -0,0 +1,69 @@
+/*
+ * Copyright 2016-present Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.onosproject.yangutils.datamodel;
+
+import java.io.Serializable;
+import java.util.List;
+
+/**
+ * Representation of data model node to maintain relative path defined in YANG path-arg.
+ */
+public class YangRelativePath implements Serializable {
+
+ private static final long serialVersionUID = 806201690L;
+
+ // Relative path ancestor node count the number of node exist between current node to parent node.
+ private int ancestorNodeCount;
+
+ // Absolute path expression.
+ private List<YangAtomicPath> atomicPathList;
+
+ /**
+ * Returns the absolute path.
+ *
+ * @return the absolute path
+ */
+ public List<YangAtomicPath> getAtomicPathList() {
+ return atomicPathList;
+ }
+
+ /**
+ * Sets the absolute path.
+ *
+ * @param atomicPathList Sets the absolute path
+ */
+ public void setAtomicPathList(List<YangAtomicPath> atomicPathList) {
+ this.atomicPathList = atomicPathList;
+ }
+
+ /**
+ * Returns the relative path ancestor count.
+ *
+ * @return the relative path ancestor count
+ */
+ public int getAncestorNodeCount() {
+ return ancestorNodeCount;
+ }
+
+ /**
+ * Sets the relative path ancestor count.
+ *
+ * @param ancestorNodeCount Sets the relative path ancestor count
+ */
+ public void setAncestorNodeCount(int ancestorNodeCount) {
+ this.ancestorNodeCount = ancestorNodeCount;
+ }
+}