All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.opendaylight.yangtools.yang.parser.api.YangParserConfiguration Maven / Gradle / Ivy

/*
 * Copyright (c) 2021 PANTHEON.tech, s.r.o. 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.api;

import static java.util.Objects.requireNonNull;

import com.google.common.annotations.Beta;
import com.google.common.base.MoreObjects;
import java.util.Objects;
import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable;
import org.opendaylight.yangtools.concepts.Immutable;
import org.opendaylight.yangtools.concepts.Mutable;
import org.opendaylight.yangtools.yang.model.api.meta.DeclarationReference;
import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;

/**
 * A configuration of {@link YangParser} wiring for use with {@link YangParserFactory}.
 */
@NonNullByDefault
public final class YangParserConfiguration implements Immutable {
    /**
     * System-wide default configuration.
     */
    public static final YangParserConfiguration DEFAULT = builder().build();

    private final ImportResolutionMode importResolutionMode;
    private final boolean retainDeclarationReferences;
    private final boolean warnForUnkeyedLists;

    private YangParserConfiguration(final ImportResolutionMode importResolutionMode,
            final boolean retainDeclarationReferences, final boolean warnForUnkeyedLists) {
        this.importResolutionMode = requireNonNull(importResolutionMode);
        this.retainDeclarationReferences = retainDeclarationReferences;
        this.warnForUnkeyedLists = warnForUnkeyedLists;
    }

    @Beta
    public ImportResolutionMode importResolutionMode() {
        return importResolutionMode;
    }

    /**
     * Return {@code true} if {@link DeclarationReference} to source location in the final parser product, notably
     * making {@link DeclaredStatement#declarationReference()} available.
     *
     * @return {@code true} if declaration references should be retained
     */
    public boolean retainDeclarationReferences() {
        return retainDeclarationReferences;
    }

    /**
     * Issue a warning when a {@code list} statement without a {@code key} statement is found in the
     * {@code config true} part of the schema tree. Such statements run contrary to
     * RFC7950, but are readily supported
     * by OpenDaylight infrastructure.
     *
     * @return {@code true} if non-compliant {@code list} statements should be reported
     */
    public boolean warnForUnkeyedLists() {
        return warnForUnkeyedLists;
    }

    @Override
    public int hashCode() {
        return Objects.hash(importResolutionMode, retainDeclarationReferences);
    }

    @Override
    public boolean equals(final @Nullable Object obj) {
        if (this == obj) {
            return true;
        }
        if (!(obj instanceof YangParserConfiguration)) {
            return false;
        }
        final YangParserConfiguration other = (YangParserConfiguration) obj;
        return importResolutionMode == other.importResolutionMode
            && retainDeclarationReferences == other.retainDeclarationReferences;
    }

    @Override
    public String toString() {
        return MoreObjects.toStringHelper(this)
            .add("importResolution", importResolutionMode)
            .add("declarationReferences", retainDeclarationReferences)
            .toString();
    }

    /**
     * Return a new {@link Builder} initialized to default configuration.
     *
     * @return A new builder
     */
    public static Builder builder() {
        return new Builder();
    }

    public static final class Builder implements Mutable {
        private ImportResolutionMode importResolutionMode = ImportResolutionMode.DEFAULT;
        private boolean retainDeclarationReferences;
        // FIXME: YANGTOOLS-1423: default to false
        private boolean warnForUnkeyedLists = true;

        private Builder() {
            // Hidden on purpose
        }

        /**
         * Return a {@link YangParserConfiguration} initialized with contents of this builder.
         *
         * @return A YangParserConfiguration
         */
        public YangParserConfiguration build() {
            return new YangParserConfiguration(importResolutionMode, retainDeclarationReferences, warnForUnkeyedLists);
        }

        @Beta
        public Builder importResolutionMode(final ImportResolutionMode newImportResolutionMode) {
            importResolutionMode = requireNonNull(newImportResolutionMode);
            return this;
        }

        /**
         * Retain {@link DeclarationReference} to source location in the final parser product. This option results in
         * quite significant memory overhead for storage of {@link DeclaredStatement}, but makes
         * {@link DeclaredStatement#declarationReference()} available, which is useful in certain scenarios, for example
         * YANG editors.
         *
         * 

* This option is disabled by default. * * @param newRetainDeclarationReferences {@code true} if declaration references should be retained * @return This builder */ public Builder retainDeclarationReferences(final boolean newRetainDeclarationReferences) { retainDeclarationReferences = newRetainDeclarationReferences; return this; } /** * Issue a warning when a {@code list} statement without a {@code key} statement is found in the * {@code config true} part of the schema tree. Such statements run contrary to * RFC7950, but are readily supported * by OpenDaylight infrastructure. * *

* This option is enabled by default. * * @param newWarnForUnkeyedLists {@code true} if non-compliant {@code list} statements should be reported * @return This builder */ public Builder warnForUnkeyedLists(final boolean newWarnForUnkeyedLists) { warnForUnkeyedLists = newWarnForUnkeyedLists; return this; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy