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 static com.google.common.base.Verify.verify;
12 import org.opendaylight.mdsal.binding.model.api.GeneratedTransferObject;
13 import org.opendaylight.mdsal.binding.model.api.JavaTypeName;
14 import org.opendaylight.mdsal.binding.model.api.Type;
15 import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilderBase;
16 import org.opendaylight.mdsal.binding.model.api.type.builder.MethodSignatureBuilder;
17 import org.opendaylight.mdsal.binding.model.ri.BindingTypes;
18 import org.opendaylight.mdsal.binding.runtime.api.RuntimeType;
19 import org.opendaylight.yangtools.odlext.model.api.ContextReferenceEffectiveStatement;
20 import org.opendaylight.yangtools.yang.model.api.TypeAware;
21 import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
22 import org.opendaylight.yangtools.yang.model.api.TypedDataSchemaNode;
23 import org.opendaylight.yangtools.yang.model.api.stmt.DataTreeEffectiveStatement;
24 import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
27 * Common base class for {@link LeafGenerator} and {@link LeafListGenerator}.
29 abstract class AbstractTypeAwareGenerator<T extends DataTreeEffectiveStatement<?>, R extends RuntimeType,
30 G extends AbstractTypeAwareGenerator<T, R, G>>
31 extends AbstractTypeObjectGenerator<T, R> {
32 private IdentityGenerator contextType;
34 AbstractTypeAwareGenerator(final T statement, final AbstractCompositeGenerator<?, ?> parent) {
35 super(statement, parent);
36 verify(statement instanceof TypeAware, "Unexpected statement %s", statement);
40 final void pushToInference(final SchemaInferenceStack dataTree) {
41 dataTree.enterDataTree(statement().getIdentifier());
45 final void bindDerivedGenerators(final TypeReference reference) {
50 final void bindTypeDefinition(final GeneratorContext context) {
51 super.bindTypeDefinition(context);
52 contextType = statement().findFirstEffectiveSubstatementArgument(ContextReferenceEffectiveStatement.class)
53 .map(context::resolveIdentity)
58 final TypeDefinition<?> extractTypeDefinition() {
59 final var stmt = statement();
60 verify(stmt instanceof TypedDataSchemaNode, "Unexpected statement %s", stmt);
61 return ((TypedDataSchemaNode) stmt).getType();
65 final JavaTypeName createTypeName() {
66 // FIXME: we should be be assigning a non-conflict name here
67 return getParent().typeName().createEnclosed(assignedName(), "$");
71 final GeneratedTransferObject createDerivedType(final TypeBuilderFactory builderFactory,
72 final GeneratedTransferObject baseType) {
73 throw new UnsupportedOperationException();
77 final MethodSignatureBuilder constructGetter(final GeneratedTypeBuilderBase<?> builder, final Type returnType) {
78 final MethodSignatureBuilder ret = super.constructGetter(builder, returnType);
80 if (contextType != null) {
81 ret.addAnnotation(BindingTypes.ROUTING_CONTEXT)
82 .addParameter("value", contextType.typeName().toString() + ".class");
89 final void constructRequire(final GeneratedTypeBuilderBase<?> builder, final Type returnType) {
90 constructRequireImpl(builder, returnType);