Package org.springframework.data.domain
Class Range<T>
java.lang.Object
org.springframework.data.domain.Range<T>
Simple value object to work with ranges and boundaries.
- Since:
- 1.10
- Author:
- Oliver Gierke, Mark Paluch
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic final class
Value object representing a boundary.static class
Builder forRange
allowing to specify the upper boundary. -
Method Summary
Modifier and TypeMethodDescriptionstatic <T> Range<T>
closed
(T from, T to) Creates a newRange
with inclusive bounds for both values.boolean
contains
(Comparable<T> value) Returns whether theRange
contains the given value.boolean
contains
(T value, Comparator<T> comparator) Returns whether theRange
contains the given value.boolean
static <T> Range.RangeBuilder<T>
from
(Range.Bound<T> lower) Create aRange.RangeBuilder
given the lowerRange.Bound
.int
hashCode()
static <T> Range<T>
just
(T value) Creates a new Range with the given value as sole member.static <T> Range<T>
leftOpen
(T from, T to) Creates a new left-openRange
, i.e. left exclusive, right inclusive.static <T> Range<T>
leftUnbounded
(Range.Bound<T> to) Creates a left-unboundedRange
(the left bound set toRange.Bound.unbounded()
) with the given right bound.<R> Range<R>
Apply a mappingFunction
to the lower and upper boundary values.static <T> Range<T>
of
(Range.Bound<T> lowerBound, Range.Bound<T> upperBound) Creates a newRange
with the given lower and upper bound.static <T> Range<T>
open
(T from, T to) Creates a newRange
with exclusive bounds for both values.static <T> Range<T>
rightOpen
(T from, T to) Creates a new right-openRange
, i.e. left inclusive, right exclusive.static <T> Range<T>
rightUnbounded
(Range.Bound<T> from) Creates a right-unboundedRange
(the right bound set toRange.Bound.unbounded()
) with the given left bound.toString()
static <T> Range<T>
Returns an unboundedRange
.
-
Method Details
-
unbounded
Returns an unboundedRange
.- Returns:
- an unbounded
Range
. - Since:
- 2.0
-
closed
Creates a newRange
with inclusive bounds for both values.- Type Parameters:
T
- the type of the range.- Parameters:
from
- must not be null.to
- must not be null.- Returns:
- a
Range
with the lower bound set inclusively and the upper bound inclusively. - Since:
- 2.2
-
open
Creates a newRange
with exclusive bounds for both values.- Type Parameters:
T
- the type of the range.- Parameters:
from
- must not be null.to
- must not be null.- Returns:
- a
Range
with the lower bound set exclusively and the upper bound exclusively. - Since:
- 2.2
-
leftOpen
Creates a new left-openRange
, i.e. left exclusive, right inclusive.- Type Parameters:
T
- the type of the range.- Parameters:
from
- must not be null.to
- must not be null.- Returns:
- a
Range
with the lower bound set exclusively and the upper bound inclusively. - Since:
- 2.2
-
rightOpen
Creates a new right-openRange
, i.e. left inclusive, right exclusive.- Type Parameters:
T
- the type of the range.- Parameters:
from
- must not be null.to
- must not be null.- Returns:
- a
Range
with the lower bound set inclusively and the upper bound exclusively. - Since:
- 2.2
-
leftUnbounded
Creates a left-unboundedRange
(the left bound set toRange.Bound.unbounded()
) with the given right bound.- Type Parameters:
T
- the type of the range.- Parameters:
to
- the rightRange.Bound
, must not be null.- Returns:
- a
Range
with the upper bound set to the given value and the lower side unbounded. - Since:
- 2.2
-
rightUnbounded
Creates a right-unboundedRange
(the right bound set toRange.Bound.unbounded()
) with the given left bound.- Type Parameters:
T
- the type of the range.- Parameters:
from
- the leftRange.Bound
, must not be null.- Returns:
- a
Range
with the lower bound set to the given value and the upper side unbounded. - Since:
- 2.2
-
from
Create aRange.RangeBuilder
given the lowerRange.Bound
.- Parameters:
lower
- must not be null.- Returns:
- a range builder to continue creating a
Range
from the lower bound. - Since:
- 2.0
-
of
Creates a newRange
with the given lower and upper bound. Preferfrom(Bound)
for a more builder style API.- Parameters:
lowerBound
- must not be null.upperBound
- must not be null.- Since:
- 2.0
- See Also:
-
just
Creates a new Range with the given value as sole member.- Type Parameters:
T
- the type of the range.>- Parameters:
value
- must not be null.- Returns:
- a range containing the given value.
- See Also:
-
contains
Returns whether theRange
contains the given value.- Parameters:
value
- must not be null.- Returns:
- true if the range contains the value; false otherwise.
-
contains
Returns whether theRange
contains the given value.- Parameters:
value
- must not be null.- Returns:
- true if the range contains the value; false otherwise.
- Since:
- 3.0
-
map
Apply a mappingFunction
to the lower and upper boundary values.- Type Parameters:
R
- target type of the mapping function.- Parameters:
mapper
- must not be null. If the mapper returnsnull
, then the corresponding boundary value represents anRange.Bound.unbounded()
boundary.- Returns:
- a new
Range
after applying the value to the mapper. - Since:
- 3.0
-
toString
-
getLowerBound
-
getUpperBound
-
equals
-
hashCode
public int hashCode()
-