groovy.lang.EmptyRange Maven / Gradle / Ivy
/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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 groovy.lang; import org.codehaus.groovy.runtime.InvokerHelper; import java.util.AbstractList; import java.util.ArrayList; import java.util.Collection; import java.util.List; /** * Constructing Ranges like 0..<0 */ public class EmptyRange extends AbstractList implements Range { /** * The value at which the range originates (may be
for an empty range. * * @throws IndexOutOfBoundsException always */ @Override public Object get(int index) { throw new IndexOutOfBoundsException("can't get values from Empty Ranges"); } /** * Always throwsnull
). */ protected Comparable at; /** * Creates a new {@link EmptyRange}. * * @param at the value at which the range starts (may benull
). */ public EmptyRange(Comparable at) { this.at = at; } /** * {@inheritDoc} */ @Override public Comparable getFrom() { return at; } /** * {@inheritDoc} */ @Override public Comparable getTo() { return at; } /** * Never true for an empty range. * * @returnfalse
*/ @Override public boolean isReverse() { return false; } /** * Never true for an empty range. * * @returnfalse
*/ @Override public boolean containsWithinBounds(Object o) { return false; } /** * {@inheritDoc} */ @Override public String inspect() { return InvokerHelper.inspect(at) + "..<" + InvokerHelper.inspect(at); } /** * {@inheritDoc} */ public String toString() { return (null == at) ? "null..IndexOutOfBoundsException UnsupportedOperationException
for an empty range. * * @throws UnsupportedOperationException always */ @Override public boolean add(Object o) { throw new UnsupportedOperationException("cannot add to Empty Ranges"); } /** * Always throwsUnsupportedOperationException
for an empty range. * * @throws UnsupportedOperationException */ @Override public boolean addAll(int index, Collection c) { throw new UnsupportedOperationException("cannot add to Empty Ranges"); } /** * Always throwsUnsupportedOperationException
for an empty range. * * @throws UnsupportedOperationException */ @Override public boolean addAll(Collection c) { throw new UnsupportedOperationException("cannot add to Empty Ranges"); } /** * Always throwsUnsupportedOperationException
for an empty range. * * @throws UnsupportedOperationException */ @Override public boolean remove(Object o) { throw new UnsupportedOperationException("cannot remove from Empty Ranges"); } /** * Always throwsUnsupportedOperationException
for an empty range. * * @throws UnsupportedOperationException */ @Override public Object remove(int index) { throw new UnsupportedOperationException("cannot remove from Empty Ranges"); } /** * Always throwsUnsupportedOperationException
for an empty range. * * @throws UnsupportedOperationException */ @Override public boolean removeAll(Collection c) { throw new UnsupportedOperationException("cannot remove from Empty Ranges"); } /** * Always throwsUnsupportedOperationException
for an empty range. * * @throws UnsupportedOperationException */ @Override public boolean retainAll(Collection c) { throw new UnsupportedOperationException("cannot retainAll in Empty Ranges"); } /** * Always throwsUnsupportedOperationException
for an empty range. * * @throws UnsupportedOperationException */ @Override public Object set(int index, Object element) { throw new UnsupportedOperationException("cannot set in Empty Ranges"); } /** * Always does nothing for an empty range. */ @Override public void step(int step, Closure closure) { } /** * Always returns an empty list for an empty range. */ @Override public List step(int step) { return new ArrayList(); } }