Allow base type builders to be used fluently
[yangtools.git] / yang / yang-model-util / src / main / java / org / opendaylight / yangtools / yang / model / util / type / StringTypeBuilder.java
1 /*
2  * Copyright (c) 2015 Pantheon Technologies s.r.o. and others.  All rights reserved.
3  *
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
7  */
8 package org.opendaylight.yangtools.yang.model.util.type;
9
10 import com.google.common.base.Preconditions;
11 import java.util.ArrayList;
12 import java.util.List;
13 import org.opendaylight.yangtools.yang.model.api.SchemaPath;
14 import org.opendaylight.yangtools.yang.model.api.type.LengthConstraint;
15 import org.opendaylight.yangtools.yang.model.api.type.PatternConstraint;
16 import org.opendaylight.yangtools.yang.model.api.type.StringTypeDefinition;
17
18 public final class StringTypeBuilder extends LengthRestrictedTypeBuilder<StringTypeDefinition> {
19     private final List<PatternConstraint> patternConstraints = new ArrayList<>(0);
20
21     StringTypeBuilder(final StringTypeDefinition baseType, final SchemaPath path) {
22         super(baseType, path);
23     }
24
25     public StringTypeBuilder addPatternConstraint(final PatternConstraint constraint) {
26         patternConstraints.add(Preconditions.checkNotNull(constraint));
27         touch();
28         return this;
29     }
30
31     @Override
32     List<LengthConstraint> getLengthConstraints(final StringTypeDefinition type) {
33         return type.getLengthConstraints();
34     }
35
36     @Override
37     List<LengthConstraint> typeLengthConstraints() {
38         /**
39          * Length constraint imposed on YANG string type by our implementation. {@link String#length()} is an integer,
40          * capping our ability to support strings up to 18446744073709551615 as defined in
41          * http://tools.ietf.org/html/rfc6020#section-9.4.4.
42          *
43          * FIXME: We could bump this number up to allow such models, but that could lead to unexpected run-time errors.
44          *        In order to do that, the parser would need another pass on the effective statements, which would cap
45          *        the constraints to the run-time environment.
46          */
47         return JavaLengthConstraints.INTEGER_SIZE_CONSTRAINTS;
48     }
49
50     @Override
51     StringTypeDefinition buildType(final List<LengthConstraint> lengthConstraints) {
52         return new RestrictedStringType(getBaseType(), getPath(), getUnknownSchemaNodes(),
53             lengthConstraints, patternConstraints);
54     }
55 }