blob: a2f941362862db8c1fb4bdb7e703863a13008643 [file] [log] [blame]
/*
* Copyright 2003-2007 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 groovy.lang;
import org.codehaus.groovy.runtime.InvokerHelper;
import java.util.*;
/**
* Constructing Ranges like 0..<0
* @author Dierk Koenig
* @author Edwin Tellman
*/
public class EmptyRange extends AbstractList implements Range {
/**
* The value at which the range originates (may be <code>null</code>).
*/
protected Comparable at;
/**
* Creates a new {@link EmptyRange}.
*
* @param at the value at which the range starts (may be <code>null</code>).
*/
public EmptyRange(Comparable at) {
this.at = at;
}
/**
* {@inheritDoc}
*/
public Comparable getFrom() {
return at;
}
/**
* {@inheritDoc}
*/
public Comparable getTo() {
return at;
}
/**
* Never true for an empty range.
*
* @return <code>false</code>
*/
public boolean isReverse() {
return false;
}
/**
* Never true for an empty range.
*
* @return <code>false</code>
*/
public boolean containsWithinBounds(Object o) {
return false;
}
/**
* {@inheritDoc}
*/
public String inspect() {
return InvokerHelper.inspect(at) + "..<" + InvokerHelper.inspect(at);
}
/**
* {@inheritDoc}
*/
public String toString() {
return (null == at)
? "null..<null"
: at.toString() + "..<" + at.toString();
}
/**
* Always 0 for an empty range.
*
* @return 0
*/
public int size() {
return 0;
}
/**
* Always throws <code>IndexOutOfBoundsException</code> for an empty range.
*
* @throws IndexOutOfBoundsException always
*/
public Object get(int index) {
throw new IndexOutOfBoundsException("can't get values from Empty Ranges");
}
/**
* Always throws <code>UnsupportedOperationException</code> for an empty range.
*
* @throws UnsupportedOperationException always
*/
public boolean add(Object o) {
throw new UnsupportedOperationException("cannot add to Empty Ranges");
}
/**
* Always throws <code>UnsupportedOperationException</code> for an empty range.
*
* @throws UnsupportedOperationException
*/
public boolean addAll(int index, Collection c) {
throw new UnsupportedOperationException("cannot add to Empty Ranges");
}
/**
* Always throws <code>UnsupportedOperationException</code> for an empty range.
*
* @throws UnsupportedOperationException
*/
public boolean addAll(Collection c) {
throw new UnsupportedOperationException("cannot add to Empty Ranges");
}
/**
* Always throws <code>UnsupportedOperationException</code> for an empty range.
*
* @throws UnsupportedOperationException
*/
public boolean remove(Object o) {
throw new UnsupportedOperationException("cannot remove from Empty Ranges");
}
/**
* Always throws <code>UnsupportedOperationException</code> for an empty range.
*
* @throws UnsupportedOperationException
*/
public Object remove(int index) {
throw new UnsupportedOperationException("cannot remove from Empty Ranges");
}
/**
* Always throws <code>UnsupportedOperationException</code> for an empty range.
*
* @throws UnsupportedOperationException
*/
public boolean removeAll(Collection c) {
throw new UnsupportedOperationException("cannot remove from Empty Ranges");
}
/**
* Always throws <code>UnsupportedOperationException</code> for an empty range.
*
* @throws UnsupportedOperationException
*/
public boolean retainAll(Collection c) {
throw new UnsupportedOperationException("cannot retainAll in Empty Ranges");
}
/**
* Always throws <code>UnsupportedOperationException</code> for an empty range.
*
* @throws UnsupportedOperationException
*/
public Object set(int index, Object element) {
throw new UnsupportedOperationException("cannot set in Empty Ranges");
}
/**
* Always does nothing for an empty range.
*/
public void step(int step, Closure closure) {
}
/**
* Always returns an empty list for an empty range.
*/
public List step(int step) {
return new ArrayList();
}
}