@ -301,12 +301,12 @@ bool ImGui::BeginTableEx(const char* name, ImGuiID id, int columns_count, ImG
table - > RawData . resize ( span_allocator . GetArenaSizeInBytes ( ) ) ;
table - > RawData . resize ( span_allocator . GetArenaSizeInBytes ( ) ) ;
span_allocator . SetArenaBasePtr ( table - > RawData . Data ) ;
span_allocator . SetArenaBasePtr ( table - > RawData . Data ) ;
span_allocator . GetSpan ( 0 , & table - > Columns ) ;
span_allocator . GetSpan ( 0 , & table - > Columns ) ;
span_allocator . GetSpan ( 1 , & table - > DisplayOrder ) ;
span_allocator . GetSpan ( 1 , & table - > DisplayOrder ToIndex ) ;
for ( int n = 0 ; n < columns_count ; n + + )
for ( int n = 0 ; n < columns_count ; n + + )
{
{
table - > Columns [ n ] = ImGuiTableColumn ( ) ;
table - > Columns [ n ] = ImGuiTableColumn ( ) ;
table - > Columns [ n ] . Index DisplayOrder = table - > DisplayOrder [ n ] = ( ImS8 ) n ;
table - > Columns [ n ] . DisplayOrder = table - > DisplayOrder ToIndex [ n ] = ( ImS8 ) n ;
}
}
table - > IsInitializing = table - > IsSettingsRequestLoad = table - > IsSortSpecsDirty = true ;
table - > IsInitializing = table - > IsSettingsRequestLoad = table - > IsSortSpecsDirty = true ;
}
}
@ -360,16 +360,16 @@ void ImGui::TableBeginUpdateColumns(ImGuiTable* table)
ImGuiTableColumn * src_column = & table - > Columns [ table - > ReorderColumn ] ;
ImGuiTableColumn * src_column = & table - > Columns [ table - > ReorderColumn ] ;
ImGuiTableColumn * dst_column = & table - > Columns [ ( reorder_dir = = - 1 ) ? src_column - > PrevActiveColumn : src_column - > NextActiveColumn ] ;
ImGuiTableColumn * dst_column = & table - > Columns [ ( reorder_dir = = - 1 ) ? src_column - > PrevActiveColumn : src_column - > NextActiveColumn ] ;
IM_UNUSED ( dst_column ) ;
IM_UNUSED ( dst_column ) ;
const int src_order = src_column - > Index DisplayOrder;
const int src_order = src_column - > DisplayOrder;
const int dst_order = dst_column - > Index DisplayOrder;
const int dst_order = dst_column - > DisplayOrder;
src_column - > Index DisplayOrder = ( ImS8 ) dst_order ;
src_column - > DisplayOrder = ( ImS8 ) dst_order ;
for ( int order_n = src_order + reorder_dir ; order_n ! = dst_order + reorder_dir ; order_n + = reorder_dir )
for ( int order_n = src_order + reorder_dir ; order_n ! = dst_order + reorder_dir ; order_n + = reorder_dir )
table - > Columns [ table - > DisplayOrder [ order_n ] ] . Index DisplayOrder - = ( ImS8 ) reorder_dir ;
table - > Columns [ table - > DisplayOrder ToIndex [ order_n ] ] . DisplayOrder - = ( ImS8 ) reorder_dir ;
IM_ASSERT ( dst_column - > Index DisplayOrder = = dst_order - reorder_dir ) ;
IM_ASSERT ( dst_column - > DisplayOrder = = dst_order - reorder_dir ) ;
// Display order is stored in both columns->IndexDisplayOrder and table->DisplayOrder[], rebuild the later from the former.
// Display order is stored in both columns->IndexDisplayOrder and table->DisplayOrder[], rebuild the later from the former.
for ( int column_n = 0 ; column_n < table - > ColumnsCount ; column_n + + )
for ( int column_n = 0 ; column_n < table - > ColumnsCount ; column_n + + )
table - > DisplayOrder [ table - > Columns [ column_n ] . Index DisplayOrder] = ( ImS8 ) column_n ;
table - > DisplayOrder ToIndex [ table - > Columns [ column_n ] . DisplayOrder] = ( ImS8 ) column_n ;
table - > ReorderColumnDir = 0 ;
table - > ReorderColumnDir = 0 ;
table - > IsSettingsDirty = true ;
table - > IsSettingsDirty = true ;
}
}
@ -379,7 +379,7 @@ void ImGui::TableBeginUpdateColumns(ImGuiTable* table)
if ( table - > IsResetDisplayOrderRequest )
if ( table - > IsResetDisplayOrderRequest )
{
{
for ( int n = 0 ; n < table - > ColumnsCount ; n + + )
for ( int n = 0 ; n < table - > ColumnsCount ; n + + )
table - > DisplayOrder [ n ] = table - > Columns [ n ] . Index DisplayOrder = ( ImS8 ) n ;
table - > DisplayOrder ToIndex [ n ] = table - > Columns [ n ] . DisplayOrder = ( ImS8 ) n ;
table - > IsResetDisplayOrderRequest = false ;
table - > IsResetDisplayOrderRequest = false ;
table - > IsSettingsDirty = true ;
table - > IsSettingsDirty = true ;
}
}
@ -391,7 +391,7 @@ void ImGui::TableBeginUpdateColumns(ImGuiTable* table)
bool want_column_auto_fit = false ;
bool want_column_auto_fit = false ;
for ( int order_n = 0 ; order_n < table - > ColumnsCount ; order_n + + )
for ( int order_n = 0 ; order_n < table - > ColumnsCount ; order_n + + )
{
{
const int column_n = table - > DisplayOrder [ order_n ] ;
const int column_n = table - > DisplayOrder ToIndex [ order_n ] ;
if ( column_n ! = order_n )
if ( column_n ! = order_n )
table - > IsDefaultDisplayOrder = false ;
table - > IsDefaultDisplayOrder = false ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
@ -411,7 +411,7 @@ void ImGui::TableBeginUpdateColumns(ImGuiTable* table)
want_column_auto_fit = true ;
want_column_auto_fit = true ;
ImU64 index_mask = ( ImU64 ) 1 < < column_n ;
ImU64 index_mask = ( ImU64 ) 1 < < column_n ;
ImU64 display_order_mask = ( ImU64 ) 1 < < column - > Index DisplayOrder;
ImU64 display_order_mask = ( ImU64 ) 1 < < column - > DisplayOrder;
if ( column - > IsActive )
if ( column - > IsActive )
{
{
column - > PrevActiveColumn = column - > NextActiveColumn = - 1 ;
column - > PrevActiveColumn = column - > NextActiveColumn = - 1 ;
@ -432,7 +432,7 @@ void ImGui::TableBeginUpdateColumns(ImGuiTable* table)
table - > ActiveMaskByIndex & = ~ index_mask ;
table - > ActiveMaskByIndex & = ~ index_mask ;
table - > ActiveMaskByDisplayOrder & = ~ display_order_mask ;
table - > ActiveMaskByDisplayOrder & = ~ display_order_mask ;
}
}
IM_ASSERT ( column - > IndexWithinActiveSet < = column - > Index DisplayOrder) ;
IM_ASSERT ( column - > IndexWithinActiveSet < = column - > DisplayOrder) ;
}
}
table - > VisibleMaskByIndex = table - > ActiveMaskByIndex ; // Columns will be masked out by TableUpdateLayout() when Clipped
table - > VisibleMaskByIndex = table - > ActiveMaskByIndex ; // Columns will be masked out by TableUpdateLayout() when Clipped
table - > RightMostActiveColumn = ( ImS8 ) ( last_active_column ? table - > Columns . index_from_ptr ( last_active_column ) : - 1 ) ;
table - > RightMostActiveColumn = ( ImS8 ) ( last_active_column ? table - > Columns . index_from_ptr ( last_active_column ) : - 1 ) ;
@ -549,7 +549,7 @@ void ImGui::TableUpdateLayout(ImGuiTable* table)
{
{
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
continue ;
continue ;
const int column_n = table - > DisplayOrder [ order_n ] ;
const int column_n = table - > DisplayOrder ToIndex [ order_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
// Adjust flags: default width mode + weighted columns are not allowed when auto extending
// Adjust flags: default width mode + weighted columns are not allowed when auto extending
@ -592,7 +592,7 @@ void ImGui::TableUpdateLayout(ImGuiTable* table)
column - > ResizeWeight = 1.0f ;
column - > ResizeWeight = 1.0f ;
total_weights + = column - > ResizeWeight ;
total_weights + = column - > ResizeWeight ;
if ( table - > LeftMostStretchedColumnDisplayOrder = = - 1 )
if ( table - > LeftMostStretchedColumnDisplayOrder = = - 1 )
table - > LeftMostStretchedColumnDisplayOrder = ( ImS8 ) column - > Index DisplayOrder;
table - > LeftMostStretchedColumnDisplayOrder = ( ImS8 ) column - > DisplayOrder;
}
}
}
}
@ -615,7 +615,7 @@ void ImGui::TableUpdateLayout(ImGuiTable* table)
{
{
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
continue ;
continue ;
ImGuiTableColumn * column = & table - > Columns [ table - > DisplayOrder [ order_n ] ] ;
ImGuiTableColumn * column = & table - > Columns [ table - > DisplayOrder ToIndex [ order_n ] ] ;
// Allocate width for stretched/weighted columns
// Allocate width for stretched/weighted columns
if ( column - > Flags & ImGuiTableColumnFlags_WidthStretch )
if ( column - > Flags & ImGuiTableColumnFlags_WidthStretch )
@ -678,7 +678,7 @@ void ImGui::TableUpdateLayout(ImGuiTable* table)
{
{
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
continue ;
continue ;
ImGuiTableColumn * column = & table - > Columns [ table - > DisplayOrder [ order_n ] ] ;
ImGuiTableColumn * column = & table - > Columns [ table - > DisplayOrder ToIndex [ order_n ] ] ;
if ( ! ( column - > Flags & ImGuiTableColumnFlags_WidthStretch ) )
if ( ! ( column - > Flags & ImGuiTableColumnFlags_WidthStretch ) )
continue ;
continue ;
column - > WidthRequested + = 1.0f ;
column - > WidthRequested + = 1.0f ;
@ -692,7 +692,7 @@ void ImGui::TableUpdateLayout(ImGuiTable* table)
ImRect host_clip_rect = table - > InnerClipRect ;
ImRect host_clip_rect = table - > InnerClipRect ;
for ( int order_n = 0 ; order_n < table - > ColumnsCount ; order_n + + )
for ( int order_n = 0 ; order_n < table - > ColumnsCount ; order_n + + )
{
{
const int column_n = table - > DisplayOrder [ order_n ] ;
const int column_n = table - > DisplayOrder ToIndex [ order_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
if ( table - > FreezeColumnsCount > 0 & & table - > FreezeColumnsCount = = active_n )
if ( table - > FreezeColumnsCount > 0 & & table - > FreezeColumnsCount = = active_n )
@ -844,7 +844,7 @@ void ImGui::TableUpdateBorders(ImGuiTable* table)
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
continue ;
continue ;
const int column_n = table - > DisplayOrder [ order_n ] ;
const int column_n = table - > DisplayOrder ToIndex [ order_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
// Detect hovered column:
// Detect hovered column:
@ -1049,7 +1049,7 @@ void ImGui::TableDrawBorders(ImGuiTable* table)
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
continue ;
continue ;
const int column_n = table - > DisplayOrder [ order_n ] ;
const int column_n = table - > DisplayOrder ToIndex [ order_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
const bool is_hovered = ( table - > HoveredColumnBorder = = column_n ) ;
const bool is_hovered = ( table - > HoveredColumnBorder = = column_n ) ;
const bool is_resized = ( table - > ResizedColumn = = column_n ) & & ( table - > InstanceInteracted = = table - > InstanceNo ) ;
const bool is_resized = ( table - > ResizedColumn = = column_n ) & & ( table - > InstanceInteracted = = table - > InstanceNo ) ;
@ -1190,7 +1190,7 @@ void ImGui::TableSetColumnWidth(ImGuiTable* table, ImGuiTableColumn* column_0, f
// [Resize Rule 3] If we are are followed by a fixed column and we have a Stretch column before, we need to
// [Resize Rule 3] If we are are followed by a fixed column and we have a Stretch column before, we need to
// ensure that our left border won't move, which we can do by making sure column_a/column_b resizes cancels each others.
// ensure that our left border won't move, which we can do by making sure column_a/column_b resizes cancels each others.
if ( column_1 & & ( column_1 - > Flags & ImGuiTableColumnFlags_WidthFixed ) )
if ( column_1 & & ( column_1 - > Flags & ImGuiTableColumnFlags_WidthFixed ) )
if ( table - > LeftMostStretchedColumnDisplayOrder ! = - 1 & & table - > LeftMostStretchedColumnDisplayOrder < column_0 - > Index DisplayOrder)
if ( table - > LeftMostStretchedColumnDisplayOrder ! = - 1 & & table - > LeftMostStretchedColumnDisplayOrder < column_0 - > DisplayOrder)
{
{
// (old_a + old_b == new_a + new_b) --> (new_a == old_a + old_b - new_b)
// (old_a + old_b == new_a + new_b) --> (new_a == old_a + old_b - new_b)
float column_1_width = ImMax ( column_1 - > WidthRequested - ( column_0_width - column_0 - > WidthRequested ) , min_width ) ;
float column_1_width = ImMax ( column_1 - > WidthRequested - ( column_0_width - column_0 - > WidthRequested ) , min_width ) ;
@ -1266,7 +1266,7 @@ void ImGui::TableDrawMergeChannels(ImGuiTable* table)
{
{
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
if ( ! ( table - > ActiveMaskByDisplayOrder & ( ( ImU64 ) 1 < < order_n ) ) )
continue ;
continue ;
const int column_n = table - > DisplayOrder [ order_n ] ;
const int column_n = table - > DisplayOrder ToIndex [ order_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
const int merge_group_sub_count = is_frozen_v ? 2 : 1 ;
const int merge_group_sub_count = is_frozen_v ? 2 : 1 ;
@ -2314,14 +2314,14 @@ void ImGui::TableSaveSettings(ImGuiTable* table)
{
{
//column_settings->WidthOrWeight = column->WidthRequested; // FIXME-WIP
//column_settings->WidthOrWeight = column->WidthRequested; // FIXME-WIP
column_settings - > Index = ( ImS8 ) n ;
column_settings - > Index = ( ImS8 ) n ;
column_settings - > DisplayOrder = column - > Index DisplayOrder;
column_settings - > DisplayOrder = column - > DisplayOrder;
column_settings - > SortOrder = column - > SortOrder ;
column_settings - > SortOrder = column - > SortOrder ;
column_settings - > SortDirection = column - > SortDirection ;
column_settings - > SortDirection = column - > SortDirection ;
column_settings - > Visible = column - > IsActive ;
column_settings - > Visible = column - > IsActive ;
// We skip saving some data in the .ini file when they are unnecessary to restore our state
// We skip saving some data in the .ini file when they are unnecessary to restore our state
// FIXME-TABLE: We don't have logic to easily compare SortOrder to DefaultSortOrder yet.
// FIXME-TABLE: We don't have logic to easily compare SortOrder to DefaultSortOrder yet.
if ( column - > Index DisplayOrder ! = n )
if ( column - > DisplayOrder ! = n )
settings - > SaveFlags | = ImGuiTableFlags_Reorderable ;
settings - > SaveFlags | = ImGuiTableFlags_Reorderable ;
if ( column_settings - > SortOrder ! = - 1 )
if ( column_settings - > SortOrder ! = - 1 )
settings - > SaveFlags | = ImGuiTableFlags_Sortable ;
settings - > SaveFlags | = ImGuiTableFlags_Sortable ;
@ -2366,7 +2366,7 @@ void ImGui::TableLoadSettings(ImGuiTable* table)
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
ImGuiTableColumn * column = & table - > Columns [ column_n ] ;
//column->WidthRequested = column_settings->WidthOrWeight; // FIXME-WIP
//column->WidthRequested = column_settings->WidthOrWeight; // FIXME-WIP
if ( column_settings - > DisplayOrder ! = - 1 )
if ( column_settings - > DisplayOrder ! = - 1 )
column - > Index DisplayOrder = column_settings - > DisplayOrder ;
column - > DisplayOrder = column_settings - > DisplayOrder ;
if ( column_settings - > SortOrder ! = - 1 )
if ( column_settings - > SortOrder ! = - 1 )
{
{
column - > SortOrder = column_settings - > SortOrder ;
column - > SortOrder = column_settings - > SortOrder ;
@ -2377,7 +2377,7 @@ void ImGui::TableLoadSettings(ImGuiTable* table)
// FIXME-TABLE: Need to validate .ini data
// FIXME-TABLE: Need to validate .ini data
for ( int column_n = 0 ; column_n < table - > ColumnsCount ; column_n + + )
for ( int column_n = 0 ; column_n < table - > ColumnsCount ; column_n + + )
table - > DisplayOrder [ table - > Columns [ column_n ] . Index DisplayOrder] = ( ImS8 ) column_n ;
table - > DisplayOrder ToIndex [ table - > Columns [ column_n ] . DisplayOrder] = ( ImS8 ) column_n ;
}
}
void * ImGui : : TableSettingsHandler_ReadOpen ( ImGuiContext * , ImGuiSettingsHandler * , const char * name )
void * ImGui : : TableSettingsHandler_ReadOpen ( ImGuiContext * , ImGuiSettingsHandler * , const char * name )
@ -2472,7 +2472,7 @@ void ImGui::DebugNodeTable(ImGuiTable* table)
" ContentWidth: RowsFrozen %d, RowsUnfrozen %d, HeadersUsed/Desired %d/%d \n "
" ContentWidth: RowsFrozen %d, RowsUnfrozen %d, HeadersUsed/Desired %d/%d \n "
" SortOrder: %d, SortDir: %s \n "
" SortOrder: %d, SortDir: %s \n "
" UserID: 0x%08X, Flags: 0x%04X: %s%s%s%s.. " ,
" UserID: 0x%08X, Flags: 0x%04X: %s%s%s%s.. " ,
n , column - > Index DisplayOrder, name ? name : " NULL " , column - > MinX - table - > WorkRect . Min . x , column - > MaxX - table - > WorkRect . Min . x ,
n , column - > DisplayOrder, name ? name : " NULL " , column - > MinX - table - > WorkRect . Min . x , column - > MaxX - table - > WorkRect . Min . x ,
column - > IsActive , column - > IsClipped , column - > DrawChannelRowsBeforeFreeze , column - > DrawChannelRowsAfterFreeze ,
column - > IsActive , column - > IsClipped , column - > DrawChannelRowsBeforeFreeze , column - > DrawChannelRowsAfterFreeze ,
column - > WidthGiven , column - > WidthRequested , column - > ResizeWeight ,
column - > WidthGiven , column - > WidthRequested , column - > ResizeWeight ,
column - > ContentWidthRowsFrozen , column - > ContentWidthRowsUnfrozen , column - > ContentWidthHeadersUsed , column - > ContentWidthHeadersDesired ,
column - > ContentWidthRowsFrozen , column - > ContentWidthRowsUnfrozen , column - > ContentWidthHeadersUsed , column - > ContentWidthHeadersDesired ,