X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=blobdiff_plain;f=unix%2Fgtkcompat.h;h=19086157e564d48519de737518a18318543a6045;hb=1bdeff715c9b8c79ec5dc021b5aca403f575f1ae;hp=3518e53ccf87feb31183f3223e8f188028db3dfb;hpb=1e4273a9295f0922a84dcea3edffcbd7b5449c11;p=PuTTY.git diff --git a/unix/gtkcompat.h b/unix/gtkcompat.h index 3518e53c..19086157 100644 --- a/unix/gtkcompat.h +++ b/unix/gtkcompat.h @@ -1,7 +1,7 @@ /* * Header file to make compatibility with older GTK versions less * painful, by #defining various things that are pure spelling changes - * between GTK1 and GTK2. + * between GTK1 and GTK2, or between 2 and 3. */ #if !GTK_CHECK_VERSION(2,0,0) @@ -37,7 +37,13 @@ #define GDK_GRAB_SUCCESS GrabSuccess +#define GDK_WINDOW_XID GDK_WINDOW_XWINDOW + #define gtk_widget_set_size_request gtk_widget_set_usize +#define gtk_radio_button_get_group gtk_radio_button_group +#define gtk_notebook_set_current_page gtk_notebook_set_page +#define gtk_color_selection_set_has_opacity_control \ + gtk_color_selection_set_opacity #define gtk_dialog_get_content_area(dlg) ((dlg)->vbox) #define gtk_dialog_get_action_area(dlg) ((dlg)->action_area) @@ -72,6 +78,12 @@ #define gtk_widget_get_realized(w) GTK_WIDGET_REALIZED(w) #define gtk_widget_get_state(w) GTK_WIDGET_STATE(w) +/* This is a bit of a bodge because it relies on us only calling this + * macro as GDK_DISPLAY_XDISPLAY(gdk_display_get_default()), so under + * GTK1 it makes sense to omit the contained function call and just + * return the GDK default display. */ +#define GDK_DISPLAY_XDISPLAY(x) GDK_DISPLAY() + #define GDK_KEY_Alt_L GDK_Alt_L #define GDK_KEY_Alt_R GDK_Alt_R #define GDK_KEY_BackSpace GDK_BackSpace @@ -144,3 +156,31 @@ #endif +#if GTK_CHECK_VERSION(3,0,0) +#define STANDARD_OK_LABEL "_OK" +#define STANDARD_OPEN_LABEL "_Open" +#define STANDARD_CANCEL_LABEL "_Cancel" +#else +#define STANDARD_OK_LABEL GTK_STOCK_OK +#define STANDARD_OPEN_LABEL GTK_STOCK_OPEN +#define STANDARD_CANCEL_LABEL GTK_STOCK_CANCEL +#endif + +#if GTK_CHECK_VERSION(3,0,0) +#define gtk_hseparator_new() gtk_separator_new(GTK_ORIENTATION_HORIZONTAL) +/* Fortunately, my hboxes and vboxes never actually set homogeneous to + * TRUE, so I can just wrap these deprecated constructors with a macro + * without also having to arrange a call to gtk_box_set_homogeneous. */ +#define gtk_hbox_new(homogeneous, spacing) \ + gtk_box_new(GTK_ORIENTATION_HORIZONTAL, spacing) +#define gtk_vbox_new(homogeneous, spacing) \ + gtk_box_new(GTK_ORIENTATION_VERTICAL, spacing) +#define gtk_vscrollbar_new(adjust) \ + gtk_scrollbar_new(GTK_ORIENTATION_VERTICAL, adjust) + +#define gdk_get_display() gdk_display_get_name(gdk_display_get_default()) + +#define gdk_cursor_new(cur) \ + gdk_cursor_new_for_display(gdk_display_get_default(), cur) + +#endif