Class CharAggregateColumnSource
java.lang.Object
com.illumon.iris.db.v2.sources.AbstractColumnSource<DB_ARRAY_TYPE>
com.illumon.iris.db.v2.sources.aggregate.CharAggregateColumnSource
- All Implemented Interfaces:
- AggregateColumnSource<DbCharArray,Character>,- ChunkSource<Attributes.Values>,- ChunkSource.WithPrev<Attributes.Values>,- DefaultChunkSource<Attributes.Values>,- DefaultChunkSource.WithPrev<Attributes.Values>,- FillContextMaker,- GetContextMaker,- ColumnSource<DbCharArray>,- ColumnSourceGetDefaults.ForObject<DbCharArray>,- ElementSource<DbCharArray>,- MutableColumnSource<DbCharArray>,- MutableColumnSourceGetDefaults.ForObject<DbCharArray>,- Releasable,- UngroupableColumnSource,- TupleExporter<DbCharArray>,- TupleSource<DbCharArray>,- Serializable
public final class CharAggregateColumnSource extends AbstractColumnSource<DB_ARRAY_TYPE>
ColumnSource implementation for aggregation result char columns.- See Also:
- Serialized Form
- 
Nested Class SummaryNested classes/interfaces inherited from class com.illumon.iris.db.v2.sources.AbstractColumnSourceAbstractColumnSource.DefaultedImmutable<DATA_TYPE>, AbstractColumnSource.DefaultedMutable<DATA_TYPE>, AbstractColumnSource.IsSerializableNested classes/interfaces inherited from interface com.illumon.iris.db.v2.sources.aggregate.AggregateColumnSourceAggregateColumnSource.AggregateColumnSourceConstructor, AggregateColumnSource.FactoryHelperNested classes/interfaces inherited from interface com.illumon.iris.db.v2.sources.chunk.ChunkSourceChunkSource.FillContext, ChunkSource.GetContext, ChunkSource.WithPrev<ATTR extends Attributes.Any>Nested classes/interfaces inherited from interface com.illumon.iris.db.v2.sources.chunk.DefaultChunkSourceDefaultChunkSource.SupportsContiguousGet<ATTR extends Attributes.Any>, DefaultChunkSource.WithPrev<ATTR extends Attributes.Any>
- 
Field SummaryFields inherited from interface com.illumon.iris.db.v2.sources.chunk.ChunkSourceDEFAULT_FILL_INSTANCE, ZERO_LENGTH_CHUNK_SOURCE_ARRAYFields inherited from interface com.illumon.iris.db.v2.sources.chunk.ChunkSource.WithPrevZERO_LENGTH_CHUNK_SOURCE_WITH_PREV_ARRAYFields inherited from interface com.illumon.iris.db.v2.sources.ColumnSourceZERO_LENGTH_COLUMN_SOURCE_ARRAY
- 
Method SummaryModifier and Type Method Description voidfillChunk(ChunkSource.FillContext context, WritableChunk<? super Attributes.Values> destination, OrderedKeys orderedKeys)Populates the given destination chunk with data corresponding to the keys from the givenOrderedKeys.voidfillPrevChunk(ChunkSource.FillContext context, WritableChunk<? super Attributes.Values> destination, OrderedKeys orderedKeys)Populates the given destination chunk with data corresponding to the keys from the givenOrderedKeys.DbCharArrayget(long index)Get the value from the source.DbCharArraygetPrev(long index)Get the previous value at the index.ObjectgetUngrouped(long groupIndexKey, int offsetInGroup)Reach into a grouped column source and pull one element out of the array.BooleangetUngroupedBoolean(long groupIndexKey, int offsetInGroup)bytegetUngroupedByte(long groupIndexKey, int offsetInGroup)chargetUngroupedChar(long groupIndexKey, int offsetInGroup)doublegetUngroupedDouble(long groupIndexKey, int offsetInGroup)floatgetUngroupedFloat(long groupIndexKey, int offsetInGroup)intgetUngroupedInt(long groupIndexKey, int offsetInGroup)longgetUngroupedLong(long groupIndexKey, int offsetInGroup)ObjectgetUngroupedPrev(long groupIndexKey, int offsetInGroup)BooleangetUngroupedPrevBoolean(long groupIndexKey, int offsetInGroup)bytegetUngroupedPrevByte(long groupIndexKey, int offsetInGroup)chargetUngroupedPrevChar(long groupIndexKey, int offsetInGroup)doublegetUngroupedPrevDouble(long groupIndexKey, int offsetInGroup)floatgetUngroupedPrevFloat(long groupIndexKey, int offsetInGroup)intgetUngroupedPrevInt(long groupIndexKey, int offsetInGroup)longgetUngroupedPrevLong(long groupIndexKey, int offsetInGroup)shortgetUngroupedPrevShort(long groupIndexKey, int offsetInGroup)longgetUngroupedPrevSize(long groupIndexKey)shortgetUngroupedShort(long groupIndexKey, int offsetInGroup)longgetUngroupedSize(long groupIndexKey)booleanisImmutable()Determine if this column source is immutable, meaning that the values at a given index key never change.booleanisUngroupable()Does this particular instance of the column source support ungrouping?ChunkSource.FillContextmakeFillContext(int chunkCapacity, SharedContext sharedContext)Allocate a newChunkSource.FillContextfor filling chunks from thisFillContextMaker, typically aChunkSource.voidstartTrackingPrevValues()ColumnSource implementations that track previous values have the option to not actually start tracking previous values until this method is called.UngroupedColumnSource<COMPONENT_TYPE>ungrouped()Methods inherited from class com.illumon.iris.db.v2.sources.AbstractColumnSourceallowsReinterpret, defaultFillChunk, doReinterpret, getComponentType, getGroupingBuilder, getGroupingProvider, getNativeType, getType, hasGrouping, isSerializable, match, reinterpret, setGroupingProviderMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.illumon.iris.db.v2.sources.ColumnSourceallowsReinterpret, cast, createPreviousTuple, createTuple, createTupleFromValues, exportElement, exportElement, exportToExternalKey, getColumnSources, getComponentType, getGroupingBuilder, getGroupingProvider, getNativeType, getPrevSource, getType, hasGrouping, match, reinterpret, releaseCachedResources, setGroupingProviderMethods inherited from interface com.illumon.iris.db.v2.sources.ColumnSourceGetDefaults.ForObjectgetBoolean, getByte, getChar, getDouble, getFloat, getInt, getLong, getShortMethods inherited from interface com.illumon.iris.db.v2.sources.chunk.DefaultChunkSourcegetChunk, getChunk, getChunkByFilling, makeGetContextMethods inherited from interface com.illumon.iris.db.v2.sources.chunk.DefaultChunkSource.WithPrevgetPrevChunk, getPrevChunk, getPrevChunkByFillingMethods inherited from interface com.illumon.iris.db.v2.sources.chunk.FillContextMakermakeFillContextMethods inherited from interface com.illumon.iris.db.v2.sources.chunk.GetContextMakermakeGetContextMethods inherited from interface com.illumon.iris.db.v2.sources.MutableColumnSourceGetDefaults.ForObjectgetPrevBoolean, getPrevByte, getPrevChar, getPrevDouble, getPrevFloat, getPrevInt, getPrevLong, getPrevShortMethods inherited from interface com.illumon.iris.db.v2.tuples.TupleExporterexportElementReinterpretedMethods inherited from interface com.illumon.iris.db.v2.tuples.TupleSourcecreateTupleFromReinterpretedValues
- 
Method Details- 
getDescription copied from interface:ElementSourceGet the value from the source. This may return boxed values for basic types.- Parameters:
- index- the location in index space to get the value from.
- Returns:
- the value at the index, potentially null.
 
