2 * Copyright (c) 2021 PANTHEON.tech, s.r.o. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.mdsal.binding.generator.impl.reactor;
10 import org.opendaylight.mdsal.binding.model.api.ConcreteType;
11 import org.opendaylight.mdsal.binding.model.api.GeneratedType;
12 import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilder;
13 import org.opendaylight.mdsal.binding.model.ri.BindingTypes;
14 import org.opendaylight.yangtools.yang.model.api.stmt.InputEffectiveStatement;
15 import org.opendaylight.yangtools.yang.model.api.stmt.OutputEffectiveStatement;
16 import org.opendaylight.yangtools.yang.model.api.stmt.SchemaTreeEffectiveStatement;
17 import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
20 * Generator corresponding to an {@code input} or an {@code output} statement.
22 class OperationContainerGenerator extends AbstractCompositeGenerator<SchemaTreeEffectiveStatement<?>> {
23 private final ConcreteType baseInterface;
25 OperationContainerGenerator(final InputEffectiveStatement statement, final AbstractCompositeGenerator<?> parent) {
26 super(statement, parent);
27 baseInterface = BindingTypes.RPC_INPUT;
30 OperationContainerGenerator(final OutputEffectiveStatement statement, final AbstractCompositeGenerator<?> parent) {
31 super(statement, parent);
32 baseInterface = BindingTypes.RPC_OUTPUT;
36 final void pushToInference(final SchemaInferenceStack dataTree) {
37 dataTree.enterSchemaTree(statement().getIdentifier());
41 final GeneratedType createTypeImpl(final TypeBuilderFactory builderFactory) {
42 final AbstractCompositeGenerator<?> parent = getParent();
43 if (parent instanceof ActionGenerator && ((ActionGenerator) parent).isAddedByUses()) {
44 // final ActionDefinition orig = findOrigAction(parentSchema, action).get();
45 // // Original definition may live in a different module, make sure we account for that
46 // final ModuleContext origContext = moduleContext(
47 // orig.getPath().getPathFromRoot().iterator().next().getModule());
48 // input = context.addAliasType(origContext, orig.getInput(), action.getInput());
49 // output = context.addAliasType(origContext, orig.getOutput(), action.getOutput());
51 throw new UnsupportedOperationException("Lookup in original");
54 final GeneratedTypeBuilder builder = builderFactory.newGeneratedTypeBuilder(typeName());
55 builder.addImplementsType(baseInterface);
56 addAugmentable(builder);
58 addUsesInterfaces(builder, builderFactory);
59 addConcreteInterfaceMethods(builder);
60 addGetterMethods(builder, builderFactory);
62 final ModuleGenerator module = currentModule();
63 module.addQNameConstant(builder, localName());
65 annotateDeprecatedIfNecessary(builder);
66 builderFactory.addCodegenInformation(module, statement(), builder);
67 // builder.setSchemaPath(schemaNode.getPath());
68 builder.setModuleName(module.statement().argument().getLocalName());
70 return builder.build();