*/
package org.opendaylight.mdsal.binding.dom.codec.impl;
-import com.google.common.base.Preconditions;
+import static com.google.common.base.Preconditions.checkArgument;
+import static com.google.common.base.Preconditions.checkState;
+
import java.util.List;
+import org.opendaylight.mdsal.binding.runtime.api.CaseRuntimeType;
import org.opendaylight.yangtools.yang.binding.DataObject;
+import org.opendaylight.yangtools.yang.binding.InstanceIdentifier.Item;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier.PathArgument;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
import org.opendaylight.yangtools.yang.data.api.schema.ChoiceNode;
import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
-import org.opendaylight.yangtools.yang.model.api.ChoiceCaseNode;
+import org.opendaylight.yangtools.yang.model.api.AddedByUsesAware;
+import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement;
-final class CaseNodeCodecContext<D extends DataObject> extends DataObjectCodecContext<D,ChoiceCaseNode> {
- CaseNodeCodecContext(final DataContainerCodecPrototype<ChoiceCaseNode> prototype) {
+final class CaseNodeCodecContext<D extends DataObject> extends DataObjectCodecContext<D, CaseRuntimeType> {
+ CaseNodeCodecContext(final DataContainerCodecPrototype<CaseRuntimeType> prototype) {
super(prototype);
}
+ @Override
+ @SuppressWarnings({ "unchecked", "rawtypes" })
+ Item<?> createBindingArg(final Class<?> childClass, final EffectiveStatement<?, ?> childSchema) {
+ // FIXME: MDSAL-697: see overridden method for further guidance
+ return childSchema instanceof AddedByUsesAware && ((AddedByUsesAware) childSchema).isAddedByUses()
+ ? Item.of((Class)getBindingClass(), (Class)childClass)
+ : super.createBindingArg(childClass, childSchema);
+ }
+
@Override
protected void addYangPathArgument(final PathArgument arg,
final List<YangInstanceIdentifier.PathArgument> builder) {
}
@Override
- public D deserialize(final NormalizedNode<?, ?> normalizedNode) {
- Preconditions.checkState(normalizedNode instanceof ChoiceNode);
- return createBindingProxy((ChoiceNode) normalizedNode);
+ public D deserialize(final NormalizedNode data) {
+ checkState(data instanceof ChoiceNode, "Unexpected data %s", data);
+ return createBindingProxy((ChoiceNode) data);
}
@Override
- protected Object deserializeObject(final NormalizedNode<?, ?> normalizedNode) {
+ protected Object deserializeObject(final NormalizedNode normalizedNode) {
return deserialize(normalizedNode);
}
@Override
public YangInstanceIdentifier.PathArgument serializePathArgument(final PathArgument arg) {
- Preconditions.checkArgument(arg == null);
+ checkArgument(arg == null, "Unexpected argument %s", arg);
return null;
}
@Override
public PathArgument deserializePathArgument(final YangInstanceIdentifier.PathArgument arg) {
- Preconditions.checkArgument(arg == null);
+ checkArgument(arg == null, "Unexpected argument %s", arg);
return null;
}
-}
\ No newline at end of file
+}