//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
-wxDataViewModel *g_model = NULL;
+class wxDataViewCtrlInternal;
+
+wxDataViewCtrlInternal *g_internal = NULL;
class wxGtkTreeModelNode;
bool Cleared();
void Resort();
+ void SetSortOrder( GtkSortType sort_order ) { m_sort_order = sort_order; }
+ GtkSortType GetSortOrder() { return m_sort_order; }
+
protected:
void InitTree();
wxGtkTreeModelNode *FindNode( const wxDataViewItem &item );
wxDataViewModel *m_wx_model;
GtkWxTreeModel *m_gtk_model;
wxDataViewCtrl *m_owner;
+ GtkSortType m_sort_order;
};
m_parent = parent;
m_item = item;
m_internal = internal;
- g_model = internal->GetDataViewModel();
+ g_internal = internal;
m_children = new wxGtkTreeModelChildren( wxGtkTreeModelNodeCmp );
}
~wxGtkTreeModelNode()
{
- g_model = m_internal->GetDataViewModel();
+ g_internal = m_internal;
size_t count = m_children->GetCount();
size_t i;
for (i = 0; i < count; i++)
unsigned int AddNode( wxGtkTreeModelNode* child )
{
- g_model = m_internal->GetDataViewModel();
+ g_internal = m_internal;
m_nodes.Add( child );
return m_children->Add( child->GetItem().GetID() );
}
unsigned int AddLeave( void* id )
{
- g_model = m_internal->GetDataViewModel();
+ g_internal = m_internal;
return m_children->Add( id );
}
void DeleteChild( void* id )
{
- g_model = m_internal->GetDataViewModel();
+ g_internal = m_internal;
size_t pos;
size_t count = m_children->GetCount();
for (pos = 0; pos < count; pos++)
int LINKAGEMODE wxGtkTreeModelNodeCmp( void* id1, void* id2 )
{
- return g_model->Compare( id1, id2 );
+ int ret = g_internal->GetDataViewModel()->Compare( id1, id2 );
+ if (g_internal->GetSortOrder() == GTK_SORT_DESCENDING)
+ return -ret;
+ return ret;
}
//-----------------------------------------------------------------------------
*sort_column_id = tree_model->internal->GetDataViewModel()->GetSortingColumn();
if (order)
- {
- bool ascending = tree_model->internal->GetDataViewModel()->GetSortOrderAscending();
- if (ascending)
- *order = GTK_SORT_ASCENDING;
- else
- *order = GTK_SORT_DESCENDING;
- }
+ *order = tree_model->internal->GetSortOrder();
return TRUE;
}
-void wxgtk_tree_model_set_sort_column_id (GtkTreeSortable *sortable,
+void wxgtk_tree_model_set_sort_column_id (GtkTreeSortable *sortable,
gint sort_column_id,
GtkSortType order)
{
GtkWxTreeModel *tree_model = (GtkWxTreeModel *) sortable;
g_return_if_fail (GTK_IS_WX_TREE_MODEL (sortable) );
- bool ascending = TRUE;
- if (order != GTK_SORT_ASCENDING)
- ascending = FALSE;
-
if ((sort_column_id == (gint) tree_model->internal->GetDataViewModel()->GetSortingColumn()) &&
- (ascending == tree_model->internal->GetDataViewModel()->GetSortOrderAscending()))
+ (order == tree_model->internal->GetSortOrder()))
return;
tree_model->internal->GetDataViewModel()->SetSortingColumn( sort_column_id );
- tree_model->internal->GetDataViewModel()->SetSortOrderAscending( ascending );
+ tree_model->internal->SetSortOrder( order );
gtk_tree_sortable_sort_column_changed (sortable);
void wxGtkTreeModelNode::Resort()
{
- g_model = m_internal->GetDataViewModel();
+ g_internal = m_internal;
size_t child_count = GetChildCount();
if (child_count == 0)
m_wx_model = wx_model;
m_gtk_model = gtk_model;
m_root = NULL;
+ m_sort_order = GTK_SORT_ASCENDING;
InitTree();
}
bool wxDataViewCtrlInternal::ItemDeleted( const wxDataViewItem &parent, const wxDataViewItem &item )
{
- wxGtkTreeModelNode *parent = FindNode( parent );
- parent->DeleteChild( item.GetID() );
+ wxGtkTreeModelNode *parent_node = FindNode( parent );
+ parent_node->DeleteChild( item.GetID() );
wxDataViewEvent event( wxEVT_COMMAND_DATAVIEW_MODEL_ITEM_DELETED, m_owner->GetId() );
event.SetEventObject( m_owner );
gboolean wxDataViewCtrlInternal::get_iter( GtkTreeIter *iter, GtkTreePath *path )
{
- g_model = m_wx_model;
+ g_internal = this;
int depth = gtk_tree_path_get_depth( path );
GtkTreePath *wxDataViewCtrlInternal::get_path( GtkTreeIter *iter )
{
- g_model = m_wx_model;
+ g_internal = this;
GtkTreePath *retval = gtk_tree_path_new ();
void *id = iter->user_data;
GtkTreePath *wxDataViewCtrlInternal::get_path_safe( GtkTreeIter *iter )
{
- g_model = m_wx_model;
+ g_internal = this;
GtkTreePath *retval = gtk_tree_path_new ();
void *id = iter->user_data;
gboolean wxDataViewCtrlInternal::iter_next( GtkTreeIter *iter )
{
- g_model = m_wx_model;
+ g_internal = this;
wxGtkTreeModelNode *parent = FindParentNode( iter );
if( parent == NULL )
gboolean wxDataViewCtrlInternal::iter_children( GtkTreeIter *iter, GtkTreeIter *parent )
{
- g_model = m_wx_model;
+ g_internal = this;
wxDataViewItem item( (void*) parent->user_data );
gboolean wxDataViewCtrlInternal::iter_has_child( GtkTreeIter *iter )
{
- g_model = m_wx_model;
+ g_internal = this;
wxDataViewItem item( (void*) iter->user_data );
bool is_container = m_wx_model->IsContainer( item );
gint wxDataViewCtrlInternal::iter_n_children( GtkTreeIter *iter )
{
- g_model = m_wx_model;
+ g_internal = this;
wxDataViewItem item( (void*) iter->user_data );
gboolean wxDataViewCtrlInternal::iter_nth_child( GtkTreeIter *iter, GtkTreeIter *parent, gint n )
{
- g_model = m_wx_model;
+ g_internal = this;
void* id = NULL;
if (parent) id = (void*) parent->user_data;
gboolean wxDataViewCtrlInternal::iter_parent( GtkTreeIter *iter, GtkTreeIter *child )
{
- g_model = m_wx_model;
+ g_internal = this;
wxGtkTreeModelNode *node = FindParentNode( child );
if (!node)