Merge "Add copyright header"
[yangtools.git] / yang / yang-parser-impl / src / main / java / org / opendaylight / yangtools / yang / parser / builder / impl / UsesNodeBuilderImpl.java
index abc1fe767a1748ef8363d371590d54dc0785c852..fbb01e5ee3384de8c76640e202ef7a5c0fdb2704 100644 (file)
@@ -28,7 +28,6 @@ import org.opendaylight.yangtools.yang.parser.builder.api.DataNodeContainerBuild
 import org.opendaylight.yangtools.yang.parser.builder.api.DataSchemaNodeBuilder;
 import org.opendaylight.yangtools.yang.parser.builder.api.GroupingBuilder;
 import org.opendaylight.yangtools.yang.parser.builder.api.SchemaNodeBuilder;
-import org.opendaylight.yangtools.yang.parser.builder.api.TypeDefinitionBuilder;
 import org.opendaylight.yangtools.yang.parser.builder.api.UsesNodeBuilder;
 import org.opendaylight.yangtools.yang.parser.util.RefineHolder;
 import org.opendaylight.yangtools.yang.parser.util.YangParseException;
@@ -36,49 +35,23 @@ import org.opendaylight.yangtools.yang.parser.util.YangParseException;
 public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNodeBuilder {
     private boolean isBuilt;
     private UsesNodeImpl instance;
-    private DataNodeContainerBuilder parent;
-    private final String groupingName;
+    private DataNodeContainerBuilder parentBuilder;
+    private final String groupingPathString;
     private SchemaPath groupingPath;
     private GroupingDefinition groupingDefinition;
     private GroupingBuilder groupingBuilder;
     private boolean addedByUses;
-    private final Set<AugmentationSchemaBuilder> addedAugments = new HashSet<AugmentationSchemaBuilder>();
-    private final List<SchemaNodeBuilder> refineBuilders = new ArrayList<SchemaNodeBuilder>();
-    private final List<RefineHolder> refines = new ArrayList<RefineHolder>();
+    private boolean augmenting;
+    private boolean resolved;
+    private final Set<AugmentationSchema> augments = new HashSet<>();
+    private final Set<AugmentationSchemaBuilder> addedAugments = new HashSet<>();
+    private final List<SchemaNodeBuilder> refineBuilders = new ArrayList<>();
+    private final List<RefineHolder> refines = new ArrayList<>();
 
-    private Set<DataSchemaNodeBuilder> targetChildren = new HashSet<>();
-    private Set<GroupingBuilder> targetGroupings = new HashSet<>();
-    private Set<TypeDefinitionBuilder> targetTypedefs = new HashSet<>();
-    private List<UnknownSchemaNodeBuilder> targetUnknownNodes = new ArrayList<>();
-
-    private final boolean isCopy;
-    private boolean dataCollected;
-
-    @Override
-    public boolean isCopy() {
-        return isCopy;
-    }
-
-    @Override
-    public boolean isDataCollected() {
-        return dataCollected;
-    }
-
-    @Override
-    public void setDataCollected(boolean dataCollected) {
-        this.dataCollected = dataCollected;
-    }
 
     public UsesNodeBuilderImpl(final String moduleName, final int line, final String groupingName) {
         super(moduleName, line);
-        this.groupingName = groupingName;
-        isCopy = false;
-    }
-
-    public UsesNodeBuilderImpl(final String moduleName, final int line, final String groupingName, final boolean isCopy) {
-        super(moduleName, line);
-        this.groupingName = groupingName;
-        this.isCopy = isCopy;
+        this.groupingPathString = groupingName;
     }
 
     @Override
@@ -88,14 +61,13 @@ public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNo
             instance.setAddedByUses(addedByUses);
 
             // AUGMENTATIONS
-            final Set<AugmentationSchema> augments = new HashSet<AugmentationSchema>();
             for (AugmentationSchemaBuilder builder : addedAugments) {
                 augments.add(builder.build());
             }
             instance.setAugmentations(augments);
 
             // REFINES
-            final Map<SchemaPath, SchemaNode> refineNodes = new HashMap<SchemaPath, SchemaNode>();
+            final Map<SchemaPath, SchemaNode> refineNodes = new HashMap<>();
             for (SchemaNodeBuilder refineBuilder : refineBuilders) {
                 SchemaNode refineNode = refineBuilder.build();
                 refineNodes.put(refineNode.getPath(), refineNode);
@@ -103,7 +75,6 @@ public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNo
             instance.setRefines(refineNodes);
 
             // UNKNOWN NODES
-            List<UnknownSchemaNode> unknownNodes = new ArrayList<UnknownSchemaNode>();
             for (UnknownSchemaNodeBuilder b : addedUnknownNodes) {
                 unknownNodes.add(b.build());
             }
@@ -117,7 +88,7 @@ public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNo
 
     @Override
     public DataNodeContainerBuilder getParent() {
-        return parent;
+        return parentBuilder;
     }
 
     @Override
@@ -126,7 +97,7 @@ public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNo
             throw new YangParseException(moduleName, line,
                     "Parent of 'uses' has to be instance of DataNodeContainerBuilder, but was: '" + parent + "'.");
         }
-        this.parent = (DataNodeContainerBuilder) parent;
+        this.parentBuilder = (DataNodeContainerBuilder) parent;
     }
 
     @Override
