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:
Lars Hamann 1998-11-11 20:46:51 +00:00 committed by Lars Hamann
parent d5f4e60c56
commit f164436f86
12 changed files with 264 additions and 205 deletions

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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);

View File

@ -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);

View File

@ -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;

View File

@ -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);

View File

@ -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);