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.eclipse.jdt.annotation.NonNull;
11 import org.opendaylight.mdsal.binding.model.api.GeneratedType;
12 import org.opendaylight.mdsal.binding.model.api.Type;
13 import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilder;
14 import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilderBase;
15 import org.opendaylight.mdsal.binding.model.ri.BindingTypes;
16 import org.opendaylight.yangtools.yang.model.api.stmt.ActionEffectiveStatement;
17 import org.opendaylight.yangtools.yang.model.api.stmt.InputEffectiveStatement;
18 import org.opendaylight.yangtools.yang.model.api.stmt.OutputEffectiveStatement;
19 import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
22 * Generator corresponding to a {@code action} statement.
24 final class ActionGenerator extends AbstractCompositeGenerator<ActionEffectiveStatement> {
25 ActionGenerator(final ActionEffectiveStatement statement, final AbstractCompositeGenerator<?> parent) {
26 super(statement, parent);
30 void pushToInference(final SchemaInferenceStack dataTree) {
31 dataTree.enterSchemaTree(statement().getIdentifier());
35 ClassPlacement classPlacement() {
36 // We do not generate Actions for groupings as they are inexact, and do not capture an actual instantiation --
37 // therefore they do not have an InstanceIdentifier. We still need to allocate a package name for the purposes
38 // of generating shared classes for input/output
39 return getParent() instanceof GroupingGenerator ? ClassPlacement.PHANTOM : ClassPlacement.TOP_LEVEL;
43 GeneratedType createTypeImpl(final TypeBuilderFactory builderFactory) {
44 final GeneratedTypeBuilder builder = builderFactory.newGeneratedTypeBuilder(typeName());
45 builder.addImplementsType(implementedType(builderFactory));
47 final ModuleGenerator module = currentModule();
48 module.addQNameConstant(builder, statement().argument());
50 // addGetterMethods(builder, builderFactory);
52 annotateDeprecatedIfNecessary(builder);
53 if (builderFactory instanceof TypeBuilderFactory.Codegen) {
54 addCodegenInformation(module, statement(), builder);
57 return builder.build();
60 private @NonNull Type implementedType(final TypeBuilderFactory builderFactory) {
61 final GeneratedType input = getChild(this, InputEffectiveStatement.class).getOriginal()
62 .getGeneratedType(builderFactory);
63 final GeneratedType output = getChild(this, OutputEffectiveStatement.class).getOriginal()
64 .getGeneratedType(builderFactory);
66 final AbstractCompositeGenerator<?> parent = getParent();
67 if (parent instanceof ListGenerator) {
68 final KeyGenerator keyGen = ((ListGenerator) parent).keyGenerator();
70 return BindingTypes.keyedListAction(Type.of(parent.typeName()), keyGen.getGeneratedType(builderFactory),
75 return BindingTypes.action(Type.of(parent.typeName()), input, output);
79 void addAsGetterMethod(final GeneratedTypeBuilderBase<?> builder, final TypeBuilderFactory builderFactory) {
80 // actions are a separate concept