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 org.opendaylight.yangtools.yang.model.api.YangStmtMapping;
11 import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement;
12 import org.opendaylight.yangtools.yang.model.api.stmt.TypeStatement.Decimal64Specification;
13 import org.opendaylight.yangtools.yang.parser.spi.meta.AbstractStatementSupport;
14 import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
15 import org.opendaylight.yangtools.yang.parser.spi.meta.SubstatementValidator;
17 final class Decimal64SpecificationSupport extends AbstractStatementSupport<String, Decimal64Specification,
18 EffectiveStatement<String, Decimal64Specification>> {
19 private static final SubstatementValidator SUBSTATEMENT_VALIDATOR = SubstatementValidator.builder(
21 .addMandatory(YangStmtMapping.FRACTION_DIGITS)
22 .addOptional(YangStmtMapping.RANGE)
25 Decimal64SpecificationSupport() {
26 super(YangStmtMapping.TYPE);
30 public String parseArgumentValue(final StmtContext<?, ?, ?> ctx, final String value) {
35 public Decimal64Specification createDeclared(final StmtContext<String, Decimal64Specification, ?> ctx) {
36 return new Decimal64SpecificationImpl(ctx);
40 public EffectiveStatement<String, Decimal64Specification> createEffective(final StmtContext<String,
41 Decimal64Specification, EffectiveStatement<String, Decimal64Specification>> ctx) {
42 return new Decimal64SpecificationEffectiveStatement(ctx);
46 protected SubstatementValidator getSubstatementValidator() {
47 return SUBSTATEMENT_VALIDATOR;