/*
 * Copyright 2012-2019 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.boot.context.properties.source;

import java.util.Iterator;
import java.util.function.Predicate;
import java.util.stream.Stream;

import org.springframework.boot.origin.OriginTrackedValue;

A ConfigurationPropertySource with a fully Iterable set of entries. Implementations of this interface must be able to iterate over all contained configuration properties. Any non-null result from ConfigurationPropertySource.getConfigurationProperty(ConfigurationPropertyName) must also have an equivalent entry in the iterator.
Author:Phillip Webb, Madhura Bhave
See Also:
Since:2.0.0
/** * A {@link ConfigurationPropertySource} with a fully {@link Iterable} set of entries. * Implementations of this interface <strong>must</strong> be able to iterate over all * contained configuration properties. Any {@code non-null} result from * {@link #getConfigurationProperty(ConfigurationPropertyName)} must also have an * equivalent entry in the {@link #iterator() iterator}. * * @author Phillip Webb * @author Madhura Bhave * @since 2.0.0 * @see ConfigurationPropertyName * @see OriginTrackedValue * @see #getConfigurationProperty(ConfigurationPropertyName) * @see #iterator() * @see #stream() */
public interface IterableConfigurationPropertySource extends ConfigurationPropertySource, Iterable<ConfigurationPropertyName> {
Return an iterator for the names managed by this source.
Returns:an iterator (never null)
/** * Return an iterator for the {@link ConfigurationPropertyName names} managed by this * source. * @return an iterator (never {@code null}) */
@Override default Iterator<ConfigurationPropertyName> iterator() { return stream().iterator(); }
Returns a sequential Stream for the names managed by this source.
Returns:a stream of names (never null)
/** * Returns a sequential {@code Stream} for the {@link ConfigurationPropertyName names} * managed by this source. * @return a stream of names (never {@code null}) */
Stream<ConfigurationPropertyName> stream(); @Override default ConfigurationPropertyState containsDescendantOf(ConfigurationPropertyName name) { return ConfigurationPropertyState.search(this, name::isAncestorOf); } @Override default IterableConfigurationPropertySource filter(Predicate<ConfigurationPropertyName> filter) { return new FilteredIterableConfigurationPropertiesSource(this, filter); } @Override default IterableConfigurationPropertySource withAliases(ConfigurationPropertyNameAliases aliases) { return new AliasedIterableConfigurationPropertySource(this, aliases); } }