/* test-libsyncdaemon-vapi.c generated by valac 0.11.7, the Vala compiler * generated from test-libsyncdaemon-vapi.vala, do not modify */ /* * Syncdaemon Vala API test binary * * Copyright 2011 Canonical Ltd. * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License version 3, as published * by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranties of * MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR * PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . * */ #include #include #include #include #include #include #define TYPE_TEST_VAPI (test_vapi_get_type ()) #define TEST_VAPI(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_TEST_VAPI, TestVapi)) #define TEST_VAPI_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_TEST_VAPI, TestVapiClass)) #define IS_TEST_VAPI(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_TEST_VAPI)) #define IS_TEST_VAPI_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_TEST_VAPI)) #define TEST_VAPI_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_TEST_VAPI, TestVapiClass)) typedef struct _TestVapi TestVapi; typedef struct _TestVapiClass TestVapiClass; typedef struct _TestVapiPrivate TestVapiPrivate; #define _g_main_loop_unref0(var) ((var == NULL) ? NULL : (var = (g_main_loop_unref (var), NULL))) #define _g_object_unref0(var) ((var == NULL) ? NULL : (var = (g_object_unref (var), NULL))) typedef struct _ParamSpecTestVapi ParamSpecTestVapi; #define _test_vapi_unref0(var) ((var == NULL) ? NULL : (var = (test_vapi_unref (var), NULL))) struct _TestVapi { GTypeInstance parent_instance; volatile int ref_count; TestVapiPrivate * priv; }; struct _TestVapiClass { GTypeClass parent_class; void (*finalize) (TestVapi *self); }; struct _TestVapiPrivate { GMainLoop* loop; gint status; }; struct _ParamSpecTestVapi { GParamSpec parent_instance; }; static gpointer test_vapi_parent_class = NULL; gpointer test_vapi_ref (gpointer instance); void test_vapi_unref (gpointer instance); GParamSpec* param_spec_test_vapi (const gchar* name, const gchar* nick, const gchar* blurb, GType object_type, GParamFlags flags); void value_set_test_vapi (GValue* value, gpointer v_object); void value_take_test_vapi (GValue* value, gpointer v_object); gpointer value_get_test_vapi (const GValue* value); GType test_vapi_get_type (void) G_GNUC_CONST; #define TEST_VAPI_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), TYPE_TEST_VAPI, TestVapiPrivate)) enum { TEST_VAPI_DUMMY_PROPERTY }; TestVapi* test_vapi_new (void); TestVapi* test_vapi_construct (GType object_type); static gboolean test_vapi_test_instantiation (TestVapi* self); gint test_vapi_main (TestVapi* self); static void test_vapi_finalize (TestVapi* obj); gint _vala_main (gchar** args, int args_length1); TestVapi* test_vapi_construct (GType object_type) { TestVapi* self = NULL; self = (TestVapi*) g_type_create_instance (object_type); self->priv->status = 0; return self; } TestVapi* test_vapi_new (void) { return test_vapi_construct (TYPE_TEST_VAPI); } static gboolean test_vapi_test_instantiation (TestVapi* self) { gboolean result = FALSE; SyncdaemonDaemon* _tmp0_ = NULL; SyncdaemonDaemon* _tmp1_; g_return_val_if_fail (self != NULL, FALSE); _tmp0_ = syncdaemon_daemon_new (); _tmp1_ = _tmp0_; _g_object_unref0 (_tmp1_); g_main_loop_quit (self->priv->loop); result = FALSE; return result; } gint test_vapi_main (TestVapi* self) { gint result = 0; GMainLoop* _tmp0_ = NULL; GSourceFunc _tmp1_; g_return_val_if_fail (self != NULL, 0); _tmp0_ = g_main_loop_new (NULL, FALSE); _g_main_loop_unref0 (self->priv->loop); self->priv->loop = _tmp0_; _tmp1_ = (GSourceFunc) test_vapi_test_instantiation; g_idle_add_full (G_PRIORITY_DEFAULT_IDLE, _tmp1_, self, NULL); g_main_loop_run (self->priv->loop); result = self->priv->status; return result; } static void value_test_vapi_init (GValue* value) { value->data[0].v_pointer = NULL; } static void value_test_vapi_free_value (GValue* value) { if (value->data[0].v_pointer) { test_vapi_unref (value->data[0].v_pointer); } } static void value_test_vapi_copy_value (const GValue* src_value, GValue* dest_value) { if (src_value->data[0].v_pointer) { dest_value->data[0].v_pointer = test_vapi_ref (src_value->data[0].v_pointer); } else { dest_value->data[0].v_pointer = NULL; } } static gpointer value_test_vapi_peek_pointer (const GValue* value) { return value->data[0].v_pointer; } static gchar* value_test_vapi_collect_value (GValue* value, guint n_collect_values, GTypeCValue* collect_values, guint collect_flags) { if (collect_values[0].v_pointer) { TestVapi* object; object = collect_values[0].v_pointer; if (object->parent_instance.g_class == NULL) { return g_strconcat ("invalid unclassed object pointer for value type `", G_VALUE_TYPE_NAME (value), "'", NULL); } else if (!g_value_type_compatible (G_TYPE_FROM_INSTANCE (object), G_VALUE_TYPE (value))) { return g_strconcat ("invalid object type `", g_type_name (G_TYPE_FROM_INSTANCE (object)), "' for value type `", G_VALUE_TYPE_NAME (value), "'", NULL); } value->data[0].v_pointer = test_vapi_ref (object); } else { value->data[0].v_pointer = NULL; } return NULL; } static gchar* value_test_vapi_lcopy_value (const GValue* value, guint n_collect_values, GTypeCValue* collect_values, guint collect_flags) { TestVapi** object_p; object_p = collect_values[0].v_pointer; if (!object_p) { return g_strdup_printf ("value location for `%s' passed as NULL", G_VALUE_TYPE_NAME (value)); } if (!value->data[0].v_pointer) { *object_p = NULL; } else if (collect_flags & G_VALUE_NOCOPY_CONTENTS) { *object_p = value->data[0].v_pointer; } else { *object_p = test_vapi_ref (value->data[0].v_pointer); } return NULL; } GParamSpec* param_spec_test_vapi (const gchar* name, const gchar* nick, const gchar* blurb, GType object_type, GParamFlags flags) { ParamSpecTestVapi* spec; g_return_val_if_fail (g_type_is_a (object_type, TYPE_TEST_VAPI), NULL); spec = g_param_spec_internal (G_TYPE_PARAM_OBJECT, name, nick, blurb, flags); G_PARAM_SPEC (spec)->value_type = object_type; return G_PARAM_SPEC (spec); } gpointer value_get_test_vapi (const GValue* value) { g_return_val_if_fail (G_TYPE_CHECK_VALUE_TYPE (value, TYPE_TEST_VAPI), NULL); return value->data[0].v_pointer; } void value_set_test_vapi (GValue* value, gpointer v_object) { TestVapi* old; g_return_if_fail (G_TYPE_CHECK_VALUE_TYPE (value, TYPE_TEST_VAPI)); old = value->data[0].v_pointer; if (v_object) { g_return_if_fail (G_TYPE_CHECK_INSTANCE_TYPE (v_object, TYPE_TEST_VAPI)); g_return_if_fail (g_value_type_compatible (G_TYPE_FROM_INSTANCE (v_object), G_VALUE_TYPE (value))); value->data[0].v_pointer = v_object; test_vapi_ref (value->data[0].v_pointer); } else { value->data[0].v_pointer = NULL; } if (old) { test_vapi_unref (old); } } void value_take_test_vapi (GValue* value, gpointer v_object) { TestVapi* old; g_return_if_fail (G_TYPE_CHECK_VALUE_TYPE (value, TYPE_TEST_VAPI)); old = value->data[0].v_pointer; if (v_object) { g_return_if_fail (G_TYPE_CHECK_INSTANCE_TYPE (v_object, TYPE_TEST_VAPI)); g_return_if_fail (g_value_type_compatible (G_TYPE_FROM_INSTANCE (v_object), G_VALUE_TYPE (value))); value->data[0].v_pointer = v_object; } else { value->data[0].v_pointer = NULL; } if (old) { test_vapi_unref (old); } } static void test_vapi_class_init (TestVapiClass * klass) { test_vapi_parent_class = g_type_class_peek_parent (klass); TEST_VAPI_CLASS (klass)->finalize = test_vapi_finalize; g_type_class_add_private (klass, sizeof (TestVapiPrivate)); } static void test_vapi_instance_init (TestVapi * self) { self->priv = TEST_VAPI_GET_PRIVATE (self); self->ref_count = 1; } static void test_vapi_finalize (TestVapi* obj) { TestVapi * self; self = TEST_VAPI (obj); _g_main_loop_unref0 (self->priv->loop); } GType test_vapi_get_type (void) { static volatile gsize test_vapi_type_id__volatile = 0; if (g_once_init_enter (&test_vapi_type_id__volatile)) { static const GTypeValueTable g_define_type_value_table = { value_test_vapi_init, value_test_vapi_free_value, value_test_vapi_copy_value, value_test_vapi_peek_pointer, "p", value_test_vapi_collect_value, "p", value_test_vapi_lcopy_value }; static const GTypeInfo g_define_type_info = { sizeof (TestVapiClass), (GBaseInitFunc) NULL, (GBaseFinalizeFunc) NULL, (GClassInitFunc) test_vapi_class_init, (GClassFinalizeFunc) NULL, NULL, sizeof (TestVapi), 0, (GInstanceInitFunc) test_vapi_instance_init, &g_define_type_value_table }; static const GTypeFundamentalInfo g_define_type_fundamental_info = { (G_TYPE_FLAG_CLASSED | G_TYPE_FLAG_INSTANTIATABLE | G_TYPE_FLAG_DERIVABLE | G_TYPE_FLAG_DEEP_DERIVABLE) }; GType test_vapi_type_id; test_vapi_type_id = g_type_register_fundamental (g_type_fundamental_next (), "TestVapi", &g_define_type_info, &g_define_type_fundamental_info, 0); g_once_init_leave (&test_vapi_type_id__volatile, test_vapi_type_id); } return test_vapi_type_id__volatile; } gpointer test_vapi_ref (gpointer instance) { TestVapi* self; self = instance; g_atomic_int_inc (&self->ref_count); return instance; } void test_vapi_unref (gpointer instance) { TestVapi* self; self = instance; if (g_atomic_int_dec_and_test (&self->ref_count)) { TEST_VAPI_GET_CLASS (self)->finalize (self); g_type_free_instance ((GTypeInstance *) self); } } gint _vala_main (gchar** args, int args_length1) { gint result = 0; TestVapi* _tmp0_ = NULL; TestVapi* test; gint _tmp1_; _tmp0_ = test_vapi_new (); test = _tmp0_; _tmp1_ = test_vapi_main (test); result = _tmp1_; _test_vapi_unref0 (test); return result; } int main (int argc, char ** argv) { g_type_init (); return _vala_main (argv, argc); }