Class TreeTableImpl
- All Implemented Interfaces:
LogOutputAppendable
,LivenessManager
,LivenessNode
,LivenessReferent
,AttributeMap<TreeTable>
,GridAttributes<TreeTable>
,HierarchicalTable<TreeTable>
,TreeTable
,Serializable
RollupTable
implementation.- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface io.deephaven.engine.table.hierarchical.HierarchicalTable
HierarchicalTable.SnapshotState
Nested classes/interfaces inherited from interface io.deephaven.engine.table.hierarchical.TreeTable
TreeTable.NodeOperationsRecorder
-
Field Summary
Fields inherited from interface io.deephaven.engine.table.GridAttributes
COLUMN_DESCRIPTIONS_ATTRIBUTE, DESCRIPTION_ATTRIBUTE, LAYOUT_HINTS_ATTRIBUTE, SORTABLE_COLUMNS_ATTRIBUTE
Fields inherited from interface io.deephaven.engine.table.hierarchical.HierarchicalTable
KEY_TABLE_ACTION_CONTRACT, KEY_TABLE_ACTION_EXPAND, KEY_TABLE_ACTION_EXPAND_ALL
-
Method Summary
Modifier and TypeMethodDescriptionprotected final void
checkAvailableColumns
(@NotNull Collection<String> columns) Check this grid to ensure that allcolumns
are present.protected TreeTableImpl
copy()
Create a copy ofthis
with initially-sharedLiveAttributeMap.mutableAttributes
.List<ColumnDefinition<?>>
Get thedefinitions
for all available columns that may be requested in a snapshot.Get a description of this HierarchicalTable.Get a re-usable, static keyTable
with zero rows that will cause a snapshot to expand only the default nodes.Get the identifier column from thetree
operation.Get theTableDefinition
that should be exposed to node table consumers, e.g.Get the parent identifier column from the {tree
operation.getRoot()
Get the rootTable
that represents the top level of this HierarchicalTable.Get the name of a column that denotes row depth.Get the name of a column ofBooleans
that denotes whether a row is expanded (or expandable).Get the sourceTable
that was aggregated to make this HierarchicalTable.List<ColumnDefinition<?>>
Get thedefinitions
for all structural columns.Get arecorder
for per-node operations to apply during snapshots.Make a re-usable snapshot state.static TreeTable
makeTree
(@NotNull QueryTable source, @NotNull ColumnName identifierColumn, @NotNull ColumnName parentIdentifierColumn) long
snapshot
(HierarchicalTable.SnapshotState snapshotState, @NotNull Table keyTable, @Nullable ColumnName keyTableActionColumn, @Nullable BitSet columns, @NotNull RowSequence rows, @NotNull WritableChunk<? super Values>[] destinations) Take a snapshot of the data in the grid defined bycolumns
,rows
, and the directives inkeyTable
.withFilter
(@NotNull Filter filter) Apply a filter to the columns of this TreeTable in order to produce a new TreeTable.withNodeFilterColumns
(@NotNull Collection<? extends ColumnName> columns) Get a new TreeTable withcolumns
designated for node-level filtering, in addition to any columns already so-designated onthis
TreeTable.withNodeOperations
(@NotNull TreeTable.NodeOperationsRecorder nodeOperations) Get a new TreeTable that will apply therecorded
operations to nodes when gathering snapshots.Methods inherited from class io.deephaven.engine.table.impl.BaseGridAttributes
clearSortingRestrictions, getSortableColumns, restrictSortTo, setColumnDescriptions, setLayoutHints, setSortableColumns, withColumnDescription, withColumnDescriptions, withDescription
Methods inherited from class io.deephaven.engine.table.impl.LiveAttributeMap
copyAttributes, getAttribute, getAttributeKeys, getAttributes, getAttributes, hasAttribute, prepareReturnCopy, prepareReturnThis, published, retainingAttributes, setAttribute, setAttribute, withAttributes, withAttributes, withoutAttributes
Methods inherited from class io.deephaven.engine.liveness.LivenessArtifact
manageWithCurrentScope
Methods inherited from class io.deephaven.engine.liveness.ReferenceCountedLivenessNode
getWeakReference, initializeTransientFieldsForLiveness, onReferenceCountAtZero, tryManage, tryUnmanage, tryUnmanage
Methods inherited from class io.deephaven.engine.liveness.ReferenceCountedLivenessReferent
destroy, dropReference, tryRetainReference
Methods inherited from class io.deephaven.util.referencecounting.ReferenceCounted
append, decrementReferenceCount, forceReferenceCountToZero, getReferenceCountDebug, incrementReferenceCount, resetReferenceCount, toString, tryDecrementReferenceCount, tryIncrementReferenceCount
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface io.deephaven.engine.table.AttributeMap
getAttribute, getAttributeKeys, getAttributes, getAttributes, hasAttribute, retainingAttributes, withAttributes, withAttributes, withoutAttributes
Methods inherited from interface io.deephaven.engine.table.GridAttributes
clearSortingRestrictions, restrictSortTo, setLayoutHints, withColumnDescription, withColumnDescriptions, withDescription
Methods inherited from interface io.deephaven.engine.table.hierarchical.HierarchicalTable
getRoot, getRowDepthColumn, getRowExpandedColumn, getSource, getStructuralColumnDefinitions, makeSnapshotState, snapshot
Methods inherited from interface io.deephaven.engine.liveness.LivenessManager
manage, unmanage, unmanage
Methods inherited from interface io.deephaven.engine.liveness.LivenessReferent
dropReference, getReferentDescription, getWeakReference, retainReference, tryRetainReference
-
Method Details
-
getDescription
Description copied from interface:HierarchicalTable
Get a description of this HierarchicalTable.- Specified by:
getDescription
in interfaceHierarchicalTable<TreeTable>
- Returns:
- The description
-
getEmptyExpansionsTable
Description copied from interface:HierarchicalTable
Get a re-usable, static keyTable
with zero rows that will cause a snapshot to expand only the default nodes.- Specified by:
getEmptyExpansionsTable
in interfaceHierarchicalTable<TreeTable>
- Returns:
- An empty key
Table
for default expansions
-
getIdentifierColumn
Description copied from interface:TreeTable
Get the identifier column from thetree
operation.- Specified by:
getIdentifierColumn
in interfaceTreeTable
- Returns:
- The identifier column
-
getParentIdentifierColumn
Description copied from interface:TreeTable
Get the parent identifier column from the {tree
operation.- Specified by:
getParentIdentifierColumn
in interfaceTreeTable
- Returns:
- The parent identifier column
-
getNodeDefinition
Description copied from interface:TreeTable
Get theTableDefinition
that should be exposed to node table consumers, e.g. UI-driven snapshots. This excludes "internal" columns used to organize the tree or support operations, as well as therow-depth column
androw-expanded column
, but includes formatting columns.- Specified by:
getNodeDefinition
in interfaceTreeTable
- Returns:
- The externally-visible node
TableDefinition
-
getAvailableColumnDefinitions
Description copied from interface:HierarchicalTable
Get thedefinitions
for all available columns that may be requested in a snapshot.The result will always begin with the
structural columns
, which are then followed by type-specific node-level columns.- Specified by:
getAvailableColumnDefinitions
in interfaceHierarchicalTable<TreeTable>
- Returns:
- A list of
definitions
for all available columns that may be requested in a snapshot
-
withNodeFilterColumns
Description copied from interface:TreeTable
Get a new TreeTable withcolumns
designated for node-level filtering, in addition to any columns already so-designated onthis
TreeTable.Filters specified via
TreeTable.withFilter(Filter)
, typically from the UI, that only use the designated node-level filtering columns will be applied to the nodes during snapshots. If no node-filter columns are designated, no filters will be handled at node level.Filters that include other columns are handled by filtering the source table in a ancestor-preserving manner and re-applying the tree operation to the result to produce a new TreeTable. Users of orphan promotion or other strategies to govern the structure of the tree should carefully consider the structure of their data before specifying node-filter columns.
Specifying node-filter columns represents a trade-off between performance (which is expected to be much better for node-level filtering) and tree structural integrity (which may be lost since node-level filters are not ancestor-preserving).
- Specified by:
withNodeFilterColumns
in interfaceTreeTable
- Parameters:
columns
- The columns to designate- Returns:
- The new TreeTable
-
withFilter
Description copied from interface:TreeTable
Apply a filter to the columns of this TreeTable in order to produce a new TreeTable.- Specified by:
withFilter
in interfaceTreeTable
- Parameters:
filter
- The filter to apply- Returns:
- The new TreeTable
-
makeNodeOperationsRecorder
Description copied from interface:TreeTable
Get arecorder
for per-node operations to apply during snapshots.- Specified by:
makeNodeOperationsRecorder
in interfaceTreeTable
- Returns:
- The new recorder
-
withNodeOperations
public TreeTable withNodeOperations(@NotNull @NotNull TreeTable.NodeOperationsRecorder nodeOperations) Description copied from interface:TreeTable
Get a new TreeTable that will apply therecorded
operations to nodes when gathering snapshots.- Specified by:
withNodeOperations
in interfaceTreeTable
- Parameters:
nodeOperations
- The node-level operations to apply. Must have been initially supplied byTreeTable.makeNodeOperationsRecorder()
fromthis
TreeTable.- Returns:
- The new TreeTable
-
copy
Description copied from class:LiveAttributeMap
Create a copy ofthis
with initially-sharedLiveAttributeMap.mutableAttributes
.- Specified by:
copy
in classLiveAttributeMap<TreeTable,
TreeTableImpl>
-
makeTree
public static TreeTable makeTree(@NotNull @NotNull QueryTable source, @NotNull @NotNull ColumnName identifierColumn, @NotNull @NotNull ColumnName parentIdentifierColumn) -
getSource
Description copied from interface:HierarchicalTable
Get the sourceTable
that was aggregated to make this HierarchicalTable.- Specified by:
getSource
in interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>
- Returns:
- The source table
-
getRoot
Description copied from interface:HierarchicalTable
Get the rootTable
that represents the top level of this HierarchicalTable.- Specified by:
getRoot
in interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>
- Returns:
- The root table
-
getRowExpandedColumn
Description copied from interface:HierarchicalTable
Get the name of a column ofBooleans
that denotes whether a row is expanded (or expandable). It takes on the valuenull
for rows that are not expandable,false
for expandable but unexpanded rows, andtrue
for expanded rows. This column is "synthetic"; that is, it's not part of the data, but rather calculated as part of snapshotting.- Specified by:
getRowExpandedColumn
in interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>
- Returns:
- The name of a column that denotes whether a row is expanded or expandable
-
getRowDepthColumn
Description copied from interface:HierarchicalTable
Get the name of a column that denotes row depth. This column is "synthetic"; that is, it's not part of the data, but rather calculated as part of snapshotting.- Specified by:
getRowDepthColumn
in interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>
- Returns:
- The name of a column that denotes row depth
-
getStructuralColumnDefinitions
Description copied from interface:HierarchicalTable
Get thedefinitions
for all structural columns. Structural columns are synthetic columns that allow snapshot consumers to make sense of the relationship between rows, and should always be included in the requested columns set when snapshotting a HierarchicalTable. This list includes therow-depth column
and therow-expanded column
, but never includes type-specific node-level columns.- Specified by:
getStructuralColumnDefinitions
in interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>
- Returns:
- A list of @link ColumnDefinition definitions} for all structural columns
-
makeSnapshotState
Description copied from interface:HierarchicalTable
Make a re-usable snapshot state. The result will ensure liveness forthis
HierarchicalTable if thesource
isRefreshing
, and callers must similarly retain the result for the duration of their usage under the same conditions.- Specified by:
makeSnapshotState
in interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>
-
checkAvailableColumns
Description copied from class:BaseGridAttributes
Check this grid to ensure that allcolumns
are present.- Specified by:
checkAvailableColumns
in classBaseGridAttributes<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>,
IMPL_TYPE extends io.deephaven.engine.table.impl.hierarchical.HierarchicalTableImpl<IFACE_TYPE, IMPL_TYPE>> - Parameters:
columns
- The column names to check
-
snapshot
public long snapshot(@NotNull HierarchicalTable.SnapshotState snapshotState, @NotNull @NotNull Table keyTable, @Nullable @Nullable ColumnName keyTableActionColumn, @Nullable @Nullable BitSet columns, @NotNull @NotNull RowSequence rows, @NotNull @NotNull WritableChunk<? super Values>[] destinations) Description copied from interface:HierarchicalTable
Take a snapshot of the data in the grid defined bycolumns
,rows
, and the directives inkeyTable
. Accumulate the results indestinations
.- Specified by:
snapshot
in interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>
- Parameters:
snapshotState
- Snapshot state object used to cache data across invocations. Must have been created by this HierarchicalTable withHierarchicalTable.makeSnapshotState()
.keyTable
- Type-specific "key" table specifying expanded and contracted nodeskeyTableActionColumn
- The name of a column ofbyte
onkeyTable
that specifies whether nodes should beexpanded
,expanded with their descendants
, orcontracted
. Ifnull
, all rows are treated assimple expansions
.columns
- Optional bit-set of columns to include,null
to include all columnsrows
- Position-space rows to include from the expanded data specified bykeyTable
destinations
- The destinationchunks
- Returns:
- The total expanded data size or an estimate thereof
-