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.SnapshotStateNested 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_ATTRIBUTEFields 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 voidcheckAvailableColumns(@NotNull Collection<String> columns) Check this grid to ensure that allcolumnsare present.protected TreeTableImplcopy()Create a copy ofthiswith initially-sharedLiveAttributeMap.mutableAttributes.List<ColumnDefinition<?>>Get thedefinitionsfor all available columns that may be requested in a snapshot.Get a description of this HierarchicalTable.Get a re-usable, static keyTablewith zero rows that will cause a snapshot to expand only the default nodes.Get the identifier column from thetreeoperation.Get theTableDefinitionthat should be exposed to node table consumers, e.g.Get the parent identifier column from the {treeoperation.getRoot()Get the rootTablethat represents the top level of this HierarchicalTable.Get the name of a column that denotes row depth.Get the name of a column ofBooleansthat denotes whether a row is expanded (or expandable).Get the sourceTablethat was aggregated to make this HierarchicalTable.List<ColumnDefinition<?>>Get thedefinitionsfor all structural columns.Get arecorderfor per-node operations to apply during snapshots.Make a re-usable snapshot state.static TreeTablemakeTree(@NotNull QueryTable source, @NotNull ColumnName identifierColumn, @NotNull ColumnName parentIdentifierColumn) Create a new TreeTable based onnewSource, inheriting this TreeTable'sidentifier column,parent column,node filter columns, andnode operations.longsnapshot(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 withcolumnsdesignated for node-level filtering, in addition to any columns already so-designated onthisTreeTable.withNodeOperations(@NotNull TreeTable.NodeOperationsRecorder nodeOperations) Get a new TreeTable that will apply therecordedoperations to nodes when gathering snapshots.Methods inherited from class io.deephaven.engine.table.impl.BaseGridAttributes
clearSortingRestrictions, getSortableColumns, restrictSortTo, setColumnDescriptions, setLayoutHints, setSortableColumns, withColumnDescription, withColumnDescriptions, withDescriptionMethods inherited from class io.deephaven.engine.table.impl.LiveAttributeMap
copyAttributes, getAttribute, getAttributeKeys, getAttributes, getAttributes, hasAttribute, prepareReturnCopy, prepareReturnThis, published, retainingAttributes, setAttribute, setAttribute, withAttributes, withAttributes, withoutAttributesMethods inherited from class io.deephaven.engine.liveness.LivenessArtifact
manageWithCurrentScopeMethods inherited from class io.deephaven.engine.liveness.ReferenceCountedLivenessNode
getWeakReference, initializeTransientFieldsForLiveness, onReferenceCountAtZero, tryManage, tryUnmanage, tryUnmanageMethods inherited from class io.deephaven.engine.liveness.ReferenceCountedLivenessReferent
destroy, dropReference, tryRetainReferenceMethods inherited from class io.deephaven.util.referencecounting.ReferenceCounted
append, decrementReferenceCount, forceReferenceCountToZero, getReferenceCountDebug, incrementReferenceCount, resetReferenceCount, toString, tryDecrementReferenceCount, tryIncrementReferenceCountMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface io.deephaven.engine.table.AttributeMap
getAttribute, getAttributeKeys, getAttributes, getAttributes, hasAttribute, retainingAttributes, withAttributes, withAttributes, withoutAttributesMethods inherited from interface io.deephaven.engine.table.GridAttributes
clearSortingRestrictions, restrictSortTo, setLayoutHints, withColumnDescription, withColumnDescriptions, withDescriptionMethods inherited from interface io.deephaven.engine.table.hierarchical.HierarchicalTable
getRoot, getRowDepthColumn, getRowExpandedColumn, getSource, getStructuralColumnDefinitions, makeSnapshotState, snapshotMethods inherited from interface io.deephaven.engine.liveness.LivenessManager
manage, unmanage, unmanageMethods inherited from interface io.deephaven.engine.liveness.LivenessReferent
dropReference, getReferentDescription, getWeakReference, retainReference, tryRetainReference
-
Method Details
-
getDescription
Description copied from interface:HierarchicalTableGet a description of this HierarchicalTable.- Specified by:
getDescriptionin interfaceHierarchicalTable<TreeTable>- Returns:
- The description
-
getEmptyExpansionsTable
Description copied from interface:HierarchicalTableGet a re-usable, static keyTablewith zero rows that will cause a snapshot to expand only the default nodes.- Specified by:
getEmptyExpansionsTablein interfaceHierarchicalTable<TreeTable>- Returns:
- An empty key
Tablefor default expansions
-
getIdentifierColumn
Description copied from interface:TreeTableGet the identifier column from thetreeoperation.- Specified by:
getIdentifierColumnin interfaceTreeTable- Returns:
- The identifier column
-
getParentIdentifierColumn
Description copied from interface:TreeTableGet the parent identifier column from the {treeoperation.- Specified by:
getParentIdentifierColumnin interfaceTreeTable- Returns:
- The parent identifier column
-
getNodeDefinition
Description copied from interface:TreeTableGet theTableDefinitionthat 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 columnandrow-expanded column, but includes formatting columns.- Specified by:
getNodeDefinitionin interfaceTreeTable- Returns:
- The externally-visible node
TableDefinition
-
getAvailableColumnDefinitions
Description copied from interface:HierarchicalTableGet thedefinitionsfor 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:
getAvailableColumnDefinitionsin interfaceHierarchicalTable<TreeTable>- Returns:
- A list of
definitionsfor all available columns that may be requested in a snapshot
-
withNodeFilterColumns
Description copied from interface:TreeTableGet a new TreeTable withcolumnsdesignated for node-level filtering, in addition to any columns already so-designated onthisTreeTable.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:
withNodeFilterColumnsin interfaceTreeTable- Parameters:
columns- The columns to designate- Returns:
- The new TreeTable
-
withFilter
Description copied from interface:TreeTableApply a filter to the columns of this TreeTable in order to produce a new TreeTable.- Specified by:
withFilterin interfaceTreeTable- Parameters:
filter- The filter to apply- Returns:
- The new TreeTable
-
makeNodeOperationsRecorder
Description copied from interface:TreeTableGet arecorderfor per-node operations to apply during snapshots.- Specified by:
makeNodeOperationsRecorderin interfaceTreeTable- Returns:
- The new recorder
-
withNodeOperations
public TreeTable withNodeOperations(@NotNull @NotNull TreeTable.NodeOperationsRecorder nodeOperations) Description copied from interface:TreeTableGet a new TreeTable that will apply therecordedoperations to nodes when gathering snapshots.- Specified by:
withNodeOperationsin interfaceTreeTable- Parameters:
nodeOperations- The node-level operations to apply. Must have been initially supplied byTreeTable.makeNodeOperationsRecorder()fromthisTreeTable.- Returns:
- The new TreeTable
-
copy
Description copied from class:LiveAttributeMapCreate a copy ofthiswith initially-sharedLiveAttributeMap.mutableAttributes.- Specified by:
copyin classLiveAttributeMap<TreeTable,TreeTableImpl>
-
rebase
Description copied from interface:TreeTableCreate a new TreeTable based onnewSource, inheriting this TreeTable'sidentifier column,parent column,node filter columns, andnode operations. -
makeTree
public static TreeTable makeTree(@NotNull @NotNull QueryTable source, @NotNull @NotNull ColumnName identifierColumn, @NotNull @NotNull ColumnName parentIdentifierColumn) -
getSource
Description copied from interface:HierarchicalTableGet the sourceTablethat was aggregated to make this HierarchicalTable.- Specified by:
getSourcein interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>- Returns:
- The source table
-
getRoot
Description copied from interface:HierarchicalTableGet the rootTablethat represents the top level of this HierarchicalTable.- Specified by:
getRootin interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>- Returns:
- The root table
-
getRowExpandedColumn
Description copied from interface:HierarchicalTableGet the name of a column ofBooleansthat denotes whether a row is expanded (or expandable). It takes on the valuenullfor rows that are not expandable,falsefor expandable but unexpanded rows, andtruefor expanded rows. This column is "synthetic"; that is, it's not part of the data, but rather calculated as part of snapshotting.- Specified by:
getRowExpandedColumnin 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:HierarchicalTableGet 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:
getRowDepthColumnin interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>- Returns:
- The name of a column that denotes row depth
-
getStructuralColumnDefinitions
Description copied from interface:HierarchicalTableGet thedefinitionsfor 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 columnand therow-expanded column, but never includes type-specific node-level columns.- Specified by:
getStructuralColumnDefinitionsin interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>- Returns:
- A list of @link ColumnDefinition definitions} for all structural columns
-
makeSnapshotState
Description copied from interface:HierarchicalTableMake a re-usable snapshot state. The result will ensure liveness forthisHierarchicalTable if thesourceisRefreshing, and callers must similarly retain the result for the duration of their usage under the same conditions.- Specified by:
makeSnapshotStatein interfaceHierarchicalTable<IFACE_TYPE extends HierarchicalTable<IFACE_TYPE>>
-
checkAvailableColumns
Description copied from class:BaseGridAttributesCheck this grid to ensure that allcolumnsare present.- Specified by:
checkAvailableColumnsin 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:HierarchicalTableTake a snapshot of the data in the grid defined bycolumns,rows, and the directives inkeyTable. Accumulate the results indestinations.- Specified by:
snapshotin 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 ofbyteonkeyTablethat 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,nullto include all columnsrows- Position-space rows to include from the expanded data specified bykeyTabledestinations- The destinationchunks- Returns:
- The total expanded data size or an estimate thereof
-