/** * g_boxed_free: * @boxed_type: The type of @boxed. * @boxed: The boxed structure to be freed. * * Free the boxed structure @boxed which is of type @boxed_type. */ void g_boxed_free (GType boxed_type, gpointer boxed) { GTypeValueTable *value_table; g_return_if_fail (G_TYPE_IS_BOXED (boxed_type)); g_return_if_fail (G_TYPE_IS_ABSTRACT (boxed_type) == FALSE); g_return_if_fail (boxed != NULL); value_table = g_type_value_table_peek (boxed_type); if (!value_table) g_return_if_fail (G_TYPE_IS_VALUE_TYPE (boxed_type)); /* check if our proxying implementation is used, we can short-cut here */ if (value_table->value_free == boxed_proxy_value_free) { BoxedNode key, *node; key.type = boxed_type; node = g_bsearch_array_lookup (boxed_bsa, &boxed_bconfig, &key); node->free (boxed); } else { GValue value; /* see g_boxed_copy() on why we think we can do this */ value_meminit (&value, boxed_type); value.data[0].v_pointer = boxed; value_table->value_free (&value); } }
static int get_widget_params(lua_State *L) { struct dt_lua_widget_type_t *widget_type = lua_touserdata(L, lua_upvalueindex(1)); if(G_TYPE_IS_ABSTRACT(widget_type->gtk_type)){ luaL_error(L,"Trying to create a widget of an abstract type : %s\n",widget_type->name); } lua_widget widget= malloc(widget_type->alloc_size); widget->widget = gtk_widget_new(widget_type->gtk_type,NULL); gtk_widget_show(widget->widget);// widgets are invisible by default g_object_ref_sink(widget->widget); widget->type = widget_type; luaA_push_type(L,widget_type->associated_type,&widget); dt_lua_type_gpointer_alias_type(L,widget_type->associated_type,widget,widget->widget); init_widget_sub(L,widget_type); luaL_getmetafield(L,-1,"__gtk_signals"); lua_pushnil(L); /* first key */ while(lua_next(L, -2) != 0) { g_signal_connect(widget->widget, lua_tostring(L,-2), G_CALLBACK(lua_touserdata(L,-1)), widget); lua_pop(L,1); } lua_pop(L,1); return 1; }
void rbgobj_init_object_class(VALUE klass) { rbgobj_define_property_accessors(klass); if (G_TYPE_IS_ABSTRACT(CLASS2GTYPE(klass))) rb_define_method(klass, "initialize", dummy_init, -1); }
gpointer g_boxed_copy (GType boxed_type, gconstpointer src_boxed) { GTypeValueTable *value_table; gpointer dest_boxed; g_return_val_if_fail (G_TYPE_IS_BOXED (boxed_type), NULL); g_return_val_if_fail (G_TYPE_IS_ABSTRACT (boxed_type) == FALSE, NULL); g_return_val_if_fail (src_boxed != NULL, NULL); value_table = g_type_value_table_peek (boxed_type); if (!value_table) g_return_val_if_fail (G_TYPE_IS_VALUE_TYPE (boxed_type), NULL); /* check if our proxying implementation is used, we can short-cut here */ if (value_table->value_copy == boxed_proxy_value_copy) { BoxedNode key, *node; key.type = boxed_type; node = g_bsearch_array_lookup (boxed_bsa, &boxed_bconfig, &key); dest_boxed = node->copy ((gpointer) src_boxed); } else { GValue src_value, dest_value; /* we heavil rely on third-party boxed type value vtable * implementations to follow normal boxed value storage * (data[0].v_pointer is the boxed struct, and * data[1].v_uint holds the G_VALUE_NOCOPY_CONTENTS flag, * rest zero). * but then, we can expect that since we layed out the * g_boxed_*() API. * data[1].v_uint&G_VALUE_NOCOPY_CONTENTS shouldn't be set * after a copy. */ /* equiv. to g_value_set_static_boxed() */ value_meminit (&src_value, boxed_type); src_value.data[0].v_pointer = (gpointer) src_boxed; src_value.data[1].v_uint = G_VALUE_NOCOPY_CONTENTS; /* call third-party code copy fucntion, fingers-crossed */ value_meminit (&dest_value, boxed_type); value_table->value_copy (&src_value, &dest_value); /* double check and grouse if things went wrong */ if (dest_value.data[1].v_ulong || dest_value.data[2].v_ulong) g_warning ("the copy_value() implementation of type `%s' seems to make use of reserved GValue fields", g_type_name (boxed_type)); dest_boxed = dest_value.data[0].v_pointer; } return dest_boxed; }
static VALUE dummy_init(int argc, VALUE *argv, VALUE self) { GType gtype = CLASS2GTYPE(CLASS_OF(self)); if (G_TYPE_IS_ABSTRACT(gtype)) rb_raise(rb_eTypeError, "initializing abstract class"); else return rb_call_super(argc, argv); }
static void * format_add_class( VipsFormatClass *format, GSList **formats ) { if( !G_TYPE_IS_ABSTRACT( G_OBJECT_CLASS_TYPE( format ) ) ) /* Append so we don't reverse the list of formats. */ *formats = g_slist_append( *formats, format ); return( NULL ); }
static void gogo_dim_start (GsfXMLIn *xin, xmlChar const **attrs) { GogXMLReadState *state = (GogXMLReadState *)xin->user_state; xmlChar const *dim_str = NULL, *type_str = NULL; GType type; int first, last; if (NULL == state->obj) return; g_return_if_fail (GOG_IS_DATASET (state->obj)); for (; attrs != NULL && attrs[0] && attrs[1] ; attrs += 2) if (0 == strcmp (attrs[0], "id")) dim_str = attrs[1]; else if (0 == strcmp (attrs[0], "type")) type_str = attrs[1]; if (NULL == dim_str) { g_warning ("missing dimension id for class `%s'", G_OBJECT_TYPE_NAME (state->obj)); return; } state->dimension_id = strtol (dim_str, NULL, 10); gog_dataset_dims (GOG_DATASET (state->obj), &first, &last); if (state->dimension_id < first || state->dimension_id > last) { g_warning ("invalid dimension id %d for class `%s'", state->dimension_id, G_OBJECT_TYPE_NAME (state->obj)); return; } if (NULL == type_str) { g_warning ("missing type for dimension `%s' of class `%s'", dim_str, G_OBJECT_TYPE_NAME (state->obj)); return; } type = g_type_from_name (type_str); if (0 == type) { g_warning ("unknown type '%s' for dimension `%s' of class `%s'", type_str, dim_str, G_OBJECT_TYPE_NAME (state->obj)); return; } else if (!g_type_is_a (type, GO_TYPE_DATA) || G_TYPE_IS_ABSTRACT (type)) { g_warning ("type '%s' is invalid as dimension `%s' of class `%s'", type_str, dim_str, G_OBJECT_TYPE_NAME (state->obj)); return; } state->dimension = g_object_new (type, NULL); g_return_if_fail (state->dimension != NULL); }
/* Help function to dump a GType */ void my_dump_type(GType type_id) { printf("Type id: %d\n", type_id); printf("Type name: %s\n", g_type_name(type_id)); printf("Is fundamental? %s\n", G_TYPE_IS_FUNDAMENTAL(type_id) ? "yes" : "no"); printf("Is derived? %s\n", G_TYPE_IS_DERIVED(type_id) ? "yes" : "no"); printf("Is interface? %s\n", G_TYPE_IS_INTERFACE(type_id) ? "yes" : "no"); printf("Is classed? %s\n", G_TYPE_IS_CLASSED(type_id) ? "yes" : "no"); printf("Is instantiatable? %s\n", G_TYPE_IS_INSTANTIATABLE(type_id) ? "yes" : "no"); printf("Is derivable? %s\n", G_TYPE_IS_DERIVABLE(type_id) ? "yes" : "no"); printf("Is deep derivable? %s\n", G_TYPE_IS_DEEP_DERIVABLE(type_id) ? "yes" : "no"); printf("Is abstract? %s\n", G_TYPE_IS_ABSTRACT(type_id) ? "yes" : "no"); printf("Is value abstract? %s\n", G_TYPE_IS_VALUE_ABSTRACT(type_id) ? "yes" : "no"); printf("Is value type: %s\n", G_TYPE_IS_VALUE_TYPE(type_id) ? "yes" : "no"); printf("Has value table: %s\n", G_TYPE_HAS_VALUE_TABLE(type_id) ? "yes" : "no"); }
/* NOTE : every path through this must push something onto obj_stack. */ static void gogo_start (GsfXMLIn *xin, xmlChar const **attrs) { GogXMLReadState *state = (GogXMLReadState *)xin->user_state; xmlChar const *type = NULL, *role = NULL; GogObject *res; unsigned i; for (i = 0; attrs != NULL && attrs[i] && attrs[i+1] ; i += 2) if (0 == strcmp (attrs[i], "type")) type = attrs[i+1]; else if (0 == strcmp (attrs[i], "role")) role = attrs[i+1]; if (NULL != type) { GType t = g_type_from_name (type); if (t == 0) { res = (GogObject *)gog_plot_new_by_name (type); if (NULL == res) res = (GogObject *)gog_trend_line_new_by_name (type); } else if (g_type_is_a (t, GOG_TYPE_OBJECT) && !G_TYPE_IS_ABSTRACT (t)) res = g_object_new (t, NULL); else res = NULL; if (res == NULL) { g_warning ("unknown type '%s'", type); } if (GOG_IS_GRAPH (res)) ((GogGraph *) res)->doc = (GODoc *) g_object_get_data (G_OBJECT (gsf_xml_in_get_input (xin)), "document"); } else res = NULL; if (role != NULL) { if (strcmp (role, GOG_BACKPLANE_OLD_ROLE_NAME) == 0) res = gog_object_add_by_name (state->obj, GOG_BACKPLANE_NEW_ROLE_NAME, res); else res = gog_object_add_by_name (state->obj, role, res); } if (res != NULL) { res->explicitly_typed_role = (type != NULL); if (GO_IS_PERSIST (res)) go_persist_prep_sax (GO_PERSIST (res), xin, attrs); } state->obj_stack = g_slist_prepend (state->obj_stack, state->obj); state->obj = res; }
static VALUE flags_s_allocate(VALUE self) { GType gtype = CLASS2GTYPE(self); if (G_TYPE_IS_ABSTRACT(gtype)) { rb_raise(rb_eTypeError, "abstract class"); } else { flags_holder* p; VALUE result = Data_Make_Struct(self, flags_holder, NULL, flags_free, p); p->gclass = g_type_class_ref(gtype); p->value = 0; p->info = NULL; return result; } }
void * ruby_vips_class_map_all( GType type, VipsClassMap fn, void *a ) { void *result; if( !G_TYPE_IS_ABSTRACT( type ) ) { if( (result = fn( VIPS_OBJECT_CLASS( g_type_class_ref( type ) ), a )) ) return( result ); } if( (result = vips_type_map( type, (VipsTypeMap2) ruby_vips_class_map_all, fn, a )) ) return( result ); return( NULL ); }
static GwyResource* gwy_resource_parse_real(const gchar *text, GType expected_type, gboolean is_const) { GwyResourceClass *klass; GwyResource *resource = NULL; GType type; gchar *name = NULL; guint len; if (!g_str_has_prefix(text, MAGIC_HEADER)) { g_warning("Wrong resource magic header"); return NULL; } text += sizeof(MAGIC_HEADER) - 1; len = strspn(text, G_CSET_a_2_z G_CSET_A_2_Z G_CSET_DIGITS); name = g_strndup(text, len); text = strchr(text + len, '\n'); if (!text) { g_warning("Truncated resource header"); goto fail; } text++; type = g_type_from_name(name); if (!type || (expected_type && type != expected_type) || !g_type_is_a(type, GWY_TYPE_RESOURCE) || !G_TYPE_IS_INSTANTIATABLE(type) || G_TYPE_IS_ABSTRACT(type)) { g_warning("Wrong resource type `%s'", name); goto fail; } klass = GWY_RESOURCE_CLASS(g_type_class_peek_static(type)); g_return_val_if_fail(klass && klass->parse, NULL); resource = klass->parse(text, is_const); if (resource) g_string_assign(resource->name, name); fail: g_free(name); return resource; }
static VALUE pspec_s_allocate(VALUE klass) { const RGObjClassInfo* cinfo = rbgobj_lookup_class(klass); if (G_TYPE_IS_ABSTRACT(cinfo->gtype)) rb_raise(rb_eTypeError, "abstract class"); { pspec_holder* holder; VALUE result; result = Data_Make_Struct(klass, pspec_holder, pspec_mark, pspec_free, holder); holder->instance = NULL; holder->cinfo = NULL; return result; } }
/* --- main test program --- */ int main (int argc, char *argv[]) { const GType *otypes; guint i; /* initialize test program */ gtk_test_init (&argc, &argv); gtk_test_register_all_types (); /* install a property test for each widget type */ otypes = gtk_test_list_all_types (NULL); for (i = 0; otypes[i]; i++) if (g_type_is_a (otypes[i], GTK_TYPE_WIDGET) && G_TYPE_IS_OBJECT (otypes[i]) && !G_TYPE_IS_ABSTRACT (otypes[i])) { gchar *testpath = g_strdup_printf ("/properties/%s", g_type_name (otypes[i])); g_test_add_data_func (testpath, (void*) otypes[i], widget_property_tests); g_free (testpath); } return g_test_run (); }
int main (int argc, char *argv[]) { GList *adaptors, *l; gtk_test_init (&argc, &argv, NULL); glade_init (); glade_app_get (); adaptors = g_list_sort (glade_widget_adaptor_list_adaptors (), adaptor_cmp); for (l = adaptors; l; l = l->next) { GladeWidgetAdaptor *adaptor = l->data; GType adaptor_type; adaptor_type = glade_widget_adaptor_get_object_type (adaptor); if (G_TYPE_IS_INSTANTIATABLE (adaptor_type) && !G_TYPE_IS_ABSTRACT (adaptor_type) && /* FIXME: FileChooserButton leaks a GTask which will crash in the following test */ adaptor_type != GTK_TYPE_FILE_CHOOSER_BUTTON && /* FIXME: GtkRecentChooser tries to remove an unknown source id */ !g_type_is_a (adaptor_type, GTK_TYPE_RECENT_CHOOSER)) { gchar *test_path = g_strdup_printf ("/CreateWidget/%s", glade_widget_adaptor_get_name (adaptor)); g_test_add_data_func (test_path, adaptor, test_create_widget); g_free (test_path); } } g_list_free (adaptors); return g_test_run (); }
static VALUE rg_initialize(int argc, VALUE *argv, VALUE self) { GType gtype; VALUE params_hash; GObject* gobj; gtype = CLASS2GTYPE(CLASS_OF(self)); if (G_TYPE_IS_ABSTRACT(gtype)) { rb_raise(rb_eTypeError, "initializing abstract class: %s", RBG_INSPECT(CLASS_OF(self))); } rb_scan_args(argc, argv, "01", ¶ms_hash); if (!NIL_P(params_hash)) Check_Type(params_hash, RUBY_T_HASH); gobj = rbgobj_gobject_new(RVAL2GTYPE(self), params_hash); G_INITIALIZE(self, gobj); return Qnil; }
static PyObject* _wrap_g_type_is_abstract(PyGTypeWrapper *self) { return PyBool_FromLong(G_TYPE_IS_ABSTRACT(self->type)); }
static void gogo_prop_start (GsfXMLIn *xin, xmlChar const **attrs) { GogXMLReadState *state = (GogXMLReadState *)xin->user_state; xmlChar const *prop_str = NULL, *type_str = NULL; GType prop_type; int i; if (NULL == state->obj) { state->prop_spec = NULL; return; } for (i = 0; attrs != NULL && attrs[i] && attrs[i+1] ; i += 2) if (0 == strcmp (attrs[i], "name")) prop_str = attrs[i+1]; else if (0 == strcmp (attrs[i], "type")) type_str = attrs[i+1]; if (prop_str == NULL) { g_warning ("missing name for property of class `%s'", G_OBJECT_TYPE_NAME (state->obj)); return; } state->prop_spec = g_object_class_find_property ( G_OBJECT_GET_CLASS (state->obj), prop_str); if (state->prop_spec == NULL) { g_warning ("unknown property `%s' for class `%s'", prop_str, G_OBJECT_TYPE_NAME (state->obj)); return; } prop_type = G_PARAM_SPEC_VALUE_TYPE (state->prop_spec); if (G_TYPE_FUNDAMENTAL (prop_type) == G_TYPE_OBJECT) { GType type; GogObject *obj; if (NULL == type_str) { g_warning ("missing type for property `%s' of class `%s'", prop_str, G_OBJECT_TYPE_NAME (state->obj)); return; } type = g_type_from_name (type_str); if (0 == type) { g_warning ("unknown type '%s' for property `%s' of class `%s'", type_str, prop_str, G_OBJECT_TYPE_NAME (state->obj)); return; } else if (!g_type_is_a (type, prop_type) || G_TYPE_IS_ABSTRACT (type)) { g_warning ("invalid type '%s' for property `%s' of class `%s'", type_str, prop_str, G_OBJECT_TYPE_NAME (state->obj)); return; } obj = g_object_new (type, NULL); g_return_if_fail (obj != NULL); state->obj_stack = g_slist_prepend (state->obj_stack, state->obj); state->obj = obj; state->prop_pushed_obj = TRUE; if (GO_IS_PERSIST (obj)) go_persist_prep_sax (GO_PERSIST (obj), xin, attrs); } }
static void test_type (gconstpointer data) { GObjectClass *klass; GObject *instance; GParamSpec **pspecs; guint n_pspecs, i; GType type; GdkDisplay *display; type = * (GType *) data; display = gdk_display_get_default (); if (!G_TYPE_IS_CLASSED (type)) return; if (G_TYPE_IS_ABSTRACT (type)) return; if (!g_type_is_a (type, G_TYPE_OBJECT)) return; /* These can't be freely constructed/destroyed */ if (g_type_is_a (type, GTK_TYPE_APPLICATION) || g_type_is_a (type, GDK_TYPE_PIXBUF_LOADER) || g_type_is_a (type, GDK_TYPE_DRAWING_CONTEXT) || #ifdef G_OS_UNIX g_type_is_a (type, GTK_TYPE_PRINT_JOB) || #endif g_type_is_a (type, gdk_pixbuf_simple_anim_iter_get_type ()) || g_str_equal (g_type_name (type), "GdkX11DeviceManagerXI2") || g_str_equal (g_type_name (type), "GdkX11DeviceManagerCore") || g_str_equal (g_type_name (type), "GdkX11Display") || g_str_equal (g_type_name (type), "GdkX11DisplayManager") || g_str_equal (g_type_name (type), "GdkX11Screen") || g_str_equal (g_type_name (type), "GdkX11GLContext")) return; /* This throws a critical when the connection is dropped */ if (g_type_is_a (type, GTK_TYPE_APP_CHOOSER_DIALOG)) return; /* These leak their GDBusConnections */ if (g_type_is_a (type, GTK_TYPE_FILE_CHOOSER_BUTTON) || g_type_is_a (type, GTK_TYPE_FILE_CHOOSER_DIALOG) || g_type_is_a (type, GTK_TYPE_FILE_CHOOSER_WIDGET) || g_type_is_a (type, GTK_TYPE_PLACES_SIDEBAR)) return; klass = g_type_class_ref (type); if (g_type_is_a (type, GTK_TYPE_SETTINGS)) instance = g_object_ref (gtk_settings_get_default ()); else if (g_type_is_a (type, GDK_TYPE_WINDOW)) { GdkWindowAttr attributes; attributes.wclass = GDK_INPUT_OUTPUT; attributes.window_type = GDK_WINDOW_TEMP; attributes.event_mask = 0; attributes.width = 100; attributes.height = 100; instance = g_object_ref (gdk_window_new (NULL, &attributes, 0)); } else if (g_str_equal (g_type_name (type), "GdkX11Cursor")) instance = g_object_new (type, "display", display, NULL); else instance = g_object_new (type, NULL); if (g_type_is_a (type, G_TYPE_INITIALLY_UNOWNED)) g_object_ref_sink (instance); pspecs = g_object_class_list_properties (klass, &n_pspecs); for (i = 0; i < n_pspecs; ++i) { GParamSpec *pspec = pspecs[i]; GValue value = G_VALUE_INIT; if (pspec->owner_type != type) continue; if ((pspec->flags & G_PARAM_READABLE) == 0) continue; /* This one has a special-purpose default value */ if (g_type_is_a (type, GTK_TYPE_DIALOG) && (strcmp (pspec->name, "use-header-bar") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_ASSISTANT) && (strcmp (pspec->name, "use-header-bar") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_POPOVER) && (strcmp (pspec->name, "pointing-to") == 0)) continue; if (g_type_is_a (type, GDK_TYPE_DISPLAY_MANAGER) && (strcmp (pspec->name, "default-display") == 0)) continue; if (g_type_is_a (type, GDK_TYPE_MONITOR) && (strcmp (pspec->name, "geometry") == 0 || strcmp (pspec->name, "workarea") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_ABOUT_DIALOG) && (strcmp (pspec->name, "program-name") == 0)) continue; /* These are set to the current date */ if (g_type_is_a (type, GTK_TYPE_CALENDAR) && (strcmp (pspec->name, "year") == 0 || strcmp (pspec->name, "month") == 0 || strcmp (pspec->name, "day") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_CELL_AREA_CONTEXT) && (strcmp (pspec->name, "minimum-width") == 0 || strcmp (pspec->name, "minimum-height") == 0 || strcmp (pspec->name, "natural-width") == 0 || strcmp (pspec->name, "natural-height") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_CELL_RENDERER_TEXT) && (strcmp (pspec->name, "background-gdk") == 0 || strcmp (pspec->name, "foreground-gdk") == 0 || strcmp (pspec->name, "background-rgba") == 0 || strcmp (pspec->name, "foreground-rgba") == 0 || strcmp (pspec->name, "font") == 0 || strcmp (pspec->name, "font-desc") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_CELL_VIEW) && (strcmp (pspec->name, "background-gdk") == 0 || strcmp (pspec->name, "foreground-gdk") == 0 || strcmp (pspec->name, "foreground-rgba") == 0 || strcmp (pspec->name, "background-rgba") == 0 || strcmp (pspec->name, "cell-area") == 0 || strcmp (pspec->name, "cell-area-context") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_COLOR_BUTTON) && (strcmp (pspec->name, "color") == 0 || strcmp (pspec->name, "rgba") == 0)) continue; G_GNUC_BEGIN_IGNORE_DEPRECATIONS if (g_type_is_a (type, GTK_TYPE_COLOR_SELECTION) && (strcmp (pspec->name, "current-color") == 0 || strcmp (pspec->name, "current-rgba") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_COLOR_SELECTION_DIALOG) && (strcmp (pspec->name, "color-selection") == 0 || strcmp (pspec->name, "ok-button") == 0 || strcmp (pspec->name, "help-button") == 0 || strcmp (pspec->name, "cancel-button") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_COMBO_BOX) && (strcmp (pspec->name, "cell-area") == 0 || strcmp (pspec->name, "cell-area-context") == 0)) continue; G_GNUC_END_IGNORE_DEPRECATIONS /* Default invisible char is determined at runtime */ if (g_type_is_a (type, GTK_TYPE_ENTRY) && (strcmp (pspec->name, "invisible-char") == 0 || strcmp (pspec->name, "buffer") == 0)) continue; G_GNUC_BEGIN_IGNORE_DEPRECATIONS if (g_type_is_a (type, GTK_TYPE_ENTRY_COMPLETION) && (strcmp (pspec->name, "cell-area") == 0 || strcmp (pspec->name, "cell-area-context") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_FONT_SELECTION) && strcmp (pspec->name, "font") == 0) continue; if (g_type_is_a (type, GTK_TYPE_ICON_VIEW) && (strcmp (pspec->name, "cell-area") == 0 || strcmp (pspec->name, "cell-area-context") == 0)) continue; G_GNUC_END_IGNORE_DEPRECATIONS if (g_type_is_a (type, GTK_TYPE_LAYOUT) && (strcmp (pspec->name, "hadjustment") == 0 || strcmp (pspec->name, "vadjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_MESSAGE_DIALOG) && (strcmp (pspec->name, "image") == 0 || strcmp (pspec->name, "message-area") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_PANED) && strcmp (pspec->name, "max-position") == 0) continue; if (g_type_is_a (type, GTK_TYPE_PRINT_OPERATION) && strcmp (pspec->name, "job-name") == 0) continue; #ifdef G_OS_UNIX if (g_type_is_a (type, GTK_TYPE_PRINT_UNIX_DIALOG) && (strcmp (pspec->name, "page-setup") == 0 || strcmp (pspec->name, "print-settings") == 0)) continue; #endif if (g_type_is_a (type, GTK_TYPE_PROGRESS_BAR) && strcmp (pspec->name, "adjustment") == 0) continue; /* filename value depends on $HOME */ if (g_type_is_a (type, GTK_TYPE_RECENT_MANAGER) && (strcmp (pspec->name, "filename") == 0 || strcmp (pspec->name, "size") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_SCALE_BUTTON) && strcmp (pspec->name, "adjustment") == 0) continue; if (g_type_is_a (type, GTK_TYPE_SCROLLED_WINDOW) && (strcmp (pspec->name, "hadjustment") == 0 || strcmp (pspec->name, "vadjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_SETTINGS)) continue; if (g_type_is_a (type, GTK_TYPE_SPIN_BUTTON) && (strcmp (pspec->name, "adjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_STATUS_ICON) && (strcmp (pspec->name, "size") == 0 || strcmp (pspec->name, "screen") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_STYLE_CONTEXT) && strcmp (pspec->name, "screen") == 0) continue; if (g_type_is_a (type, GTK_TYPE_TEXT_BUFFER) && (strcmp (pspec->name, "tag-table") == 0 || strcmp (pspec->name, "copy-target-list") == 0 || strcmp (pspec->name, "paste-target-list") == 0)) continue; /* language depends on the current locale */ if (g_type_is_a (type, GTK_TYPE_TEXT_TAG) && (strcmp (pspec->name, "background-gdk") == 0 || strcmp (pspec->name, "foreground-gdk") == 0 || strcmp (pspec->name, "language") == 0 || strcmp (pspec->name, "font") == 0 || strcmp (pspec->name, "font-desc") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_TEXT_VIEW) && strcmp (pspec->name, "buffer") == 0) continue; if (g_type_is_a (type, GTK_TYPE_TOOL_ITEM_GROUP) && strcmp (pspec->name, "label-widget") == 0) continue; if (g_type_is_a (type, GTK_TYPE_TREE_VIEW) && (strcmp (pspec->name, "hadjustment") == 0 || strcmp (pspec->name, "vadjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_TREE_VIEW_COLUMN) && (strcmp (pspec->name, "cell-area") == 0 || strcmp (pspec->name, "cell-area-context") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_VIEWPORT) && (strcmp (pspec->name, "hadjustment") == 0 || strcmp (pspec->name, "vadjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_WIDGET) && (strcmp (pspec->name, "name") == 0 || strcmp (pspec->name, "screen") == 0 || strcmp (pspec->name, "style") == 0)) continue; /* resize-grip-visible is determined at runtime */ if (g_type_is_a (type, GTK_TYPE_WINDOW) && strcmp (pspec->name, "resize-grip-visible") == 0) continue; /* show-desktop depends on desktop environment */ if (g_type_is_a (type, GTK_TYPE_PLACES_SIDEBAR) && strcmp (pspec->name, "show-desktop") == 0) continue; if (g_test_verbose ()) g_print ("Property %s.%s\n", g_type_name (pspec->owner_type), pspec->name); g_value_init (&value, G_PARAM_SPEC_VALUE_TYPE (pspec)); g_object_get_property (instance, pspec->name, &value); check_property ("Property", pspec, &value); g_value_unset (&value); } g_free (pspecs); if (g_type_is_a (type, GTK_TYPE_WIDGET)) { g_object_set (gtk_settings_get_default (), "gtk-theme-name", "Raleigh", NULL); pspecs = gtk_widget_class_list_style_properties (GTK_WIDGET_CLASS (klass), &n_pspecs); for (i = 0; i < n_pspecs; ++i) { GParamSpec *pspec = pspecs[i]; GValue value = G_VALUE_INIT; if (pspec->owner_type != type) continue; if ((pspec->flags & G_PARAM_READABLE) == 0) continue; if (g_type_is_a (type, GTK_TYPE_BUTTON) && strcmp (pspec->name, "default-border") == 0) continue; if (g_type_is_a (type, GTK_TYPE_WINDOW) && (strcmp (pspec->name, "resize-grip-width") == 0 || strcmp (pspec->name, "resize-grip-height") == 0 || strcmp (pspec->name, "decoration-button-layout") == 0)) continue; g_value_init (&value, G_PARAM_SPEC_VALUE_TYPE (pspec)); gtk_widget_style_get_property (GTK_WIDGET (instance), pspec->name, &value); check_property ("Style property", pspec, &value); g_value_unset (&value); } g_free (pspecs); } if (g_type_is_a (type, GDK_TYPE_WINDOW)) gdk_window_destroy (GDK_WINDOW (instance)); else g_object_unref (instance); g_type_class_unref (klass); }
static VALUE rg_abstract_p(VALUE self) { return CBOOL2RVAL(G_TYPE_IS_ABSTRACT(rbgobj_gtype_get(self))); }
int main (int argc, char **argv) { const GType *all_types; guint n_types = 0, i; gchar *schema_dir; GTestDBus *bus; gint result; /* These must be set before before gtk_test_init */ g_setenv ("GIO_USE_VFS", "local", TRUE); g_setenv ("GSETTINGS_BACKEND", "memory", TRUE); /* initialize test program */ gtk_test_init (&argc, &argv); gtk_test_register_all_types (); /* g_test_build_filename must be called after gtk_test_init */ schema_dir = g_test_build_filename (G_TEST_BUILT, "", NULL); g_setenv ("GSETTINGS_SCHEMA_DIR", schema_dir, TRUE); /* Create one test bus for all tests, as we have a lot of very small * and quick tests. */ bus = g_test_dbus_new (G_TEST_DBUS_NONE); g_test_dbus_up (bus); all_types = gtk_test_list_all_types (&n_types); for (i = 0; i < n_types; i++) { if (g_type_is_a (all_types[i], G_TYPE_OBJECT) && G_TYPE_IS_INSTANTIATABLE (all_types[i]) && !G_TYPE_IS_ABSTRACT (all_types[i]) && #ifdef GDK_WINDOWING_X11 all_types[i] != GDK_TYPE_X11_WINDOW && all_types[i] != GDK_TYPE_X11_CURSOR && all_types[i] != GDK_TYPE_X11_SCREEN && all_types[i] != GDK_TYPE_X11_DISPLAY && all_types[i] != GDK_TYPE_X11_DEVICE_MANAGER_XI2 && all_types[i] != GDK_TYPE_X11_DISPLAY_MANAGER && all_types[i] != GDK_TYPE_X11_GL_CONTEXT && #endif /* Not allowed to finalize a GdkPixbufLoader without calling gdk_pixbuf_loader_close() */ all_types[i] != GDK_TYPE_PIXBUF_LOADER && all_types[i] != gdk_pixbuf_simple_anim_iter_get_type()) { gchar *test_path = g_strdup_printf ("/FinalizeObject/%s", g_type_name (all_types[i])); g_test_add_data_func (test_path, GSIZE_TO_POINTER (all_types[i]), test_finalize_object); g_free (test_path); } } result = g_test_run(); g_test_dbus_down (bus); g_object_unref (bus); g_free (schema_dir); return result; }
static void test_type (gconstpointer data) { GObjectClass *klass; GObject *instance; GParamSpec **pspecs; guint n_pspecs, i; GType type; type = * (GType *) data; if (!G_TYPE_IS_CLASSED (type)) return; if (G_TYPE_IS_ABSTRACT (type)) return; if (!g_type_is_a (type, G_TYPE_OBJECT)) return; /* These can't be freely constructed/destroyed */ if (g_type_is_a (type, GTK_TYPE_PRINT_JOB) || g_type_is_a (type, GTK_TYPE_APPLICATION) || g_type_is_a (type, GDK_TYPE_PIXBUF_LOADER) || g_type_is_a (type, gdk_pixbuf_simple_anim_iter_get_type ())) return; klass = g_type_class_ref (type); if (g_type_is_a (type, GTK_TYPE_SETTINGS)) instance = g_object_ref (gtk_settings_get_default ()); else if (g_type_is_a (type, GDK_TYPE_WINDOW)) { GdkWindowAttr attributes; attributes.window_type = GDK_WINDOW_TEMP; attributes.event_mask = 0; attributes.width = 100; attributes.height = 100; instance = g_object_ref (gdk_window_new (NULL, &attributes, 0)); } else instance = g_object_new (type, NULL); if (g_type_is_a (type, G_TYPE_INITIALLY_UNOWNED)) g_object_ref_sink (instance); pspecs = g_object_class_list_properties (klass, &n_pspecs); for (i = 0; i < n_pspecs; ++i) { GParamSpec *pspec = pspecs[i]; GValue value = G_VALUE_INIT; if (pspec->owner_type != type) continue; if ((pspec->flags & G_PARAM_READABLE) == 0) continue; if (g_type_is_a (type, GDK_TYPE_DISPLAY_MANAGER) && (strcmp (pspec->name, "default-display") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_ABOUT_DIALOG) && (strcmp (pspec->name, "program-name") == 0)) continue; /* These are set to the current date */ if (g_type_is_a (type, GTK_TYPE_CALENDAR) && (strcmp (pspec->name, "year") == 0 || strcmp (pspec->name, "month") == 0 || strcmp (pspec->name, "day") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_CELL_RENDERER_TEXT) && (strcmp (pspec->name, "background-gdk") == 0 || strcmp (pspec->name, "foreground-gdk") == 0 || strcmp (pspec->name, "font") == 0 || strcmp (pspec->name, "font-desc") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_CELL_VIEW) && (strcmp (pspec->name, "background-gdk") == 0 || strcmp (pspec->name, "foreground-gdk") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_COLOR_BUTTON) && strcmp (pspec->name, "color") == 0) continue; if (g_type_is_a (type, GTK_TYPE_COLOR_SELECTION) && strcmp (pspec->name, "current-color") == 0) continue; if (g_type_is_a (type, GTK_TYPE_COLOR_SELECTION_DIALOG) && (strcmp (pspec->name, "color-selection") == 0 || strcmp (pspec->name, "ok-button") == 0 || strcmp (pspec->name, "help-button") == 0 || strcmp (pspec->name, "cancel-button") == 0)) continue; /* Default invisible char is determined at runtime */ if (g_type_is_a (type, GTK_TYPE_ENTRY) && (strcmp (pspec->name, "invisible-char") == 0 || strcmp (pspec->name, "buffer") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_FONT_SELECTION) && strcmp (pspec->name, "font") == 0) continue; if (g_type_is_a (type, GTK_TYPE_LAYOUT) && (strcmp (pspec->name, "hadjustment") == 0 || strcmp (pspec->name, "vadjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_MESSAGE_DIALOG) && (strcmp (pspec->name, "image") == 0 || strcmp (pspec->name, "message-area") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_PANED) && strcmp (pspec->name, "max-position") == 0) continue; if (g_type_is_a (type, GTK_TYPE_PRINT_OPERATION) && strcmp (pspec->name, "job-name") == 0) continue; if (g_type_is_a (type, GTK_TYPE_PRINT_UNIX_DIALOG) && (strcmp (pspec->name, "page-setup") == 0 || strcmp (pspec->name, "print-settings") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_PROGRESS_BAR) && strcmp (pspec->name, "adjustment") == 0) continue; /* filename value depends on $HOME */ if (g_type_is_a (type, GTK_TYPE_RECENT_MANAGER) && (strcmp (pspec->name, "filename") == 0 || strcmp (pspec->name, "size") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_SCALE_BUTTON) && strcmp (pspec->name, "adjustment") == 0) continue; if (g_type_is_a (type, GTK_TYPE_SCROLLED_WINDOW) && (strcmp (pspec->name, "hadjustment") == 0 || strcmp (pspec->name, "vadjustment") == 0)) continue; /* these defaults come from XResources */ if (g_type_is_a (type, GTK_TYPE_SETTINGS) && strncmp (pspec->name, "gtk-xft-", 8) == 0) continue; if (g_type_is_a (type, GTK_TYPE_SETTINGS) && (strcmp (pspec->name, "color-hash") == 0 || strcmp (pspec->name, "gtk-cursor-theme-name") == 0 || strcmp (pspec->name, "gtk-cursor-theme-size") == 0 || strcmp (pspec->name, "gtk-dnd-drag-threshold") == 0 || strcmp (pspec->name, "gtk-double-click-time") == 0 || strcmp (pspec->name, "gtk-fallback-icon-theme") == 0 || strcmp (pspec->name, "gtk-file-chooser-backend") == 0 || strcmp (pspec->name, "gtk-icon-theme-name") == 0 || strcmp (pspec->name, "gtk-im-module") == 0 || strcmp (pspec->name, "gtk-key-theme-name") == 0 || strcmp (pspec->name, "gtk-theme-name") == 0 || strcmp (pspec->name, "gtk-sound-theme-name") == 0 || strcmp (pspec->name, "gtk-enable-input-feedback-sounds") == 0 || strcmp (pspec->name, "gtk-enable-event-sounds") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_SPIN_BUTTON) && (strcmp (pspec->name, "adjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_STATUS_ICON) && (strcmp (pspec->name, "size") == 0 || strcmp (pspec->name, "screen") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_TEXT_BUFFER) && (strcmp (pspec->name, "tag-table") == 0 || strcmp (pspec->name, "copy-target-list") == 0 || strcmp (pspec->name, "paste-target-list") == 0)) continue; /* language depends on the current locale */ if (g_type_is_a (type, GTK_TYPE_TEXT_TAG) && (strcmp (pspec->name, "background-gdk") == 0 || strcmp (pspec->name, "foreground-gdk") == 0 || strcmp (pspec->name, "language") == 0 || strcmp (pspec->name, "font") == 0 || strcmp (pspec->name, "font-desc") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_TEXT_VIEW) && strcmp (pspec->name, "buffer") == 0) continue; if (g_type_is_a (type, GTK_TYPE_TOOL_ITEM_GROUP) && strcmp (pspec->name, "label-widget") == 0) continue; if (g_type_is_a (type, GTK_TYPE_TREE_VIEW) && (strcmp (pspec->name, "hadjustment") == 0 || strcmp (pspec->name, "vadjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_VIEWPORT) && (strcmp (pspec->name, "hadjustment") == 0 || strcmp (pspec->name, "vadjustment") == 0)) continue; if (g_type_is_a (type, GTK_TYPE_WIDGET) && (strcmp (pspec->name, "name") == 0 || strcmp (pspec->name, "screen") == 0 || strcmp (pspec->name, "style") == 0)) continue; /* resize-grip-visible is determined at runtime */ if (g_type_is_a (type, GTK_TYPE_WINDOW) && (strcmp (pspec->name, "resize-grip-visible") == 0)) continue; if (g_test_verbose ()) g_print ("Property %s.%s\n", g_type_name (pspec->owner_type), pspec->name); g_value_init (&value, G_PARAM_SPEC_VALUE_TYPE (pspec)); g_object_get_property (instance, pspec->name, &value); check_property ("Property", pspec, &value); g_value_unset (&value); } g_free (pspecs); if (g_type_is_a (type, GTK_TYPE_WIDGET)) { pspecs = gtk_widget_class_list_style_properties (GTK_WIDGET_CLASS (klass), &n_pspecs); for (i = 0; i < n_pspecs; ++i) { GParamSpec *pspec = pspecs[i]; GValue value = G_VALUE_INIT; if (pspec->owner_type != type) continue; if ((pspec->flags & G_PARAM_READABLE) == 0) continue; g_value_init (&value, G_PARAM_SPEC_VALUE_TYPE (pspec)); gtk_widget_style_get_property (GTK_WIDGET (instance), pspec->name, &value); check_property ("Style property", pspec, &value); g_value_unset (&value); } g_free (pspecs); } if (g_type_is_a (type, GDK_TYPE_WINDOW)) gdk_window_destroy (GDK_WINDOW (instance)); else g_object_unref (instance); g_type_class_unref (klass); }