/* * Copyright 2015-2025 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 * * 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. */ package sockslib.common; import java.util.Iterator; /** * The class <code>IPIterator</code> represents an IP address iterator. * * @author Youchao Feng * @version 1.0 * @date May 2, 2015 9:23:00 AM */ public class IPIterator implements Iterator<IP> { /** * IP address range. */ private IPRange range; /** * Current IP address. */ private IP currentIP; /** * A flag. It's always <code>true</code> in the beginning but it will become <code>false</code> if * {{@link #next()} is invoked. */ private boolean start = true; /** * Constructs an instance of {@link IPIterator} with a {@link IPRange}. * * @param range IP address range. */ public IPIterator(IPRange range) { this.range = range; currentIP = range.getStartIP(); } /** * Constructs an instance of {@link IPIterator} with tow IP address. * * @param startIP Starting IP address. * @param endIP End IP address. */ public IPIterator(IP startIP, IP endIP) { range = new IPRange(startIP, endIP); currentIP = startIP; } @Override public boolean hasNext() { if (start) { return true; } else { return range.contains(currentIP.nextIP()); } } @Override public IP next() { if (start) { start = false; return currentIP; } else { currentIP = currentIP.nextIP(); return currentIP; } } @Override public void remove() { } }