com.google.common.collect.AbstractRangeSet Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of guava Show documentation
Show all versions of guava Show documentation
Guava is a suite of core and expanded libraries that include
utility classes, google's collections, io classes, and much
much more.
/*
* Copyright (C) 2011 The Guava 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 com.google.common.collect;
import com.google.common.annotations.GwtIncompatible;
import javax.annotation.CheckForNull;
/**
* A skeletal implementation of {@code RangeSet}.
*
* @author Louis Wasserman
*/
@GwtIncompatible
@ElementTypesAreNonnullByDefault
abstract class AbstractRangeSet implements RangeSet {
AbstractRangeSet() {}
@Override
public boolean contains(C value) {
return rangeContaining(value) != null;
}
@Override
@CheckForNull
public abstract Range rangeContaining(C value);
@Override
public boolean isEmpty() {
return asRanges().isEmpty();
}
@Override
public void add(Range range) {
throw new UnsupportedOperationException();
}
@Override
public void remove(Range range) {
throw new UnsupportedOperationException();
}
@Override
public void clear() {
remove(Range.all());
}
@Override
public boolean enclosesAll(RangeSet other) {
return enclosesAll(other.asRanges());
}
@Override
public boolean enclosesAll(Iterable> ranges) {
for (Range range : ranges) {
if (!encloses(range)) {
return false;
}
}
return true;
}
@Override
public void addAll(RangeSet other) {
addAll(other.asRanges());
}
@Override
public void addAll(Iterable> ranges) {
for (Range range : ranges) {
add(range);
}
}
@Override
public void removeAll(RangeSet other) {
removeAll(other.asRanges());
}
@Override
public void removeAll(Iterable> ranges) {
for (Range range : ranges) {
remove(range);
}
}
@Override
public boolean intersects(Range otherRange) {
return !subRangeSet(otherRange).isEmpty();
}
@Override
public abstract boolean encloses(Range otherRange);
@Override
public boolean equals(@CheckForNull Object obj) {
if (obj == this) {
return true;
} else if (obj instanceof RangeSet) {
RangeSet> other = (RangeSet>) obj;
return this.asRanges().equals(other.asRanges());
}
return false;
}
@Override
public final int hashCode() {
return asRanges().hashCode();
}
@Override
public final String toString() {
return asRanges().toString();
}
}