- 
getPrevDescription copied from interface:ElementSourceGet the previous value at the index. Previous values are used during anLTMupdatecycle to process changes in data. Duringnormaloperation previous values will be identical tocurrentvalues.- Parameters:
- index- the location in index space to get the value from.
- Returns:
- the previous value at the index, or null.
 
- 
fillChunkpublic void fillChunk(@NotNull ChunkSource.FillContext context, @NotNull WritableChunk<? super Attributes.Values> destination, @NotNull OrderedKeys orderedKeys)Description copied from interface:ChunkSourcePopulates the given destination chunk with data corresponding to the keys from the givenOrderedKeys.- Specified by:
- fillChunkin interface- ChunkSource<Attributes.Values>
- Overrides:
- fillChunkin class- AbstractColumnSource<DbCharArray>
- Parameters:
- context- A context containing all mutable/state related data used in retrieving the Chunk.
- destination- The chunk to be populated according to- orderedKeys. No assumptions shall be made about the size of the chunk shall be made. The chunk will be populated from position [0,orderedKeys.size()).
- orderedKeys- An- OrderedKeysrepresenting the keys to be fetched
 
- 
fillPrevChunkpublic void fillPrevChunk(@NotNull ChunkSource.FillContext context, @NotNull WritableChunk<? super Attributes.Values> destination, @NotNull OrderedKeys orderedKeys)Description copied from interface:ChunkSource.WithPrevPopulates the given destination chunk with data corresponding to the keys from the givenOrderedKeys.- Specified by:
- fillPrevChunkin interface- ChunkSource.WithPrev<Attributes.Values>
- Overrides:
- fillPrevChunkin class- AbstractColumnSource<DbCharArray>
- Parameters:
- context- A context containing all mutable/state related data used in retrieving the Chunk.
- destination- The chunk to be populated according to- orderedKeys. No assumptions shall be made about the size of the chunk shall be made. The chunk will be populated from position [0,orderedKeys.size()).
- orderedKeys- An- OrderedKeysrepresenting the keys to be fetched
 
- 
ungrouped- Specified by:
- ungroupedin interface- AggregateColumnSource<DB_ARRAY_TYPE extends DbArrayBase,COMPONENT_TYPE>
 
