Remove EffectiveAugmentationSchema.create() 32/99932/2
authorRobert Varga <robert.varga@pantheon.tech>
Wed, 2 Mar 2022 11:30:57 +0000 (12:30 +0100)
committerRobert Varga <robert.varga@pantheon.tech>
Wed, 2 Mar 2022 12:43:19 +0000 (13:43 +0100)
This is a simple class, there is no need to have a static method, just
a constructor suffices.

Change-Id: I0eeff5c1f5dbcefe6f0b356323762cb2a3152b9f
Signed-off-by: Robert Varga <robert.varga@pantheon.tech>
data/yang-data-impl/src/main/java/org/opendaylight/yangtools/yang/data/impl/schema/InstanceIdToCompositeNodes.java
data/yang-data-tree-ri/src/main/java/org/opendaylight/yangtools/yang/data/tree/impl/AugmentationModificationStrategy.java
data/yang-data-util/src/main/java/org/opendaylight/yangtools/yang/data/util/AugmentationContextNode.java
data/yang-data-util/src/main/java/org/opendaylight/yangtools/yang/data/util/NormalizedNodeStreamWriterStack.java
model/yang-model-util/src/main/java/org/opendaylight/yangtools/yang/model/util/EffectiveAugmentationSchema.java
model/yang-model-util/src/test/java/org/opendaylight/yangtools/yang/model/util/YT1404Test.java

index 43899ce18abfcde2f4d27fa9bcf1ab00cb70ad3a..f5f447dd55b1225db7689cc6cf4096f08de76dc5 100644 (file)
@@ -281,7 +281,7 @@ abstract class InstanceIdToCompositeNodes<T extends PathArgument> extends Instan
             extends DataContainerNormalizationOperation<AugmentationIdentifier, AugmentationSchemaNode> {
         AugmentationNormalization(final AugmentationSchemaNode augmentation, final DataNodeContainer schema) {
             super(DataSchemaContextNode.augmentationIdentifierFrom(augmentation),
-                    EffectiveAugmentationSchema.create(augmentation, schema));
+                new EffectiveAugmentationSchema(augmentation, schema));
         }
 
         @Override
