/*
* 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.model.api.stmt;
import com.google.common.annotations.Beta;
import java.util.Set;
import java.util.function.Predicate;
import javax.annotation.Nonnull;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.model.api.meta.DeclaredStatement;
/**
* Represents YANG if-feature statement.
*
* The "if-feature" statement makes its parent statement conditional.
*/
public interface IfFeatureStatement extends DeclaredStatement<Predicate<Set<QName>>> {
/**
* In Yang 1.1 (RFC7950) implementation of IfFeatureStatement, the
* argument is a boolean expression over feature names defined by
* "feature" statements. Hence, add implementation to return a
* predicate on a collection of features against which to evaluate.
*
* @return Predicate on a collection of QNames against which to evaluate
*/
@Beta
@Nonnull
Predicate<Set<QName>> getIfFeaturePredicate();
}