bd3ea607ae0131f2572a4e7c1f7071cbbce0de71
[mdsal.git] / binding / mdsal-binding-generator / src / main / java / org / opendaylight / mdsal / binding / generator / impl / reactor / OperationContainerGenerator.java
1 /*
2  * Copyright (c) 2021 PANTHEON.tech, s.r.o. and others.  All rights reserved.
3  *
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
7  */
8 package org.opendaylight.mdsal.binding.generator.impl.reactor;
9
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;
18
19 /**
20  * Generator corresponding to an {@code input} or an {@code output} statement.
21  */
22 class OperationContainerGenerator extends AbstractCompositeGenerator<SchemaTreeEffectiveStatement<?>> {
23     private final ConcreteType baseInterface;
24
25     OperationContainerGenerator(final InputEffectiveStatement statement, final AbstractCompositeGenerator<?> parent) {
26         super(statement, parent);
27         baseInterface = BindingTypes.RPC_INPUT;
28     }
29
30     OperationContainerGenerator(final OutputEffectiveStatement statement, final AbstractCompositeGenerator<?> parent) {
31         super(statement, parent);
32         baseInterface = BindingTypes.RPC_OUTPUT;
33     }
34
35     @Override
36     final void pushToInference(final SchemaInferenceStack dataTree) {
37         dataTree.enterSchemaTree(statement().getIdentifier());
38     }
39
40     @Override
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());
50
51             throw new UnsupportedOperationException("Lookup in original");
52         }
53
54         final GeneratedTypeBuilder builder = builderFactory.newGeneratedTypeBuilder(typeName());
55         builder.addImplementsType(baseInterface);
56         addAugmentable(builder);
57
58         addUsesInterfaces(builder, builderFactory);
59         addConcreteInterfaceMethods(builder);
60         addGetterMethods(builder, builderFactory);
61
62         final ModuleGenerator module = currentModule();
63         module.addQNameConstant(builder, localName());
64
65         annotateDeprecatedIfNecessary(builder);
66         builderFactory.addCodegenInformation(module, statement(), builder);
67 //                builder.setSchemaPath(schemaNode.getPath());
68         builder.setModuleName(module.statement().argument().getLocalName());
69
70         return builder.build();
71     }
72 }