index 53f8d9f3e6cf7d78fb881ae2b471b10933ca7914..42b0ea339ec88b4128f4ed36d6b97407f9c3aac8 100644 (file)
@@ -30,7 +30,7 @@ final class AugmentationModificationStrategy
 
     AugmentationModificationStrategy(final AugmentationSchemaNode schema, final DataNodeContainer resolved,
             final DataTreeConfiguration treeConfig) {
-        super(SUPPORT, EffectiveAugmentationSchema.create(schema, resolved), treeConfig);
+        super(SUPPORT, new EffectiveAugmentationSchema(schema, resolved), treeConfig);
         emptyNode = Builders.augmentationBuilder()
                 .withNodeIdentifier(DataSchemaContextNode.augmentationIdentifierFrom(schema))
                 .build();
index 15fb6a2d5f37aacc550917030cb73410d6edd7c3..e4c81ece17a8b2bc30d16c83843688a3b5a6d11e 100644 (file)
@@ -18,7 +18,7 @@ import org.opendaylight.yangtools.yang.model.util.EffectiveAugmentationSchema;
 
 final class AugmentationContextNode extends DataContainerContextNode<AugmentationIdentifier> {
     AugmentationContextNode(final AugmentationSchemaNode augmentation, final DataNodeContainer schema) {
-        super(augmentationIdentifierFrom(augmentation), EffectiveAugmentationSchema.create(augmentation, schema), null);
+        super(augmentationIdentifierFrom(augmentation), new EffectiveAugmentationSchema(augmentation, schema), null);
     }
 
     @Override
index 6eb0e7750b0df3009a1bc869c8cb78d5327cf874..686e0d8739bdbdd8c5a769f13d9386d8e6c9fde7 100644 (file)
@@ -298,7 +298,7 @@ public final class NormalizedNodeStreamWriterStack implements LeafrefResolver {
         checkArgument(parent instanceof DataNodeContainer, "Augmentation allowed only in DataNodeContainer", parent);
         final AugmentationSchemaNode schema = findSchemaForAugment((AugmentationTarget) parent,
             identifier.getPossibleChildNames());
-        final AugmentationSchemaNode resolvedSchema = EffectiveAugmentationSchema.create(schema,
+        final AugmentationSchemaNode resolvedSchema = new EffectiveAugmentationSchema(schema,
             (DataNodeContainer) parent);
         schemaStack.push(resolvedSchema);
         return resolvedSchema;
index 5c4a8598a165e23b78dafbc7f999df6c32e00c2f..30f54f7c07609a092b1a5d2b17034ced5802cf4d 100644 (file)
@@ -10,13 +10,8 @@ package org.opendaylight.yangtools.yang.model.util;
 import static java.util.Objects.requireNonNull;
 
 import com.google.common.collect.ImmutableMap;
-import com.google.common.collect.ImmutableSet;
 import java.util.Collection;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Map;
 import java.util.Optional;
-import java.util.Set;
 import org.opendaylight.yangtools.yang.common.QName;
 import org.opendaylight.yangtools.yang.model.api.ActionDefinition;
 import org.opendaylight.yangtools.yang.model.api.AugmentationSchemaNode;
@@ -56,43 +51,24 @@ import org.opendaylight.yangtools.yang.xpath.api.YangXPathExpression.QualifiedBo
  */
 // FIXME: YANGTOOLS-1403: this functionality should be integrated into EffectiveAugmentStatement/AugmentationSchemaNode
 public final class EffectiveAugmentationSchema implements AugmentationSchemaNode {
+    private final ImmutableMap<QName, DataSchemaNode> children;
     private final AugmentationSchemaNode delegate;
-    private final ImmutableSet<DataSchemaNode> realChildSchemas;
-    private final ImmutableMap<QName, DataSchemaNode> mappedChildSchemas;
 
-    public EffectiveAugmentationSchema(final AugmentationSchemaNode augmentSchema,
-            final Collection<? extends DataSchemaNode> realChildSchemas) {
-        delegate = requireNonNull(augmentSchema);
-        this.realChildSchemas = ImmutableSet.copyOf(realChildSchemas);
+    public EffectiveAugmentationSchema(final AugmentationSchemaNode augment, final DataNodeContainer target) {
+        delegate = requireNonNull(augment);
 
-        final Map<QName, DataSchemaNode> m = new HashMap<>(realChildSchemas.size());
-        for (DataSchemaNode realChildSchema : realChildSchemas) {
-            m.put(realChildSchema.getQName(), realChildSchema);
-        }
-
-        mappedChildSchemas = ImmutableMap.copyOf(m);
-    }
-
-    /**
-     * Returns an AugmentationSchemaNode as effective in a parent node.
-     *
-     * @param schema Augmentation schema
-     * @param parent Parent schema
-     * @return Adjusted Augmentation schema
-     * @throws NullPointerException if any of the arguments is null
-     */
-    // FIXME: 8.0.0: integrate this method into the constructor
-    public static AugmentationSchemaNode create(final AugmentationSchemaNode schema, final DataNodeContainer parent) {
-        final Set<DataSchemaNode> children = new HashSet<>();
-        for (DataSchemaNode augNode : schema.getChildNodes()) {
+        final var augmentChildren = augment.getChildNodes();
+        final var builder = ImmutableMap.<QName, DataSchemaNode>builderWithExpectedSize(augmentChildren.size());
+        for (var augChild : augmentChildren) {
             // parent may have the corresponding child removed via 'deviate unsupported', i.e. the child is effectively
             // not present at the target site
-            final DataSchemaNode child = parent.dataChildByName(augNode.getQName());
-            if (child != null) {
-                children.add(child);
+            final var qname = augChild.getQName();
+            final var targetChild = target.dataChildByName(qname);
+            if (targetChild != null) {
+                builder.put(qname, targetChild);
             }
         }
-        return new EffectiveAugmentationSchema(schema, children);
+        children = builder.build();
     }
 
     @Override
@@ -127,7 +103,7 @@ public final class EffectiveAugmentationSchema implements AugmentationSchemaNode
 
     @Override
     public Collection<? extends DataSchemaNode> getChildNodes() {
-        return realChildSchemas;
+        return children.values();
     }
 
     @Override
@@ -137,7 +113,7 @@ public final class EffectiveAugmentationSchema implements AugmentationSchemaNode
 
     @Override
     public DataSchemaNode dataChildByName(final QName name) {
-        return mappedChildSchemas.get(requireNonNull(name));
+        return children.get(requireNonNull(name));
     }
 
     @Override
index 63e597fd3ed709c9b4bcf8082593503940b1fb72..a90a4562db64ec3c3647973db1cf0165d4741929 100644 (file)
@@ -42,7 +42,7 @@ public class YT1404Test {
         final var fooAugment = Iterables.getOnlyElement(fooCont.getAvailableAugmentations());
         assertSame(augment, fooAugment);
 
-        final var effectiveAug = EffectiveAugmentationSchema.create(augment, fooCont);
+        final var effectiveAug = new EffectiveAugmentationSchema(augment, fooCont);
         assertEquals(1, effectiveAug.getChildNodes().size());
         assertSame(fooBar, effectiveAug.getDataChildByName(BAR));
     }