public class DateRangePrefixTree extends NumberRangePrefixTree
Calendar objects with the desired fields set and the unspecified
fields unset, which conveys the precision. The implementation makes some optimization assumptions about a
GregorianCalendar; others could probably be supported easily.
Warning: If you construct a Calendar and then get something from the object like a field (e.g. year) or milliseconds, then every field is fully set by side-effect. So after setting the fields, pass it to this API first.
NumberRangePrefixTree.NRCell, NumberRangePrefixTree.NRShape, NumberRangePrefixTree.SpanUnitsNRShape, NumberRangePrefixTree.UnitNRShape| Modifier and Type | Field and Description |
|---|---|
static Calendar |
DEFAULT_CAL
The Java platform default
Calendar with UTC & ROOT Locale. |
static DateRangePrefixTree |
INSTANCE
Deprecated.
|
static Calendar |
JAVA_UTIL_TIME_COMPAT_CAL
A Calendar instance compatible with
ZonedDateTime as seen from
GregorianCalendar.from(ZonedDateTime). |
levelByTermLen, maxSubCellsByLevel, maxTermLen, termLenByLevelctx, maxLevels| Constructor and Description |
|---|
DateRangePrefixTree(Calendar templateCal)
Constructs with the specified calendar used as a template to be cloned whenever a new
Calendar needs to be created.
|
| Modifier and Type | Method and Description |
|---|---|
void |
clearFieldsAfter(Calendar cal,
int field)
Calendar utility method:
Calls
Calendar.clear(int) for every field after field. |
int |
getCalPrecisionField(Calendar cal)
Calendar utility method:
Gets the Calendar field code of the last field that is set prior to an unset field.
|
int |
getNumSubCells(NumberRangePrefixTree.UnitNRShape lv)
Returns the number of sub-cells beneath the given UnitNRShape.
|
int |
getTreeLevelForCalendarField(int calField)
Calendar utility method:
Returns the spatial prefix tree level for the corresponding
Calendar field, such as
Calendar.YEAR. |
Calendar |
newCal()
Calendar utility method:
Returns a clone of the
Calendar passed to the constructor with all fields cleared. |
Calendar |
parseCalendar(String str)
Calendar utility method:
The reverse of
toString(java.util.Calendar). |
protected NumberRangePrefixTree.UnitNRShape |
parseUnitShape(String str)
Parse a String to a UnitNRShape.
|
Calendar |
toCalendar(NumberRangePrefixTree.UnitNRShape lv)
Converts the
NumberRangePrefixTree.UnitNRShape shape to a
corresponding Calendar that is cleared below its level. |
Object |
toObject(NumberRangePrefixTree.UnitNRShape shape)
|
NumberRangePrefixTree.UnitNRShape |
toShape(Calendar cal)
Converts the Calendar into a Shape.
|
String |
toString(Calendar cal)
Calendar utility method consistent with
DateTimeFormatter.ISO_INSTANT except
has no trailing 'Z', and will be truncated to the units given according to
Calendar.isSet(int). |
protected String |
toString(NumberRangePrefixTree.UnitNRShape lv)
A string representation of the UnitNRShape that is parse-able by
NumberRangePrefixTree.parseUnitShape(String). |
NumberRangePrefixTree.UnitNRShape |
toUnitShape(Object value)
|
comparePrefix, getDistanceForLevel, getLevelForDistance, getWorldCell, newCellStack, parseShape, readCell, toRangeShape, toShape, toString, toStringUnitRawgetMaxLevels, getSpatialContext, getTreeCellIteratorpublic static final Calendar DEFAULT_CAL
Calendar with UTC & ROOT Locale. Generally a GregorianCalendar.
Do not modify this!public static final Calendar JAVA_UTIL_TIME_COMPAT_CAL
ZonedDateTime as seen from
GregorianCalendar.from(ZonedDateTime).
Do not modify this!@Deprecated public static final DateRangePrefixTree INSTANCE
Calendar.getInstance(TimeZone, Locale) with UTC and Locale.Root. This
will (always?) be a GregorianCalendar with a so-called "Gregorian Change Date" of 1582.public DateRangePrefixTree(Calendar templateCal)
DEFAULT_CAL and JAVA_UTIL_TIME_COMPAT_CAL.public int getNumSubCells(NumberRangePrefixTree.UnitNRShape lv)
NumberRangePrefixTreegetNumSubCells in class NumberRangePrefixTreepublic Calendar newCal()
Calendar passed to the constructor with all fields cleared.public int getTreeLevelForCalendarField(int calField)
Calendar field, such as
Calendar.YEAR. If there's no match, the next greatest level is returned as a negative value.public int getCalPrecisionField(Calendar cal)
public void clearFieldsAfter(Calendar cal, int field)
Calendar.clear(int) for every field after field. Beware of Calendar underflow.public NumberRangePrefixTree.UnitNRShape toUnitShape(Object value)
value from a Calendar or Date to a Shape. Other arguments
result in a IllegalArgumentException.
If a Calendar is passed in, there might be problems if it is not created via newCal().toUnitShape in class NumberRangePrefixTreepublic NumberRangePrefixTree.UnitNRShape toShape(Calendar cal)
newCal().public Object toObject(NumberRangePrefixTree.UnitNRShape shape)
toObject in class NumberRangePrefixTreepublic Calendar toCalendar(NumberRangePrefixTree.UnitNRShape lv)
NumberRangePrefixTree.UnitNRShape shape to a
corresponding Calendar that is cleared below its level.protected String toString(NumberRangePrefixTree.UnitNRShape lv)
NumberRangePrefixTreeNumberRangePrefixTree.parseUnitShape(String).toString in class NumberRangePrefixTreepublic String toString(Calendar cal)
DateTimeFormatter.ISO_INSTANT except
has no trailing 'Z', and will be truncated to the units given according to
Calendar.isSet(int).
A fully cleared calendar will yield the string "*".
The isSet() state of the Calendar is re-instated when done.protected NumberRangePrefixTree.UnitNRShape parseUnitShape(String str) throws ParseException
NumberRangePrefixTreeparseUnitShape in class NumberRangePrefixTreeParseExceptionpublic Calendar parseCalendar(String str) throws ParseException
toString(java.util.Calendar). It will only set the fields found, leaving
the remainder in an un-set state. A leading '-' or '+' is optional (positive assumed), and a
trailing 'Z' is also optional.str - not null and not emptyParseExceptionCopyright © 2000-2019 Apache Software Foundation. All Rights Reserved.