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.spi.meta;
10 import com.google.common.annotations.Beta;
11 import org.opendaylight.yangtools.yang.common.QName;
12 import org.opendaylight.yangtools.yang.common.QNameModule;
13 import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
14 import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement;
15 import org.opendaylight.yangtools.yang.model.api.meta.StatementDefinition;
18 * Class providing necessary support for processing a YANG statements which has a {@link QName} argument. In addition
19 * to functions of {@link AbstractStatementSupport}, it takes care of adapting QNames across modules.
22 * Declared Statement representation
24 * Effective Statement representation
27 public abstract class AbstractQNameStatementSupport<D extends DeclaredStatement<QName>,
28 E extends EffectiveStatement<QName, D>> extends AbstractStatementSupport<QName, D, E> {
30 protected AbstractQNameStatementSupport(final StatementDefinition publicDefinition) {
31 super(publicDefinition);
35 public QName adaptArgumentValue(final StmtContext<QName, D, E> ctx, final QNameModule targetModule) {
36 return ctx.getFromNamespace(QNameCacheNamespace.class,
37 QName.create(targetModule, ctx.getStatementArgument().getLocalName()));