- java.lang.Object
-
- com.pervasive.datarush.sequences.scalar.AbstractScalarTokenSequence
-
- com.pervasive.datarush.sequences.scalar.DateTokenList
-
- All Implemented Interfaces:
MutableTokenSequence
,DateTokenSequence
,MutableDateTokenSequence
,MutableScalarTokenSequence
,ScalarTokenAppendable
,ScalarTokenSequence
,TokenAppendable
,TokenSequence
,ScalarTyped
,TokenTyped
public final class DateTokenList extends AbstractScalarTokenSequence implements MutableDateTokenSequence
Primary implementation ofMutableDateTokenSequence
.- See Also:
TokenTypeConstant.DATE
-
-
Constructor Summary
Constructors Constructor Description DateTokenList(int initialCapacity)
Create an empty array
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
append(CalendarDate value)
Appends the specified calendar date to this sequence.void
append(CalendarDate value, int count)
Appends the specified calendar date to this sequence.void
append(Date value)
Appends the specified date to this sequence.void
append(Date value, int count)
Appends the specified date to this sequence.void
appendEpochDays(long epochDays)
Appends the date specified as days elapsed since January 1, 1970 00:00:00 GMT to this sequence.void
appendEpochDays(long epochDays, int count)
Appends the date specified as days elapsed since January 1, 1970 00:00:00 GMT to this sequence multiple times.void
fillCalendarDate(int start, int length, CalendarDate value)
Sets the tokens in the specified subsequence to the specified calendar date.void
fillDate(int start, int length, Date value)
Sets the tokens in the specified subsequence to a date value specified as ajava.util.Date
object, relative to the default time zone.void
fillDate(int start, int length, Date value, TimeZone tz)
Sets the tokens in the specified subsequence to a date value specified as ajava.util.Date
object, relative to the given time zone.void
fillEpochDays(int start, int length, long days)
Sets the tokens in the specified subsequence to a date value specified as the number of days since Java epoch (January 1, 1970 GMT).void
fillValue(int start, int length, TokenValued value)
Sets the tokens in the specified subsequence to the given value.CalendarDate
getCalendarDate(int index)
Gets the value of the specified token as a calendar date.Date
getDate(int index)
Gets the value of the specified token as a date.Date
getDate(int index, TimeZone tz)
Gets the value of the specified token as a date interpreted in the given timezone.long
getEpochDays(int index)
Get the value of the specified token as the number of days elapsed since January 1, 1970 00:00:00 GMT.DateValued
getToken(int index)
Gets the value at the specified position.DateSettable
getTokenSetter(int index)
Returns a mutator for the given index.ScalarTokenType
getType()
Gets the data type of the tokens in the sequence.void
getValues(int index, long[] values, boolean[] nullFlags, int offset, int length)
Gets the values and null indicators for a range of tokens.boolean
isZero(int index)
Indicates whether the specified token has a zero value.DateValuedIterator
newValueIterator()
Creates an iterator over the non-null values of this sequence.void
setCalendarDate(int index, CalendarDate value)
Sets the token at the specified position to the specified calendar date.void
setDate(int index, Date value)
Sets the token at the specified position to a date value specified as ajava.util.Date
object, relative to the default time zone.void
setDate(int index, Date value, TimeZone tz)
Sets the token at the specified position to a date value specified as ajava.util.Date
object, relative to the given time zone.void
setEpochDays(int index, long days)
Sets the token at the specified position to a date value specified as the number of days since Java epoch (January 1, 1970 GMT).void
setNull(int index)
Sets the token at the specified position to be null valued.void
setNull(int start, int length)
Sets the tokens in the specified subsequence to be null valued.void
setValue(int index, TokenValued value)
Sets the token at the specified position to the given value.void
setValues(int start, TokenSequence values, int offset, int length)
Sets the tokens in the specified subsequence of the array to the corresponding values from a subsequence of the given source sequence.void
setZero(int index)
Sets the token at the specified position to be zero valued.void
setZero(int start, int length)
Sets the tokens in the specified subsequence to be zero valued.-
Methods inherited from class com.pervasive.datarush.sequences.scalar.AbstractScalarTokenSequence
append, append, append, append, appendNull, appendNull, appendZero, appendZero, capacity, compareElement, compareElements, ensureCanonical, getElementComparator, getModificationCount, hashCode, isNull, isNull, map, remaining, reset, size, toString, toString
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface com.pervasive.datarush.sequences.scalar.MutableScalarTokenSequence
ensureCanonical, getModificationCount
-
Methods inherited from interface com.pervasive.datarush.sequences.MutableTokenSequence
appendNull, appendNull, appendZero, appendZero, reset
-
Methods inherited from interface com.pervasive.datarush.sequences.scalar.ScalarTokenSequence
isNull
-
Methods inherited from interface com.pervasive.datarush.sequences.TokenAppendable
append, append, append, append
-
Methods inherited from interface com.pervasive.datarush.sequences.TokenSequence
compareElement, compareElements, getElementComparator, hashCode, isNull, size, toString
-
-
-
-
Method Detail
-
getType
public ScalarTokenType getType()
Description copied from interface:ScalarTokenSequence
Gets the data type of the tokens in the sequence.- Specified by:
getType
in interfaceScalarTokenSequence
- Specified by:
getType
in interfaceScalarTyped
- Specified by:
getType
in interfaceTokenTyped
- Returns:
- the token data type
-
getDate
public Date getDate(int index)
Description copied from interface:DateTokenSequence
Gets the value of the specified token as a date.- Specified by:
getDate
in interfaceDateTokenSequence
- Parameters:
index
- the position of the token in the sequence- Returns:
- the value of the token. If the
token is null valued,
null
is returned.
-
getDate
public Date getDate(int index, TimeZone tz)
Description copied from interface:DateTokenSequence
Gets the value of the specified token as a date interpreted in the given timezone.- Specified by:
getDate
in interfaceDateTokenSequence
- Parameters:
index
- the index of the tokentz
- the timezone relative to which to interpret the date.- Returns:
- the value of the token. If the
token is null valued,
null
is returned.
-
getEpochDays
public long getEpochDays(int index)
Description copied from interface:DateTokenSequence
Get the value of the specified token as the number of days elapsed since January 1, 1970 00:00:00 GMT.- Specified by:
getEpochDays
in interfaceDateTokenSequence
- Parameters:
index
- the index of the token- Returns:
- the value of the element. If the
token is null valued,
0
is returned.
-
getCalendarDate
public CalendarDate getCalendarDate(int index)
Description copied from interface:DateTokenSequence
Gets the value of the specified token as a calendar date.- Specified by:
getCalendarDate
in interfaceDateTokenSequence
- Parameters:
index
- the position of the token in the sequence- Returns:
- the value of the token. If the
token is null valued,
null
is returned.
-
getToken
public DateValued getToken(int index)
Description copied from interface:TokenSequence
Gets the value at the specified position.- Specified by:
getToken
in interfaceDateTokenSequence
- Specified by:
getToken
in interfaceScalarTokenSequence
- Specified by:
getToken
in interfaceTokenSequence
- Parameters:
index
- the index of the token- Returns:
- the value
-
getTokenSetter
public DateSettable getTokenSetter(int index)
Description copied from interface:MutableTokenSequence
Returns a mutator for the given index.- Specified by:
getTokenSetter
in interfaceMutableDateTokenSequence
- Specified by:
getTokenSetter
in interfaceMutableScalarTokenSequence
- Specified by:
getTokenSetter
in interfaceMutableTokenSequence
- Parameters:
index
- the position- Returns:
- a mutator for the given index.
-
getValues
public void getValues(int index, long[] values, boolean[] nullFlags, int offset, int length)
Description copied from interface:DateTokenSequence
Gets the values and null indicators for a range of tokens.- Specified by:
getValues
in interfaceDateTokenSequence
- Parameters:
index
- the starting index of the rangevalues
- an array into which to place element values, represented as epoch daysnullFlags
- an array into which to place null indicator valuesoffset
- the starting offset into the target arrays. That is,elements[offset]
andnulls[offset]
will get the value and null indicator respectively of the token at positionstart
, and so on.length
- number of tokens to get- See Also:
DateTokenSequence.getEpochDays(int)
-
setNull
public void setNull(int index)
Description copied from interface:MutableTokenSequence
Sets the token at the specified position to be null valued.- Specified by:
setNull
in interfaceMutableTokenSequence
- Parameters:
index
- the position of the token in the array
-
setNull
public void setNull(int start, int length)
Description copied from interface:MutableTokenSequence
Sets the tokens in the specified subsequence to be null valued.- Specified by:
setNull
in interfaceMutableTokenSequence
- Parameters:
start
- the starting index of the subsequence in the arraylength
- the length of the subsequence
-
setZero
public void setZero(int index)
Description copied from interface:MutableTokenSequence
Sets the token at the specified position to be zero valued.- Specified by:
setZero
in interfaceMutableTokenSequence
- Parameters:
index
- the position of the token in the array
-
setZero
public void setZero(int start, int length)
Description copied from interface:MutableTokenSequence
Sets the tokens in the specified subsequence to be zero valued.- Specified by:
setZero
in interfaceMutableTokenSequence
- Parameters:
start
- the starting index of the subsequence in the arraylength
- the length of the subsequence
-
isZero
public final boolean isZero(int index)
Description copied from interface:ScalarTokenSequence
Indicates whether the specified token has a zero value.- Specified by:
isZero
in interfaceScalarTokenSequence
- Parameters:
index
- the index of the token- Returns:
true
if the element is zero,false
otherwise
-
setDate
public void setDate(int index, Date value)
Sets the token at the specified position to a date value specified as ajava.util.Date
object, relative to the default time zone. The time zone returned byTimeZone.getDefault()
is used.- Parameters:
index
- the position of the token in the arrayvalue
- the date value to which to set the token, expressed as a point in time relative to the default time zone. Passingnull
is equivalent to callingsetNull(index
}.
-
fillDate
public void fillDate(int start, int length, Date value)
Sets the tokens in the specified subsequence to a date value specified as ajava.util.Date
object, relative to the default time zone.- Parameters:
start
- the starting index of the subsequence in the arraylength
- the length of the subsequencevalue
- the date value to which to set the tokens, expressed as a point in time relative to the default time zone. Passingnull
is equivalent to callingsetNull(start, length
}.
-
setDate
public void setDate(int index, Date value, TimeZone tz)
Sets the token at the specified position to a date value specified as ajava.util.Date
object, relative to the given time zone. The time zone returned byTimeZone.getDefault()
is used.- Parameters:
index
- the position of the token in the arrayvalue
- the date value to which to set the token, expressed as a point in time relative to the specified time zone. Passingnull
is equivalent to callingsetNull(index
}.tz
- the time zone in which the date should be interpreted
-
fillDate
public void fillDate(int start, int length, Date value, TimeZone tz)
Sets the tokens in the specified subsequence to a date value specified as ajava.util.Date
object, relative to the given time zone.- Parameters:
start
- the starting index of the subsequence in the arraylength
- the length of the subsequencevalue
- the date value to which to set the tokens, expressed as a point in time relative to the specified time zone. Passingnull
is equivalent to callingsetNull(start, length
}.tz
- the time zone in which the date should be interpreted
-
setEpochDays
public void setEpochDays(int index, long days)
Sets the token at the specified position to a date value specified as the number of days since Java epoch (January 1, 1970 GMT).- Specified by:
setEpochDays
in interfaceMutableDateTokenSequence
- Parameters:
days
- date value to which to set the token, expressed as the number of days since Java epochindex
- the position to modify
-
fillEpochDays
public void fillEpochDays(int start, int length, long days)
Sets the tokens in the specified subsequence to a date value specified as the number of days since Java epoch (January 1, 1970 GMT).- Parameters:
start
- the starting index of the subsequence in the arraylength
- the length of the subsequencedays
- date value to which to set the token, expressed as the number of days since Java epoch
-
setCalendarDate
public void setCalendarDate(int index, CalendarDate value)
Sets the token at the specified position to the specified calendar date.- Parameters:
index
- the position of the token in the arrayvalue
- the calendar date to which to set the token. Passingnull
is equivalent to callingsetNull(index
}.
-
fillCalendarDate
public void fillCalendarDate(int start, int length, CalendarDate value)
Sets the tokens in the specified subsequence to the specified calendar date.- Parameters:
start
- the starting index of the subsequence in the arraylength
- the length of the subsequencevalue
- the calendar date to which to set the tokens. Passingnull
is equivalent to callingsetNull(start, length
}.
-
setValue
public void setValue(int index, TokenValued value)
Description copied from interface:MutableTokenSequence
Sets the token at the specified position to the given value.- Specified by:
setValue
in interfaceMutableTokenSequence
- Parameters:
index
- the position of the token in the arrayvalue
- the value to which to set the token. This value must be of an appropriate type for the array.
-
fillValue
public void fillValue(int start, int length, TokenValued value)
Description copied from interface:MutableTokenSequence
Sets the tokens in the specified subsequence to the given value.- Specified by:
fillValue
in interfaceMutableTokenSequence
- Parameters:
start
- the starting index of the subsequence in the arraylength
- the length of the subsequencevalue
- the value to which to set the tokens. This value must be of an appropriate type for the array
-
setValues
public void setValues(int start, TokenSequence values, int offset, int length)
Description copied from interface:MutableTokenSequence
Sets the tokens in the specified subsequence of the array to the corresponding values from a subsequence of the given source sequence.- Specified by:
setValues
in interfaceMutableTokenSequence
- Parameters:
start
- the starting index of the subsequence in the arrayvalues
- the source sequence. This sequence must be of an appropriate type for the array.offset
- the starting index in the source sequence. Corresponding values will be taken relative to this position. That is, the value of the token at positionoffset
invalues
will be assigned to the token at positionstart
, and so on.length
- the number of tokens to copy
-
append
public void append(Date value)
Description copied from interface:MutableDateTokenSequence
Appends the specified date to this sequence.- Specified by:
append
in interfaceMutableDateTokenSequence
- Parameters:
value
- the value to append.
-
append
public void append(Date value, int count)
Description copied from interface:MutableDateTokenSequence
Appends the specified date to this sequence.- Specified by:
append
in interfaceMutableDateTokenSequence
- Parameters:
value
- the value to append.count
- the number of copies to append.
-
appendEpochDays
public void appendEpochDays(long epochDays)
Description copied from interface:MutableDateTokenSequence
Appends the date specified as days elapsed since January 1, 1970 00:00:00 GMT to this sequence.- Specified by:
appendEpochDays
in interfaceMutableDateTokenSequence
- Parameters:
epochDays
- the value to append.
-
appendEpochDays
public void appendEpochDays(long epochDays, int count)
Description copied from interface:MutableDateTokenSequence
Appends the date specified as days elapsed since January 1, 1970 00:00:00 GMT to this sequence multiple times.- Specified by:
appendEpochDays
in interfaceMutableDateTokenSequence
- Parameters:
epochDays
- the value to append.count
- the number of copies to append.
-
append
public void append(CalendarDate value)
Description copied from interface:MutableDateTokenSequence
Appends the specified calendar date to this sequence.- Specified by:
append
in interfaceMutableDateTokenSequence
- Parameters:
value
- the value to append.
-
append
public void append(CalendarDate value, int count)
Description copied from interface:MutableDateTokenSequence
Appends the specified calendar date to this sequence.- Specified by:
append
in interfaceMutableDateTokenSequence
- Parameters:
value
- the value to append.count
- the number of copies to append.
-
newValueIterator
public DateValuedIterator newValueIterator()
Description copied from interface:TokenSequence
Creates an iterator over the non-null values of this sequence. The iterator will automatically be reset as modifications are made to the sequence.- Specified by:
newValueIterator
in interfaceDateTokenSequence
- Specified by:
newValueIterator
in interfaceScalarTokenSequence
- Specified by:
newValueIterator
in interfaceTokenSequence
- Returns:
- an newly-created iterator over the non-null values of this sequence.
-
-