@@ -162,7 +133,7 @@ public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNo
 
     @Override
     public String getGroupingPathAsString() {
-        return groupingName;
+        return groupingPathString;
     }
 
     @Override
@@ -179,79 +150,57 @@ public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNo
     public boolean isAddedByUses() {
         return addedByUses;
     }
-
     @Override
     public void setAddedByUses(final boolean addedByUses) {
         this.addedByUses = addedByUses;
     }
 
     @Override
-    public List<SchemaNodeBuilder> getRefineNodes() {
-        return refineBuilders;
-    }
-
-    @Override
-    public void addRefineNode(DataSchemaNodeBuilder refineNode) {
-        refineBuilders.add(refineNode);
-    }
-
-    @Override
-    public List<RefineHolder> getRefines() {
-        return refines;
-    }
-
-    @Override
-    public void addRefine(RefineHolder refine) {
-        refines.add(refine);
-    }
-
-    @Override
-    public Set<DataSchemaNodeBuilder> getTargetChildren() {
-        return targetChildren;
+    public boolean isAugmenting() {
+        return augmenting;
     }
 
     @Override
-    public void setTargetChildren(Set<DataSchemaNodeBuilder> targetChildren) {
-        this.targetChildren = targetChildren;
+    public void setAugmenting(boolean augmenting) {
+        this.augmenting = augmenting;
     }
 
     @Override
-    public Set<GroupingBuilder> getTargetGroupings() {
-        return targetGroupings;
+    public boolean isResolved() {
+        return resolved;
     }
 
     @Override
-    public void setTargetGroupings(Set<GroupingBuilder> targetGroupings) {
-        this.targetGroupings = targetGroupings;
+    public void setResolved(boolean resolved) {
+        this.resolved = resolved;
     }
 
     @Override
-    public Set<TypeDefinitionBuilder> getTargetTypedefs() {
-        return targetTypedefs;
+    public List<SchemaNodeBuilder> getRefineNodes() {
+        return refineBuilders;
     }
 
     @Override
-    public void setTargetTypedefs(Set<TypeDefinitionBuilder> targetTypedefs) {
-        this.targetTypedefs = targetTypedefs;
+    public void addRefineNode(DataSchemaNodeBuilder refineNode) {
+        refineBuilders.add(refineNode);
     }
 
     @Override
-    public List<UnknownSchemaNodeBuilder> getTargetUnknownNodes() {
-        return targetUnknownNodes;
+    public List<RefineHolder> getRefines() {
+        return refines;
     }
 
     @Override
-    public void setTargetUnknownNodes(List<UnknownSchemaNodeBuilder> targetUnknownNodes) {
-        this.targetUnknownNodes = targetUnknownNodes;
+    public void addRefine(RefineHolder refine) {
+        refines.add(refine);
     }
 
     @Override
     public int hashCode() {
         final int prime = 31;
         int result = 1;
-        result = prime * result + ((groupingName == null) ? 0 : groupingName.hashCode());
-        result = prime * result + ((parent == null) ? 0 : parent.hashCode());
-        result = prime * result + ((refines == null) ? 0 : refines.hashCode());
+        result = prime * result + ((groupingPathString == null) ? 0 : groupingPathString.hashCode());
+        result = prime * result + ((parentBuilder == null) ? 0 : parentBuilder.hashCode());
         return result;
     }
 
@@ -267,25 +216,18 @@ public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNo
             return false;
         }
         UsesNodeBuilderImpl other = (UsesNodeBuilderImpl) obj;
-        if (groupingName == null) {
-            if (other.groupingName != null) {
-                return false;
-            }
-        } else if (!groupingName.equals(other.groupingName)) {
-            return false;
-        }
-        if (parent == null) {
-            if (other.parent != null) {
+        if (groupingPathString == null) {
+            if (other.groupingPathString != null) {
                 return false;
             }
-        } else if (!parent.equals(other.parent)) {
+        } else if (!groupingPathString.equals(other.groupingPathString)) {
             return false;
         }
-        if (refines == null) {
-            if (other.refines != null) {
+        if (parentBuilder == null) {
+            if (other.parentBuilder != null) {
                 return false;
             }
-        } else if (!refines.equals(other.refines)) {
+        } else if (!parentBuilder.equals(other.parentBuilder)) {
             return false;
         }
         return true;
@@ -293,7 +235,7 @@ public final class UsesNodeBuilderImpl extends AbstractBuilder implements UsesNo
 
     @Override
     public String toString() {
-        return "uses '" + groupingName + "'";
+        return "uses '" + groupingPathString + "'";
     }
 
     public final class UsesNodeImpl implements UsesNode {