0
0
mirror of https://github.com/vim/vim.git synced 2025-09-24 03:44:06 -04:00

patch 8.2.1881: cannot build with GTK3

Problem:    Cannot build with GTK3.
Solution:   Adjust form functions.
This commit is contained in:
Bram Moolenaar
2020-10-21 17:28:27 +02:00
parent af7a9066a9
commit 692d1a51e7
2 changed files with 21 additions and 10 deletions

View File

@@ -48,8 +48,12 @@ struct _GtkFormChild
}; };
static void form_class_init(GtkFormClass *klass); static void gui_gtk_form_class_init(GtkFormClass *klass);
static void form_init(GtkForm *form, void *g_class); #if GTK_CHECK_VERSION(3,0,0)
static void gui_gtk_form_init(GtkForm *form);
#else
static void gui_gtk_form_init(GtkForm *form, void *g_class);
#endif
static void form_realize(GtkWidget *widget); static void form_realize(GtkWidget *widget);
static void form_unrealize(GtkWidget *widget); static void form_unrealize(GtkWidget *widget);
@@ -195,8 +199,9 @@ gui_gtk_form_thaw(GtkForm *form)
} }
// Basic Object handling procedures // Basic Object handling procedures
#if GTK_CHECK_VERSION(3,0,0) #if GTK_CHECK_VERSION(3,0,0)
G_DEFINE_TYPE(GtkForm, gtk_form, GTK_TYPE_CONTAINER) G_DEFINE_TYPE(GtkForm, gui_gtk_form, GTK_TYPE_CONTAINER)
#else #else
GtkType GtkType
gui_gtk_form_get_type(void) gui_gtk_form_get_type(void)
@@ -211,8 +216,8 @@ gui_gtk_form_get_type(void)
form_info.type_name = "GtkForm"; form_info.type_name = "GtkForm";
form_info.object_size = sizeof(GtkForm); form_info.object_size = sizeof(GtkForm);
form_info.class_size = sizeof(GtkFormClass); form_info.class_size = sizeof(GtkFormClass);
form_info.class_init_func = (GtkClassInitFunc)form_class_init; form_info.class_init_func = (GtkClassInitFunc)gui_gtk_form_class_init;
form_info.object_init_func = (GtkObjectInitFunc)form_init; form_info.object_init_func = (GtkObjectInitFunc)gui_gtk_form_init;
form_type = gtk_type_unique(GTK_TYPE_CONTAINER, &form_info); form_type = gtk_type_unique(GTK_TYPE_CONTAINER, &form_info);
} }
@@ -221,7 +226,7 @@ gui_gtk_form_get_type(void)
#endif // !GTK_CHECK_VERSION(3,0,0) #endif // !GTK_CHECK_VERSION(3,0,0)
static void static void
form_class_init(GtkFormClass *klass) gui_gtk_form_class_init(GtkFormClass *klass)
{ {
GtkWidgetClass *widget_class; GtkWidgetClass *widget_class;
GtkContainerClass *container_class; GtkContainerClass *container_class;
@@ -254,7 +259,11 @@ form_class_init(GtkFormClass *klass)
} }
static void static void
form_init(GtkForm *form, void *g_class UNUSED) gui_gtk_form_init(GtkForm *form
#if !GTK_CHECK_VERSION(3,0,0)
, void *g_class UNUSED
#endif
)
{ {
#if GTK_CHECK_VERSION(3,0,0) #if GTK_CHECK_VERSION(3,0,0)
gtk_widget_set_has_window(GTK_WIDGET(form), TRUE); gtk_widget_set_has_window(GTK_WIDGET(form), TRUE);
@@ -416,8 +425,8 @@ form_unrealize(GtkWidget *widget)
} }
#if GTK_CHECK_VERSION(3,0,0) #if GTK_CHECK_VERSION(3,0,0)
if (GTK_WIDGET_CLASS (gtk_form_parent_class)->unrealize) if (GTK_WIDGET_CLASS (gui_gtk_form_parent_class)->unrealize)
(* GTK_WIDGET_CLASS (gtk_form_parent_class)->unrealize) (widget); (* GTK_WIDGET_CLASS (gui_gtk_form_parent_class)->unrealize) (widget);
#else #else
if (GTK_WIDGET_CLASS (parent_class)->unrealize) if (GTK_WIDGET_CLASS (parent_class)->unrealize)
(* GTK_WIDGET_CLASS (parent_class)->unrealize) (widget); (* GTK_WIDGET_CLASS (parent_class)->unrealize) (widget);
@@ -555,7 +564,7 @@ form_draw(GtkWidget *widget, cairo_t *cr)
} }
} }
return GTK_WIDGET_CLASS(gtk_form_parent_class)->draw(widget, cr); return GTK_WIDGET_CLASS(gui_gtk_form_parent_class)->draw(widget, cr);
} }
#else // !GTK_CHECK_VERSION(3,0,0) #else // !GTK_CHECK_VERSION(3,0,0)
static gint static gint

View File

@@ -750,6 +750,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
1881,
/**/ /**/
1880, 1880,
/**/ /**/