X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=binding%2Fmdsal-binding-dom-adapter%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fmdsal%2Fbinding%2Fdom%2Fadapter%2FCurrentAdapterSerializer.java;h=cad0c4fda686a081f4071a41ec026dfb696bdba3;hb=77d4d3fb01c2164be405b683d2df7f9662884e2c;hp=7a7cdf6ff19acf08a83178fc0203fb9b6ceed454;hpb=21249970a16898dd8e8472d20ecf1dd1f70a0aa3;p=mdsal.git diff --git a/binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/CurrentAdapterSerializer.java b/binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/CurrentAdapterSerializer.java index 7a7cdf6ff1..cad0c4fda6 100644 --- a/binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/CurrentAdapterSerializer.java +++ b/binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/CurrentAdapterSerializer.java @@ -30,24 +30,28 @@ import org.opendaylight.mdsal.binding.api.InstanceNotificationSpec; import org.opendaylight.mdsal.binding.dom.codec.spi.BindingDOMCodecServices; import org.opendaylight.mdsal.binding.dom.codec.spi.ForwardingBindingDOMCodecServices; import org.opendaylight.mdsal.binding.model.api.JavaTypeName; +import org.opendaylight.mdsal.binding.runtime.api.ActionRuntimeType; import org.opendaylight.mdsal.binding.runtime.api.InputRuntimeType; -import org.opendaylight.mdsal.binding.spec.reflect.BindingReflections; +import org.opendaylight.mdsal.binding.runtime.api.NotificationRuntimeType; import org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier; import org.opendaylight.yangtools.yang.binding.DataObject; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.opendaylight.yangtools.yang.common.QNameModule; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; -import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.AugmentationIdentifier; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier; import org.opendaylight.yangtools.yang.model.api.stmt.ActionEffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.ListEffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.NotificationEffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.SchemaNodeIdentifier.Absolute; import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; @Beta @VisibleForTesting public final class CurrentAdapterSerializer extends ForwardingBindingDOMCodecServices { + private static final Logger LOG = LoggerFactory.getLogger(CurrentAdapterSerializer.class); + private final LoadingCache, YangInstanceIdentifier> cache = CacheBuilder.newBuilder() .softValues().build(new CacheLoader, YangInstanceIdentifier>() { @Override @@ -77,7 +81,7 @@ public final class CurrentAdapterSerializer extends ForwardingBindingDOMCodecSer } DOMDataTreeIdentifier toDOMDataTreeIdentifier(final DataTreeIdentifier path) { - return new DOMDataTreeIdentifier(path.getDatastoreType(), toYangInstanceIdentifier(path.getRootIdentifier())); + return DOMDataTreeIdentifier.of(path.datastore(), toYangInstanceIdentifier(path.path())); } Collection toDOMDataTreeIdentifiers(final Collection> subtrees) { @@ -85,17 +89,29 @@ public final class CurrentAdapterSerializer extends ForwardingBindingDOMCodecSer } @NonNull Absolute getActionPath(final @NonNull ActionSpec spec) { + final var type = getRuntimeContext().getTypes().findSchema(JavaTypeName.create(spec.type())) + .orElseThrow(() -> new IllegalArgumentException("Action " + spec + " is not known")); + if (!(type instanceof ActionRuntimeType actionType)) { + throw new IllegalArgumentException("Action " + spec + " resolved to unexpected " + type); + } + final var entry = resolvePath(spec.path()); final var stack = entry.getKey(); - final var stmt = stack.enterSchemaTree(BindingReflections.findQName(spec.type()).bindTo(entry.getValue())); + final var stmt = stack.enterSchemaTree(actionType.statement().argument().bindTo(entry.getValue())); verify(stmt instanceof ActionEffectiveStatement, "Action %s resolved to unexpected statement %s", spec, stmt); return stack.toSchemaNodeIdentifier(); } @NonNull Absolute getNotificationPath(final @NonNull InstanceNotificationSpec spec) { + final var type = getRuntimeContext().getTypes().findSchema(JavaTypeName.create(spec.type())) + .orElseThrow(() -> new IllegalArgumentException("Notification " + spec + " is not known")); + if (!(type instanceof NotificationRuntimeType notifType)) { + throw new IllegalArgumentException("Notification " + spec + " resolved to unexpected " + type); + } + final var entry = resolvePath(spec.path()); final var stack = entry.getKey(); - final var stmt = stack.enterSchemaTree(BindingReflections.findQName(spec.type()).bindTo(entry.getValue())); + final var stmt = stack.enterSchemaTree(notifType.statement().argument().bindTo(entry.getValue())); verify(stmt instanceof NotificationEffectiveStatement, "Notification %s resolved to unexpected statement %s", spec, stmt); return stack.toSchemaNodeIdentifier(); @@ -135,13 +151,6 @@ public final class CurrentAdapterSerializer extends ForwardingBindingDOMCodecSer QNameModule lastNamespace; do { final var arg = it.next(); - if (arg instanceof AugmentationIdentifier) { - final var augChildren = ((AugmentationIdentifier) arg).getPossibleChildNames(); - verify(!augChildren.isEmpty(), "Invalid empty augmentation %s", arg); - lastNamespace = augChildren.iterator().next().getModule(); - continue; - } - final var qname = arg.getNodeType(); final var stmt = stack.enterDataTree(qname); lastNamespace = qname.getModule();