*/
package org.opendaylight.mdsal.binding.dom.adapter;
-import static com.google.common.base.Preconditions.checkArgument;
+import static com.google.common.base.Verify.verify;
import static com.google.common.base.Verify.verifyNotNull;
import static java.util.Objects.requireNonNull;
import com.google.common.cache.CacheLoader;
import com.google.common.cache.LoadingCache;
import com.google.common.collect.ImmutableBiMap;
-import com.google.common.collect.ImmutableList;
import java.lang.reflect.Method;
import java.util.Collection;
import java.util.stream.Collectors;
import org.eclipse.jdt.annotation.NonNull;
+import org.opendaylight.mdsal.binding.api.ActionSpec;
import org.opendaylight.mdsal.binding.api.DataTreeIdentifier;
import org.opendaylight.mdsal.binding.dom.codec.spi.BindingDOMCodecServices;
import org.opendaylight.mdsal.binding.dom.codec.spi.ForwardingBindingDOMCodecServices;
import org.opendaylight.mdsal.binding.spec.naming.BindingMapping;
import org.opendaylight.mdsal.binding.spec.reflect.BindingReflections;
import org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier;
-import org.opendaylight.yangtools.yang.binding.Action;
import org.opendaylight.yangtools.yang.binding.DataObject;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
import org.opendaylight.yangtools.yang.binding.RpcService;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.common.QNameModule;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
-import org.opendaylight.yangtools.yang.model.api.ActionDefinition;
+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.Module;
import org.opendaylight.yangtools.yang.model.api.RpcDefinition;
+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.SchemaNodeIdentifier.Absolute;
+import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
return subtrees.stream().map(this::toDOMDataTreeIdentifier).collect(Collectors.toSet());
}
- @NonNull Absolute getActionPath(final @NonNull Class<? extends Action<?, ?, ?>> type) {
- // FIXME: we really just want a SchemaNodeIdentifier.Absolute here
- final ActionDefinition schema = getRuntimeContext().getActionDefinition(type);
- checkArgument(schema != null, "Failed to find schema for %s", type);
- return Absolute.of(ImmutableList.copyOf(schema.getPath().getPathFromRoot()));
+ @NonNull Absolute getActionPath(final @NonNull ActionSpec<?, ?> spec) {
+ final var stack = SchemaInferenceStack.of(getRuntimeContext().getEffectiveModelContext());
+ final var it = toYangInstanceIdentifier(spec.path()).getPathArguments().iterator();
+ verify(it.hasNext(), "Unexpected empty instance identifier for %s", spec);
+
+ 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();
+ if (stmt instanceof ListEffectiveStatement) {
+ // Lists have two steps
+ verify(it.hasNext(), "Unexpected list termination at %s in %s", stmt, spec);
+ // Verify just to make sure we are doing the right thing
+ final var skipped = it.next();
+ verify(skipped instanceof NodeIdentifier, "Unexpected skipped list entry item %s in %s", skipped, spec);
+ verify(stmt.argument().equals(skipped.getNodeType()), "Mismatched list entry item %s in %s", skipped,
+ spec);
+ }
+ } while (it.hasNext());
+
+ final var stmt = stack.enterSchemaTree(BindingReflections.findQName(spec.type()).bindTo(lastNamespace));
+ verify(stmt instanceof ActionEffectiveStatement, "Action %s resolved to unexpected statement %s", spec, stmt);
+ return stack.toSchemaNodeIdentifier();
}
// FIXME: This should be probably part of Binding Runtime context
}
// FIXME: This should be probably part of Binding Runtime context
- ImmutableBiMap<Method, QName> getRpcMethodToSchemaPath(final Class<? extends RpcService> key) {
+ ImmutableBiMap<Method, QName> getRpcMethodToQName(final Class<? extends RpcService> key) {
final Module module = getModule(key);
final ImmutableBiMap.Builder<Method, QName> ret = ImmutableBiMap.builder();
try {
private Module getModule(final Class<?> modeledClass) {
final QNameModule moduleName = BindingReflections.getQNameModule(modeledClass);
final BindingRuntimeContext localRuntimeContext = getRuntimeContext();
- final Module module = localRuntimeContext.getSchemaContext().findModule(moduleName).orElse(null);
+ final Module module = localRuntimeContext.getEffectiveModelContext().findModule(moduleName).orElse(null);
if (module != null) {
return module;
}
private Method findRpcMethod(final Class<? extends RpcService> key, final RpcDefinition rpcDef)
throws NoSuchMethodException {
- final String methodName = BindingMapping.getRpcMethodName(rpcDef.getQName());
- final Class<?> inputClz = getRuntimeContext().getClassForSchema(rpcDef.getInput());
- return key.getMethod(methodName, inputClz);
+ final var rpcName = rpcDef.getQName();
+ final var inputClz = getRuntimeContext().getRpcInput(rpcName);
+ return key.getMethod(BindingMapping.getRpcMethodName(rpcName), inputClz);
}
}