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.util.BindingTypes;
18 import org.opendaylight.yangtools.odlext.model.api.ContextReferenceEffectiveStatement;
19 import org.opendaylight.yangtools.yang.model.api.TypeAware;
20 import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
21 import org.opendaylight.yangtools.yang.model.api.TypedDataSchemaNode;
22 import org.opendaylight.yangtools.yang.model.api.stmt.DataTreeEffectiveStatement;
23 import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
28 * Common base class for {@link LeafGenerator} and {@link LeafListGenerator}.
30 abstract class AbstractTypeAwareGenerator<T extends DataTreeEffectiveStatement<?>>
31 extends AbstractTypeObjectGenerator<T> {
32 private static final Logger LOG = LoggerFactory.getLogger(AbstractTypeAwareGenerator.class);
34 private IdentityGenerator contextType;
36 AbstractTypeAwareGenerator(final T statement, final AbstractCompositeGenerator<?> parent) {
37 super(statement, parent);
38 verify(statement instanceof TypeAware, "Unexpected statement %s", statement);
42 final void pushToInference(final SchemaInferenceStack dataTree) {
43 dataTree.enterDataTree(statement().getIdentifier());
47 final void bindDerivedGenerators(final TypeReference reference) {
52 final void bindTypeDefinition(final GeneratorContext context) {
53 super.bindTypeDefinition(context);
54 contextType = statement().findFirstEffectiveSubstatementArgument(ContextReferenceEffectiveStatement.class)
55 .map(context::resolveIdentity)
60 final TypeDefinition<?> extractTypeDefinition() {
61 return ((TypedDataSchemaNode) statement()).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 void constructRequire(final GeneratedTypeBuilderBase<?> builder, final Type returnType) {
90 constructRequireImpl(builder, returnType);