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 org.opendaylight.mdsal.binding.model.ri.BindingTypes.BASE_IDENTITY;
12 import java.util.List;
13 import java.util.stream.Collectors;
14 import org.opendaylight.mdsal.binding.generator.impl.rt.DefaultIdentityRuntimeType;
15 import org.opendaylight.mdsal.binding.model.api.GeneratedType;
16 import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilder;
17 import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilderBase;
18 import org.opendaylight.mdsal.binding.runtime.api.IdentityRuntimeType;
19 import org.opendaylight.yangtools.yang.model.api.stmt.BaseEffectiveStatement;
20 import org.opendaylight.yangtools.yang.model.api.stmt.IdentityEffectiveStatement;
21 import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
24 * Generator corresponding to a {@code identity} statement.
26 public final class IdentityGenerator
27 extends AbstractDependentGenerator<IdentityEffectiveStatement, IdentityRuntimeType> {
28 private List<IdentityGenerator> baseIdentities = null;
30 IdentityGenerator(final IdentityEffectiveStatement statement, final AbstractCompositeGenerator<?, ?> parent) {
31 super(statement, parent);
35 StatementNamespace namespace() {
36 return StatementNamespace.IDENTITY;
40 void pushToInference(final SchemaInferenceStack dataTree) {
41 throw new UnsupportedOperationException("Cannot push " + statement() + " to data tree");
45 void linkDependencies(final GeneratorContext context) {
46 baseIdentities = statement().streamEffectiveSubstatements(BaseEffectiveStatement.class)
47 .map(BaseEffectiveStatement::argument)
48 .map(context::resolveIdentity)
49 .collect(Collectors.toUnmodifiableList());
53 GeneratedType createTypeImpl(final TypeBuilderFactory builderFactory) {
54 final GeneratedTypeBuilder builder = builderFactory.newGeneratedTypeBuilder(typeName());
55 if (!baseIdentities.isEmpty()) {
56 for (IdentityGenerator baseIdentity : baseIdentities) {
57 builder.addImplementsType(baseIdentity.getGeneratedType(builderFactory));
60 builder.addImplementsType(BASE_IDENTITY);
63 final ModuleGenerator module = currentModule();
64 module.addQNameConstant(builder, localName());
66 builderFactory.addCodegenInformation(module, statement(), builder);
67 builder.setModuleName(module.statement().argument().getLocalName());
68 // builder.setSchemaPath(identity.getPath());
70 return builder.build();
74 IdentityRuntimeType createRuntimeType() {
75 return generatedType().map(type -> new DefaultIdentityRuntimeType(type, statement())).orElse(null);
79 IdentityRuntimeType rebaseRuntimeType(final IdentityRuntimeType type, final IdentityEffectiveStatement statement) {
80 return new DefaultIdentityRuntimeType(type.javaType(), statement);
84 void addAsGetterMethod(final GeneratedTypeBuilderBase<?> builder, final TypeBuilderFactory builderFactory) {
85 // identities are a separate concept