*/
package org.opendaylight.yangtools.yang.parser.spi.meta;
+import static com.google.common.base.Preconditions.checkArgument;
+import static com.google.common.base.Preconditions.checkState;
+import static java.util.Objects.requireNonNull;
+
import com.google.common.base.Preconditions;
import com.google.common.collect.HashBasedTable;
import com.google.common.collect.ImmutableMap;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.common.YangVersion;
import org.opendaylight.yangtools.yang.model.api.meta.IdentifierNamespace;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
public final class StatementSupportBundle implements Immutable, NamespaceBehaviour.Registry {
}
public static Builder derivedFrom(final StatementSupportBundle parent) {
- Preconditions.checkNotNull(parent);
return new Builder(parent.getSupportedVersions(), parent);
}
@Override
public <K, V, N extends IdentifierNamespace<K, V>> NamespaceBehaviour<K, V, N> getNamespaceBehaviour(
- final Class<N> namespace) throws NamespaceNotAvailableException {
+ final Class<N> namespace) {
final NamespaceBehaviour<?, ?, ?> potential = namespaceDefinitions.get(namespace);
if (potential != null) {
- Preconditions.checkState(namespace.equals(potential.getIdentifier()));
+ checkState(namespace.equals(potential.getIdentifier()));
// Safe cast, previous checkState checks equivalence of key from which type argument are derived
return (NamespaceBehaviour<K, V, N>) potential;
}
public static class Builder implements org.opendaylight.yangtools.concepts.Builder<StatementSupportBundle> {
+ private static final Logger LOG = LoggerFactory.getLogger(Builder.class);
+
private final Map<QName, StatementSupport<?, ?, ?>> commonStatements = new HashMap<>();
private final Table<YangVersion, QName, StatementSupport<?, ?, ?>> versionSpecificStatements = HashBasedTable
.create();
private StatementSupportBundle parent;
Builder(final Set<YangVersion> supportedVersions, final StatementSupportBundle parent) {
- this.parent = Preconditions.checkNotNull(parent);
+ this.parent = requireNonNull(parent);
this.supportedVersions = ImmutableSet.copyOf(supportedVersions);
}
- public Builder addSupport(final StatementSupport<?, ?, ?> definition) {
- final QName identifier = definition.getStatementName();
- Preconditions.checkState(!commonStatements.containsKey(identifier),
+ public Builder addSupport(final StatementSupport<?, ?, ?> support) {
+ final QName identifier = support.getStatementName();
+ checkNoParentDefinition(identifier);
+
+ checkState(!commonStatements.containsKey(identifier),
"Statement %s already defined in common statement bundle.", identifier);
- Preconditions.checkState(parent.getCommonStatementDefinition(identifier) == null,
- "Statement %s already defined.", identifier);
- commonStatements.put(identifier, definition);
+ commonStatements.put(identifier, support);
return this;
}
public <K, V, N extends IdentifierNamespace<K, V>> Builder addSupport(
final NamespaceBehaviour<K, V, N> namespaceSupport) {
final Class<N> identifier = namespaceSupport.getIdentifier();
- Preconditions.checkState(!namespaces.containsKey(identifier));
- Preconditions.checkState(!parent.hasNamespaceBehaviour(identifier));
+ checkState(!namespaces.containsKey(identifier));
+ checkState(!parent.hasNamespaceBehaviour(identifier));
namespaces.put(identifier, namespaceSupport);
return this;
}
public Builder addVersionSpecificSupport(final YangVersion version,
final StatementSupport<?, ?, ?> definition) {
- Preconditions.checkNotNull(version);
- Preconditions.checkNotNull(definition);
- Preconditions.checkArgument(supportedVersions.contains(version));
+ checkArgument(supportedVersions.contains(requireNonNull(version)));
final QName identifier = definition.getStatementName();
- Preconditions.checkState(!commonStatements.containsKey(identifier),
+ checkState(!commonStatements.containsKey(identifier),
"Statement %s already defined in common statement bundle.", identifier);
- Preconditions.checkState(!versionSpecificStatements.contains(version, identifier),
+ checkState(!versionSpecificStatements.contains(version, identifier),
"Statement %s already defined for version %s.", identifier, version);
- Preconditions.checkState(parent.getCommonStatementDefinition(identifier) == null,
- "Statement %s already defined in parent's common statement bundle.", identifier);
- Preconditions.checkState(parent.getVersionSpecificStatementDefinition(version, identifier) == null,
+ checkNoParentDefinition(identifier);
+ checkState(parent.getVersionSpecificStatementDefinition(version, identifier) == null,
"Statement %s already defined for version %s in parent's statement bundle.", identifier, version);
versionSpecificStatements.put(version, identifier, definition);
return this;
return this;
}
+ public Builder overrideSupport(final StatementSupport<?, ?, ?> support) {
+ final QName identifier = support.getStatementName();
+ checkNoParentDefinition(identifier);
+
+ final StatementSupport<?, ?, ?> previousSupport = commonStatements.replace(identifier, support);
+ checkState(previousSupport != null, "Statement %s was not previously defined", identifier);
+ LOG.debug("Changed statement {} support from {} to {}", identifier, previousSupport, support);
+ return this;
+ }
+
@Override
public StatementSupportBundle build() {
Preconditions.checkState(parent != null, "Parent must not be null");
return new StatementSupportBundle(parent, supportedVersions, ImmutableMap.copyOf(commonStatements),
ImmutableMap.copyOf(namespaces), ImmutableTable.copyOf(versionSpecificStatements));
}
+
+ private void checkNoParentDefinition(final QName identifier) {
+ checkState(parent.getCommonStatementDefinition(identifier) == null,
+ "Statement %s is defined in parent's common statement bundle", identifier);
+ }
}
}