2 * Copyright (c) 2015 Cisco Systems, Inc. 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.yangtools.yang.parser.stmt.rfc6020.effective;
10 import java.util.Collection;
12 import javax.annotation.Nonnull;
13 import org.opendaylight.yangtools.yang.common.QName;
14 import org.opendaylight.yangtools.yang.model.api.TypeDefinition;
15 import org.opendaylight.yangtools.yang.model.api.YangStmtMapping;
16 import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement;
17 import org.opendaylight.yangtools.yang.model.api.meta.IdentifierNamespace;
18 import org.opendaylight.yangtools.yang.model.api.meta.StatementDefinition;
19 import org.opendaylight.yangtools.yang.model.api.meta.StatementSource;
20 import org.opendaylight.yangtools.yang.model.api.stmt.TypeEffectiveStatement;
21 import org.opendaylight.yangtools.yang.model.api.stmt.TypeStatement;
22 import org.opendaylight.yangtools.yang.model.api.stmt.TypedefEffectiveStatement;
23 import org.opendaylight.yangtools.yang.model.api.stmt.TypedefStatement;
24 import org.opendaylight.yangtools.yang.model.util.type.DerivedTypeBuilder;
25 import org.opendaylight.yangtools.yang.model.util.type.DerivedTypes;
26 import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
27 import org.opendaylight.yangtools.yang.parser.spi.source.SourceException;
28 import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.TypeUtils;
29 import org.slf4j.Logger;
30 import org.slf4j.LoggerFactory;
32 public final class TypeDefEffectiveStatementImpl extends AbstractEffectiveSchemaNode<TypedefStatement> implements
33 TypedefEffectiveStatement {
34 private static final Logger LOG = LoggerFactory.getLogger(TypeDefEffectiveStatementImpl.class);
35 private final TypeDefinition<?> typeDefinition;
36 private TypeEffectiveStatement<TypeStatement> typeStatement;
38 public TypeDefEffectiveStatementImpl(final StmtContext<QName, TypedefStatement, ?> ctx) {
41 final TypeEffectiveStatement<?> typeEffectiveStmt = firstSubstatementOfType(TypeEffectiveStatement.class);
42 final DerivedTypeBuilder<?> builder = DerivedTypes.derivedTypeBuilder(typeEffectiveStmt.getTypeDefinition(),
43 ctx.getSchemaPath().get());
44 String defaultValue = null;
45 for (final EffectiveStatement<?, ?> stmt : effectiveSubstatements()) {
46 if (stmt instanceof DefaultEffectiveStatementImpl) {
47 defaultValue = ((DefaultEffectiveStatementImpl) stmt).argument();
48 builder.setDefaultValue(defaultValue);
49 } else if (stmt instanceof DescriptionEffectiveStatementImpl) {
50 builder.setDescription(((DescriptionEffectiveStatementImpl)stmt).argument());
51 } else if (stmt instanceof ReferenceEffectiveStatementImpl) {
52 builder.setReference(((ReferenceEffectiveStatementImpl)stmt).argument());
53 } else if (stmt instanceof StatusEffectiveStatementImpl) {
54 builder.setStatus(((StatusEffectiveStatementImpl)stmt).argument());
55 } else if (stmt instanceof UnitsEffectiveStatementImpl) {
56 builder.setUnits(((UnitsEffectiveStatementImpl)stmt).argument());
57 } else if (stmt instanceof UnknownEffectiveStatementImpl) {
58 // FIXME: should not directly implement, I think
59 builder.addUnknownSchemaNode((UnknownEffectiveStatementImpl)stmt);
61 if (!(stmt instanceof TypeEffectiveStatement)) {
62 LOG.debug("Ignoring statement {}", stmt);
69 .throwIf(TypeUtils.hasDefaultValueMarkedWithIfFeature(ctx.getRootVersion(), typeEffectiveStmt,
70 defaultValue), ctx.getStatementSourceReference(),
71 "Typedef '%s' has default value '%s' marked with an if-feature statement.", ctx
72 .getStatementArgument(), defaultValue);
73 } catch (final IllegalStateException e) {
74 throw new SourceException(ctx.getStatementSourceReference(), e,
75 "Unable to find a default value for typedef '%s'", ctx.getStatementArgument());
78 typeDefinition = builder.build();
83 public TypeDefinition<?> getTypeDefinition() {
84 return typeDefinition;
87 public TypeEffectiveStatement<TypeStatement> asTypeEffectiveStatement() {
88 TypeEffectiveStatement<TypeStatement> ret = typeStatement;
93 ret = new ProxyTypeEffectiveStatement();
102 private final class ProxyTypeEffectiveStatement implements TypeEffectiveStatement<TypeStatement> {
104 public TypeStatement getDeclared() {
109 public <K, V, N extends IdentifierNamespace<K, V>> V get(@Nonnull final Class<N> namespace, @Nonnull final K identifier) {
110 return TypeDefEffectiveStatementImpl.this.get(namespace, identifier);
114 public <K, V, N extends IdentifierNamespace<K, V>> Map<K, V> getAll(@Nonnull final Class<N> namespace) {
115 return TypeDefEffectiveStatementImpl.this.getAll(namespace);
120 public Collection<? extends EffectiveStatement<?, ?>> effectiveSubstatements() {
121 return TypeDefEffectiveStatementImpl.this.effectiveSubstatements();
126 public StatementDefinition statementDefinition() {
127 return YangStmtMapping.TYPE;
131 public String argument() {
132 return getQName().getLocalName();
137 public StatementSource getStatementSource() {
138 return StatementSource.CONTEXT;
143 public TypeDefinition<?> getTypeDefinition() {
144 return TypeDefEffectiveStatementImpl.this.getTypeDefinition();