/* * Copyright (c) 2015 Cisco Systems, Inc. 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.yangtools.yang.parser.stmt.rfc6020.effective.type; import javax.annotation.Nonnull; import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.TypeEffectiveStatement; import org.opendaylight.yangtools.yang.model.api.stmt.TypeStatement; import org.opendaylight.yangtools.yang.model.api.type.LengthConstraint; import org.opendaylight.yangtools.yang.model.api.type.PatternConstraint; import org.opendaylight.yangtools.yang.model.api.type.StringTypeDefinition; import org.opendaylight.yangtools.yang.model.util.type.InvalidLengthConstraintException; import org.opendaylight.yangtools.yang.model.util.type.RestrictedTypes; import org.opendaylight.yangtools.yang.model.util.type.StringTypeBuilder; import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext; import org.opendaylight.yangtools.yang.parser.spi.source.SourceException; import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.TypeUtils; import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective.DeclaredEffectiveStatementBase; import org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective.UnknownEffectiveStatementImpl; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public final class StringTypeEffectiveStatementImpl extends DeclaredEffectiveStatementBase<String, TypeStatement> implements TypeEffectiveStatement<TypeStatement> { private static final Logger LOG = LoggerFactory.getLogger(StringTypeEffectiveStatementImpl.class); private final StringTypeDefinition typeDefinition; public StringTypeEffectiveStatementImpl( final StmtContext<String, TypeStatement, EffectiveStatement<String, TypeStatement>> ctx, final StringTypeDefinition baseType) { super(ctx); final StringTypeBuilder builder = RestrictedTypes.newStringBuilder(baseType, TypeUtils.typeEffectiveSchemaPath(ctx)); for (EffectiveStatement<?, ?> stmt : effectiveSubstatements()) { if (stmt instanceof LengthEffectiveStatementImpl) { builder.setLengthAlternatives(((LengthEffectiveStatementImpl)stmt).argument()); } if (stmt instanceof PatternEffectiveStatementImpl) { final PatternConstraint pattern = ((PatternEffectiveStatementImpl)stmt).argument(); if (pattern != null) { builder.addPatternConstraint(pattern); } else { LOG.debug("Ignoring empty pattern statement {}", stmt); } } if (stmt instanceof UnknownEffectiveStatementImpl) { builder.addUnknownSchemaNode((UnknownEffectiveStatementImpl)stmt); } } try { typeDefinition = builder.build(); } catch (InvalidLengthConstraintException e) { final LengthConstraint c = e.getOffendingConstraint(); throw new SourceException(ctx.getStatementSourceReference(), e, "Invalid length constraint: <%s, %s>", c.getMin(), c.getMax()); } } @Nonnull @Override public StringTypeDefinition getTypeDefinition() { return typeDefinition; } }