/* * Copyright (c) 2021 PANTHEON.tech, s.r.o. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.mdsal.binding.generator.impl.reactor; import static org.opendaylight.mdsal.binding.model.ri.BindingTypes.BASE_IDENTITY; import java.util.List; import java.util.stream.Collectors; import org.opendaylight.mdsal.binding.generator.impl.rt.DefaultIdentityRuntimeType; import org.opendaylight.mdsal.binding.model.api.GeneratedType; import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilder; import org.opendaylight.mdsal.binding.model.api.type.builder.GeneratedTypeBuilderBase; import org.opendaylight.mdsal.binding.runtime.api.IdentityRuntimeType; import org.opendaylight.yangtools.yang.model.api.stmt.BaseEffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.IdentityEffectiveStatement; import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack; /** * Generator corresponding to a {@code identity} statement. */ public final class IdentityGenerator extends AbstractDependentGenerator { private List baseIdentities = null; IdentityGenerator(final IdentityEffectiveStatement statement, final AbstractCompositeGenerator parent) { super(statement, parent); } @Override StatementNamespace namespace() { return StatementNamespace.IDENTITY; } @Override void pushToInference(final SchemaInferenceStack dataTree) { throw new UnsupportedOperationException("Cannot push " + statement() + " to data tree"); } @Override void linkDependencies(final GeneratorContext context) { baseIdentities = statement().streamEffectiveSubstatements(BaseEffectiveStatement.class) .map(BaseEffectiveStatement::argument) .map(context::resolveIdentity) .collect(Collectors.toUnmodifiableList()); } @Override GeneratedType createTypeImpl(final TypeBuilderFactory builderFactory) { final GeneratedTypeBuilder builder = builderFactory.newGeneratedTypeBuilder(typeName()); if (!baseIdentities.isEmpty()) { for (IdentityGenerator baseIdentity : baseIdentities) { builder.addImplementsType(baseIdentity.getGeneratedType(builderFactory)); } } else { builder.addImplementsType(BASE_IDENTITY); } final ModuleGenerator module = currentModule(); module.addQNameConstant(builder, localName()); builderFactory.addCodegenInformation(module, statement(), builder); builder.setModuleName(module.statement().argument().getLocalName()); // builder.setSchemaPath(identity.getPath()); return builder.build(); } @Override IdentityRuntimeType createRuntimeType() { return generatedType().map(type -> new DefaultIdentityRuntimeType(type, statement())).orElse(null); } @Override IdentityRuntimeType rebaseRuntimeType(final IdentityRuntimeType type, final IdentityEffectiveStatement statement) { return new DefaultIdentityRuntimeType(type.javaType(), statement); } @Override void addAsGetterMethod(final GeneratedTypeBuilderBase builder, final TypeBuilderFactory builderFactory) { // identities are a separate concept } }