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;
11 import static org.opendaylight.mdsal.binding.model.ri.BindingTypes.BASE_IDENTITY;
13 import java.util.List;
14 import java.util.stream.Collectors;
15 import org.opendaylight.mdsal.binding.generator.impl.rt.DefaultIdentityRuntimeType;
16 import org.opendaylight.mdsal.binding.model.api.GeneratedType;
17 import org.opendaylight.mdsal.binding.model.api.Type;
18 import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilder;
19 import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilderBase;
20 import org.opendaylight.mdsal.binding.runtime.api.IdentityRuntimeType;
21 import org.opendaylight.mdsal.binding.spec.naming.BindingMapping;
22 import org.opendaylight.yangtools.yang.binding.BaseIdentity;
23 import org.opendaylight.yangtools.yang.model.api.stmt.BaseEffectiveStatement;
24 import org.opendaylight.yangtools.yang.model.api.stmt.IdentityEffectiveStatement;
25 import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
28 * Generator corresponding to a {@code identity} statement.
30 public final class IdentityGenerator
31 extends AbstractDependentGenerator<IdentityEffectiveStatement, IdentityRuntimeType> {
32 private List<IdentityGenerator> baseIdentities = null;
34 IdentityGenerator(final IdentityEffectiveStatement statement, final AbstractCompositeGenerator<?, ?> parent) {
35 super(statement, parent);
39 StatementNamespace namespace() {
40 return StatementNamespace.IDENTITY;
44 void pushToInference(final SchemaInferenceStack dataTree) {
45 throw new UnsupportedOperationException("Cannot push " + statement() + " to data tree");
49 void linkDependencies(final GeneratorContext context) {
50 baseIdentities = statement().streamEffectiveSubstatements(BaseEffectiveStatement.class)
51 .map(BaseEffectiveStatement::argument)
52 .map(context::resolveIdentity)
53 .collect(Collectors.toUnmodifiableList());
57 GeneratedType createTypeImpl(final TypeBuilderFactory builderFactory) {
58 final GeneratedTypeBuilder builder = builderFactory.newGeneratedTypeBuilder(typeName());
59 if (!baseIdentities.isEmpty()) {
60 for (IdentityGenerator baseIdentity : baseIdentities) {
61 builder.addImplementsType(baseIdentity.getGeneratedType(builderFactory));
64 builder.addImplementsType(BASE_IDENTITY);
67 narrowImplementedInterface(builder);
69 final ModuleGenerator module = currentModule();
70 module.addQNameConstant(builder, localName());
72 // Constant implementation
73 builder.addConstant(Type.of(builder), BindingMapping.VALUE_STATIC_FIELD_NAME, BaseIdentity.class);
75 builderFactory.addCodegenInformation(module, statement(), builder);
76 builder.setModuleName(module.statement().argument().getLocalName());
77 // builder.setSchemaPath(identity.getPath());
79 return builder.build();
83 GeneratedType runtimeJavaType() {
84 return generatedType().orElse(null);
88 IdentityRuntimeType createExternalRuntimeType(final Type type) {
89 verify(type instanceof GeneratedType, "Unexpected type %s", type);
90 return new DefaultIdentityRuntimeType((GeneratedType) type, statement());
94 IdentityRuntimeType createInternalRuntimeType(final AugmentResolver resolver,
95 final IdentityEffectiveStatement statement, final Type type) {
96 // 'identity' statements are not part of schema tree and hence should never an internal reference
97 throw new UnsupportedOperationException("Should never be called");
101 void addAsGetterMethod(final GeneratedTypeBuilderBase<?> builder, final TypeBuilderFactory builderFactory) {
102 // identities are a separate concept