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

org.jenetics.internal.collection.ArrayProxySpliterator Maven / Gradle / Ivy

/*
 * Java Genetic Algorithm Library (jenetics-3.1.0).
 * Copyright (c) 2007-2015 Franz Wilhelmstötter
 *
 * 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
 *
 *      http://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.
 *
 * Author:
 *    Franz Wilhelmstötter ([email protected])
 */
package org.jenetics.internal.collection;

import static java.util.Objects.requireNonNull;

import java.util.Spliterator;
import java.util.function.Consumer;

/**
 * @author Franz Wilhelmstötter
 * @since 3.0
 * @version 3.0
 */
public final class ArrayProxySpliterator implements Spliterator {

	private final ArrayProxy _proxy;
	private final int _fence;
	private int _index;

	public ArrayProxySpliterator(
		final ArrayProxy proxy,
		final int origin,
		final int fence
	) {
		_proxy = requireNonNull(proxy);
		_index = origin;
		_fence = fence;
	}

	public ArrayProxySpliterator(final ArrayProxy proxy) {
		this(proxy, 0, proxy.length);
	}

	@Override
	public void forEachRemaining(final Consumer action) {
		requireNonNull(action);

		ArrayProxy proxy;
		int i;
		int hi;

		if ((proxy = _proxy).length >= (hi = _fence) &&
			(i = _index) >= 0 && i < (_index = hi))
		{
			do {
				action.accept(proxy.__get(i));
			} while (++i < hi);
		}
	}

	@Override
	public boolean tryAdvance(final Consumer action) {
		if (_index >= 0 && _index < _fence) {
			action.accept(_proxy.__get(_index++));
			return true;
		}
		return false;
	}

	@Override
	public Spliterator trySplit() {
		final int lo = _index;
		final int mid = (lo + _fence) >>> 1;

		return (lo >= mid)
			? null
			: new ArrayProxySpliterator<>(_proxy, lo, _index = mid);
	}

	@Override
	public long estimateSize() {
		return _fence - _index;
	}

	@Override
	public int characteristics() {
		return Spliterator.NONNULL | Spliterator.SIZED | Spliterator.SUBSIZED;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy