voc Pennington <hp@redhat.com>

* gtk/gtktextlayout.c (gtk_text_layout_move_iter_to_previous_line):
	(gtk_text_layout_move_iter_to_next_line): fix these two for
	invisible text, lots of other stuff still hosed.

	* gtk/gtkcolorsel.c (gtk_color_selection_set_change_palette_hook):
	new function, replaces the get/set palette stuff. This function
	is intended for use by libgnomeui which should set the hook to a
	thing which sets the palette in GConf, and we need the
	GConf-to-xsettings proxy which will result in the change being
	propagated back to the GTK app.

	* gtk/gtkaccelgroup.c (gtk_accel_group_add): add note to warning
	about unusable signals that it may be because the signal has
	parameters.

	* gtk/gtkwidget.c (gtk_widget_modify_style): always copy the
	style, otherwise gtkrc.c won't know to create a new GtkStyle for
	it.
	(gtk_widget_modify_color_component): call
	gtk_widget_modify_style() so the rc style will get copied.
	(gtk_widget_modify_font): ditto

	* gtk/gtkrc.c: make a couple variables static

	* gtk/gtkcolorseldialog.c (gtk_color_selection_dialog_init): hide
	help button by default, since it does nothing

	* gtk/gtkcolorsel.c: add tooltips, work on key navigation, fool
	around with UI

	* gtk/gtkentry.c (gtk_entry_realize): request enter/leave notify
	so we can have tooltips

	* gtk/gtkhsv.c (gtk_hsv_realize): request enter/leave notify so we
	can have tooltips

	* gdk/gdkimage.h: mark gdk_image_new_bitmap with
	GDK_ENABLE_BROKEN, because its memory behavior is completely
	hosed.

	* gtk/gtknotebook.c: remove key press handler, replace with
	binding set, add numeric keypad support

	* gtk/gtktextview.c (gtk_text_view_class_init): accept KP_Delete

	* gtk/gtktext.c (gtk_text_key_press): add a bunch of KP keysyms

	* gtk/gtkentry.c (gtk_entry_class_init): accept GDK_KP_Delete in
	addition to plain Delete

	* gtk/gtktextview.c (gtk_text_view_key_press_event): accept
	GDK_KP_Enter in addition to GDK_Return

	* gtk/gtkfontsel.c (gtk_font_selection_size_key_press): connect to
	activate on entry instead of key press
	(gtk_font_selection_on_clist_key_press): get
	rid of this signal handler, not needed with new font sel.

	* gtk/gtkfilesel.c (gtk_file_selection_key_press): remove a
	no-longer-needed emit_stop_by_name(), just return TRUE

	* gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.c: remove keybindings
	cruft, this widget is no longer focusable.

	* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkvscale.c,
	gtk/gtkhscale.c: Get rid of trough_keys virtual function, add
	move_slider action signal, add binding set for vscale/hscale, in
	the process support numeric keypad

	* gtk/gtkentry.c (gtk_entry_class_init): Add keypad bindings;
	make GDK_Return and GDK_KP_Enter activate the entry via
	binding set, instead of hardcoded.
This commit is contained in:
Havoc Pennington 2001-04-28 20:18:29 +00:00
parent f06a725358
commit 7ad3641353
39 changed files with 1885 additions and 685 deletions

View File

@ -1,3 +1,78 @@
2001-04-24 Havoc Pennington <hp@redhat.com>
* gtk/gtktextlayout.c (gtk_text_layout_move_iter_to_previous_line):
(gtk_text_layout_move_iter_to_next_line): fix these two for
invisible text, lots of other stuff still hosed.
* gtk/gtkcolorsel.c (gtk_color_selection_set_change_palette_hook):
new function, replaces the get/set palette stuff. This function
is intended for use by libgnomeui which should set the hook to a
thing which sets the palette in GConf, and we need the
GConf-to-xsettings proxy which will result in the change being
propagated back to the GTK app.
* gtk/gtkaccelgroup.c (gtk_accel_group_add): add note to warning
about unusable signals that it may be because the signal has
parameters.
* gtk/gtkwidget.c (gtk_widget_modify_style): always copy the
style, otherwise gtkrc.c won't know to create a new GtkStyle for
it.
(gtk_widget_modify_color_component): call
gtk_widget_modify_style() so the rc style will get copied.
(gtk_widget_modify_font): ditto
* gtk/gtkrc.c: make a couple variables static
* gtk/gtkcolorseldialog.c (gtk_color_selection_dialog_init): hide
help button by default, since it does nothing
* gtk/gtkcolorsel.c: add tooltips, work on key navigation, fool
around with UI
* gtk/gtkentry.c (gtk_entry_realize): request enter/leave notify
so we can have tooltips
* gtk/gtkhsv.c (gtk_hsv_realize): request enter/leave notify so we
can have tooltips
* gdk/gdkimage.h: mark gdk_image_new_bitmap with
GDK_ENABLE_BROKEN, because its memory behavior is completely
hosed.
* gtk/gtknotebook.c: remove key press handler, replace with
binding set, add numeric keypad support
* gtk/gtktextview.c (gtk_text_view_class_init): accept KP_Delete
* gtk/gtktext.c (gtk_text_key_press): add a bunch of KP keysyms
* gtk/gtkentry.c (gtk_entry_class_init): accept GDK_KP_Delete in
addition to plain Delete
* gtk/gtktextview.c (gtk_text_view_key_press_event): accept
GDK_KP_Enter in addition to GDK_Return
* gtk/gtkfontsel.c (gtk_font_selection_size_key_press): connect to
activate on entry instead of key press
(gtk_font_selection_on_clist_key_press): get
rid of this signal handler, not needed with new font sel.
* gtk/gtkfilesel.c (gtk_file_selection_key_press): remove a
no-longer-needed emit_stop_by_name(), just return TRUE
* gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.c: remove keybindings
cruft, this widget is no longer focusable.
* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkvscale.c,
gtk/gtkhscale.c: Get rid of trough_keys virtual function, add
move_slider action signal, add binding set for vscale/hscale, in
the process support numeric keypad
* gtk/gtkentry.c (gtk_entry_class_init): Add keypad bindings;
make GDK_Return and GDK_KP_Enter activate the entry via
binding set, instead of hardcoded.
Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com> Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com>
* gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the * gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the

View File

@ -1,3 +1,78 @@
2001-04-24 Havoc Pennington <hp@redhat.com>
* gtk/gtktextlayout.c (gtk_text_layout_move_iter_to_previous_line):
(gtk_text_layout_move_iter_to_next_line): fix these two for
invisible text, lots of other stuff still hosed.
* gtk/gtkcolorsel.c (gtk_color_selection_set_change_palette_hook):
new function, replaces the get/set palette stuff. This function
is intended for use by libgnomeui which should set the hook to a
thing which sets the palette in GConf, and we need the
GConf-to-xsettings proxy which will result in the change being
propagated back to the GTK app.
* gtk/gtkaccelgroup.c (gtk_accel_group_add): add note to warning
about unusable signals that it may be because the signal has
parameters.
* gtk/gtkwidget.c (gtk_widget_modify_style): always copy the
style, otherwise gtkrc.c won't know to create a new GtkStyle for
it.
(gtk_widget_modify_color_component): call
gtk_widget_modify_style() so the rc style will get copied.
(gtk_widget_modify_font): ditto
* gtk/gtkrc.c: make a couple variables static
* gtk/gtkcolorseldialog.c (gtk_color_selection_dialog_init): hide
help button by default, since it does nothing
* gtk/gtkcolorsel.c: add tooltips, work on key navigation, fool
around with UI
* gtk/gtkentry.c (gtk_entry_realize): request enter/leave notify
so we can have tooltips
* gtk/gtkhsv.c (gtk_hsv_realize): request enter/leave notify so we
can have tooltips
* gdk/gdkimage.h: mark gdk_image_new_bitmap with
GDK_ENABLE_BROKEN, because its memory behavior is completely
hosed.
* gtk/gtknotebook.c: remove key press handler, replace with
binding set, add numeric keypad support
* gtk/gtktextview.c (gtk_text_view_class_init): accept KP_Delete
* gtk/gtktext.c (gtk_text_key_press): add a bunch of KP keysyms
* gtk/gtkentry.c (gtk_entry_class_init): accept GDK_KP_Delete in
addition to plain Delete
* gtk/gtktextview.c (gtk_text_view_key_press_event): accept
GDK_KP_Enter in addition to GDK_Return
* gtk/gtkfontsel.c (gtk_font_selection_size_key_press): connect to
activate on entry instead of key press
(gtk_font_selection_on_clist_key_press): get
rid of this signal handler, not needed with new font sel.
* gtk/gtkfilesel.c (gtk_file_selection_key_press): remove a
no-longer-needed emit_stop_by_name(), just return TRUE
* gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.c: remove keybindings
cruft, this widget is no longer focusable.
* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkvscale.c,
gtk/gtkhscale.c: Get rid of trough_keys virtual function, add
move_slider action signal, add binding set for vscale/hscale, in
the process support numeric keypad
* gtk/gtkentry.c (gtk_entry_class_init): Add keypad bindings;
make GDK_Return and GDK_KP_Enter activate the entry via
binding set, instead of hardcoded.
Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com> Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com>
* gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the * gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the

View File

@ -1,3 +1,78 @@
2001-04-24 Havoc Pennington <hp@redhat.com>
* gtk/gtktextlayout.c (gtk_text_layout_move_iter_to_previous_line):
(gtk_text_layout_move_iter_to_next_line): fix these two for
invisible text, lots of other stuff still hosed.
* gtk/gtkcolorsel.c (gtk_color_selection_set_change_palette_hook):
new function, replaces the get/set palette stuff. This function
is intended for use by libgnomeui which should set the hook to a
thing which sets the palette in GConf, and we need the
GConf-to-xsettings proxy which will result in the change being
propagated back to the GTK app.
* gtk/gtkaccelgroup.c (gtk_accel_group_add): add note to warning
about unusable signals that it may be because the signal has
parameters.
* gtk/gtkwidget.c (gtk_widget_modify_style): always copy the
style, otherwise gtkrc.c won't know to create a new GtkStyle for
it.
(gtk_widget_modify_color_component): call
gtk_widget_modify_style() so the rc style will get copied.
(gtk_widget_modify_font): ditto
* gtk/gtkrc.c: make a couple variables static
* gtk/gtkcolorseldialog.c (gtk_color_selection_dialog_init): hide
help button by default, since it does nothing
* gtk/gtkcolorsel.c: add tooltips, work on key navigation, fool
around with UI
* gtk/gtkentry.c (gtk_entry_realize): request enter/leave notify
so we can have tooltips
* gtk/gtkhsv.c (gtk_hsv_realize): request enter/leave notify so we
can have tooltips
* gdk/gdkimage.h: mark gdk_image_new_bitmap with
GDK_ENABLE_BROKEN, because its memory behavior is completely
hosed.
* gtk/gtknotebook.c: remove key press handler, replace with
binding set, add numeric keypad support
* gtk/gtktextview.c (gtk_text_view_class_init): accept KP_Delete
* gtk/gtktext.c (gtk_text_key_press): add a bunch of KP keysyms
* gtk/gtkentry.c (gtk_entry_class_init): accept GDK_KP_Delete in
addition to plain Delete
* gtk/gtktextview.c (gtk_text_view_key_press_event): accept
GDK_KP_Enter in addition to GDK_Return
* gtk/gtkfontsel.c (gtk_font_selection_size_key_press): connect to
activate on entry instead of key press
(gtk_font_selection_on_clist_key_press): get
rid of this signal handler, not needed with new font sel.
* gtk/gtkfilesel.c (gtk_file_selection_key_press): remove a
no-longer-needed emit_stop_by_name(), just return TRUE
* gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.c: remove keybindings
cruft, this widget is no longer focusable.
* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkvscale.c,
gtk/gtkhscale.c: Get rid of trough_keys virtual function, add
move_slider action signal, add binding set for vscale/hscale, in
the process support numeric keypad
* gtk/gtkentry.c (gtk_entry_class_init): Add keypad bindings;
make GDK_Return and GDK_KP_Enter activate the entry via
binding set, instead of hardcoded.
Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com> Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com>
* gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the * gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the

View File

@ -1,3 +1,78 @@
2001-04-24 Havoc Pennington <hp@redhat.com>
* gtk/gtktextlayout.c (gtk_text_layout_move_iter_to_previous_line):
(gtk_text_layout_move_iter_to_next_line): fix these two for
invisible text, lots of other stuff still hosed.
* gtk/gtkcolorsel.c (gtk_color_selection_set_change_palette_hook):
new function, replaces the get/set palette stuff. This function
is intended for use by libgnomeui which should set the hook to a
thing which sets the palette in GConf, and we need the
GConf-to-xsettings proxy which will result in the change being
propagated back to the GTK app.
* gtk/gtkaccelgroup.c (gtk_accel_group_add): add note to warning
about unusable signals that it may be because the signal has
parameters.
* gtk/gtkwidget.c (gtk_widget_modify_style): always copy the
style, otherwise gtkrc.c won't know to create a new GtkStyle for
it.
(gtk_widget_modify_color_component): call
gtk_widget_modify_style() so the rc style will get copied.
(gtk_widget_modify_font): ditto
* gtk/gtkrc.c: make a couple variables static
* gtk/gtkcolorseldialog.c (gtk_color_selection_dialog_init): hide
help button by default, since it does nothing
* gtk/gtkcolorsel.c: add tooltips, work on key navigation, fool
around with UI
* gtk/gtkentry.c (gtk_entry_realize): request enter/leave notify
so we can have tooltips
* gtk/gtkhsv.c (gtk_hsv_realize): request enter/leave notify so we
can have tooltips
* gdk/gdkimage.h: mark gdk_image_new_bitmap with
GDK_ENABLE_BROKEN, because its memory behavior is completely
hosed.
* gtk/gtknotebook.c: remove key press handler, replace with
binding set, add numeric keypad support
* gtk/gtktextview.c (gtk_text_view_class_init): accept KP_Delete
* gtk/gtktext.c (gtk_text_key_press): add a bunch of KP keysyms
* gtk/gtkentry.c (gtk_entry_class_init): accept GDK_KP_Delete in
addition to plain Delete
* gtk/gtktextview.c (gtk_text_view_key_press_event): accept
GDK_KP_Enter in addition to GDK_Return
* gtk/gtkfontsel.c (gtk_font_selection_size_key_press): connect to
activate on entry instead of key press
(gtk_font_selection_on_clist_key_press): get
rid of this signal handler, not needed with new font sel.
* gtk/gtkfilesel.c (gtk_file_selection_key_press): remove a
no-longer-needed emit_stop_by_name(), just return TRUE
* gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.c: remove keybindings
cruft, this widget is no longer focusable.
* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkvscale.c,
gtk/gtkhscale.c: Get rid of trough_keys virtual function, add
move_slider action signal, add binding set for vscale/hscale, in
the process support numeric keypad
* gtk/gtkentry.c (gtk_entry_class_init): Add keypad bindings;
make GDK_Return and GDK_KP_Enter activate the entry via
binding set, instead of hardcoded.
Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com> Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com>
* gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the * gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the

View File

@ -1,3 +1,78 @@
2001-04-24 Havoc Pennington <hp@redhat.com>
* gtk/gtktextlayout.c (gtk_text_layout_move_iter_to_previous_line):
(gtk_text_layout_move_iter_to_next_line): fix these two for
invisible text, lots of other stuff still hosed.
* gtk/gtkcolorsel.c (gtk_color_selection_set_change_palette_hook):
new function, replaces the get/set palette stuff. This function
is intended for use by libgnomeui which should set the hook to a
thing which sets the palette in GConf, and we need the
GConf-to-xsettings proxy which will result in the change being
propagated back to the GTK app.
* gtk/gtkaccelgroup.c (gtk_accel_group_add): add note to warning
about unusable signals that it may be because the signal has
parameters.
* gtk/gtkwidget.c (gtk_widget_modify_style): always copy the
style, otherwise gtkrc.c won't know to create a new GtkStyle for
it.
(gtk_widget_modify_color_component): call
gtk_widget_modify_style() so the rc style will get copied.
(gtk_widget_modify_font): ditto
* gtk/gtkrc.c: make a couple variables static
* gtk/gtkcolorseldialog.c (gtk_color_selection_dialog_init): hide
help button by default, since it does nothing
* gtk/gtkcolorsel.c: add tooltips, work on key navigation, fool
around with UI
* gtk/gtkentry.c (gtk_entry_realize): request enter/leave notify
so we can have tooltips
* gtk/gtkhsv.c (gtk_hsv_realize): request enter/leave notify so we
can have tooltips
* gdk/gdkimage.h: mark gdk_image_new_bitmap with
GDK_ENABLE_BROKEN, because its memory behavior is completely
hosed.
* gtk/gtknotebook.c: remove key press handler, replace with
binding set, add numeric keypad support
* gtk/gtktextview.c (gtk_text_view_class_init): accept KP_Delete
* gtk/gtktext.c (gtk_text_key_press): add a bunch of KP keysyms
* gtk/gtkentry.c (gtk_entry_class_init): accept GDK_KP_Delete in
addition to plain Delete
* gtk/gtktextview.c (gtk_text_view_key_press_event): accept
GDK_KP_Enter in addition to GDK_Return
* gtk/gtkfontsel.c (gtk_font_selection_size_key_press): connect to
activate on entry instead of key press
(gtk_font_selection_on_clist_key_press): get
rid of this signal handler, not needed with new font sel.
* gtk/gtkfilesel.c (gtk_file_selection_key_press): remove a
no-longer-needed emit_stop_by_name(), just return TRUE
* gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.c: remove keybindings
cruft, this widget is no longer focusable.
* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkvscale.c,
gtk/gtkhscale.c: Get rid of trough_keys virtual function, add
move_slider action signal, add binding set for vscale/hscale, in
the process support numeric keypad
* gtk/gtkentry.c (gtk_entry_class_init): Add keypad bindings;
make GDK_Return and GDK_KP_Enter activate the entry via
binding set, instead of hardcoded.
Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com> Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com>
* gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the * gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the

View File

@ -1,3 +1,78 @@
2001-04-24 Havoc Pennington <hp@redhat.com>
* gtk/gtktextlayout.c (gtk_text_layout_move_iter_to_previous_line):
(gtk_text_layout_move_iter_to_next_line): fix these two for
invisible text, lots of other stuff still hosed.
* gtk/gtkcolorsel.c (gtk_color_selection_set_change_palette_hook):
new function, replaces the get/set palette stuff. This function
is intended for use by libgnomeui which should set the hook to a
thing which sets the palette in GConf, and we need the
GConf-to-xsettings proxy which will result in the change being
propagated back to the GTK app.
* gtk/gtkaccelgroup.c (gtk_accel_group_add): add note to warning
about unusable signals that it may be because the signal has
parameters.
* gtk/gtkwidget.c (gtk_widget_modify_style): always copy the
style, otherwise gtkrc.c won't know to create a new GtkStyle for
it.
(gtk_widget_modify_color_component): call
gtk_widget_modify_style() so the rc style will get copied.
(gtk_widget_modify_font): ditto
* gtk/gtkrc.c: make a couple variables static
* gtk/gtkcolorseldialog.c (gtk_color_selection_dialog_init): hide
help button by default, since it does nothing
* gtk/gtkcolorsel.c: add tooltips, work on key navigation, fool
around with UI
* gtk/gtkentry.c (gtk_entry_realize): request enter/leave notify
so we can have tooltips
* gtk/gtkhsv.c (gtk_hsv_realize): request enter/leave notify so we
can have tooltips
* gdk/gdkimage.h: mark gdk_image_new_bitmap with
GDK_ENABLE_BROKEN, because its memory behavior is completely
hosed.
* gtk/gtknotebook.c: remove key press handler, replace with
binding set, add numeric keypad support
* gtk/gtktextview.c (gtk_text_view_class_init): accept KP_Delete
* gtk/gtktext.c (gtk_text_key_press): add a bunch of KP keysyms
* gtk/gtkentry.c (gtk_entry_class_init): accept GDK_KP_Delete in
addition to plain Delete
* gtk/gtktextview.c (gtk_text_view_key_press_event): accept
GDK_KP_Enter in addition to GDK_Return
* gtk/gtkfontsel.c (gtk_font_selection_size_key_press): connect to
activate on entry instead of key press
(gtk_font_selection_on_clist_key_press): get
rid of this signal handler, not needed with new font sel.
* gtk/gtkfilesel.c (gtk_file_selection_key_press): remove a
no-longer-needed emit_stop_by_name(), just return TRUE
* gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.c: remove keybindings
cruft, this widget is no longer focusable.
* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkvscale.c,
gtk/gtkhscale.c: Get rid of trough_keys virtual function, add
move_slider action signal, add binding set for vscale/hscale, in
the process support numeric keypad
* gtk/gtkentry.c (gtk_entry_class_init): Add keypad bindings;
make GDK_Return and GDK_KP_Enter activate the entry via
binding set, instead of hardcoded.
Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com> Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com>
* gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the * gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the

View File

@ -1,3 +1,78 @@
2001-04-24 Havoc Pennington <hp@redhat.com>
* gtk/gtktextlayout.c (gtk_text_layout_move_iter_to_previous_line):
(gtk_text_layout_move_iter_to_next_line): fix these two for
invisible text, lots of other stuff still hosed.
* gtk/gtkcolorsel.c (gtk_color_selection_set_change_palette_hook):
new function, replaces the get/set palette stuff. This function
is intended for use by libgnomeui which should set the hook to a
thing which sets the palette in GConf, and we need the
GConf-to-xsettings proxy which will result in the change being
propagated back to the GTK app.
* gtk/gtkaccelgroup.c (gtk_accel_group_add): add note to warning
about unusable signals that it may be because the signal has
parameters.
* gtk/gtkwidget.c (gtk_widget_modify_style): always copy the
style, otherwise gtkrc.c won't know to create a new GtkStyle for
it.
(gtk_widget_modify_color_component): call
gtk_widget_modify_style() so the rc style will get copied.
(gtk_widget_modify_font): ditto
* gtk/gtkrc.c: make a couple variables static
* gtk/gtkcolorseldialog.c (gtk_color_selection_dialog_init): hide
help button by default, since it does nothing
* gtk/gtkcolorsel.c: add tooltips, work on key navigation, fool
around with UI
* gtk/gtkentry.c (gtk_entry_realize): request enter/leave notify
so we can have tooltips
* gtk/gtkhsv.c (gtk_hsv_realize): request enter/leave notify so we
can have tooltips
* gdk/gdkimage.h: mark gdk_image_new_bitmap with
GDK_ENABLE_BROKEN, because its memory behavior is completely
hosed.
* gtk/gtknotebook.c: remove key press handler, replace with
binding set, add numeric keypad support
* gtk/gtktextview.c (gtk_text_view_class_init): accept KP_Delete
* gtk/gtktext.c (gtk_text_key_press): add a bunch of KP keysyms
* gtk/gtkentry.c (gtk_entry_class_init): accept GDK_KP_Delete in
addition to plain Delete
* gtk/gtktextview.c (gtk_text_view_key_press_event): accept
GDK_KP_Enter in addition to GDK_Return
* gtk/gtkfontsel.c (gtk_font_selection_size_key_press): connect to
activate on entry instead of key press
(gtk_font_selection_on_clist_key_press): get
rid of this signal handler, not needed with new font sel.
* gtk/gtkfilesel.c (gtk_file_selection_key_press): remove a
no-longer-needed emit_stop_by_name(), just return TRUE
* gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.c: remove keybindings
cruft, this widget is no longer focusable.
* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkvscale.c,
gtk/gtkhscale.c: Get rid of trough_keys virtual function, add
move_slider action signal, add binding set for vscale/hscale, in
the process support numeric keypad
* gtk/gtkentry.c (gtk_entry_class_init): Add keypad bindings;
make GDK_Return and GDK_KP_Enter activate the entry via
binding set, instead of hardcoded.
Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com> Fri Apr 27 20:27:21 2001 Jonathan Blandford <jrb@redhat.com>
* gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the * gtk/gtktreeview.[hc]: Massive reorder/cleanup of a lot of the

View File

@ -6,6 +6,7 @@ democodedir=$(datadir)/gtk-2.0/demo
## demo app, which means alphabetized by demo title, not filename ## demo app, which means alphabetized by demo title, not filename
demos = @STRIP_BEGIN@ \ demos = @STRIP_BEGIN@ \
button_box.c \ button_box.c \
colorsel.c \
dialog.c \ dialog.c \
drawingarea.c \ drawingarea.c \
images.c \ images.c \

110
demos/gtk-demo/colorsel.c Normal file
View File

@ -0,0 +1,110 @@
/* Color Selector
*
* GtkColorSelection lets the user choose a color. GtkColorSelectionDialog is
* a prebuilt dialog containing a GtkColorSelection.
*
*/
#include <gtk/gtk.h>
static GtkWidget *window = NULL;
static GtkWidget *da;
static GdkColor color;
static GtkWidget *frame;
static void
change_color_callback (GtkWidget *button,
gpointer data)
{
GtkWidget *dialog;
GtkColorSelection *colorsel;
gint response;
dialog = gtk_color_selection_dialog_new ("Changing color");
gtk_window_set_transient_for (GTK_WINDOW (dialog), GTK_WINDOW (window));
colorsel = GTK_COLOR_SELECTION (GTK_COLOR_SELECTION_DIALOG (dialog)->colorsel);
gtk_color_selection_set_previous_color (colorsel, &color);
gtk_color_selection_set_current_color (colorsel, &color);
gtk_color_selection_set_has_palette (colorsel, TRUE);
response = gtk_dialog_run (GTK_DIALOG (dialog));
if (response == GTK_RESPONSE_OK)
{
gtk_color_selection_get_current_color (colorsel,
&color);
gtk_widget_modify_bg (da, GTK_STATE_NORMAL, &color);
}
gtk_widget_destroy (dialog);
}
GtkWidget *
do_colorsel (void)
{
GtkWidget *vbox;
GtkWidget *button;
GtkWidget *alignment;
if (!window)
{
color.red = 0;
color.blue = 65535;
color.green = 0;
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
gtk_window_set_title (GTK_WINDOW (window), "Color Selection");
gtk_signal_connect (GTK_OBJECT (window), "destroy", GTK_SIGNAL_FUNC (gtk_widget_destroyed), &window);
gtk_container_set_border_width (GTK_CONTAINER (window), 8);
vbox = gtk_vbox_new (FALSE, 8);
gtk_container_set_border_width (GTK_CONTAINER (vbox), 8);
gtk_container_add (GTK_CONTAINER (window), vbox);
/*
* Create the color swatch area
*/
frame = gtk_frame_new (NULL);
gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
gtk_box_pack_start (GTK_BOX (vbox), frame, TRUE, TRUE, 0);
da = gtk_drawing_area_new ();
/* set a minimum size */
gtk_widget_set_usize (da, 200, 200);
/* set the color */
gtk_widget_modify_bg (da, GTK_STATE_NORMAL, &color);
gtk_container_add (GTK_CONTAINER (frame), da);
alignment = gtk_alignment_new (1.0, 0.5, 0.0, 0.0);
button = gtk_button_new_with_mnemonic ("_Change the above color");
gtk_container_add (GTK_CONTAINER (alignment), button);
gtk_box_pack_start (GTK_BOX (vbox), alignment, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (button), "clicked",
GTK_SIGNAL_FUNC (change_color_callback),
NULL);
}
if (!GTK_WIDGET_VISIBLE (window))
{
gtk_widget_show_all (window);
}
else
{
gtk_widget_destroy (window);
window = NULL;
}
return window;
}

View File

@ -1,3 +1,7 @@
2001-04-20 Havoc Pennington <hp@redhat.com>
* gdk/tmpl/images.sgml: add warning about gtk_image_new_bitmap
Wed Apr 25 12:33:03 2001 Owen Taylor <otaylor@redhat.com> Wed Apr 25 12:33:03 2001 Owen Taylor <otaylor@redhat.com>
* gtk/tmpl/gtktreeitem.sgml: Add note about GTK_ENABLE_BROKEN. * gtk/tmpl/gtktreeitem.sgml: Add note about GTK_ENABLE_BROKEN.

View File

@ -105,6 +105,9 @@ and if that fails then %GDK_IMAGE_NORMAL will be used.
<!-- ##### FUNCTION gdk_image_new_bitmap ##### --> <!-- ##### FUNCTION gdk_image_new_bitmap ##### -->
<para> <para>
Creates a new #GdkImage with a depth of 1 from the given data. Creates a new #GdkImage with a depth of 1 from the given data.
<warning><para>THIS FUNCTION IS INCREDIBLY BROKEN. The passed-in data must
be allocated by malloc() (NOT g_malloc()) and will be freed when the
image is freed.</para></warning>
</para> </para>
@visual: the #GdkVisual to use for the image. @visual: the #GdkVisual to use for the image.

View File

@ -85,45 +85,6 @@ Retrieve the currently selected color value.
blue, and opacity. blue, and opacity.
<!-- ##### FUNCTION gtk_color_selection_set_palette_color ##### -->
<para>
</para>
@colorsel:
@index:
@color:
<!-- # Unused Parameters # -->
@x:
@y:
<!-- ##### FUNCTION gtk_color_selection_get_palette_color ##### -->
<para>
</para>
@colorsel:
@index:
@color:
@Returns:
<!-- # Unused Parameters # -->
@x:
@y:
<!-- ##### FUNCTION gtk_color_selection_unset_palette_color ##### -->
<para>
</para>
@colorsel:
@index:
<!-- # Unused Parameters # -->
@x:
@y:
<!-- ##### FUNCTION gtk_color_selection_is_adjusting ##### --> <!-- ##### FUNCTION gtk_color_selection_is_adjusting ##### -->
<para> <para>

View File

@ -336,6 +336,22 @@ Compatibility macro; in gtkcompat.h.
@tab_vborder: @tab_vborder:
<!-- ##### SIGNAL GtkNotebook::focus-tab ##### -->
<para>
</para>
@notebook: the object which received the signal.
@arg1:
<!-- ##### SIGNAL GtkNotebook::select-page ##### -->
<para>
</para>
@notebook: the object which received the signal.
@arg1:
<!-- ##### SIGNAL GtkNotebook::switch-page ##### --> <!-- ##### SIGNAL GtkNotebook::switch-page ##### -->
<para> <para>
Emitted when the user or a function changes the current page. Emitted when the user or a function changes the current page.

View File

@ -65,6 +65,15 @@ GtkRange
@setting: @setting:
<!-- ##### SIGNAL GtkRange::move-slider ##### -->
<para>
</para>
@range: the object which received the signal.
@arg1:
@arg2:
<!-- ##### ARG GtkRange:update-policy ##### --> <!-- ##### ARG GtkRange:update-policy ##### -->
<para> <para>

View File

@ -59,10 +59,6 @@ struct _GdkImageClass
GType gdk_image_get_type (void) G_GNUC_CONST; GType gdk_image_get_type (void) G_GNUC_CONST;
GdkImage* gdk_image_new_bitmap (GdkVisual *visual,
gpointer data,
gint width,
gint height);
GdkImage* gdk_image_new (GdkImageType type, GdkImage* gdk_image_new (GdkImageType type,
GdkVisual *visual, GdkVisual *visual,
gint width, gint width,
@ -85,6 +81,13 @@ guint32 gdk_image_get_pixel (GdkImage *image,
gint x, gint x,
gint y); gint y);
#ifdef GDK_ENABLE_BROKEN
GdkImage* gdk_image_new_bitmap (GdkVisual *visual,
gpointer data,
gint width,
gint height);
#endif /* GDK_ENABLE_BROKEN */
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */

View File

@ -381,7 +381,7 @@ gtk_accel_group_add (GtkAccelGroup *accel_group,
if (!query.signal_id || query.n_params > 0) if (!query.signal_id || query.n_params > 0)
{ {
g_warning ("gtk_accel_group_add(): signal \"%s\" in the `%s' class ancestry" g_warning ("gtk_accel_group_add(): signal \"%s\" in the `%s' class ancestry"
"cannot be used as accelerator signal", "cannot be used as accelerator signal (perhaps it has parameters)",
accel_signal, accel_signal,
gtk_type_name (GTK_OBJECT_TYPE (object))); gtk_type_name (GTK_OBJECT_TYPE (object)));

File diff suppressed because it is too large Load Diff

View File

@ -47,6 +47,9 @@ typedef struct _GtkColorSelection GtkColorSelection;
typedef struct _GtkColorSelectionClass GtkColorSelectionClass; typedef struct _GtkColorSelectionClass GtkColorSelectionClass;
typedef void (* GtkColorSelectionChangePaletteFunc) (const GdkColor *colors,
gint n_colors);
struct _GtkColorSelection struct _GtkColorSelection
{ {
GtkVBox parent_instance; GtkVBox parent_instance;
@ -63,7 +66,7 @@ struct _GtkColorSelectionClass
}; };
/* ColorSelection */ /* ColorSelection */
GtkType gtk_color_selection_get_type (void) G_GNUC_CONST; GtkType gtk_color_selection_get_type (void) G_GNUC_CONST;
GtkWidget *gtk_color_selection_new (void); GtkWidget *gtk_color_selection_new (void);
@ -91,17 +94,16 @@ void gtk_color_selection_set_previous_alpha (GtkColorSelection *colorsel,
void gtk_color_selection_get_previous_color (GtkColorSelection *colorsel, void gtk_color_selection_get_previous_color (GtkColorSelection *colorsel,
GdkColor *color); GdkColor *color);
guint16 gtk_color_selection_get_previous_alpha (GtkColorSelection *colorsel); guint16 gtk_color_selection_get_previous_alpha (GtkColorSelection *colorsel);
gint gtk_color_selection_get_palette_size (GtkColorSelection *colorsel);
gboolean gtk_color_selection_get_palette_color (GtkColorSelection *colorsel,
gint index,
GdkColor *color);
void gtk_color_selection_set_palette_color (GtkColorSelection *colorsel,
gint index,
GdkColor *color);
void gtk_color_selection_unset_palette_color (GtkColorSelection *colorsel,
gint index);
gboolean gtk_color_selection_is_adjusting (GtkColorSelection *colorsel); gboolean gtk_color_selection_is_adjusting (GtkColorSelection *colorsel);
gboolean gtk_color_selection_palette_from_string (const gchar *str,
GdkColor **colors,
gint *n_colors);
gchar* gtk_color_selection_palette_to_string (const GdkColor *colors,
gint n_colors);
GtkColorSelectionChangePaletteFunc gtk_color_selection_set_change_palette_hook (GtkColorSelectionChangePaletteFunc func);
#ifndef GTK_DISABLE_DEPRECATED #ifndef GTK_DISABLE_DEPRECATED
/* Deprecated calls: */ /* Deprecated calls: */

View File

@ -109,6 +109,8 @@ gtk_color_selection_dialog_init (GtkColorSelectionDialog *colorseldiag)
colorseldiag->help_button = gtk_dialog_add_button (GTK_DIALOG (colorseldiag), colorseldiag->help_button = gtk_dialog_add_button (GTK_DIALOG (colorseldiag),
GTK_STOCK_HELP, GTK_STOCK_HELP,
GTK_RESPONSE_HELP); GTK_RESPONSE_HELP);
gtk_widget_hide (colorseldiag->help_button);
} }
GtkWidget* GtkWidget*

View File

@ -552,6 +552,12 @@ gtk_entry_class_init (GtkEntryClass *class)
add_move_binding (binding_set, GDK_Left, 0, add_move_binding (binding_set, GDK_Left, 0,
GTK_MOVEMENT_VISUAL_POSITIONS, -1); GTK_MOVEMENT_VISUAL_POSITIONS, -1);
add_move_binding (binding_set, GDK_KP_Right, 0,
GTK_MOVEMENT_VISUAL_POSITIONS, 1);
add_move_binding (binding_set, GDK_KP_Left, 0,
GTK_MOVEMENT_VISUAL_POSITIONS, -1);
add_move_binding (binding_set, GDK_f, GDK_CONTROL_MASK, add_move_binding (binding_set, GDK_f, GDK_CONTROL_MASK,
GTK_MOVEMENT_LOGICAL_POSITIONS, 1); GTK_MOVEMENT_LOGICAL_POSITIONS, 1);
@ -563,6 +569,12 @@ gtk_entry_class_init (GtkEntryClass *class)
add_move_binding (binding_set, GDK_Left, GDK_CONTROL_MASK, add_move_binding (binding_set, GDK_Left, GDK_CONTROL_MASK,
GTK_MOVEMENT_WORDS, -1); GTK_MOVEMENT_WORDS, -1);
add_move_binding (binding_set, GDK_KP_Right, GDK_CONTROL_MASK,
GTK_MOVEMENT_WORDS, 1);
add_move_binding (binding_set, GDK_KP_Left, GDK_CONTROL_MASK,
GTK_MOVEMENT_WORDS, -1);
add_move_binding (binding_set, GDK_a, GDK_CONTROL_MASK, add_move_binding (binding_set, GDK_a, GDK_CONTROL_MASK,
GTK_MOVEMENT_PARAGRAPH_ENDS, -1); GTK_MOVEMENT_PARAGRAPH_ENDS, -1);
@ -581,6 +593,12 @@ gtk_entry_class_init (GtkEntryClass *class)
add_move_binding (binding_set, GDK_End, 0, add_move_binding (binding_set, GDK_End, 0,
GTK_MOVEMENT_DISPLAY_LINE_ENDS, 1); GTK_MOVEMENT_DISPLAY_LINE_ENDS, 1);
add_move_binding (binding_set, GDK_KP_Home, 0,
GTK_MOVEMENT_DISPLAY_LINE_ENDS, -1);
add_move_binding (binding_set, GDK_KP_End, 0,
GTK_MOVEMENT_DISPLAY_LINE_ENDS, 1);
add_move_binding (binding_set, GDK_Home, GDK_CONTROL_MASK, add_move_binding (binding_set, GDK_Home, GDK_CONTROL_MASK,
GTK_MOVEMENT_BUFFER_ENDS, -1); GTK_MOVEMENT_BUFFER_ENDS, -1);
@ -588,12 +606,31 @@ gtk_entry_class_init (GtkEntryClass *class)
add_move_binding (binding_set, GDK_End, GDK_CONTROL_MASK, add_move_binding (binding_set, GDK_End, GDK_CONTROL_MASK,
GTK_MOVEMENT_BUFFER_ENDS, 1); GTK_MOVEMENT_BUFFER_ENDS, 1);
add_move_binding (binding_set, GDK_KP_Home, GDK_CONTROL_MASK,
GTK_MOVEMENT_BUFFER_ENDS, -1);
add_move_binding (binding_set, GDK_KP_End, GDK_CONTROL_MASK,
GTK_MOVEMENT_BUFFER_ENDS, 1);
/* Activate */
gtk_binding_entry_add_signal (binding_set, GDK_Return, 0,
"activate", 0);
gtk_binding_entry_add_signal (binding_set, GDK_KP_Enter, 0,
"activate", 0);
/* Deleting text */ /* Deleting text */
gtk_binding_entry_add_signal (binding_set, GDK_Delete, 0, gtk_binding_entry_add_signal (binding_set, GDK_Delete, 0,
"delete_from_cursor", 2, "delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_CHARS, GTK_TYPE_ENUM, GTK_DELETE_CHARS,
GTK_TYPE_INT, 1); GTK_TYPE_INT, 1);
gtk_binding_entry_add_signal (binding_set, GDK_KP_Delete, 0,
"delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_CHARS,
GTK_TYPE_INT, 1);
gtk_binding_entry_add_signal (binding_set, GDK_d, GDK_CONTROL_MASK, gtk_binding_entry_add_signal (binding_set, GDK_d, GDK_CONTROL_MASK,
"delete_from_cursor", 2, "delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_CHARS, GTK_TYPE_ENUM, GTK_DELETE_CHARS,
@ -609,6 +646,11 @@ gtk_entry_class_init (GtkEntryClass *class)
GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS, GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS,
GTK_TYPE_INT, 1); GTK_TYPE_INT, 1);
gtk_binding_entry_add_signal (binding_set, GDK_KP_Delete, GDK_CONTROL_MASK,
"delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS,
GTK_TYPE_INT, 1);
gtk_binding_entry_add_signal (binding_set, GDK_d, GDK_MOD1_MASK, gtk_binding_entry_add_signal (binding_set, GDK_d, GDK_MOD1_MASK,
"delete_from_cursor", 2, "delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS, GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS,
@ -882,7 +924,9 @@ gtk_entry_realize (GtkWidget *widget)
GDK_BUTTON_RELEASE_MASK | GDK_BUTTON_RELEASE_MASK |
GDK_BUTTON1_MOTION_MASK | GDK_BUTTON1_MOTION_MASK |
GDK_BUTTON3_MOTION_MASK | GDK_BUTTON3_MOTION_MASK |
GDK_POINTER_MOTION_HINT_MASK); GDK_POINTER_MOTION_HINT_MASK |
GDK_ENTER_NOTIFY_MASK |
GDK_LEAVE_NOTIFY_MASK);
attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL | GDK_WA_COLORMAP; attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL | GDK_WA_COLORMAP;
widget->window = gdk_window_new (gtk_widget_get_parent_window (widget), &attributes, attributes_mask); widget->window = gdk_window_new (gtk_widget_get_parent_window (widget), &attributes, attributes_mask);
@ -1463,11 +1507,6 @@ gtk_entry_key_press (GtkWidget *widget,
/* Activate key bindings /* Activate key bindings
*/ */
return TRUE; return TRUE;
else if (event->keyval == GDK_Return)
{
gtk_widget_activate (widget);
return TRUE;
}
return FALSE; return FALSE;
} }

View File

@ -1430,8 +1430,6 @@ gtk_file_selection_key_press (GtkWidget *widget,
g_free (text); g_free (text);
gtk_signal_emit_stop_by_name (GTK_OBJECT (widget), "key_press_event");
return TRUE; return TRUE;
} }

View File

@ -86,13 +86,6 @@ static void gtk_font_selection_select_font (GtkWidget *w,
gint column, gint column,
GdkEventButton *bevent, GdkEventButton *bevent,
gpointer data); gpointer data);
static gint gtk_font_selection_on_clist_key_press (GtkWidget *clist,
GdkEventKey *event,
GtkFontSelection *fs);
static gboolean gtk_font_selection_select_next (GtkFontSelection *fs,
GtkWidget *clist,
gint step);
static void gtk_font_selection_show_available_fonts (GtkFontSelection *fs); static void gtk_font_selection_show_available_fonts (GtkFontSelection *fs);
static void gtk_font_selection_show_available_styles (GtkFontSelection *fs); static void gtk_font_selection_show_available_styles (GtkFontSelection *fs);
@ -106,8 +99,7 @@ static void gtk_font_selection_select_style (GtkWidget *w,
static void gtk_font_selection_select_best_size (GtkFontSelection *fs); static void gtk_font_selection_select_best_size (GtkFontSelection *fs);
static void gtk_font_selection_show_available_sizes (GtkFontSelection *fs); static void gtk_font_selection_show_available_sizes (GtkFontSelection *fs);
static gint gtk_font_selection_size_key_press (GtkWidget *w, static void gtk_font_selection_size_activate (GtkWidget *w,
GdkEventKey *event,
gpointer data); gpointer data);
static void gtk_font_selection_select_size (GtkWidget *w, static void gtk_font_selection_select_size (GtkWidget *w,
gint row, gint row,
@ -206,8 +198,8 @@ gtk_font_selection_init(GtkFontSelection *fontsel)
gtk_widget_show (fontsel->size_entry); gtk_widget_show (fontsel->size_entry);
gtk_table_attach (GTK_TABLE (table), fontsel->size_entry, 2, 3, 1, 2, gtk_table_attach (GTK_TABLE (table), fontsel->size_entry, 2, 3, 1, 2,
GTK_FILL, 0, 0, 0); GTK_FILL, 0, 0, 0);
gtk_signal_connect (GTK_OBJECT (fontsel->size_entry), "key_press_event", gtk_signal_connect (GTK_OBJECT (fontsel->size_entry), "activate",
(GtkSignalFunc) gtk_font_selection_size_key_press, (GtkSignalFunc) gtk_font_selection_size_activate,
fontsel); fontsel);
fontsel->font_label = gtk_label_new_with_mnemonic (_("_Family:")); fontsel->font_label = gtk_label_new_with_mnemonic (_("_Family:"));
@ -285,9 +277,10 @@ gtk_font_selection_init(GtkFontSelection *fontsel)
GTK_SIGNAL_FUNC(gtk_font_selection_select_font), GTK_SIGNAL_FUNC(gtk_font_selection_select_font),
fontsel); fontsel);
GTK_WIDGET_SET_FLAGS (fontsel->font_clist, GTK_CAN_FOCUS); GTK_WIDGET_SET_FLAGS (fontsel->font_clist, GTK_CAN_FOCUS);
gtk_signal_connect (GTK_OBJECT (fontsel->font_clist), "key_press_event",
GTK_SIGNAL_FUNC(gtk_font_selection_on_clist_key_press), gtk_signal_connect_after (GTK_OBJECT (fontsel->font_clist), "expose_event",
fontsel); GTK_SIGNAL_FUNC(gtk_font_selection_expose_list),
fontsel);
gtk_font_selection_show_available_styles (fontsel); gtk_font_selection_show_available_styles (fontsel);
@ -295,10 +288,6 @@ gtk_font_selection_init(GtkFontSelection *fontsel)
GTK_SIGNAL_FUNC(gtk_font_selection_select_style), GTK_SIGNAL_FUNC(gtk_font_selection_select_style),
fontsel); fontsel);
GTK_WIDGET_SET_FLAGS (fontsel->font_style_clist, GTK_CAN_FOCUS); GTK_WIDGET_SET_FLAGS (fontsel->font_style_clist, GTK_CAN_FOCUS);
gtk_signal_connect (GTK_OBJECT (fontsel->font_style_clist),
"key_press_event",
GTK_SIGNAL_FUNC(gtk_font_selection_on_clist_key_press),
fontsel);
gtk_font_selection_show_available_sizes (fontsel); gtk_font_selection_show_available_sizes (fontsel);
@ -306,9 +295,6 @@ gtk_font_selection_init(GtkFontSelection *fontsel)
GTK_SIGNAL_FUNC(gtk_font_selection_select_size), GTK_SIGNAL_FUNC(gtk_font_selection_select_size),
fontsel); fontsel);
GTK_WIDGET_SET_FLAGS (fontsel->size_clist, GTK_CAN_FOCUS); GTK_WIDGET_SET_FLAGS (fontsel->size_clist, GTK_CAN_FOCUS);
gtk_signal_connect (GTK_OBJECT (fontsel->size_clist), "key_press_event",
GTK_SIGNAL_FUNC(gtk_font_selection_on_clist_key_press),
fontsel);
/* create the text entry widget */ /* create the text entry widget */
text_frame = gtk_frame_new (_("Preview:")); text_frame = gtk_frame_new (_("Preview:"));
@ -477,59 +463,6 @@ gtk_font_selection_show_available_fonts (GtkFontSelection *fontsel)
pango_font_map_free_families (families, n_families); pango_font_map_free_families (families, n_families);
} }
static gint
gtk_font_selection_on_clist_key_press (GtkWidget *clist,
GdkEventKey *event,
GtkFontSelection *fontsel)
{
#ifdef FONTSEL_DEBUG
g_message("In on_clist_key_press\n");
#endif
if (event->keyval == GDK_Up)
return gtk_font_selection_select_next (fontsel, clist, -1);
else if (event->keyval == GDK_Down)
return gtk_font_selection_select_next (fontsel, clist, 1);
else
return FALSE;
}
static gboolean
gtk_font_selection_select_next (GtkFontSelection *fontsel,
GtkWidget *clist,
gint step)
{
GList *selection;
gint current_row, row;
selection = GTK_CLIST(clist)->selection;
if (!selection)
return FALSE;
current_row = GPOINTER_TO_INT (selection->data);
/* Stop the normal clist key handler from being run. */
gtk_signal_emit_stop_by_name (GTK_OBJECT (clist), "key_press_event");
for (row = current_row + step;
row >= 0 && row < GTK_CLIST(clist)->rows;
row += step)
{
/* If this is the style clist, make sure that the item is not a charset
entry. */
if (clist == fontsel->font_style_clist)
if (GPOINTER_TO_INT (gtk_clist_get_row_data(GTK_CLIST(clist), row)) == -1)
continue;
/* Now we've found the row to select. */
if (gtk_clist_row_is_visible(GTK_CLIST(clist), row)
!= GTK_VISIBILITY_FULL)
gtk_clist_moveto(GTK_CLIST(clist), row, -1, (step < 0) ? 0 : 1, 0);
gtk_clist_select_row(GTK_CLIST(clist), row, 0);
break;
}
return TRUE;
}
static int static int
compare_font_descriptions (const PangoFontDescription *a, const PangoFontDescription *b) compare_font_descriptions (const PangoFontDescription *a, const PangoFontDescription *b)
{ {
@ -699,31 +632,24 @@ gtk_font_selection_select_best_size (GtkFontSelection *fontsel)
/* If the user hits return in the font size entry, we change to the new font /* If the user hits return in the font size entry, we change to the new font
size. */ size. */
static gint static void
gtk_font_selection_size_key_press (GtkWidget *w, gtk_font_selection_size_activate (GtkWidget *w,
GdkEventKey *event, gpointer data)
gpointer data)
{ {
GtkFontSelection *fontsel; GtkFontSelection *fontsel;
gint new_size; gint new_size;
gchar *text; gchar *text;
fontsel = GTK_FONT_SELECTION (data); fontsel = GTK_FONT_SELECTION (data);
if (event->keyval == GDK_Return)
{
text = gtk_entry_get_text (GTK_ENTRY (fontsel->size_entry));
new_size = atoi (text) * PANGO_SCALE;
if (fontsel->font_desc->size != new_size) text = gtk_entry_get_text (GTK_ENTRY (fontsel->size_entry));
{ new_size = atoi (text) * PANGO_SCALE;
fontsel->font_desc->size = new_size;
gtk_font_selection_load_font (fontsel);
}
return TRUE;
}
return FALSE; if (fontsel->font_desc->size != new_size)
{
fontsel->font_desc->size = new_size;
gtk_font_selection_load_font (fontsel);
}
} }
/* This is called when a size is selected in the list. */ /* This is called when a size is selected in the list. */

View File

@ -29,6 +29,7 @@
#include "gtksignal.h" #include "gtksignal.h"
#include "gdk/gdkkeysyms.h" #include "gdk/gdkkeysyms.h"
#include "gtkintl.h" #include "gtkintl.h"
#include "gtkbindings.h"
#define SCALE_CLASS(w) GTK_SCALE_GET_CLASS (w) #define SCALE_CLASS(w) GTK_SCALE_GET_CLASS (w)
#define RANGE_CLASS(w) GTK_RANGE_GET_CLASS (w) #define RANGE_CLASS(w) GTK_RANGE_GET_CLASS (w)
@ -65,10 +66,7 @@ static void gtk_hscale_pos_background (GtkHScale *hscale,
gint *h); gint *h);
static void gtk_hscale_draw_slider (GtkRange *range); static void gtk_hscale_draw_slider (GtkRange *range);
static void gtk_hscale_draw_value (GtkScale *scale); static void gtk_hscale_draw_value (GtkScale *scale);
static gboolean gtk_hscale_trough_keys (GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *pos);
static void gtk_hscale_clear_background (GtkRange *range); static void gtk_hscale_clear_background (GtkRange *range);
@ -97,6 +95,12 @@ gtk_hscale_get_type (void)
return hscale_type; return hscale_type;
} }
#define add_slider_binding(binding_set, keyval, mask, scroll, trough) \
gtk_binding_entry_add_signal (binding_set, keyval, mask, \
"move_slider", 2, \
GTK_TYPE_SCROLL_TYPE, scroll, \
GTK_TYPE_TROUGH_TYPE, trough)
static void static void
gtk_hscale_class_init (GtkHScaleClass *class) gtk_hscale_class_init (GtkHScaleClass *class)
{ {
@ -105,7 +109,8 @@ gtk_hscale_class_init (GtkHScaleClass *class)
GtkWidgetClass *widget_class; GtkWidgetClass *widget_class;
GtkRangeClass *range_class; GtkRangeClass *range_class;
GtkScaleClass *scale_class; GtkScaleClass *scale_class;
GtkBindingSet *binding_set;
gobject_class = (GObjectClass*) class; gobject_class = (GObjectClass*) class;
object_class = (GtkObjectClass*) class; object_class = (GtkObjectClass*) class;
widget_class = (GtkWidgetClass*) class; widget_class = (GtkWidgetClass*) class;
@ -123,7 +128,6 @@ gtk_hscale_class_init (GtkHScaleClass *class)
range_class->trough_click = _gtk_range_default_htrough_click; range_class->trough_click = _gtk_range_default_htrough_click;
range_class->motion = _gtk_range_default_hmotion; range_class->motion = _gtk_range_default_hmotion;
range_class->draw_slider = gtk_hscale_draw_slider; range_class->draw_slider = gtk_hscale_draw_slider;
range_class->trough_keys = gtk_hscale_trough_keys;
range_class->clear_background = gtk_hscale_clear_background; range_class->clear_background = gtk_hscale_clear_background;
scale_class->draw_value = gtk_hscale_draw_value; scale_class->draw_value = gtk_hscale_draw_value;
@ -135,7 +139,45 @@ gtk_hscale_class_init (GtkHScaleClass *class)
_("The GtkAdjustment that determines the values to use for this HScale."), _("The GtkAdjustment that determines the values to use for this HScale."),
GTK_TYPE_ADJUSTMENT, GTK_TYPE_ADJUSTMENT,
G_PARAM_READWRITE)); G_PARAM_READWRITE));
binding_set = gtk_binding_set_by_class (object_class);
add_slider_binding (binding_set, GDK_Left, 0,
GTK_SCROLL_STEP_LEFT, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Left, GDK_CONTROL_MASK,
GTK_SCROLL_PAGE_LEFT, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Left, 0,
GTK_SCROLL_STEP_LEFT, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Left, GDK_CONTROL_MASK,
GTK_SCROLL_PAGE_LEFT, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Right, 0,
GTK_SCROLL_STEP_RIGHT, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Right, GDK_CONTROL_MASK,
GTK_SCROLL_PAGE_RIGHT, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Right, 0,
GTK_SCROLL_STEP_RIGHT, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Right, GDK_CONTROL_MASK,
GTK_SCROLL_PAGE_RIGHT, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Home, 0,
GTK_SCROLL_NONE, GTK_TROUGH_START);
add_slider_binding (binding_set, GDK_KP_Home, 0,
GTK_SCROLL_NONE, GTK_TROUGH_START);
add_slider_binding (binding_set, GDK_End, 0,
GTK_SCROLL_NONE, GTK_TROUGH_END);
add_slider_binding (binding_set, GDK_KP_End, 0,
GTK_SCROLL_NONE, GTK_TROUGH_END);
} }
static void static void
@ -555,38 +597,3 @@ gtk_hscale_draw_value (GtkScale *scale)
g_object_unref (G_OBJECT (layout)); g_object_unref (G_OBJECT (layout));
} }
} }
static gboolean
gtk_hscale_trough_keys (GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *pos)
{
gint return_val = FALSE;
switch (key->keyval)
{
case GDK_Left:
return_val = TRUE;
if (key->state & GDK_CONTROL_MASK)
*scroll = GTK_SCROLL_PAGE_LEFT;
else
*scroll = GTK_SCROLL_STEP_LEFT;
break;
case GDK_Right:
return_val = TRUE;
if (key->state & GDK_CONTROL_MASK)
*scroll = GTK_SCROLL_PAGE_RIGHT;
else
*scroll = GTK_SCROLL_STEP_RIGHT;
break;
case GDK_Home:
return_val = TRUE;
*pos = GTK_TROUGH_START;
break;
case GDK_End:
return_val = TRUE;
*pos = GTK_TROUGH_END;
break;
}
return return_val;
}

View File

@ -58,10 +58,6 @@ static void gtk_hscrollbar_draw_step_forw (GtkRange *range);
static void gtk_hscrollbar_draw_step_back (GtkRange *range); static void gtk_hscrollbar_draw_step_back (GtkRange *range);
static void gtk_hscrollbar_slider_update (GtkRange *range); static void gtk_hscrollbar_slider_update (GtkRange *range);
static void gtk_hscrollbar_calc_slider_size (GtkHScrollbar *hscrollbar); static void gtk_hscrollbar_calc_slider_size (GtkHScrollbar *hscrollbar);
static gboolean gtk_hscrollbar_trough_keys (GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *pos);
GtkType GtkType
gtk_hscrollbar_get_type (void) gtk_hscrollbar_get_type (void)
@ -112,7 +108,6 @@ gtk_hscrollbar_class_init (GtkHScrollbarClass *class)
range_class->draw_step_back = gtk_hscrollbar_draw_step_back; range_class->draw_step_back = gtk_hscrollbar_draw_step_back;
range_class->slider_update = gtk_hscrollbar_slider_update; range_class->slider_update = gtk_hscrollbar_slider_update;
range_class->trough_click = _gtk_range_default_htrough_click; range_class->trough_click = _gtk_range_default_htrough_click;
range_class->trough_keys = gtk_hscrollbar_trough_keys;
range_class->motion = _gtk_range_default_hmotion; range_class->motion = _gtk_range_default_hmotion;
g_object_class_install_property (gobject_class, g_object_class_install_property (gobject_class,
@ -464,38 +459,3 @@ gtk_hscrollbar_calc_slider_size (GtkHScrollbar *hscrollbar)
} }
} }
} }
static gboolean
gtk_hscrollbar_trough_keys(GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *pos)
{
gint return_val = FALSE;
switch (key->keyval)
{
case GDK_Left:
return_val = TRUE;
*scroll = GTK_SCROLL_STEP_BACKWARD;
break;
case GDK_Right:
return_val = TRUE;
*scroll = GTK_SCROLL_STEP_FORWARD;
break;
case GDK_Home:
return_val = TRUE;
if (key->state & GDK_CONTROL_MASK)
*scroll = GTK_SCROLL_PAGE_BACKWARD;
else
*pos = GTK_TROUGH_START;
break;
case GDK_End:
return_val = TRUE;
if (key->state & GDK_CONTROL_MASK)
*scroll = GTK_SCROLL_PAGE_FORWARD;
else
*pos = GTK_TROUGH_END;
break;
}
return return_val;
}

View File

@ -331,7 +331,9 @@ gtk_hsv_realize (GtkWidget *widget)
attr.event_mask |= (GDK_KEY_PRESS_MASK attr.event_mask |= (GDK_KEY_PRESS_MASK
| GDK_BUTTON_PRESS_MASK | GDK_BUTTON_PRESS_MASK
| GDK_BUTTON_RELEASE_MASK | GDK_BUTTON_RELEASE_MASK
| GDK_POINTER_MOTION_MASK); | GDK_POINTER_MOTION_MASK
| GDK_ENTER_NOTIFY_MASK
| GDK_LEAVE_NOTIFY_MASK);
attr_mask = GDK_WA_X | GDK_WA_Y; attr_mask = GDK_WA_X | GDK_WA_Y;
@ -1275,14 +1277,17 @@ paint_triangle (GtkHSV *hsv,
gdk_rgb_gc_set_foreground (priv->gc, 0x000000); gdk_rgb_gc_set_foreground (priv->gc, 0x000000);
else else
gdk_rgb_gc_set_foreground (priv->gc, 0xffffff); gdk_rgb_gc_set_foreground (priv->gc, 0xffffff);
#define OUTER_RADIUS 4
#define INNER_RADIUS 3
gdk_draw_arc (drawable, priv->gc, FALSE, gdk_draw_arc (drawable, priv->gc, FALSE,
xx - 3, yy - 3, xx - OUTER_RADIUS, yy - OUTER_RADIUS,
6, 6, OUTER_RADIUS * 2, OUTER_RADIUS * 2,
0, 360 * 64); 0, 360 * 64);
gdk_draw_arc (drawable, priv->gc, FALSE, gdk_draw_arc (drawable, priv->gc, FALSE,
xx - 2, yy - 2, xx - INNER_RADIUS, yy - INNER_RADIUS,
4, 4, INNER_RADIUS * 2, INNER_RADIUS * 2,
0, 360 * 64); 0, 360 * 64);
} }

View File

@ -48,6 +48,7 @@ VOID:BOXED,UINT
VOID:BOXED,UINT,FLAGS VOID:BOXED,UINT,FLAGS
VOID:BOXED,UINT,UINT VOID:BOXED,UINT,UINT
VOID:ENUM VOID:ENUM
VOID:ENUM,ENUM
VOID:ENUM,FLOAT VOID:ENUM,FLOAT
VOID:ENUM,FLOAT,BOOL VOID:ENUM,FLOAT,BOOL
VOID:ENUM,INT VOID:ENUM,INT

View File

@ -48,6 +48,7 @@ VOID:BOXED,UINT
VOID:BOXED,UINT,FLAGS VOID:BOXED,UINT,FLAGS
VOID:BOXED,UINT,UINT VOID:BOXED,UINT,UINT
VOID:ENUM VOID:ENUM
VOID:ENUM,ENUM
VOID:ENUM,FLOAT VOID:ENUM,FLOAT
VOID:ENUM,FLOAT,BOOL VOID:ENUM,FLOAT,BOOL
VOID:ENUM,INT VOID:ENUM,INT

View File

@ -33,6 +33,7 @@
#include <gdk/gdkkeysyms.h> #include <gdk/gdkkeysyms.h>
#include <stdio.h> #include <stdio.h>
#include "gtkintl.h" #include "gtkintl.h"
#include "gtkbindings.h"
#define TAB_OVERLAP 2 #define TAB_OVERLAP 2
@ -46,6 +47,8 @@
enum { enum {
SWITCH_PAGE, SWITCH_PAGE,
FOCUS_TAB,
SELECT_PAGE,
LAST_SIGNAL LAST_SIGNAL
}; };
@ -111,6 +114,11 @@ struct _GtkNotebookPage
static void gtk_notebook_class_init (GtkNotebookClass *klass); static void gtk_notebook_class_init (GtkNotebookClass *klass);
static void gtk_notebook_init (GtkNotebook *notebook); static void gtk_notebook_init (GtkNotebook *notebook);
static void gtk_notebook_select_page (GtkNotebook *notebook,
gboolean move_focus);
static void gtk_notebook_focus_tab (GtkNotebook *notebook,
GtkNotebookTab type);
/*** GtkObject Methods ***/ /*** GtkObject Methods ***/
static void gtk_notebook_destroy (GtkObject *object); static void gtk_notebook_destroy (GtkObject *object);
static void gtk_notebook_set_arg (GtkObject *object, static void gtk_notebook_set_arg (GtkObject *object,
@ -141,8 +149,6 @@ static gint gtk_notebook_leave_notify (GtkWidget *widget,
GdkEventCrossing *event); GdkEventCrossing *event);
static gint gtk_notebook_motion_notify (GtkWidget *widget, static gint gtk_notebook_motion_notify (GtkWidget *widget,
GdkEventMotion *event); GdkEventMotion *event);
static gint gtk_notebook_key_press (GtkWidget *widget,
GdkEventKey *event);
static gint gtk_notebook_focus_in (GtkWidget *widget, static gint gtk_notebook_focus_in (GtkWidget *widget,
GdkEventFocus *event); GdkEventFocus *event);
static void gtk_notebook_draw_focus (GtkWidget *widget); static void gtk_notebook_draw_focus (GtkWidget *widget);
@ -274,7 +280,8 @@ gtk_notebook_class_init (GtkNotebookClass *class)
GtkObjectClass *object_class; GtkObjectClass *object_class;
GtkWidgetClass *widget_class; GtkWidgetClass *widget_class;
GtkContainerClass *container_class; GtkContainerClass *container_class;
GtkBindingSet *binding_set;
object_class = (GtkObjectClass*) class; object_class = (GtkObjectClass*) class;
widget_class = (GtkWidgetClass*) class; widget_class = (GtkWidgetClass*) class;
container_class = (GtkContainerClass*) class; container_class = (GtkContainerClass*) class;
@ -297,7 +304,6 @@ gtk_notebook_class_init (GtkNotebookClass *class)
widget_class->enter_notify_event = gtk_notebook_enter_notify; widget_class->enter_notify_event = gtk_notebook_enter_notify;
widget_class->leave_notify_event = gtk_notebook_leave_notify; widget_class->leave_notify_event = gtk_notebook_leave_notify;
widget_class->motion_notify_event = gtk_notebook_motion_notify; widget_class->motion_notify_event = gtk_notebook_motion_notify;
widget_class->key_press_event = gtk_notebook_key_press;
widget_class->focus_in_event = gtk_notebook_focus_in; widget_class->focus_in_event = gtk_notebook_focus_in;
widget_class->style_set = gtk_notebook_style_set; widget_class->style_set = gtk_notebook_style_set;
@ -312,6 +318,9 @@ gtk_notebook_class_init (GtkNotebookClass *class)
class->switch_page = gtk_notebook_real_switch_page; class->switch_page = gtk_notebook_real_switch_page;
class->focus_tab = gtk_notebook_focus_tab;
class->select_page = gtk_notebook_select_page;
gtk_object_add_arg_type ("GtkNotebook::page", GTK_TYPE_INT, GTK_ARG_READWRITE, ARG_PAGE); gtk_object_add_arg_type ("GtkNotebook::page", GTK_TYPE_INT, GTK_ARG_READWRITE, ARG_PAGE);
gtk_object_add_arg_type ("GtkNotebook::tab_pos", GTK_TYPE_POSITION_TYPE, GTK_ARG_READWRITE, ARG_TAB_POS); gtk_object_add_arg_type ("GtkNotebook::tab_pos", GTK_TYPE_POSITION_TYPE, GTK_ARG_READWRITE, ARG_TAB_POS);
gtk_object_add_arg_type ("GtkNotebook::tab_border", GTK_TYPE_UINT, GTK_ARG_WRITABLE, ARG_TAB_BORDER); gtk_object_add_arg_type ("GtkNotebook::tab_border", GTK_TYPE_UINT, GTK_ARG_WRITABLE, ARG_TAB_BORDER);
@ -338,6 +347,60 @@ gtk_notebook_class_init (GtkNotebookClass *class)
GTK_TYPE_NONE, 2, GTK_TYPE_NONE, 2,
GTK_TYPE_POINTER, GTK_TYPE_POINTER,
GTK_TYPE_UINT); GTK_TYPE_UINT);
notebook_signals[FOCUS_TAB] =
g_signal_newc ("focus_tab",
G_TYPE_FROM_CLASS (object_class),
G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
G_STRUCT_OFFSET (GtkNotebookClass, focus_tab),
NULL, NULL,
gtk_marshal_VOID__ENUM,
G_TYPE_NONE, 1,
GTK_TYPE_NOTEBOOK_TAB);
notebook_signals[SELECT_PAGE] =
g_signal_newc ("select_page",
G_TYPE_FROM_CLASS (object_class),
G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
G_STRUCT_OFFSET (GtkNotebookClass, select_page),
NULL, NULL,
gtk_marshal_VOID__BOOLEAN,
G_TYPE_NONE, 1,
G_TYPE_BOOLEAN);
binding_set = gtk_binding_set_by_class (object_class);
gtk_binding_entry_add_signal (binding_set,
GDK_Return, 0,
"select_page", 1,
G_TYPE_BOOLEAN, TRUE);
gtk_binding_entry_add_signal (binding_set,
GDK_KP_Enter, 0,
"select_page", 1,
G_TYPE_BOOLEAN, TRUE);
gtk_binding_entry_add_signal (binding_set,
GDK_space, 0,
"select_page", 1,
G_TYPE_BOOLEAN, FALSE);
gtk_binding_entry_add_signal (binding_set,
GDK_Home, 0,
"focus_tab", 1,
GTK_TYPE_NOTEBOOK_TAB, GTK_NOTEBOOK_TAB_FIRST);
gtk_binding_entry_add_signal (binding_set,
GDK_KP_Home, 0,
"focus_tab", 1,
GTK_TYPE_NOTEBOOK_TAB, GTK_NOTEBOOK_TAB_FIRST);
gtk_binding_entry_add_signal (binding_set,
GDK_End, 0,
"focus_tab", 1,
GTK_TYPE_NOTEBOOK_TAB, GTK_NOTEBOOK_TAB_LAST);
gtk_binding_entry_add_signal (binding_set,
GDK_KP_End, 0,
"focus_tab", 1,
GTK_TYPE_NOTEBOOK_TAB, GTK_NOTEBOOK_TAB_LAST);
} }
static void static void
@ -368,6 +431,34 @@ gtk_notebook_init (GtkNotebook *notebook)
notebook->have_visible_child = FALSE; notebook->have_visible_child = FALSE;
} }
static void
gtk_notebook_select_page (GtkNotebook *notebook,
gboolean move_focus)
{
gtk_notebook_page_select (notebook, move_focus);
}
static void
gtk_notebook_focus_tab (GtkNotebook *notebook,
GtkNotebookTab type)
{
GList *list;
switch (type)
{
case GTK_NOTEBOOK_TAB_FIRST:
list = gtk_notebook_search_page (notebook, NULL, STEP_NEXT, TRUE);
if (list)
gtk_notebook_switch_focus_tab (notebook, list);
break;
case GTK_NOTEBOOK_TAB_LAST:
list = gtk_notebook_search_page (notebook, NULL, STEP_PREV, TRUE);
if (list)
gtk_notebook_switch_focus_tab (notebook, list);
break;
}
}
/** /**
* gtk_notebook_new: * gtk_notebook_new:
* *
@ -509,7 +600,6 @@ gtk_notebook_get_arg (GtkObject *object,
* gtk_notebook_enter_notify * gtk_notebook_enter_notify
* gtk_notebook_leave_notify * gtk_notebook_leave_notify
* gtk_notebook_motion_notify * gtk_notebook_motion_notify
* gtk_notebook_key_press
* gtk_notebook_focus_in * gtk_notebook_focus_in
* gtk_notebook_focus_out * gtk_notebook_focus_out
* gtk_notebook_draw_focus * gtk_notebook_draw_focus
@ -1236,45 +1326,6 @@ gtk_notebook_motion_notify (GtkWidget *widget,
return FALSE; return FALSE;
} }
static gint
gtk_notebook_key_press (GtkWidget *widget,
GdkEventKey *event)
{
GtkNotebook *notebook;
GList *list;
g_return_val_if_fail (widget != NULL, FALSE);
g_return_val_if_fail (GTK_IS_NOTEBOOK (widget), FALSE);
g_return_val_if_fail (event != NULL, FALSE);
notebook = GTK_NOTEBOOK (widget);
if (!notebook->children || !notebook->show_tabs)
return FALSE;
switch (event->keyval)
{
case GDK_Home:
list = gtk_notebook_search_page (notebook, NULL, STEP_NEXT, TRUE);
if (list)
gtk_notebook_switch_focus_tab (notebook, list);
return TRUE;
case GDK_End:
list = gtk_notebook_search_page (notebook, NULL, STEP_PREV, TRUE);
if (list)
gtk_notebook_switch_focus_tab (notebook, list);
return TRUE;
case GDK_Return:
gtk_notebook_page_select (GTK_NOTEBOOK (widget), TRUE);
return TRUE;
case GDK_space:
gtk_notebook_page_select (GTK_NOTEBOOK (widget), FALSE);
return TRUE;
}
return FALSE;
}
static gint static gint
gtk_notebook_focus_in (GtkWidget *widget, gtk_notebook_focus_in (GtkWidget *widget,
GdkEventFocus *event) GdkEventFocus *event)

View File

@ -45,6 +45,12 @@ extern "C" {
#define GTK_NOTEBOOK_GET_CLASS(obj) (GTK_CHECK_GET_CLASS ((obj), GTK_TYPE_NOTEBOOK, GtkNotebookClass)) #define GTK_NOTEBOOK_GET_CLASS(obj) (GTK_CHECK_GET_CLASS ((obj), GTK_TYPE_NOTEBOOK, GtkNotebookClass))
typedef enum
{
GTK_NOTEBOOK_TAB_FIRST,
GTK_NOTEBOOK_TAB_LAST
} GtkNotebookTab;
typedef struct _GtkNotebook GtkNotebook; typedef struct _GtkNotebook GtkNotebook;
typedef struct _GtkNotebookClass GtkNotebookClass; typedef struct _GtkNotebookClass GtkNotebookClass;
typedef struct _GtkNotebookPage GtkNotebookPage; typedef struct _GtkNotebookPage GtkNotebookPage;
@ -86,6 +92,14 @@ struct _GtkNotebookClass
void (* switch_page) (GtkNotebook *notebook, void (* switch_page) (GtkNotebook *notebook,
GtkNotebookPage *page, GtkNotebookPage *page,
guint page_num); guint page_num);
/* Action signals for keybindings */
void (* select_page) (GtkNotebook *notebook,
gboolean move_focus);
void (* focus_tab) (GtkNotebook *notebook,
GtkNotebookTab type);
}; };
/*********************************************************** /***********************************************************

View File

@ -43,6 +43,11 @@ enum {
PROP_UPDATE_POLICY PROP_UPDATE_POLICY
}; };
enum {
MOVE_SLIDER,
LAST_SIGNAL
};
static void gtk_range_class_init (GtkRangeClass *klass); static void gtk_range_class_init (GtkRangeClass *klass);
static void gtk_range_init (GtkRange *range); static void gtk_range_init (GtkRange *range);
static void gtk_range_set_property (GObject *object, static void gtk_range_set_property (GObject *object,
@ -63,8 +68,6 @@ static gint gtk_range_button_release (GtkWidget *widget,
GdkEventButton *event); GdkEventButton *event);
static gint gtk_range_motion_notify (GtkWidget *widget, static gint gtk_range_motion_notify (GtkWidget *widget,
GdkEventMotion *event); GdkEventMotion *event);
static gint gtk_range_key_press (GtkWidget *widget,
GdkEventKey *event);
static gint gtk_range_enter_notify (GtkWidget *widget, static gint gtk_range_enter_notify (GtkWidget *widget,
GdkEventCrossing *event); GdkEventCrossing *event);
static gint gtk_range_leave_notify (GtkWidget *widget, static gint gtk_range_leave_notify (GtkWidget *widget,
@ -74,6 +77,10 @@ static gint gtk_range_scroll_event (GtkWidget *widget,
static void gtk_range_style_set (GtkWidget *widget, static void gtk_range_style_set (GtkWidget *widget,
GtkStyle *previous_style); GtkStyle *previous_style);
static void gtk_range_move_slider (GtkRange *range,
GtkScrollType scroll,
GtkTroughType trough);
static void gtk_real_range_draw_trough (GtkRange *range); static void gtk_real_range_draw_trough (GtkRange *range);
static void gtk_real_range_draw_slider (GtkRange *range); static void gtk_real_range_draw_slider (GtkRange *range);
static gint gtk_real_range_timer (GtkRange *range); static gint gtk_real_range_timer (GtkRange *range);
@ -96,6 +103,7 @@ static void gtk_range_trough_vdims (GtkRange *range,
gint *bottom); gint *bottom);
static GtkWidgetClass *parent_class = NULL; static GtkWidgetClass *parent_class = NULL;
static guint signals[LAST_SIGNAL];
GtkType GtkType
@ -146,16 +154,18 @@ gtk_range_class_init (GtkRangeClass *class)
widget_class->button_release_event = gtk_range_button_release; widget_class->button_release_event = gtk_range_button_release;
widget_class->motion_notify_event = gtk_range_motion_notify; widget_class->motion_notify_event = gtk_range_motion_notify;
widget_class->scroll_event = gtk_range_scroll_event; widget_class->scroll_event = gtk_range_scroll_event;
widget_class->key_press_event = gtk_range_key_press;
widget_class->enter_notify_event = gtk_range_enter_notify; widget_class->enter_notify_event = gtk_range_enter_notify;
widget_class->leave_notify_event = gtk_range_leave_notify; widget_class->leave_notify_event = gtk_range_leave_notify;
widget_class->style_set = gtk_range_style_set; widget_class->style_set = gtk_range_style_set;
class->min_slider_size = 7; class->min_slider_size = 7;
class->trough = 1; class->trough = 1;
class->slider = 2; class->slider = 2;
class->step_forw = 3; class->step_forw = 3;
class->step_back = 4; class->step_back = 4;
class->move_slider = gtk_range_move_slider;
class->draw_background = NULL; class->draw_background = NULL;
class->clear_background = NULL; class->clear_background = NULL;
class->draw_trough = gtk_real_range_draw_trough; class->draw_trough = gtk_real_range_draw_trough;
@ -163,10 +173,21 @@ gtk_range_class_init (GtkRangeClass *class)
class->draw_step_forw = NULL; class->draw_step_forw = NULL;
class->draw_step_back = NULL; class->draw_step_back = NULL;
class->trough_click = NULL; class->trough_click = NULL;
class->trough_keys = NULL;
class->motion = NULL; class->motion = NULL;
class->timer = gtk_real_range_timer; class->timer = gtk_real_range_timer;
signals[MOVE_SLIDER] =
g_signal_newc ("move_slider",
G_TYPE_FROM_CLASS (object_class),
G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
G_STRUCT_OFFSET (GtkRangeClass, move_slider),
NULL, NULL,
gtk_marshal_VOID__ENUM_ENUM,
G_TYPE_NONE, 2,
GTK_TYPE_SCROLL_TYPE,
GTK_TYPE_TROUGH_TYPE);
g_object_class_install_property (gobject_class, g_object_class_install_property (gobject_class,
PROP_UPDATE_POLICY, PROP_UPDATE_POLICY,
g_param_spec_enum ("update_policy", g_param_spec_enum ("update_policy",
@ -1138,93 +1159,77 @@ gtk_range_motion_notify (GtkWidget *widget,
return TRUE; return TRUE;
} }
static gint static void
gtk_range_key_press (GtkWidget *widget, gtk_range_move_slider (GtkRange *range,
GdkEventKey *event) GtkScrollType scroll,
GtkTroughType pos)
{ {
GtkRange *range; if (scroll != GTK_SCROLL_NONE)
gint return_val;
GtkScrollType scroll = GTK_SCROLL_NONE;
GtkTroughType pos = GTK_TROUGH_NONE;
g_return_val_if_fail (GTK_IS_RANGE (widget), FALSE);
g_return_val_if_fail (event != NULL, FALSE);
range = GTK_RANGE (widget);
return_val = FALSE;
if (RANGE_CLASS (range)->trough_keys)
return_val = (* RANGE_CLASS (range)->trough_keys) (range, event, &scroll, &pos);
if (return_val)
{ {
if (scroll != GTK_SCROLL_NONE) range->scroll_type = scroll;
{
range->scroll_type = scroll;
gtk_range_scroll (range, -1); gtk_range_scroll (range, -1);
if (range->old_value != range->adjustment->value) if (range->old_value != range->adjustment->value)
{ {
gtk_signal_emit_by_name (GTK_OBJECT (range->adjustment), "value_changed"); gtk_signal_emit_by_name (GTK_OBJECT (range->adjustment), "value_changed");
switch (range->scroll_type) switch (range->scroll_type)
{ {
case GTK_SCROLL_STEP_LEFT: case GTK_SCROLL_STEP_LEFT:
if (should_invert (range, TRUE)) if (should_invert (range, TRUE))
_gtk_range_draw_step_forw (range); _gtk_range_draw_step_forw (range);
else else
_gtk_range_draw_step_back (range); _gtk_range_draw_step_back (range);
break; break;
case GTK_SCROLL_STEP_UP: case GTK_SCROLL_STEP_UP:
if (should_invert (range, FALSE)) if (should_invert (range, FALSE))
_gtk_range_draw_step_forw (range); _gtk_range_draw_step_forw (range);
else else
_gtk_range_draw_step_back (range); _gtk_range_draw_step_back (range);
break; break;
case GTK_SCROLL_STEP_RIGHT: case GTK_SCROLL_STEP_RIGHT:
if (should_invert (range, TRUE)) if (should_invert (range, TRUE))
_gtk_range_draw_step_back (range); _gtk_range_draw_step_back (range);
else else
_gtk_range_draw_step_forw (range); _gtk_range_draw_step_forw (range);
break; break;
case GTK_SCROLL_STEP_DOWN: case GTK_SCROLL_STEP_DOWN:
if (should_invert (range, FALSE)) if (should_invert (range, FALSE))
_gtk_range_draw_step_back (range); _gtk_range_draw_step_back (range);
else else
_gtk_range_draw_step_forw (range); _gtk_range_draw_step_forw (range);
break; break;
case GTK_SCROLL_STEP_BACKWARD: case GTK_SCROLL_STEP_BACKWARD:
_gtk_range_draw_step_back (range); _gtk_range_draw_step_back (range);
break; break;
case GTK_SCROLL_STEP_FORWARD: case GTK_SCROLL_STEP_FORWARD:
_gtk_range_draw_step_forw (range); _gtk_range_draw_step_forw (range);
break; break;
} }
} }
} }
if (pos != GTK_TROUGH_NONE)
{ if (pos != GTK_TROUGH_NONE)
if (pos == GTK_TROUGH_START) {
range->adjustment->value = range->adjustment->lower; if (pos == GTK_TROUGH_START)
else if (pos == GTK_TROUGH_END) range->adjustment->value = range->adjustment->lower;
range->adjustment->value = else if (pos == GTK_TROUGH_END)
range->adjustment->upper - range->adjustment->page_size; range->adjustment->value =
range->adjustment->upper - range->adjustment->page_size;
if (range->old_value != range->adjustment->value)
{ if (range->old_value != range->adjustment->value)
gtk_signal_emit_by_name (GTK_OBJECT (range->adjustment), {
"value_changed"); gtk_signal_emit_by_name (GTK_OBJECT (range->adjustment),
"value_changed");
_gtk_range_slider_update (range);
_gtk_range_clear_background (range); _gtk_range_slider_update (range);
} _gtk_range_clear_background (range);
} }
} }
return return_val;
} }
static gint static gint

View File

@ -92,6 +92,12 @@ struct _GtkRangeClass
guint8 step_forw; guint8 step_forw;
guint8 step_back; guint8 step_back;
/* action signals for keybindings */
void (* move_slider) (GtkRange *range,
GtkScrollType scroll,
GtkTroughType trough);
/* Completely broken virtual functions, please ignore */
void (* draw_background) (GtkRange *range); void (* draw_background) (GtkRange *range);
void (* clear_background) (GtkRange *range); void (* clear_background) (GtkRange *range);
void (* draw_trough) (GtkRange *range); void (* draw_trough) (GtkRange *range);
@ -103,10 +109,6 @@ struct _GtkRangeClass
gint x, gint x,
gint y, gint y,
gdouble *jump_perc); gdouble *jump_perc);
gboolean (* trough_keys) (GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *trough);
void (* motion) (GtkRange *range, void (* motion) (GtkRange *range,
gint xdelta, gint xdelta,
gint ydelta); gint ydelta);

View File

@ -257,10 +257,10 @@ static gchar *module_path[GTK_RC_MAX_MODULE_PATHS];
/* A stack of directories for RC files we are parsing currently. /* A stack of directories for RC files we are parsing currently.
* these are implicitely added to the end of PIXMAP_PATHS * these are implicitely added to the end of PIXMAP_PATHS
*/ */
GSList *rc_dir_stack = NULL; static GSList *rc_dir_stack = NULL;
/* The files we have parsed, to reread later if necessary */ /* The files we have parsed, to reread later if necessary */
GSList *rc_files = NULL; static GSList *rc_files = NULL;
static GtkImageLoader image_loader = NULL; static GtkImageLoader image_loader = NULL;

View File

@ -1970,29 +1970,37 @@ gtk_text_key_press (GtkWidget *widget,
switch (event->keyval) switch (event->keyval)
{ {
case GDK_KP_Home:
case GDK_Home: case GDK_Home:
if (event->state & GDK_CONTROL_MASK) if (event->state & GDK_CONTROL_MASK)
move_cursor_buffer_ver (text, -1); move_cursor_buffer_ver (text, -1);
else else
gtk_text_move_beginning_of_line (text); gtk_text_move_beginning_of_line (text);
break; break;
case GDK_KP_End:
case GDK_End: case GDK_End:
if (event->state & GDK_CONTROL_MASK) if (event->state & GDK_CONTROL_MASK)
move_cursor_buffer_ver (text, +1); move_cursor_buffer_ver (text, +1);
else else
gtk_text_move_end_of_line (text); gtk_text_move_end_of_line (text);
break; break;
case GDK_KP_Page_Up:
case GDK_Page_Up: move_cursor_page_ver (text, -1); break; case GDK_Page_Up: move_cursor_page_ver (text, -1); break;
case GDK_KP_Page_Down:
case GDK_Page_Down: move_cursor_page_ver (text, +1); break; case GDK_Page_Down: move_cursor_page_ver (text, +1); break;
/* CUA has Ctrl-Up/Ctrl-Down as paragraph up down */ /* CUA has Ctrl-Up/Ctrl-Down as paragraph up down */
case GDK_KP_Up:
case GDK_Up: move_cursor_ver (text, -1); break; case GDK_Up: move_cursor_ver (text, -1); break;
case GDK_KP_Down:
case GDK_Down: move_cursor_ver (text, +1); break; case GDK_Down: move_cursor_ver (text, +1); break;
case GDK_KP_Left:
case GDK_Left: case GDK_Left:
if (event->state & GDK_CONTROL_MASK) if (event->state & GDK_CONTROL_MASK)
gtk_text_move_backward_word (text); gtk_text_move_backward_word (text);
else else
move_cursor_hor (text, -1); move_cursor_hor (text, -1);
break; break;
case GDK_KP_Right:
case GDK_Right: case GDK_Right:
if (event->state & GDK_CONTROL_MASK) if (event->state & GDK_CONTROL_MASK)
gtk_text_move_forward_word (text); gtk_text_move_forward_word (text);
@ -2025,6 +2033,7 @@ gtk_text_key_press (GtkWidget *widget,
} }
break; break;
case GDK_Delete: case GDK_Delete:
case GDK_KP_Delete:
if (event->state & GDK_CONTROL_MASK) if (event->state & GDK_CONTROL_MASK)
gtk_text_delete_forward_word (text); gtk_text_delete_forward_word (text);
else if (event->state & GDK_SHIFT_MASK) else if (event->state & GDK_SHIFT_MASK)
@ -2036,9 +2045,11 @@ gtk_text_key_press (GtkWidget *widget,
gtk_text_delete_forward_character (text); gtk_text_delete_forward_character (text);
break; break;
case GDK_Tab: case GDK_Tab:
case GDK_ISO_Left_Tab:
position = text->point.index; position = text->point.index;
gtk_editable_insert_text (GTK_EDITABLE (old_editable), "\t", 1, &position); gtk_editable_insert_text (GTK_EDITABLE (old_editable), "\t", 1, &position);
break; break;
case GDK_KP_Enter:
case GDK_Return: case GDK_Return:
if (event->state & GDK_CONTROL_MASK) if (event->state & GDK_CONTROL_MASK)
gtk_signal_emit_by_name (GTK_OBJECT (text), "activate"); gtk_signal_emit_by_name (GTK_OBJECT (text), "activate");

View File

@ -2436,38 +2436,74 @@ gtk_text_layout_move_iter_to_previous_line (GtkTextLayout *layout,
GSList *tmp_list; GSList *tmp_list;
PangoLayoutLine *layout_line; PangoLayoutLine *layout_line;
GtkTextIter orig; GtkTextIter orig;
gboolean update_byte = FALSE;
g_return_val_if_fail (layout != NULL, FALSE); g_return_val_if_fail (layout != NULL, FALSE);
g_return_val_if_fail (GTK_IS_TEXT_LAYOUT (layout), FALSE); g_return_val_if_fail (GTK_IS_TEXT_LAYOUT (layout), FALSE);
g_return_val_if_fail (iter != NULL, FALSE); g_return_val_if_fail (iter != NULL, FALSE);
orig = *iter; orig = *iter;
line = _gtk_text_iter_get_text_line (iter); line = _gtk_text_iter_get_text_line (iter);
display = gtk_text_layout_get_line_display (layout, line, FALSE); display = gtk_text_layout_get_line_display (layout, line, FALSE);
line_byte = line_display_iter_to_index (layout, display, iter); line_byte = line_display_iter_to_index (layout, display, iter);
/* FIXME can't use layout until we check display->height > 0) */ /* If display->height == 0 then the line is invisible, so don't
* move onto it.
*/
while (display->height == 0)
{
GtkTextLine *prev_line;
prev_line = _gtk_text_line_previous (line);
if (prev_line == NULL)
{
line_display_index_to_iter (layout, display, iter, 0, 0);
goto out;
}
gtk_text_layout_free_line_display (layout, display);
line = prev_line;
display = gtk_text_layout_get_line_display (layout, prev_line, FALSE);
update_byte = TRUE;
}
tmp_list = pango_layout_get_lines (display->layout); tmp_list = pango_layout_get_lines (display->layout);
layout_line = tmp_list->data; layout_line = tmp_list->data;
if (update_byte)
{
line_byte = layout_line->start_index + layout_line->length;
}
if (line_byte < layout_line->length || !tmp_list->next) /* first line of paragraph */ if (line_byte < layout_line->length || !tmp_list->next) /* first line of paragraph */
{ {
GtkTextLine *prev_line = _gtk_text_line_previous (line); GtkTextLine *prev_line;
/* FIXME keep going back while display->height == 0 */ prev_line = _gtk_text_line_previous (line);
while (prev_line)
if (prev_line)
{ {
gtk_text_layout_free_line_display (layout, display); gtk_text_layout_free_line_display (layout, display);
display = gtk_text_layout_get_line_display (layout, prev_line, FALSE);
tmp_list = g_slist_last (pango_layout_get_lines (display->layout));
layout_line = tmp_list->data;
line_display_index_to_iter (layout, display, iter, display = gtk_text_layout_get_line_display (layout, prev_line, FALSE);
layout_line->start_index + layout_line->length, 0);
if (display->height > 0)
{
tmp_list = g_slist_last (pango_layout_get_lines (display->layout));
layout_line = tmp_list->data;
line_display_index_to_iter (layout, display, iter,
layout_line->start_index + layout_line->length, 0);
break;
}
prev_line = _gtk_text_line_previous (prev_line);
} }
else
if (prev_line == NULL)
line_display_index_to_iter (layout, display, iter, 0, 0); line_display_index_to_iter (layout, display, iter, 0, 0);
} }
else else
@ -2491,6 +2527,8 @@ gtk_text_layout_move_iter_to_previous_line (GtkTextLayout *layout,
} }
} }
out:
gtk_text_layout_free_line_display (layout, display); gtk_text_layout_free_line_display (layout, display);
return return
@ -2533,6 +2571,9 @@ gtk_text_layout_move_iter_to_next_line (GtkTextLayout *layout,
display = gtk_text_layout_get_line_display (layout, line, FALSE); display = gtk_text_layout_get_line_display (layout, line, FALSE);
if (display->height == 0)
goto next;
if (first) if (first)
{ {
line_byte = line_display_iter_to_index (layout, display, iter); line_byte = line_display_iter_to_index (layout, display, iter);
@ -2558,6 +2599,8 @@ gtk_text_layout_move_iter_to_next_line (GtkTextLayout *layout,
tmp_list = tmp_list->next; tmp_list = tmp_list->next;
} }
next:
gtk_text_layout_free_line_display (layout, display); gtk_text_layout_free_line_display (layout, display);
line = _gtk_text_line_next (line); line = _gtk_text_line_next (line);
@ -2661,7 +2704,7 @@ gtk_text_layout_iter_starts_line (GtkTextLayout *layout,
if (line_byte < layout_line->start_index + layout_line->length || if (line_byte < layout_line->start_index + layout_line->length ||
!tmp_list->next) !tmp_list->next)
{ {
/* We're located on this line of the para delimiters before /* We're located on this line or the para delimiters before
* it * it
*/ */
gtk_text_layout_free_line_display (layout, display); gtk_text_layout_free_line_display (layout, display);

View File

@ -683,6 +683,11 @@ gtk_text_view_class_init (GtkTextViewClass *klass)
GTK_TYPE_ENUM, GTK_DELETE_CHARS, GTK_TYPE_ENUM, GTK_DELETE_CHARS,
GTK_TYPE_INT, 1); GTK_TYPE_INT, 1);
gtk_binding_entry_add_signal (binding_set, GDK_KP_Delete, 0,
"delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_CHARS,
GTK_TYPE_INT, 1);
gtk_binding_entry_add_signal (binding_set, GDK_d, GDK_CONTROL_MASK, gtk_binding_entry_add_signal (binding_set, GDK_d, GDK_CONTROL_MASK,
"delete_from_cursor", 2, "delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_CHARS, GTK_TYPE_ENUM, GTK_DELETE_CHARS,
@ -698,6 +703,11 @@ gtk_text_view_class_init (GtkTextViewClass *klass)
GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS, GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS,
GTK_TYPE_INT, 1); GTK_TYPE_INT, 1);
gtk_binding_entry_add_signal (binding_set, GDK_KP_Delete, GDK_CONTROL_MASK,
"delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS,
GTK_TYPE_INT, 1);
gtk_binding_entry_add_signal (binding_set, GDK_d, GDK_MOD1_MASK, gtk_binding_entry_add_signal (binding_set, GDK_d, GDK_MOD1_MASK,
"delete_from_cursor", 2, "delete_from_cursor", 2,
GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS, GTK_TYPE_ENUM, GTK_DELETE_WORD_ENDS,
@ -2951,7 +2961,8 @@ gtk_text_view_key_press_event (GtkWidget *widget, GdkEventKey *event)
else if (GTK_WIDGET_CLASS (parent_class)->key_press_event && else if (GTK_WIDGET_CLASS (parent_class)->key_press_event &&
GTK_WIDGET_CLASS (parent_class)->key_press_event (widget, event)) GTK_WIDGET_CLASS (parent_class)->key_press_event (widget, event))
retval = TRUE; retval = TRUE;
else if (event->keyval == GDK_Return) else if (event->keyval == GDK_Return ||
event->keyval == GDK_KP_Enter)
{ {
gtk_text_buffer_insert_interactive_at_cursor (get_buffer (text_view), "\n", 1, gtk_text_buffer_insert_interactive_at_cursor (get_buffer (text_view), "\n", 1,
text_view->editable); text_view->editable);

View File

@ -29,6 +29,7 @@
#include "gtksignal.h" #include "gtksignal.h"
#include "gdk/gdkkeysyms.h" #include "gdk/gdkkeysyms.h"
#include "gtkintl.h" #include "gtkintl.h"
#include "gtkbindings.h"
#define SCALE_CLASS(w) GTK_SCALE_GET_CLASS (w) #define SCALE_CLASS(w) GTK_SCALE_GET_CLASS (w)
@ -66,10 +67,6 @@ static void gtk_vscale_pos_background (GtkVScale *vscale,
gint *h); gint *h);
static void gtk_vscale_draw_slider (GtkRange *range); static void gtk_vscale_draw_slider (GtkRange *range);
static void gtk_vscale_draw_value (GtkScale *scale); static void gtk_vscale_draw_value (GtkScale *scale);
static gboolean gtk_vscale_trough_keys (GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *pos);
static void gtk_vscale_clear_background (GtkRange *range); static void gtk_vscale_clear_background (GtkRange *range);
GtkType GtkType
@ -97,6 +94,12 @@ gtk_vscale_get_type (void)
return vscale_type; return vscale_type;
} }
#define add_slider_binding(binding_set, keyval, mask, scroll, trough) \
gtk_binding_entry_add_signal (binding_set, keyval, mask, \
"move_slider", 2, \
GTK_TYPE_SCROLL_TYPE, scroll, \
GTK_TYPE_TROUGH_TYPE, trough)
static void static void
gtk_vscale_class_init (GtkVScaleClass *class) gtk_vscale_class_init (GtkVScaleClass *class)
{ {
@ -105,6 +108,7 @@ gtk_vscale_class_init (GtkVScaleClass *class)
GtkWidgetClass *widget_class; GtkWidgetClass *widget_class;
GtkRangeClass *range_class; GtkRangeClass *range_class;
GtkScaleClass *scale_class; GtkScaleClass *scale_class;
GtkBindingSet *binding_set;
object_class = (GtkObjectClass*) class; object_class = (GtkObjectClass*) class;
gobject_class = G_OBJECT_CLASS (class); gobject_class = G_OBJECT_CLASS (class);
@ -123,7 +127,6 @@ gtk_vscale_class_init (GtkVScaleClass *class)
range_class->trough_click = _gtk_range_default_vtrough_click; range_class->trough_click = _gtk_range_default_vtrough_click;
range_class->motion = _gtk_range_default_vmotion; range_class->motion = _gtk_range_default_vmotion;
range_class->draw_slider = gtk_vscale_draw_slider; range_class->draw_slider = gtk_vscale_draw_slider;
range_class->trough_keys = gtk_vscale_trough_keys;
range_class->clear_background = gtk_vscale_clear_background; range_class->clear_background = gtk_vscale_clear_background;
scale_class->draw_value = gtk_vscale_draw_value; scale_class->draw_value = gtk_vscale_draw_value;
@ -135,6 +138,58 @@ gtk_vscale_class_init (GtkVScaleClass *class)
_("The GtkAdjustment that determines the values to use for this VScale."), _("The GtkAdjustment that determines the values to use for this VScale."),
GTK_TYPE_ADJUSTMENT, GTK_TYPE_ADJUSTMENT,
G_PARAM_READWRITE)); G_PARAM_READWRITE));
binding_set = gtk_binding_set_by_class (object_class);
add_slider_binding (binding_set, GDK_Up, 0,
GTK_SCROLL_STEP_UP, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Up, GDK_CONTROL_MASK,
GTK_SCROLL_PAGE_UP, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Up, 0,
GTK_SCROLL_STEP_UP, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Up, GDK_CONTROL_MASK,
GTK_SCROLL_PAGE_UP, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Down, 0,
GTK_SCROLL_STEP_DOWN, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Down, GDK_CONTROL_MASK,
GTK_SCROLL_PAGE_DOWN, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Down, 0,
GTK_SCROLL_STEP_DOWN, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Down, GDK_CONTROL_MASK,
GTK_SCROLL_PAGE_DOWN, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Page_Up, 0,
GTK_SCROLL_PAGE_BACKWARD, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Page_Up, 0,
GTK_SCROLL_PAGE_BACKWARD, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Page_Down, 0,
GTK_SCROLL_PAGE_FORWARD, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_KP_Page_Down, 0,
GTK_SCROLL_PAGE_FORWARD, GTK_TROUGH_NONE);
add_slider_binding (binding_set, GDK_Home, 0,
GTK_SCROLL_NONE, GTK_TROUGH_START);
add_slider_binding (binding_set, GDK_KP_Home, 0,
GTK_SCROLL_NONE, GTK_TROUGH_START);
add_slider_binding (binding_set, GDK_End, 0,
GTK_SCROLL_NONE, GTK_TROUGH_END);
add_slider_binding (binding_set, GDK_KP_End, 0,
GTK_SCROLL_NONE, GTK_TROUGH_END);
} }
static void static void
@ -552,46 +607,3 @@ gtk_vscale_draw_value (GtkScale *scale)
g_object_unref (G_OBJECT (layout)); g_object_unref (G_OBJECT (layout));
} }
} }
static gboolean
gtk_vscale_trough_keys (GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *pos)
{
gint return_val = FALSE;
switch (key->keyval)
{
case GDK_Up:
return_val = TRUE;
if (key->state & GDK_CONTROL_MASK)
*scroll = GTK_SCROLL_PAGE_UP;
else
*scroll = GTK_SCROLL_STEP_UP;
break;
case GDK_Down:
return_val = TRUE;
if (key->state & GDK_CONTROL_MASK)
*scroll = GTK_SCROLL_PAGE_DOWN;
else
*scroll = GTK_SCROLL_STEP_DOWN;
break;
case GDK_Page_Up:
return_val = TRUE;
*scroll = GTK_SCROLL_PAGE_BACKWARD;
break;
case GDK_Page_Down:
return_val = TRUE;
*scroll = GTK_SCROLL_PAGE_FORWARD;
break;
case GDK_Home:
return_val = TRUE;
*pos = GTK_TROUGH_START;
break;
case GDK_End:
return_val = TRUE;
*pos = GTK_TROUGH_END;
break;
}
return return_val;
}

View File

@ -58,10 +58,6 @@ static void gtk_vscrollbar_draw_step_forw (GtkRange *range);
static void gtk_vscrollbar_draw_step_back (GtkRange *range); static void gtk_vscrollbar_draw_step_back (GtkRange *range);
static void gtk_vscrollbar_slider_update (GtkRange *range); static void gtk_vscrollbar_slider_update (GtkRange *range);
static void gtk_vscrollbar_calc_slider_size (GtkVScrollbar *vscrollbar); static void gtk_vscrollbar_calc_slider_size (GtkVScrollbar *vscrollbar);
static gboolean gtk_vscrollbar_trough_keys (GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *pos);
GtkType GtkType
gtk_vscrollbar_get_type (void) gtk_vscrollbar_get_type (void)
@ -110,7 +106,6 @@ gtk_vscrollbar_class_init (GtkVScrollbarClass *class)
range_class->draw_step_back = gtk_vscrollbar_draw_step_back; range_class->draw_step_back = gtk_vscrollbar_draw_step_back;
range_class->slider_update = gtk_vscrollbar_slider_update; range_class->slider_update = gtk_vscrollbar_slider_update;
range_class->trough_click = _gtk_range_default_vtrough_click; range_class->trough_click = _gtk_range_default_vtrough_click;
range_class->trough_keys = gtk_vscrollbar_trough_keys;
range_class->motion = _gtk_range_default_vmotion; range_class->motion = _gtk_range_default_vmotion;
g_object_class_install_property (gobject_class, g_object_class_install_property (gobject_class,
@ -460,38 +455,3 @@ gtk_vscrollbar_calc_slider_size (GtkVScrollbar *vscrollbar)
} }
} }
} }
static gboolean
gtk_vscrollbar_trough_keys (GtkRange *range,
GdkEventKey *key,
GtkScrollType *scroll,
GtkTroughType *pos)
{
gint return_val = FALSE;
switch (key->keyval)
{
case GDK_Up:
return_val = TRUE;
*scroll = GTK_SCROLL_STEP_UP;
break;
case GDK_Down:
return_val = TRUE;
*scroll = GTK_SCROLL_STEP_DOWN;
break;
case GDK_Page_Up:
return_val = TRUE;
if (key->state & GDK_CONTROL_MASK)
*pos = GTK_TROUGH_START;
else
*scroll = GTK_SCROLL_PAGE_BACKWARD;
break;
case GDK_Page_Down:
return_val = TRUE;
if (key->state & GDK_CONTROL_MASK)
*pos = GTK_TROUGH_END;
else
*scroll = GTK_SCROLL_PAGE_FORWARD;
break;
}
return return_val;
}

View File

@ -3509,12 +3509,15 @@ gtk_widget_modify_style (GtkWidget *widget,
old_style = gtk_object_get_data_by_id (GTK_OBJECT (widget), old_style = gtk_object_get_data_by_id (GTK_OBJECT (widget),
quark_rc_style); quark_rc_style);
if (style != old_style) gtk_object_set_data_by_id_full (GTK_OBJECT (widget),
gtk_object_set_data_by_id_full (GTK_OBJECT (widget), quark_rc_style,
quark_rc_style, gtk_rc_style_copy (style),
gtk_rc_style_copy (style), (GtkDestroyNotify)gtk_rc_style_unref);
(GtkDestroyNotify)gtk_rc_style_unref);
/* note that "style" may be invalid here if it was the old
* modifier style and the only reference was our own.
*/
if (GTK_WIDGET_RC_STYLE (widget)) if (GTK_WIDGET_RC_STYLE (widget))
gtk_widget_set_rc_style (widget); gtk_widget_set_rc_style (widget);
} }
@ -3529,6 +3532,12 @@ gtk_widget_modify_style (GtkWidget *widget,
* modifier style for the widget. If you make changes to this rc * modifier style for the widget. If you make changes to this rc
* style, you must call gtk_widget_modify_style(), passing in the * style, you must call gtk_widget_modify_style(), passing in the
* returned rc style, to make sure that your changes take effect. * returned rc style, to make sure that your changes take effect.
*
* Caution: passing the style back to gtk_widget_modify_style() will
* normally end up destroying it, because gtk_widget_modify_style() copies
* the passed-in style and sets the copy as the new modifier style,
* thus dropping any reference to the old modifier style. Add a reference
* to the modifier style if you want to keep it alive.
* *
* Return value: the modifier style for the widget. This rc style is * Return value: the modifier style for the widget. This rc style is
* owned by the widget. If you want to keep a pointer to value this * owned by the widget. If you want to keep a pointer to value this
@ -3582,8 +3591,7 @@ gtk_widget_modify_color_component (GtkWidget *widget,
rc_style->color_flags[state] |= component; rc_style->color_flags[state] |= component;
if (GTK_WIDGET_RC_STYLE (widget)) gtk_widget_modify_style (widget, rc_style);
gtk_widget_set_rc_style (widget);
} }
/** /**
@ -3701,9 +3709,8 @@ gtk_widget_modify_font (GtkWidget *widget,
pango_font_description_free (rc_style->font_desc); pango_font_description_free (rc_style->font_desc);
rc_style->font_desc = pango_font_description_copy (font_desc); rc_style->font_desc = pango_font_description_copy (font_desc);
if (GTK_WIDGET_RC_STYLE (widget)) gtk_widget_modify_style (widget, rc_style);
gtk_widget_set_rc_style (widget);
} }
static void static void

View File

@ -773,6 +773,8 @@ create_toolbar (void)
gtk_toolbar_append_space (GTK_TOOLBAR (toolbar)); gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
gtk_toolbar_append_item (GTK_TOOLBAR (toolbar), gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
"Enable", "Enable tooltips", NULL, "Enable", "Enable tooltips", NULL,
new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]), new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
@ -3205,6 +3207,9 @@ cmw_color (GtkWidget *widget, GtkWidget *parent)
csd=gtk_color_selection_dialog_new ("This is a modal color selection dialog"); csd=gtk_color_selection_dialog_new ("This is a modal color selection dialog");
gtk_color_selection_set_has_palette (GTK_COLOR_SELECTION (GTK_COLOR_SELECTION_DIALOG (csd)->colorsel),
TRUE);
/* Set as modal */ /* Set as modal */
gtk_window_set_modal (GTK_WINDOW(csd),TRUE); gtk_window_set_modal (GTK_WINDOW(csd),TRUE);