- 
startTrackingPrevValuespublic final void startTrackingPrevValues()Description copied from interface:ColumnSourceColumnSource implementations that track previous values have the option to not actually start tracking previous values until this method is called. This is an option, not an obligation: some simple ColumnSource implementations (like TSingleValueSource for various T) always track previous values; other implementations (like PrevColumnSource) never do; some (like TArrayColumnSource) only start tracking once this method is called. An immutable column source can not have distinct prev values; therefore it is implemented as a no-op.- Specified by:
- startTrackingPrevValuesin interface- ColumnSource<DB_ARRAY_TYPE extends DbArrayBase>
 
- 
makeFillContextpublic final ChunkSource.FillContext makeFillContext(int chunkCapacity, SharedContext sharedContext)Description copied from interface:FillContextMakerAllocate a newChunkSource.FillContextfor filling chunks from thisFillContextMaker, typically aChunkSource.- Specified by:
- makeFillContextin interface- DefaultChunkSource<DB_ARRAY_TYPE extends DbArrayBase>
- Specified by:
- makeFillContextin interface- FillContextMaker
- Parameters:
- chunkCapacity- The maximum size of any- WritableChunkthat will be filled with this context
- sharedContext- Shared store of intermediate results.
- Returns:
- A context for use with fill operations
 
- 
isUngroupablepublic final boolean isUngroupable()Description copied from interface:UngroupableColumnSourceDoes this particular instance of the column source support ungrouping?- Specified by:
- isUngroupablein interface- UngroupableColumnSource
- Returns:
- true if you can call the getUngrouped family of methods and get a valid answer.
 
- 
getUngroupedSizepublic final long getUngroupedSize(long groupIndexKey)- Specified by:
- getUngroupedSizein interface- UngroupableColumnSource
- Parameters:
- groupIndexKey- the index within this column to interrogate
- Returns:
- the size of the DbArray at columnIndex.
 
- 
getUngroupedPrevSizepublic final long getUngroupedPrevSize(long groupIndexKey)- Specified by:
- getUngroupedPrevSizein interface- UngroupableColumnSource
 
- 
getUngroupedDescription copied from interface:UngroupableColumnSourceReach into a grouped column source and pull one element out of the array.- Specified by:
- getUngroupedin interface- UngroupableColumnSource
- Parameters:
- groupIndexKey- the index within the column of the cell to get
- offsetInGroup- the index within the array at the specified cell
- Returns:
- Equivalent to ((DbArray)columnSource.get(columnIndex)).get(arrayIndex)
 
- 
getUngroupedPrev- Specified by:
- getUngroupedPrevin interface- UngroupableColumnSource
 
- 
getUngroupedBoolean- Specified by:
- getUngroupedBooleanin interface- UngroupableColumnSource
 
- 
getUngroupedPrevBoolean- Specified by:
- getUngroupedPrevBooleanin interface- UngroupableColumnSource
 
- 
getUngroupedDoublepublic final double getUngroupedDouble(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedDoublein interface- UngroupableColumnSource
 
- 
getUngroupedPrevDoublepublic final double getUngroupedPrevDouble(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedPrevDoublein interface- UngroupableColumnSource
 
- 
getUngroupedFloatpublic final float getUngroupedFloat(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedFloatin interface- UngroupableColumnSource
 
- 
getUngroupedPrevFloatpublic final float getUngroupedPrevFloat(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedPrevFloatin interface- UngroupableColumnSource
 
- 
getUngroupedBytepublic final byte getUngroupedByte(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedBytein interface- UngroupableColumnSource
 
- 
getUngroupedPrevBytepublic final byte getUngroupedPrevByte(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedPrevBytein interface- UngroupableColumnSource
 
- 
getUngroupedCharpublic final char getUngroupedChar(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedCharin interface- UngroupableColumnSource
 
- 
getUngroupedPrevCharpublic final char getUngroupedPrevChar(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedPrevCharin interface- UngroupableColumnSource
 
- 
getUngroupedShortpublic final short getUngroupedShort(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedShortin interface- UngroupableColumnSource
 
- 
getUngroupedPrevShortpublic final short getUngroupedPrevShort(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedPrevShortin interface- UngroupableColumnSource
 
- 
getUngroupedIntpublic final int getUngroupedInt(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedIntin interface- UngroupableColumnSource
 
- 
getUngroupedPrevIntpublic final int getUngroupedPrevInt(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedPrevIntin interface- UngroupableColumnSource
 
- 
getUngroupedLongpublic final long getUngroupedLong(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedLongin interface- UngroupableColumnSource
 
- 
getUngroupedPrevLongpublic final long getUngroupedPrevLong(long groupIndexKey, int offsetInGroup)- Specified by:
- getUngroupedPrevLongin interface- UngroupableColumnSource
 
- 
isImmutablepublic boolean isImmutable()Description copied from interface:ColumnSourceDetermine if this column source is immutable, meaning that the values at a given index key never change.- Specified by:
- isImmutablein interface- ColumnSource<DB_ARRAY_TYPE extends DbArrayBase>
- Specified by:
- isImmutablein interface- MutableColumnSource<DB_ARRAY_TYPE extends DbArrayBase>
- Returns:
- true if the values at a given index of the column source never change, false otherwise
 
 
-