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 java.util.List;
11 import org.opendaylight.mdsal.binding.generator.impl.rt.DefaultContainerRuntimeType;
12 import org.opendaylight.mdsal.binding.runtime.api.AugmentRuntimeType;
13 import org.opendaylight.mdsal.binding.runtime.api.ContainerRuntimeType;
14 import org.opendaylight.mdsal.binding.runtime.api.RuntimeType;
15 import org.opendaylight.yangtools.binding.lib.contract.Naming;
16 import org.opendaylight.yangtools.binding.lib.contract.StatementNamespace;
17 import org.opendaylight.yangtools.binding.model.api.GeneratedType;
18 import org.opendaylight.yangtools.binding.model.api.MethodSignature.ValueMechanics;
19 import org.opendaylight.yangtools.binding.model.api.Type;
20 import org.opendaylight.yangtools.binding.model.api.type.builder.GeneratedTypeBuilder;
21 import org.opendaylight.yangtools.binding.model.api.type.builder.GeneratedTypeBuilderBase;
22 import org.opendaylight.yangtools.binding.model.api.type.builder.MethodSignatureBuilder;
23 import org.opendaylight.yangtools.yang.model.api.stmt.ContainerEffectiveStatement;
24 import org.opendaylight.yangtools.yang.model.api.stmt.PresenceEffectiveStatement;
25 import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
28 * Generator corresponding to a {@code container} statement.
30 final class ContainerGenerator extends CompositeSchemaTreeGenerator<ContainerEffectiveStatement, ContainerRuntimeType> {
31 ContainerGenerator(final ContainerEffectiveStatement statement, final AbstractCompositeGenerator<?, ?> parent) {
32 super(statement, parent);
36 StatementNamespace namespace() {
37 return StatementNamespace.CONTAINER;
41 void pushToInference(final SchemaInferenceStack dataTree) {
42 dataTree.enterDataTree(statement().argument());
46 GeneratedType createTypeImpl(final TypeBuilderFactory builderFactory) {
47 final GeneratedTypeBuilder builder = builderFactory.newGeneratedTypeBuilder(typeName());
48 addImplementsChildOf(builder);
49 addAugmentable(builder);
50 addUsesInterfaces(builder, builderFactory);
51 addConcreteInterfaceMethods(builder);
53 final ModuleGenerator module = currentModule();
54 module.addQNameConstant(builder, localName());
56 addGetterMethods(builder, builderFactory);
58 annotateDeprecatedIfNecessary(builder);
59 builderFactory.addCodegenInformation(module, statement(), builder);
60 builder.setModuleName(module.statement().argument().getLocalName());
61 // builder.setSchemaPath(node.getPath());
63 return builder.build();
67 CompositeRuntimeTypeBuilder<ContainerEffectiveStatement, ContainerRuntimeType> createBuilder(
68 final ContainerEffectiveStatement statement) {
69 return new CompositeRuntimeTypeBuilder<>(statement) {
71 ContainerRuntimeType build(final GeneratedType type, final ContainerEffectiveStatement statement,
72 final List<RuntimeType> children, final List<AugmentRuntimeType> augments) {
73 return new DefaultContainerRuntimeType(type, statement, children, augments);
79 MethodSignatureBuilder constructGetter(final GeneratedTypeBuilderBase<?> builder, final Type returnType) {
80 final MethodSignatureBuilder ret = super.constructGetter(builder, returnType)
81 .setMechanics(ValueMechanics.NORMAL);
82 if (statement().findFirstEffectiveSubstatement(PresenceEffectiveStatement.class).isEmpty()) {
83 final MethodSignatureBuilder nonnull = builder
84 .addMethod(Naming.getNonnullMethodName(localName().getLocalName()))
85 .setReturnType(returnType)
87 annotateDeprecatedIfNecessary(nonnull);