import java.util.List;
import java.util.Map;
import org.eclipse.jdt.annotation.NonNull;
+import org.opendaylight.mdsal.binding.runtime.api.ListRuntimeType;
import org.opendaylight.yangtools.yang.binding.DataObject;
import org.opendaylight.yangtools.yang.binding.Identifiable;
import org.opendaylight.yangtools.yang.binding.Identifier;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier.IdentifiableItem;
+import org.opendaylight.yangtools.yang.common.Ordering;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifierWithPredicates;
import org.opendaylight.yangtools.yang.data.api.schema.MapNode;
-import org.opendaylight.yangtools.yang.model.api.ListSchemaNode;
abstract class KeyedListNodeCodecContext<I extends Identifier<D>, D extends DataObject & Identifiable<I>>
extends ListNodeCodecContext<D> {
private static final class Ordered<I extends Identifier<D>, D extends DataObject & Identifiable<I>>
extends KeyedListNodeCodecContext<I, D> {
- Ordered(final DataContainerCodecPrototype<ListSchemaNode> prototype, final Method keyMethod,
+ Ordered(final DataContainerCodecPrototype<ListRuntimeType> prototype, final Method keyMethod,
final IdentifiableItemCodec codec) {
super(prototype, keyMethod, codec);
}
static final class Unordered<I extends Identifier<D>, D extends DataObject & Identifiable<I>>
extends KeyedListNodeCodecContext<I, D> {
- Unordered(final DataContainerCodecPrototype<ListSchemaNode> prototype, final Method keyMethod,
+ Unordered(final DataContainerCodecPrototype<ListRuntimeType> prototype, final Method keyMethod,
final IdentifiableItemCodec codec) {
super(prototype, keyMethod, codec);
}
private final IdentifiableItemCodec codec;
- KeyedListNodeCodecContext(final DataContainerCodecPrototype<ListSchemaNode> prototype,
+ KeyedListNodeCodecContext(final DataContainerCodecPrototype<ListRuntimeType> prototype,
final Method keyMethod, final IdentifiableItemCodec codec) {
super(prototype, keyMethod);
this.codec = requireNonNull(codec);
}
@SuppressWarnings("rawtypes")
- static KeyedListNodeCodecContext create(final DataContainerCodecPrototype<ListSchemaNode> prototype) {
+ static KeyedListNodeCodecContext create(final DataContainerCodecPrototype<ListRuntimeType> prototype) {
final Class<?> bindingClass = prototype.getBindingClass();
final Method keyMethod;
try {
throw new IllegalStateException("Required method not available", e);
}
- final ListSchemaNode schema = prototype.getSchema();
- final IdentifiableItemCodec codec = prototype.getFactory().getPathArgumentCodec(bindingClass, schema);
- return schema.isUserOrdered() ? new Ordered<>(prototype, keyMethod, codec)
- : new Unordered<>(prototype, keyMethod, codec);
+ final ListRuntimeType type = prototype.getType();
+ final IdentifiableItemCodec codec = prototype.getFactory().getPathArgumentCodec(bindingClass, type);
+
+ return type.statement().ordering() == Ordering.SYSTEM ? new Unordered<>(prototype, keyMethod, codec)
+ : new Ordered<>(prototype, keyMethod, codec);
}
@Override
super.addYangPathArgument(arg, builder);
if (arg instanceof IdentifiableItem) {
- builder.add(codec.serialize((IdentifiableItem<?, ?>) arg));
+ builder.add(codec.bindingToDom((IdentifiableItem<?, ?>) arg));
} else {
// Adding wildcarded
super.addYangPathArgument(arg, builder);
@Override
protected InstanceIdentifier.PathArgument getBindingPathArgument(final YangInstanceIdentifier.PathArgument domArg) {
- if (domArg instanceof NodeIdentifierWithPredicates) {
- return codec.deserialize((NodeIdentifierWithPredicates) domArg);
- }
- return super.getBindingPathArgument(domArg);
+ return domArg instanceof NodeIdentifierWithPredicates
+ ? codec.domToBinding((NodeIdentifierWithPredicates) domArg) : super.getBindingPathArgument(domArg);
}
@SuppressWarnings({ "rawtypes", "unchecked" })
NodeIdentifierWithPredicates serialize(final Identifier<?> key) {
- return codec.serialize(IdentifiableItem.of((Class)getBindingClass(), (Identifier)key));
+ return codec.bindingToDom(IdentifiableItem.of((Class)getBindingClass(), (Identifier)key));
}
@NonNull Identifier<?> deserialize(final NodeIdentifierWithPredicates arg) {
@Override
public YangInstanceIdentifier.PathArgument serializePathArgument(final InstanceIdentifier.PathArgument arg) {
- if (arg instanceof IdentifiableItem) {
- return codec.serialize((IdentifiableItem<?, ?>) arg);
- }
- return super.serializePathArgument(arg);
+ return arg instanceof IdentifiableItem
+ ? codec.bindingToDom((IdentifiableItem<?, ?>) arg) : super.serializePathArgument(arg);
}
@Override
public InstanceIdentifier.PathArgument deserializePathArgument(final YangInstanceIdentifier.PathArgument arg) {
- if (arg instanceof NodeIdentifierWithPredicates) {
- return codec.deserialize((NodeIdentifierWithPredicates) arg);
- }
- return super.deserializePathArgument(arg);
+ return arg instanceof NodeIdentifierWithPredicates
+ ? codec.domToBinding((NodeIdentifierWithPredicates) arg) : super.deserializePathArgument(arg);
}
}