-/**
+/*
* Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
*/
package org.opendaylight.yangtools.yang.parser.stmt.rfc6020.effective;
-import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
-
-import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
import org.opendaylight.yangtools.yang.model.api.DocumentedNode;
import org.opendaylight.yangtools.yang.model.api.Status;
+import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
+import org.opendaylight.yangtools.yang.parser.spi.meta.StmtContext;
-public abstract class AbstractEffectiveDocumentedNode<A, D extends DeclaredStatement<A>>
- extends EffectiveStatementBase<A, D> implements DocumentedNode {
+abstract class AbstractEffectiveDocumentedNode<A, D extends DeclaredStatement<A>>
+ extends DeclaredEffectiveStatementBase<A, D> implements DocumentedNode {
private final String description;
private final String reference;
private final Status status;
AbstractEffectiveDocumentedNode(final StmtContext<A, D, ?> ctx) {
- super(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.
+ */
+ AbstractEffectiveDocumentedNode(final StmtContext<A, D, ?> ctx, boolean buildUnknownSubstatements) {
+ super(ctx, buildUnknownSubstatements);
DescriptionEffectiveStatementImpl descStmt = firstEffective(DescriptionEffectiveStatementImpl.class);
if (descStmt != null) {
description = descStmt.argument();
} else {
- description = "";
+ description = null;
}
ReferenceEffectiveStatementImpl refStmt = firstEffective(ReferenceEffectiveStatementImpl.class);
if (refStmt != null) {
reference = refStmt.argument();
} else {
- reference = "";
+ RevisionEffectiveStatementImpl revision = firstEffective(RevisionEffectiveStatementImpl.class);
+ if (revision != null) {
+ reference = revision.getReference();
+ } else {
+ reference = null;
+ }
}
- // :TODO
- status = null;
+ StatusEffectiveStatementImpl statusStmt = firstEffective(StatusEffectiveStatementImpl.class);
+ if (statusStmt != null) {
+ status = statusStmt.argument();
+ } else {
+ status = Status.CURRENT;
+ }
}
@Override