2 * Copyright (c) 2017 Pantheon Technologies, 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.yangtools.yang.parser.rfc7950.stmt.type;
10 import com.google.common.collect.ImmutableList;
11 import org.opendaylight.yangtools.yang.model.api.YangStmtMapping;
12 import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
13 import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement;
14 import org.opendaylight.yangtools.yang.model.api.stmt.FractionDigitsEffectiveStatement;
15 import org.opendaylight.yangtools.yang.model.api.stmt.RangeEffectiveStatement;
16 import org.opendaylight.yangtools.yang.model.api.stmt.TypeStatement.Decimal64Specification;
17 import org.opendaylight.yangtools.yang.model.util.type.BaseTypes;
18 import org.opendaylight.yangtools.yang.model.util.type.DecimalTypeBuilder;
19 import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractStatementSupport;
20 import org.opendaylight.yangtools.yang.parser.spi.meta.CommonStmtCtx;
21 import org.opendaylight.yangtools.yang.parser.spi.meta.EffectiveStmtCtx.Current;
22 import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
23 import org.opendaylight.yangtools.yang.parser.spi.meta.SubstatementValidator;
24 import org.opendaylight.yangtools.yang.parser.spi.source.SourceException;
26 final class Decimal64SpecificationSupport extends AbstractStatementSupport<String, Decimal64Specification,
27 EffectiveStatement<String, Decimal64Specification>> {
28 private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = SubstatementValidator.builder(
30 .addMandatory(YangStmtMapping.FRACTION_DIGITS)
31 .addOptional(YangStmtMapping.RANGE)
34 Decimal64SpecificationSupport() {
35 super(YangStmtMapping.TYPE, StatementPolicy.legacyDeclaredCopy());
39 public String parseArgumentValue(final StmtContext<?, ?, ?> ctx, final String value) {
44 protected SubstatementValidator getSubstatementValidator() {
45 return SUBSTATEMENT_VALIDATOR;
49 protected Decimal64Specification createDeclared(final StmtContext<String, Decimal64Specification, ?> ctx,
50 final ImmutableList<? extends DeclaredStatement<?>> substatements) {
51 return new Decimal64SpecificationImpl(ctx.getRawArgument(), substatements);
55 protected Decimal64Specification createEmptyDeclared(final StmtContext<String, Decimal64Specification, ?> ctx) {
56 throw noFracDigits(ctx);
60 protected EffectiveStatement<String, Decimal64Specification> createEffective(
61 final Current<String, Decimal64Specification> stmt,
62 final ImmutableList<? extends EffectiveStatement<?, ?>> substatements) {
63 if (substatements.isEmpty()) {
64 throw noFracDigits(stmt);
67 final DecimalTypeBuilder builder = BaseTypes.decimalTypeBuilder(stmt.wrapSchemaPath());
68 for (final EffectiveStatement<?, ?> subStmt : substatements) {
69 if (subStmt instanceof FractionDigitsEffectiveStatement) {
70 builder.setFractionDigits(((FractionDigitsEffectiveStatement) subStmt).argument());
72 if (subStmt instanceof RangeEffectiveStatement) {
73 final RangeEffectiveStatement range = (RangeEffectiveStatement) subStmt;
74 builder.setRangeConstraint(range, range.argument());
78 return new TypeEffectiveStatementImpl<>(stmt.declared(), substatements, builder);
81 private static SourceException noFracDigits(final CommonStmtCtx stmt) {
83 * https://tools.ietf.org/html/rfc7950#section-9.3.4
85 * The "fraction-digits" statement, which is a substatement to the
86 * "type" statement, MUST be present if the type is "decimal64".
88 return new SourceException("At least one fraction-digits statement has to be present", stmt);