forked from AuroraMiddleware/gtk
added ARG_WINDOW_PLACEMENT
Wed Nov 11 19:54:58 1998 Lars Hamann <lars@gtk.org> * gtk/gtkscrolledwindow.c (gtk_scrolled_window_class_init) (gtk_scrolled_window_set_arg) (gtk_scrolled_window_get_arg): added ARG_WINDOW_PLACEMENT * gtk/gtkclist.c (size_allocate_columns): resize column if column button > column width and auto_resize is set (real_clear) (column_auto_resize) (gtk_clist_optimal_column_width): consider column button width of auto resized columns (gtk_clist_parent_set): removed * gtk/gtkctree.c (gtk_ctree_insert_node): call column_auto_resize. (auto_resize_columns): auto_resize all columns (real_tree_collapse) (gtk_ctree_remove_node): call auto_resize_columns (column_auto_resize): respect column button width of auto resized columns
This commit is contained in:
parent
d5f4e60c56
commit
f164436f86
18
ChangeLog
18
ChangeLog
@ -1,3 +1,21 @@
|
|||||||
|
Wed Nov 11 19:54:58 1998 Lars Hamann <lars@gtk.org>
|
||||||
|
|
||||||
|
* gtk/gtkscrolledwindow.c (gtk_scrolled_window_class_init)
|
||||||
|
(gtk_scrolled_window_set_arg) (gtk_scrolled_window_get_arg):
|
||||||
|
added ARG_WINDOW_PLACEMENT
|
||||||
|
|
||||||
|
* gtk/gtkclist.c (size_allocate_columns): resize column if column
|
||||||
|
button > column width and auto_resize is set
|
||||||
|
(real_clear) (column_auto_resize) (gtk_clist_optimal_column_width):
|
||||||
|
consider column button width of auto resized columns
|
||||||
|
(gtk_clist_parent_set): removed
|
||||||
|
|
||||||
|
* gtk/gtkctree.c (gtk_ctree_insert_node): call column_auto_resize.
|
||||||
|
(auto_resize_columns): auto_resize all columns
|
||||||
|
(real_tree_collapse) (gtk_ctree_remove_node): call auto_resize_columns
|
||||||
|
(column_auto_resize): respect column button width of auto resized
|
||||||
|
columns
|
||||||
|
|
||||||
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
||||||
|
|
||||||
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
||||||
|
@ -1,3 +1,21 @@
|
|||||||
|
Wed Nov 11 19:54:58 1998 Lars Hamann <lars@gtk.org>
|
||||||
|
|
||||||
|
* gtk/gtkscrolledwindow.c (gtk_scrolled_window_class_init)
|
||||||
|
(gtk_scrolled_window_set_arg) (gtk_scrolled_window_get_arg):
|
||||||
|
added ARG_WINDOW_PLACEMENT
|
||||||
|
|
||||||
|
* gtk/gtkclist.c (size_allocate_columns): resize column if column
|
||||||
|
button > column width and auto_resize is set
|
||||||
|
(real_clear) (column_auto_resize) (gtk_clist_optimal_column_width):
|
||||||
|
consider column button width of auto resized columns
|
||||||
|
(gtk_clist_parent_set): removed
|
||||||
|
|
||||||
|
* gtk/gtkctree.c (gtk_ctree_insert_node): call column_auto_resize.
|
||||||
|
(auto_resize_columns): auto_resize all columns
|
||||||
|
(real_tree_collapse) (gtk_ctree_remove_node): call auto_resize_columns
|
||||||
|
(column_auto_resize): respect column button width of auto resized
|
||||||
|
columns
|
||||||
|
|
||||||
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
||||||
|
|
||||||
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
||||||
|
@ -1,3 +1,21 @@
|
|||||||
|
Wed Nov 11 19:54:58 1998 Lars Hamann <lars@gtk.org>
|
||||||
|
|
||||||
|
* gtk/gtkscrolledwindow.c (gtk_scrolled_window_class_init)
|
||||||
|
(gtk_scrolled_window_set_arg) (gtk_scrolled_window_get_arg):
|
||||||
|
added ARG_WINDOW_PLACEMENT
|
||||||
|
|
||||||
|
* gtk/gtkclist.c (size_allocate_columns): resize column if column
|
||||||
|
button > column width and auto_resize is set
|
||||||
|
(real_clear) (column_auto_resize) (gtk_clist_optimal_column_width):
|
||||||
|
consider column button width of auto resized columns
|
||||||
|
(gtk_clist_parent_set): removed
|
||||||
|
|
||||||
|
* gtk/gtkctree.c (gtk_ctree_insert_node): call column_auto_resize.
|
||||||
|
(auto_resize_columns): auto_resize all columns
|
||||||
|
(real_tree_collapse) (gtk_ctree_remove_node): call auto_resize_columns
|
||||||
|
(column_auto_resize): respect column button width of auto resized
|
||||||
|
columns
|
||||||
|
|
||||||
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
||||||
|
|
||||||
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
||||||
|
@ -1,3 +1,21 @@
|
|||||||
|
Wed Nov 11 19:54:58 1998 Lars Hamann <lars@gtk.org>
|
||||||
|
|
||||||
|
* gtk/gtkscrolledwindow.c (gtk_scrolled_window_class_init)
|
||||||
|
(gtk_scrolled_window_set_arg) (gtk_scrolled_window_get_arg):
|
||||||
|
added ARG_WINDOW_PLACEMENT
|
||||||
|
|
||||||
|
* gtk/gtkclist.c (size_allocate_columns): resize column if column
|
||||||
|
button > column width and auto_resize is set
|
||||||
|
(real_clear) (column_auto_resize) (gtk_clist_optimal_column_width):
|
||||||
|
consider column button width of auto resized columns
|
||||||
|
(gtk_clist_parent_set): removed
|
||||||
|
|
||||||
|
* gtk/gtkctree.c (gtk_ctree_insert_node): call column_auto_resize.
|
||||||
|
(auto_resize_columns): auto_resize all columns
|
||||||
|
(real_tree_collapse) (gtk_ctree_remove_node): call auto_resize_columns
|
||||||
|
(column_auto_resize): respect column button width of auto resized
|
||||||
|
columns
|
||||||
|
|
||||||
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
||||||
|
|
||||||
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
||||||
|
@ -1,3 +1,21 @@
|
|||||||
|
Wed Nov 11 19:54:58 1998 Lars Hamann <lars@gtk.org>
|
||||||
|
|
||||||
|
* gtk/gtkscrolledwindow.c (gtk_scrolled_window_class_init)
|
||||||
|
(gtk_scrolled_window_set_arg) (gtk_scrolled_window_get_arg):
|
||||||
|
added ARG_WINDOW_PLACEMENT
|
||||||
|
|
||||||
|
* gtk/gtkclist.c (size_allocate_columns): resize column if column
|
||||||
|
button > column width and auto_resize is set
|
||||||
|
(real_clear) (column_auto_resize) (gtk_clist_optimal_column_width):
|
||||||
|
consider column button width of auto resized columns
|
||||||
|
(gtk_clist_parent_set): removed
|
||||||
|
|
||||||
|
* gtk/gtkctree.c (gtk_ctree_insert_node): call column_auto_resize.
|
||||||
|
(auto_resize_columns): auto_resize all columns
|
||||||
|
(real_tree_collapse) (gtk_ctree_remove_node): call auto_resize_columns
|
||||||
|
(column_auto_resize): respect column button width of auto resized
|
||||||
|
columns
|
||||||
|
|
||||||
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
||||||
|
|
||||||
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
||||||
|
@ -1,3 +1,21 @@
|
|||||||
|
Wed Nov 11 19:54:58 1998 Lars Hamann <lars@gtk.org>
|
||||||
|
|
||||||
|
* gtk/gtkscrolledwindow.c (gtk_scrolled_window_class_init)
|
||||||
|
(gtk_scrolled_window_set_arg) (gtk_scrolled_window_get_arg):
|
||||||
|
added ARG_WINDOW_PLACEMENT
|
||||||
|
|
||||||
|
* gtk/gtkclist.c (size_allocate_columns): resize column if column
|
||||||
|
button > column width and auto_resize is set
|
||||||
|
(real_clear) (column_auto_resize) (gtk_clist_optimal_column_width):
|
||||||
|
consider column button width of auto resized columns
|
||||||
|
(gtk_clist_parent_set): removed
|
||||||
|
|
||||||
|
* gtk/gtkctree.c (gtk_ctree_insert_node): call column_auto_resize.
|
||||||
|
(auto_resize_columns): auto_resize all columns
|
||||||
|
(real_tree_collapse) (gtk_ctree_remove_node): call auto_resize_columns
|
||||||
|
(column_auto_resize): respect column button width of auto resized
|
||||||
|
columns
|
||||||
|
|
||||||
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
||||||
|
|
||||||
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
||||||
|
@ -1,3 +1,21 @@
|
|||||||
|
Wed Nov 11 19:54:58 1998 Lars Hamann <lars@gtk.org>
|
||||||
|
|
||||||
|
* gtk/gtkscrolledwindow.c (gtk_scrolled_window_class_init)
|
||||||
|
(gtk_scrolled_window_set_arg) (gtk_scrolled_window_get_arg):
|
||||||
|
added ARG_WINDOW_PLACEMENT
|
||||||
|
|
||||||
|
* gtk/gtkclist.c (size_allocate_columns): resize column if column
|
||||||
|
button > column width and auto_resize is set
|
||||||
|
(real_clear) (column_auto_resize) (gtk_clist_optimal_column_width):
|
||||||
|
consider column button width of auto resized columns
|
||||||
|
(gtk_clist_parent_set): removed
|
||||||
|
|
||||||
|
* gtk/gtkctree.c (gtk_ctree_insert_node): call column_auto_resize.
|
||||||
|
(auto_resize_columns): auto_resize all columns
|
||||||
|
(real_tree_collapse) (gtk_ctree_remove_node): call auto_resize_columns
|
||||||
|
(column_auto_resize): respect column button width of auto resized
|
||||||
|
columns
|
||||||
|
|
||||||
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
1998-11-10 Martin Baulig <baulig@merkur.uni-trier.de>
|
||||||
|
|
||||||
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
* gtk/gtkfeatures.h.in (GTK_HAVE_FEATURES_1_1_4): Define this so
|
||||||
|
@ -188,8 +188,6 @@ static gint gtk_clist_focus (GtkContainer *container,
|
|||||||
GtkDirectionType direction);
|
GtkDirectionType direction);
|
||||||
static void gtk_clist_style_set (GtkWidget *widget,
|
static void gtk_clist_style_set (GtkWidget *widget,
|
||||||
GtkStyle *previous_style);
|
GtkStyle *previous_style);
|
||||||
static void gtk_clist_parent_set (GtkWidget *widget,
|
|
||||||
GtkWidget *previous_parent);
|
|
||||||
|
|
||||||
/* GtkContainer Methods */
|
/* GtkContainer Methods */
|
||||||
static void gtk_clist_set_focus_child (GtkContainer *container,
|
static void gtk_clist_set_focus_child (GtkContainer *container,
|
||||||
@ -324,7 +322,8 @@ static void draw_rows (GtkCList *clist,
|
|||||||
|
|
||||||
/* Size Allocation / Requisition */
|
/* Size Allocation / Requisition */
|
||||||
static void size_allocate_title_buttons (GtkCList *clist);
|
static void size_allocate_title_buttons (GtkCList *clist);
|
||||||
static void size_allocate_columns (GtkCList *clist);
|
static void size_allocate_columns (GtkCList *clist,
|
||||||
|
gboolean block_resize);
|
||||||
static gint list_requisition_width (GtkCList *clist);
|
static gint list_requisition_width (GtkCList *clist);
|
||||||
|
|
||||||
/* Memory Allocation/Distruction Routines */
|
/* Memory Allocation/Distruction Routines */
|
||||||
@ -559,7 +558,6 @@ gtk_clist_class_init (GtkCListClass *klass)
|
|||||||
widget_class->focus_out_event = gtk_clist_focus_out;
|
widget_class->focus_out_event = gtk_clist_focus_out;
|
||||||
widget_class->draw_focus = gtk_clist_draw_focus;
|
widget_class->draw_focus = gtk_clist_draw_focus;
|
||||||
widget_class->style_set = gtk_clist_style_set;
|
widget_class->style_set = gtk_clist_style_set;
|
||||||
widget_class->parent_set = gtk_clist_parent_set;
|
|
||||||
|
|
||||||
/* container_class->add = NULL; use the default GtkContainerClass warning */
|
/* container_class->add = NULL; use the default GtkContainerClass warning */
|
||||||
/* container_class->remove=NULL; use the default GtkContainerClass warning */
|
/* container_class->remove=NULL; use the default GtkContainerClass warning */
|
||||||
@ -1530,7 +1528,7 @@ gtk_clist_optimal_column_width (GtkCList *clist,
|
|||||||
{
|
{
|
||||||
GtkRequisition requisition;
|
GtkRequisition requisition;
|
||||||
GList *list;
|
GList *list;
|
||||||
gint width = 0;
|
gint width;
|
||||||
|
|
||||||
g_return_val_if_fail (clist != NULL, 0);
|
g_return_val_if_fail (clist != NULL, 0);
|
||||||
g_return_val_if_fail (GTK_CLIST (clist), 0);
|
g_return_val_if_fail (GTK_CLIST (clist), 0);
|
||||||
@ -1538,6 +1536,12 @@ gtk_clist_optimal_column_width (GtkCList *clist,
|
|||||||
if (column < 0 || column > clist->columns)
|
if (column < 0 || column > clist->columns)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (GTK_CLIST_SHOW_TITLES (clist) && clist->column[column].button)
|
||||||
|
width = (clist->column[column].button->requisition.width -
|
||||||
|
(CELL_SPACING + (2 * COLUMN_INSET)));
|
||||||
|
else
|
||||||
|
width = 0;
|
||||||
|
|
||||||
for (list = clist->row_list; list; list = list->next)
|
for (list = clist->row_list; list; list = list->next)
|
||||||
{
|
{
|
||||||
GTK_CLIST_CLASS_FW (clist)->cell_size_request
|
GTK_CLIST_CLASS_FW (clist)->cell_size_request
|
||||||
@ -1633,19 +1637,14 @@ column_auto_resize (GtkCList *clist,
|
|||||||
GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (clist_row)
|
||||||
GTK_CLIST_CLASS_FW (clist)->cell_size_request (clist, clist_row,
|
GTK_CLIST_CLASS_FW (clist)->cell_size_request (clist, clist_row,
|
||||||
column, &requisition);
|
column, &requisition);
|
||||||
|
else
|
||||||
|
requisition.width = 0;
|
||||||
|
|
||||||
if (requisition.width > clist->column[column].width)
|
if (requisition.width > clist->column[column].width)
|
||||||
{
|
|
||||||
if (clist->column[column].max_width < 0)
|
|
||||||
gtk_clist_set_column_width (clist, column, requisition.width);
|
gtk_clist_set_column_width (clist, column, requisition.width);
|
||||||
else if (clist->column[column].max_width >
|
|
||||||
clist->column[column].width)
|
|
||||||
gtk_clist_set_column_width (clist, column,
|
|
||||||
MIN (requisition.width,
|
|
||||||
clist->column[column].max_width));
|
|
||||||
}
|
|
||||||
else if (requisition.width < old_width &&
|
else if (requisition.width < old_width &&
|
||||||
old_width == clist->column[column].width)
|
old_width == clist->column[column].width)
|
||||||
{
|
{
|
||||||
@ -1654,7 +1653,12 @@ column_auto_resize (GtkCList *clist,
|
|||||||
|
|
||||||
/* run a "gtk_clist_optimal_column_width" but break, if
|
/* run a "gtk_clist_optimal_column_width" but break, if
|
||||||
* the column doesn't shrink */
|
* the column doesn't shrink */
|
||||||
|
if (GTK_CLIST_SHOW_TITLES (clist) && clist->column[column].button)
|
||||||
|
new_width = (clist->column[column].button->requisition.width -
|
||||||
|
(CELL_SPACING + (2 * COLUMN_INSET)));
|
||||||
|
else
|
||||||
new_width = 0;
|
new_width = 0;
|
||||||
|
|
||||||
for (list = clist->row_list; list; list = list->next)
|
for (list = clist->row_list; list; list = list->next)
|
||||||
{
|
{
|
||||||
GTK_CLIST_CLASS_FW (clist)->cell_size_request
|
GTK_CLIST_CLASS_FW (clist)->cell_size_request
|
||||||
@ -1693,7 +1697,7 @@ real_resize_column (GtkCList *clist,
|
|||||||
* been size_allocated yet, and pointless. Should
|
* been size_allocated yet, and pointless. Should
|
||||||
* a flag be kept
|
* a flag be kept
|
||||||
*/
|
*/
|
||||||
size_allocate_columns (clist);
|
size_allocate_columns (clist, TRUE);
|
||||||
size_allocate_title_buttons (clist);
|
size_allocate_title_buttons (clist);
|
||||||
|
|
||||||
if (!GTK_CLIST_FROZEN (clist))
|
if (!GTK_CLIST_FROZEN (clist))
|
||||||
@ -1804,7 +1808,8 @@ size_allocate_title_buttons (GtkCList *clist)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
size_allocate_columns (GtkCList *clist)
|
size_allocate_columns (GtkCList *clist,
|
||||||
|
gboolean block_resize)
|
||||||
{
|
{
|
||||||
gint xoffset = CELL_SPACING + COLUMN_INSET;
|
gint xoffset = CELL_SPACING + COLUMN_INSET;
|
||||||
gint last_column;
|
gint last_column;
|
||||||
@ -1824,6 +1829,18 @@ size_allocate_columns (GtkCList *clist)
|
|||||||
clist->column[i].area.x = xoffset;
|
clist->column[i].area.x = xoffset;
|
||||||
if (clist->column[i].width_set)
|
if (clist->column[i].width_set)
|
||||||
{
|
{
|
||||||
|
if (!block_resize && GTK_CLIST_SHOW_TITLES (clist) &&
|
||||||
|
clist->column[i].auto_resize && clist->column[i].button)
|
||||||
|
{
|
||||||
|
gint width;
|
||||||
|
|
||||||
|
width = (clist->column[i].button->requisition.width -
|
||||||
|
(CELL_SPACING + (2 * COLUMN_INSET)));
|
||||||
|
|
||||||
|
if (width > clist->column[i].width)
|
||||||
|
gtk_clist_set_column_width (clist, i, width);
|
||||||
|
}
|
||||||
|
|
||||||
clist->column[i].area.width = clist->column[i].width;
|
clist->column[i].area.width = clist->column[i].width;
|
||||||
xoffset += clist->column[i].width + CELL_SPACING + (2* COLUMN_INSET);
|
xoffset += clist->column[i].width + CELL_SPACING + (2* COLUMN_INSET);
|
||||||
}
|
}
|
||||||
@ -2670,9 +2687,15 @@ real_clear (GtkCList *clist)
|
|||||||
g_list_free (free_list);
|
g_list_free (free_list);
|
||||||
GTK_CLIST_UNSET_FLAG (clist, CLIST_AUTO_RESIZE_BLOCKED);
|
GTK_CLIST_UNSET_FLAG (clist, CLIST_AUTO_RESIZE_BLOCKED);
|
||||||
for (i = 0; i < clist->columns; i++)
|
for (i = 0; i < clist->columns; i++)
|
||||||
if (clist->column[i].auto_resize && clist->column[i].width > 0)
|
if (clist->column[i].auto_resize)
|
||||||
|
{
|
||||||
|
if (GTK_CLIST_SHOW_TITLES (clist) && clist->column[i].button)
|
||||||
|
gtk_clist_set_column_width
|
||||||
|
(clist, i, (clist->column[i].button->requisition.width -
|
||||||
|
(CELL_SPACING + (2 * COLUMN_INSET))));
|
||||||
|
else
|
||||||
gtk_clist_set_column_width (clist, i, 0);
|
gtk_clist_set_column_width (clist, i, 0);
|
||||||
|
}
|
||||||
/* zero-out the scrollbars */
|
/* zero-out the scrollbars */
|
||||||
if (clist->vadjustment)
|
if (clist->vadjustment)
|
||||||
{
|
{
|
||||||
@ -3034,11 +3057,8 @@ gtk_clist_set_row_style (GtkCList *clist,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
if (GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
||||||
{
|
|
||||||
for (i = 0; i < clist->columns; i++)
|
for (i = 0; i < clist->columns; i++)
|
||||||
if (clist->column[i].auto_resize)
|
|
||||||
column_auto_resize (clist, clist_row, i, old_width[i]);
|
column_auto_resize (clist, clist_row, i, old_width[i]);
|
||||||
}
|
|
||||||
|
|
||||||
g_free (old_width);
|
g_free (old_width);
|
||||||
|
|
||||||
@ -4086,7 +4106,6 @@ gtk_clist_finalize (GtkObject *object)
|
|||||||
* gtk_clist_draw
|
* gtk_clist_draw
|
||||||
* gtk_clist_expose
|
* gtk_clist_expose
|
||||||
* gtk_clist_style_set
|
* gtk_clist_style_set
|
||||||
* gtk_clist_parent_set
|
|
||||||
* gtk_clist_key_press
|
* gtk_clist_key_press
|
||||||
* gtk_clist_button_press
|
* gtk_clist_button_press
|
||||||
* gtk_clist_button_release
|
* gtk_clist_button_release
|
||||||
@ -4513,24 +4532,6 @@ gtk_clist_style_set (GtkWidget *widget,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
gtk_clist_parent_set (GtkWidget *widget,
|
|
||||||
GtkWidget *previous_parent)
|
|
||||||
{
|
|
||||||
GtkCList *clist;
|
|
||||||
|
|
||||||
g_return_if_fail (widget != NULL);
|
|
||||||
g_return_if_fail (GTK_IS_WIDGET (widget));
|
|
||||||
|
|
||||||
clist = GTK_CLIST (widget);
|
|
||||||
|
|
||||||
/* create adjustments */
|
|
||||||
/* if (!clist->hadjustment)
|
|
||||||
gtk_clist_set_hadjustment (clist, NULL);
|
|
||||||
if (!clist->vadjustment)
|
|
||||||
gtk_clist_set_vadjustment (clist, NULL);*/
|
|
||||||
}
|
|
||||||
|
|
||||||
static gint
|
static gint
|
||||||
gtk_clist_key_press (GtkWidget *widget,
|
gtk_clist_key_press (GtkWidget *widget,
|
||||||
GdkEventKey *event)
|
GdkEventKey *event)
|
||||||
@ -5177,7 +5178,7 @@ gtk_clist_size_allocate (GtkWidget *widget,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* column button allocation */
|
/* column button allocation */
|
||||||
size_allocate_columns (clist);
|
size_allocate_columns (clist, FALSE);
|
||||||
size_allocate_title_buttons (clist);
|
size_allocate_title_buttons (clist);
|
||||||
|
|
||||||
adjust_adjustments (clist, TRUE);
|
adjust_adjustments (clist, TRUE);
|
||||||
|
@ -228,6 +228,7 @@ static void column_auto_resize (GtkCList *clist,
|
|||||||
GtkCListRow *clist_row,
|
GtkCListRow *clist_row,
|
||||||
gint column,
|
gint column,
|
||||||
gint old_width);
|
gint old_width);
|
||||||
|
static void auto_resize_columns (GtkCList *clist);
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
@ -2860,31 +2861,7 @@ real_tree_collapse (GtkCTree *ctree,
|
|||||||
if (visible)
|
if (visible)
|
||||||
{
|
{
|
||||||
/* resize auto_resize columns if needed */
|
/* resize auto_resize columns if needed */
|
||||||
if (!GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
auto_resize_columns (clist);
|
||||||
{
|
|
||||||
GList *list;
|
|
||||||
gint new_width;
|
|
||||||
gint i;
|
|
||||||
|
|
||||||
for (i = 0; i < clist->columns; i++)
|
|
||||||
if (clist->column[i].auto_resize)
|
|
||||||
{
|
|
||||||
/* run a "gtk_clist_optimal_column_width" but break, if
|
|
||||||
* the column doesn't shrink */
|
|
||||||
new_width = 0;
|
|
||||||
for (list = clist->row_list; list; list = list->next)
|
|
||||||
{
|
|
||||||
GTK_CLIST_CLASS_FW (clist)->cell_size_request
|
|
||||||
(clist, GTK_CLIST_ROW (list), i, &requisition);
|
|
||||||
new_width = MAX (new_width, requisition.width);
|
|
||||||
if (new_width == clist->column[i].width)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (new_width < clist->column[i].width)
|
|
||||||
gtk_clist_set_column_width (clist, i, new_width);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
row = g_list_position (clist->row_list, (GList *)node);
|
row = g_list_position (clist->row_list, (GList *)node);
|
||||||
if (row < clist->focus_row)
|
if (row < clist->focus_row)
|
||||||
@ -2915,26 +2892,28 @@ column_auto_resize (GtkCList *clist,
|
|||||||
GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (clist_row)
|
||||||
GTK_CLIST_CLASS_FW (clist)->cell_size_request (clist, clist_row,
|
GTK_CLIST_CLASS_FW (clist)->cell_size_request (clist, clist_row,
|
||||||
column, &requisition);
|
column, &requisition);
|
||||||
|
else
|
||||||
|
requisition.width = 0;
|
||||||
|
|
||||||
if (requisition.width > clist->column[column].width)
|
if (requisition.width > clist->column[column].width)
|
||||||
{
|
|
||||||
if (clist->column[column].max_width < 0)
|
|
||||||
gtk_clist_set_column_width (clist, column, requisition.width);
|
gtk_clist_set_column_width (clist, column, requisition.width);
|
||||||
else if (clist->column[column].max_width > clist->column[column].width)
|
|
||||||
gtk_clist_set_column_width (clist, column,
|
|
||||||
MIN (requisition.width,
|
|
||||||
clist->column[column].max_width));
|
|
||||||
}
|
|
||||||
else if (requisition.width < old_width &&
|
else if (requisition.width < old_width &&
|
||||||
old_width == clist->column[column].width)
|
old_width == clist->column[column].width)
|
||||||
{
|
{
|
||||||
GList *list;
|
GList *list;
|
||||||
gint new_width = 0;
|
gint new_width;
|
||||||
|
|
||||||
/* run a "gtk_clist_optimal_column_width" but break, if
|
/* run a "gtk_clist_optimal_column_width" but break, if
|
||||||
* the column doesn't shrink */
|
* the column doesn't shrink */
|
||||||
|
if (GTK_CLIST_SHOW_TITLES (clist) && clist->column[column].button)
|
||||||
|
new_width = (clist->column[column].button->requisition.width -
|
||||||
|
(CELL_SPACING + (2 * COLUMN_INSET)));
|
||||||
|
else
|
||||||
|
new_width = 0;
|
||||||
|
|
||||||
for (list = clist->row_list; list; list = list->next)
|
for (list = clist->row_list; list; list = list->next)
|
||||||
{
|
{
|
||||||
GTK_CLIST_CLASS_FW (clist)->cell_size_request
|
GTK_CLIST_CLASS_FW (clist)->cell_size_request
|
||||||
@ -2944,11 +2923,22 @@ column_auto_resize (GtkCList *clist,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (new_width < clist->column[column].width)
|
if (new_width < clist->column[column].width)
|
||||||
gtk_clist_set_column_width
|
gtk_clist_set_column_width (clist, column, new_width);
|
||||||
(clist, column, MAX (new_width, clist->column[column].min_width));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
auto_resize_columns (GtkCList *clist)
|
||||||
|
{
|
||||||
|
gint i;
|
||||||
|
|
||||||
|
if (GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (i = 0; i < clist->columns; i++)
|
||||||
|
column_auto_resize (clist, NULL, i, clist->column[i].width);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
cell_size_request (GtkCList *clist,
|
cell_size_request (GtkCList *clist,
|
||||||
GtkCListRow *clist_row,
|
GtkCListRow *clist_row,
|
||||||
@ -3875,17 +3865,9 @@ gtk_ctree_insert_node (GtkCTree *ctree,
|
|||||||
if (text && !GTK_CLIST_AUTO_RESIZE_BLOCKED (clist) &&
|
if (text && !GTK_CLIST_AUTO_RESIZE_BLOCKED (clist) &&
|
||||||
gtk_ctree_is_viewable (ctree, node))
|
gtk_ctree_is_viewable (ctree, node))
|
||||||
{
|
{
|
||||||
GtkRequisition requisition;
|
|
||||||
|
|
||||||
for (i = 0; i < clist->columns; i++)
|
for (i = 0; i < clist->columns; i++)
|
||||||
if (clist->column[i].auto_resize)
|
if (clist->column[i].auto_resize)
|
||||||
{
|
column_auto_resize (clist, &(new_row->row), i, 0);
|
||||||
GTK_CLIST_CLASS_FW (clist)->cell_size_request (clist,
|
|
||||||
&(new_row->row),
|
|
||||||
i, &requisition);
|
|
||||||
if (requisition.width > clist->column[i].width)
|
|
||||||
gtk_clist_set_column_width (clist, i, requisition.width);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!GTK_CLIST_FROZEN (clist))
|
if (!GTK_CLIST_FROZEN (clist))
|
||||||
@ -4061,33 +4043,7 @@ gtk_ctree_remove_node (GtkCTree *ctree,
|
|||||||
!clist->selection && clist->focus_row >= 0)
|
!clist->selection && clist->focus_row >= 0)
|
||||||
gtk_clist_select_row (clist, clist->focus_row, -1);
|
gtk_clist_select_row (clist, clist->focus_row, -1);
|
||||||
|
|
||||||
if (!GTK_CLIST_AUTO_RESIZE_BLOCKED (clist))
|
auto_resize_columns (clist);
|
||||||
{
|
|
||||||
GtkRequisition requisition;
|
|
||||||
GList *list;
|
|
||||||
gint new_width;
|
|
||||||
gint i;
|
|
||||||
|
|
||||||
for (i = 0; i < clist->columns; i++)
|
|
||||||
if (clist->column[i].auto_resize)
|
|
||||||
{
|
|
||||||
/* run a "gtk_clist_optimal_column_width" but break, if
|
|
||||||
* the column doesn't shrink */
|
|
||||||
new_width = 0;
|
|
||||||
for (list = clist->row_list; list; list = list->next)
|
|
||||||
{
|
|
||||||
GTK_CLIST_CLASS_FW (clist)->cell_size_request
|
|
||||||
(clist, GTK_CLIST_ROW (list), i, &requisition);
|
|
||||||
new_width = MAX (new_width, requisition.width);
|
|
||||||
if (new_width == clist->column[i].width)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (new_width < clist->column[i].width)
|
|
||||||
gtk_clist_set_column_width (clist, i, new_width);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
gtk_clist_clear (clist);
|
gtk_clist_clear (clist);
|
||||||
|
@ -26,7 +26,8 @@ enum {
|
|||||||
ARG_0,
|
ARG_0,
|
||||||
ARG_VIEWPORT,
|
ARG_VIEWPORT,
|
||||||
ARG_HSCROLLBAR_POLICY,
|
ARG_HSCROLLBAR_POLICY,
|
||||||
ARG_VSCROLLBAR_POLICY
|
ARG_VSCROLLBAR_POLICY,
|
||||||
|
ARG_WINDOW_PLACEMENT
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -114,6 +115,10 @@ gtk_scrolled_window_class_init (GtkScrolledWindowClass *class)
|
|||||||
GTK_TYPE_POLICY_TYPE,
|
GTK_TYPE_POLICY_TYPE,
|
||||||
GTK_ARG_READWRITE,
|
GTK_ARG_READWRITE,
|
||||||
ARG_VSCROLLBAR_POLICY);
|
ARG_VSCROLLBAR_POLICY);
|
||||||
|
gtk_object_add_arg_type ("GtkScrolledWindow::window_placement",
|
||||||
|
GTK_TYPE_CORNER_TYPE,
|
||||||
|
GTK_ARG_READWRITE,
|
||||||
|
ARG_WINDOW_PLACEMENT);
|
||||||
|
|
||||||
object_class->set_arg = gtk_scrolled_window_set_arg;
|
object_class->set_arg = gtk_scrolled_window_set_arg;
|
||||||
object_class->get_arg = gtk_scrolled_window_get_arg;
|
object_class->get_arg = gtk_scrolled_window_get_arg;
|
||||||
@ -159,6 +164,10 @@ gtk_scrolled_window_set_arg (GtkObject *object,
|
|||||||
scrolled_window->hscrollbar_policy,
|
scrolled_window->hscrollbar_policy,
|
||||||
GTK_VALUE_ENUM (*arg));
|
GTK_VALUE_ENUM (*arg));
|
||||||
break;
|
break;
|
||||||
|
case ARG_WINDOW_PLACEMENT:
|
||||||
|
gtk_scrolled_window_set_placement (scrolled_window,
|
||||||
|
GTK_VALUE_ENUM (*arg));
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -184,6 +193,9 @@ gtk_scrolled_window_get_arg (GtkObject *object,
|
|||||||
case ARG_VSCROLLBAR_POLICY:
|
case ARG_VSCROLLBAR_POLICY:
|
||||||
GTK_VALUE_ENUM (*arg) = scrolled_window->vscrollbar_policy;
|
GTK_VALUE_ENUM (*arg) = scrolled_window->vscrollbar_policy;
|
||||||
break;
|
break;
|
||||||
|
case ARG_WINDOW_PLACEMENT:
|
||||||
|
GTK_VALUE_ENUM (*arg) = scrolled_window->window_placement;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
arg->type = GTK_TYPE_INVALID;
|
arg->type = GTK_TYPE_INVALID;
|
||||||
break;
|
break;
|
||||||
|
@ -3725,10 +3725,10 @@ insert_row_clist (GtkWidget *widget, gpointer data)
|
|||||||
{
|
{
|
||||||
static char *text[] =
|
static char *text[] =
|
||||||
{
|
{
|
||||||
"This", "is", "a", "inserted", "row.",
|
"This", "is", "an", "inserted", "row.",
|
||||||
"This", "is", "a", "inserted", "row.",
|
"This", "is", "an", "inserted", "row.",
|
||||||
"This", "is", "a", "inserted", "row.",
|
"This", "is", "an", "inserted", "row.",
|
||||||
"This", "is", "a", "inserted", "row."
|
"This", "is", "an", "inserted", "row."
|
||||||
};
|
};
|
||||||
|
|
||||||
static GtkStyle *style1 = NULL;
|
static GtkStyle *style1 = NULL;
|
||||||
@ -3908,7 +3908,6 @@ create_clist (void)
|
|||||||
GTK_POLICY_AUTOMATIC,
|
GTK_POLICY_AUTOMATIC,
|
||||||
GTK_POLICY_AUTOMATIC);
|
GTK_POLICY_AUTOMATIC);
|
||||||
gtk_container_add (GTK_CONTAINER (scrolled_win), clist);
|
gtk_container_add (GTK_CONTAINER (scrolled_win), clist);
|
||||||
/*clist = gtk_clist_new (TESTGTK_CLIST_COLUMNS);*/
|
|
||||||
|
|
||||||
gtk_signal_connect (GTK_OBJECT (clist), "click_column",
|
gtk_signal_connect (GTK_OBJECT (clist), "click_column",
|
||||||
(GtkSignalFunc) clist_click_column, NULL);
|
(GtkSignalFunc) clist_click_column, NULL);
|
||||||
@ -4006,8 +4005,6 @@ create_clist (void)
|
|||||||
gtk_clist_set_row_height (GTK_CLIST (clist), 18);
|
gtk_clist_set_row_height (GTK_CLIST (clist), 18);
|
||||||
gtk_widget_set_usize (clist, -1, 300);
|
gtk_widget_set_usize (clist, -1, 300);
|
||||||
|
|
||||||
gtk_clist_set_column_width (GTK_CLIST (clist), 0, 100);
|
|
||||||
|
|
||||||
for (i = 1; i < TESTGTK_CLIST_COLUMNS; i++)
|
for (i = 1; i < TESTGTK_CLIST_COLUMNS; i++)
|
||||||
gtk_clist_set_column_width (GTK_CLIST (clist), i, 80);
|
gtk_clist_set_column_width (GTK_CLIST (clist), i, 80);
|
||||||
|
|
||||||
@ -4296,7 +4293,6 @@ void change_style (GtkWidget *widget, GtkCTree *ctree)
|
|||||||
if (GTK_CTREE_ROW (node)->children)
|
if (GTK_CTREE_ROW (node)->children)
|
||||||
gtk_ctree_node_set_row_style (ctree, GTK_CTREE_ROW (node)->children,
|
gtk_ctree_node_set_row_style (ctree, GTK_CTREE_ROW (node)->children,
|
||||||
style2);
|
style2);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void unselect_all (GtkWidget *widget, GtkCTree *ctree)
|
void unselect_all (GtkWidget *widget, GtkCTree *ctree)
|
||||||
@ -4307,50 +4303,37 @@ void unselect_all (GtkWidget *widget, GtkCTree *ctree)
|
|||||||
|
|
||||||
void remove_selection (GtkWidget *widget, GtkCTree *ctree)
|
void remove_selection (GtkWidget *widget, GtkCTree *ctree)
|
||||||
{
|
{
|
||||||
GtkCTreeNode *work;
|
GtkCList *clist;
|
||||||
GtkCTreeNode *new_sel;
|
GtkCTreeNode *node;
|
||||||
GList *selection;
|
GList *selection;
|
||||||
|
GList *list = NULL;
|
||||||
|
|
||||||
selection = GTK_CLIST (ctree)->selection;
|
clist = GTK_CLIST (ctree);
|
||||||
new_sel = NULL;
|
|
||||||
|
|
||||||
gtk_clist_freeze (GTK_CLIST (ctree));
|
gtk_clist_freeze (clist);
|
||||||
|
|
||||||
|
for (selection = clist->selection; selection; selection = selection->next)
|
||||||
|
list = g_list_prepend (list, selection->data);
|
||||||
|
|
||||||
|
selection = clist->selection;
|
||||||
while (selection)
|
while (selection)
|
||||||
{
|
{
|
||||||
work = selection->data;
|
node = selection->data;
|
||||||
selection = selection->next;
|
|
||||||
|
|
||||||
if (GTK_CTREE_ROW (work)->is_leaf)
|
if (!g_list_find (list, node))
|
||||||
|
break;
|
||||||
|
|
||||||
|
if (GTK_CTREE_ROW (node)->is_leaf)
|
||||||
pages--;
|
pages--;
|
||||||
else
|
else
|
||||||
gtk_ctree_post_recursive (ctree, work,
|
gtk_ctree_post_recursive (ctree, node,
|
||||||
(GtkCTreeFunc) count_items, NULL);
|
(GtkCTreeFunc) count_items, NULL);
|
||||||
|
|
||||||
if (GTK_CLIST (ctree)->selection_mode == GTK_SELECTION_BROWSE)
|
gtk_ctree_remove_node (ctree, node);
|
||||||
{
|
selection = clist->selection;
|
||||||
if (GTK_CTREE_ROW (work)->children)
|
|
||||||
{
|
|
||||||
new_sel = GTK_CTREE_ROW (work)->sibling;
|
|
||||||
if (!new_sel)
|
|
||||||
new_sel = GTK_CTREE_NODE_NEXT (work);
|
|
||||||
}
|
}
|
||||||
else
|
g_list_free (list);
|
||||||
{
|
gtk_clist_thaw (clist);
|
||||||
if (GTK_CTREE_NODE_NEXT (work))
|
|
||||||
new_sel = GTK_CTREE_NODE_NEXT (work);
|
|
||||||
else
|
|
||||||
new_sel = GTK_CTREE_NODE_PREV (work);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
gtk_ctree_remove_node (ctree, work);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (new_sel)
|
|
||||||
gtk_ctree_select (ctree, new_sel);
|
|
||||||
|
|
||||||
gtk_clist_thaw (GTK_CLIST (ctree));
|
|
||||||
after_press (ctree, NULL);
|
after_press (ctree, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4880,7 +4863,6 @@ void create_ctree (void)
|
|||||||
gtk_container_border_width (GTK_CONTAINER (scrolled_win), 5);
|
gtk_container_border_width (GTK_CONTAINER (scrolled_win), 5);
|
||||||
gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
|
gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
|
||||||
gtk_clist_set_selection_mode (GTK_CLIST (ctree), GTK_SELECTION_EXTENDED);
|
gtk_clist_set_selection_mode (GTK_CLIST (ctree), GTK_SELECTION_EXTENDED);
|
||||||
gtk_clist_set_column_min_width (GTK_CLIST (ctree), 0, 50);
|
|
||||||
gtk_clist_set_column_auto_resize (GTK_CLIST (ctree), 0, TRUE);
|
gtk_clist_set_column_auto_resize (GTK_CLIST (ctree), 0, TRUE);
|
||||||
gtk_clist_set_column_width (GTK_CLIST (ctree), 1, 200);
|
gtk_clist_set_column_width (GTK_CLIST (ctree), 1, 200);
|
||||||
|
|
||||||
|
@ -3725,10 +3725,10 @@ insert_row_clist (GtkWidget *widget, gpointer data)
|
|||||||
{
|
{
|
||||||
static char *text[] =
|
static char *text[] =
|
||||||
{
|
{
|
||||||
"This", "is", "a", "inserted", "row.",
|
"This", "is", "an", "inserted", "row.",
|
||||||
"This", "is", "a", "inserted", "row.",
|
"This", "is", "an", "inserted", "row.",
|
||||||
"This", "is", "a", "inserted", "row.",
|
"This", "is", "an", "inserted", "row.",
|
||||||
"This", "is", "a", "inserted", "row."
|
"This", "is", "an", "inserted", "row."
|
||||||
};
|
};
|
||||||
|
|
||||||
static GtkStyle *style1 = NULL;
|
static GtkStyle *style1 = NULL;
|
||||||
@ -3908,7 +3908,6 @@ create_clist (void)
|
|||||||
GTK_POLICY_AUTOMATIC,
|
GTK_POLICY_AUTOMATIC,
|
||||||
GTK_POLICY_AUTOMATIC);
|
GTK_POLICY_AUTOMATIC);
|
||||||
gtk_container_add (GTK_CONTAINER (scrolled_win), clist);
|
gtk_container_add (GTK_CONTAINER (scrolled_win), clist);
|
||||||
/*clist = gtk_clist_new (TESTGTK_CLIST_COLUMNS);*/
|
|
||||||
|
|
||||||
gtk_signal_connect (GTK_OBJECT (clist), "click_column",
|
gtk_signal_connect (GTK_OBJECT (clist), "click_column",
|
||||||
(GtkSignalFunc) clist_click_column, NULL);
|
(GtkSignalFunc) clist_click_column, NULL);
|
||||||
@ -4006,8 +4005,6 @@ create_clist (void)
|
|||||||
gtk_clist_set_row_height (GTK_CLIST (clist), 18);
|
gtk_clist_set_row_height (GTK_CLIST (clist), 18);
|
||||||
gtk_widget_set_usize (clist, -1, 300);
|
gtk_widget_set_usize (clist, -1, 300);
|
||||||
|
|
||||||
gtk_clist_set_column_width (GTK_CLIST (clist), 0, 100);
|
|
||||||
|
|
||||||
for (i = 1; i < TESTGTK_CLIST_COLUMNS; i++)
|
for (i = 1; i < TESTGTK_CLIST_COLUMNS; i++)
|
||||||
gtk_clist_set_column_width (GTK_CLIST (clist), i, 80);
|
gtk_clist_set_column_width (GTK_CLIST (clist), i, 80);
|
||||||
|
|
||||||
@ -4296,7 +4293,6 @@ void change_style (GtkWidget *widget, GtkCTree *ctree)
|
|||||||
if (GTK_CTREE_ROW (node)->children)
|
if (GTK_CTREE_ROW (node)->children)
|
||||||
gtk_ctree_node_set_row_style (ctree, GTK_CTREE_ROW (node)->children,
|
gtk_ctree_node_set_row_style (ctree, GTK_CTREE_ROW (node)->children,
|
||||||
style2);
|
style2);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void unselect_all (GtkWidget *widget, GtkCTree *ctree)
|
void unselect_all (GtkWidget *widget, GtkCTree *ctree)
|
||||||
@ -4307,50 +4303,37 @@ void unselect_all (GtkWidget *widget, GtkCTree *ctree)
|
|||||||
|
|
||||||
void remove_selection (GtkWidget *widget, GtkCTree *ctree)
|
void remove_selection (GtkWidget *widget, GtkCTree *ctree)
|
||||||
{
|
{
|
||||||
GtkCTreeNode *work;
|
GtkCList *clist;
|
||||||
GtkCTreeNode *new_sel;
|
GtkCTreeNode *node;
|
||||||
GList *selection;
|
GList *selection;
|
||||||
|
GList *list = NULL;
|
||||||
|
|
||||||
selection = GTK_CLIST (ctree)->selection;
|
clist = GTK_CLIST (ctree);
|
||||||
new_sel = NULL;
|
|
||||||
|
|
||||||
gtk_clist_freeze (GTK_CLIST (ctree));
|
gtk_clist_freeze (clist);
|
||||||
|
|
||||||
|
for (selection = clist->selection; selection; selection = selection->next)
|
||||||
|
list = g_list_prepend (list, selection->data);
|
||||||
|
|
||||||
|
selection = clist->selection;
|
||||||
while (selection)
|
while (selection)
|
||||||
{
|
{
|
||||||
work = selection->data;
|
node = selection->data;
|
||||||
selection = selection->next;
|
|
||||||
|
|
||||||
if (GTK_CTREE_ROW (work)->is_leaf)
|
if (!g_list_find (list, node))
|
||||||
|
break;
|
||||||
|
|
||||||
|
if (GTK_CTREE_ROW (node)->is_leaf)
|
||||||
pages--;
|
pages--;
|
||||||
else
|
else
|
||||||
gtk_ctree_post_recursive (ctree, work,
|
gtk_ctree_post_recursive (ctree, node,
|
||||||
(GtkCTreeFunc) count_items, NULL);
|
(GtkCTreeFunc) count_items, NULL);
|
||||||
|
|
||||||
if (GTK_CLIST (ctree)->selection_mode == GTK_SELECTION_BROWSE)
|
gtk_ctree_remove_node (ctree, node);
|
||||||
{
|
selection = clist->selection;
|
||||||
if (GTK_CTREE_ROW (work)->children)
|
|
||||||
{
|
|
||||||
new_sel = GTK_CTREE_ROW (work)->sibling;
|
|
||||||
if (!new_sel)
|
|
||||||
new_sel = GTK_CTREE_NODE_NEXT (work);
|
|
||||||
}
|
}
|
||||||
else
|
g_list_free (list);
|
||||||
{
|
gtk_clist_thaw (clist);
|
||||||
if (GTK_CTREE_NODE_NEXT (work))
|
|
||||||
new_sel = GTK_CTREE_NODE_NEXT (work);
|
|
||||||
else
|
|
||||||
new_sel = GTK_CTREE_NODE_PREV (work);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
gtk_ctree_remove_node (ctree, work);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (new_sel)
|
|
||||||
gtk_ctree_select (ctree, new_sel);
|
|
||||||
|
|
||||||
gtk_clist_thaw (GTK_CLIST (ctree));
|
|
||||||
after_press (ctree, NULL);
|
after_press (ctree, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4880,7 +4863,6 @@ void create_ctree (void)
|
|||||||
gtk_container_border_width (GTK_CONTAINER (scrolled_win), 5);
|
gtk_container_border_width (GTK_CONTAINER (scrolled_win), 5);
|
||||||
gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
|
gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
|
||||||
gtk_clist_set_selection_mode (GTK_CLIST (ctree), GTK_SELECTION_EXTENDED);
|
gtk_clist_set_selection_mode (GTK_CLIST (ctree), GTK_SELECTION_EXTENDED);
|
||||||
gtk_clist_set_column_min_width (GTK_CLIST (ctree), 0, 50);
|
|
||||||
gtk_clist_set_column_auto_resize (GTK_CLIST (ctree), 0, TRUE);
|
gtk_clist_set_column_auto_resize (GTK_CLIST (ctree), 0, TRUE);
|
||||||
gtk_clist_set_column_width (GTK_CLIST (ctree), 1, 200);
|
gtk_clist_set_column_width (GTK_CLIST (ctree), 1, 200);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user