/*
* 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;
import com.google.common.base.Verify;
import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
import org.opendaylight.yangtools.yang.model.api.meta.StatementDefinition;
import org.opendaylight.yangtools.yang.model.api.meta.StatementSource;
import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
public abstract class DeclaredEffectiveStatementBase>
extends EffectiveStatementBase {
private final D declaredInstance;
public DeclaredEffectiveStatementBase(final StmtContext ctx) {
this(ctx, true);
}
/**
* Constructor.
*
* @param ctx
* context of statement.
* @param buildUnknownSubstatements
* if it is false, the unknown substatements are omitted from
* build of effective substatements till the call of either
* effectiveSubstatements or getOmittedUnknownSubstatements
* method of EffectiveStatementBase class. The main purpose of
* this is to allow the build of recursive extension definitions.
*/
protected DeclaredEffectiveStatementBase(final StmtContext ctx, boolean buildUnknownSubstatements) {
super(ctx, buildUnknownSubstatements);
declaredInstance = Verify.verifyNotNull(ctx.buildDeclared(), "Statement %s failed to build declared statement",
ctx);
}
@Override
public final StatementDefinition statementDefinition() {
return declaredInstance.statementDefinition();
}
@Override
public final A argument() {
return declaredInstance.argument();
}
@Override
public final StatementSource getStatementSource() {
return declaredInstance.getStatementSource();
}
@Override
public final D getDeclared() {
return declaredInstance;
}
}