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

com.liferay.object.tree.BreadthFirstIterator Maven / Gradle / Ivy

There is a newer version: 93.0.0
Show newest version
/**
 * SPDX-FileCopyrightText: (c) 2023 Liferay, Inc. https://liferay.com
 * SPDX-License-Identifier: LGPL-2.1-or-later OR LicenseRef-Liferay-DXP-EULA-2.0.0-2023-06
 */

package com.liferay.object.tree;

import com.liferay.portal.kernel.util.ListUtil;

import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Queue;

/**
 * @author Feliphe Marinho
 */
public class BreadthFirstIterator implements Iterator {

	public BreadthFirstIterator(Node node) {
		_queue.add(node);
	}

	@Override
	public boolean hasNext() {
		return !_queue.isEmpty();
	}

	@Override
	public Node next() {
		Node node = _queue.poll();

		List nodes = node.getChildNodes();

		if (ListUtil.isNotEmpty(nodes)) {
			_queue.addAll(nodes);
		}

		return node;
	}

	private final Queue _queue = new LinkedList<>();

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy