sl@0: /* sl@0: * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. sl@0: * sl@0: * This library is free software; you can redistribute it and/or sl@0: * modify it under the terms of the GNU Lesser General Public sl@0: * License as published by the Free Software Foundation; either sl@0: * version 2 of the License, or (at your option) any later version. sl@0: * sl@0: * This library is distributed in the hope that it will be useful, sl@0: * but WITHOUT ANY WARRANTY; without even the implied warranty of sl@0: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU sl@0: * Lesser General Public License for more details. sl@0: * sl@0: * You should have received a copy of the GNU Lesser General Public sl@0: * License along with this library; if not, write to the sl@0: * Free Software Foundation, Inc., 59 Temple Place - Suite 330, sl@0: * Boston, MA 02111-1307, USA. sl@0: * sl@0: * Description: sl@0: * sl@0: */ sl@0: sl@0: #include sl@0: #include sl@0: #include sl@0: sl@0: #include sl@0: #ifdef SYMBIAN sl@0: #include "mrt2_glib2_test.h" sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: sl@0: #define G_TYPE_TEST (g_test_get_type ()) sl@0: #define G_TEST(test) (G_TYPE_CHECK_INSTANCE_CAST ((test), G_TYPE_TEST, GTest)) sl@0: #define G_IS_TEST(test) (G_TYPE_CHECK_INSTANCE_TYPE ((test), G_TYPE_TEST)) sl@0: #define G_TEST_CLASS(tclass) (G_TYPE_CHECK_CLASS_CAST ((tclass), G_TYPE_TEST, GTestClass)) sl@0: #define G_IS_TEST_CLASS(tclass) (G_TYPE_CHECK_CLASS_TYPE ((tclass), G_TYPE_TEST)) sl@0: #define G_TEST_GET_CLASS(test) (G_TYPE_INSTANCE_GET_CLASS ((test), G_TYPE_TEST, GTestClass)) sl@0: sl@0: enum { sl@0: PROP_0, sl@0: PROP_DUMMY sl@0: }; sl@0: sl@0: typedef struct _GTest GTest; sl@0: typedef struct _GTestClass GTestClass; sl@0: sl@0: struct _GTest sl@0: { sl@0: GObject object; sl@0: sl@0: gint dummy; sl@0: }; sl@0: sl@0: struct _GTestClass sl@0: { sl@0: GObjectClass parent_class; sl@0: }; sl@0: sl@0: static GType g_test_get_type (void); sl@0: sl@0: static void g_test_class_init (GTestClass * klass); sl@0: static void g_test_init (GTest * test); sl@0: static void g_test_dispose (GObject * object); sl@0: static void g_test_get_property (GObject *object, sl@0: guint prop_id, sl@0: GValue *value, sl@0: GParamSpec *pspec); sl@0: static void g_test_set_property (GObject *object, sl@0: guint prop_id, sl@0: const GValue *value, sl@0: GParamSpec *pspec); sl@0: sl@0: static GObjectClass *parent_class = NULL; sl@0: sl@0: static GType sl@0: g_test_get_type (void) sl@0: { sl@0: static GType test_type = 0; sl@0: sl@0: if (!test_type) { sl@0: static const GTypeInfo test_info = { sl@0: sizeof (GTestClass), sl@0: NULL, sl@0: NULL, sl@0: (GClassInitFunc) g_test_class_init, sl@0: NULL, sl@0: NULL, sl@0: sizeof (GTest), sl@0: 0, sl@0: (GInstanceInitFunc) g_test_init, sl@0: NULL sl@0: }; sl@0: sl@0: test_type = g_type_register_static (G_TYPE_OBJECT, "GTest", sl@0: &test_info, 0); sl@0: if(!test_type) sl@0: { sl@0: g_print("properties2.c : g_type_register_static is failed @ line : %d",__LINE__); sl@0: g_assert(FALSE && "properties"); sl@0: } sl@0: } sl@0: return test_type; sl@0: } sl@0: sl@0: static void sl@0: g_test_class_init (GTestClass * klass) sl@0: { sl@0: GObjectClass *gobject_class; sl@0: GParamSpec *gparam_spec; sl@0: sl@0: gobject_class = (GObjectClass *) klass; sl@0: sl@0: parent_class = g_type_class_ref (G_TYPE_OBJECT); sl@0: if(!parent_class) sl@0: { sl@0: g_print("properties2.c : g_tupe_class_ref failed @ line : %d",__LINE__); sl@0: g_assert(FALSE && "properties"); sl@0: } sl@0: sl@0: sl@0: sl@0: gobject_class->dispose = g_test_dispose; sl@0: gobject_class->get_property = g_test_get_property; sl@0: gobject_class->set_property = g_test_set_property; sl@0: sl@0: g_object_class_install_property (gobject_class, sl@0: PROP_DUMMY, sl@0: g_param_spec_int ("dummy", sl@0: NULL, sl@0: NULL, sl@0: 0, G_MAXINT, 0, sl@0: G_PARAM_READWRITE)); sl@0: sl@0: } sl@0: sl@0: static void sl@0: g_test_init (GTest * test) sl@0: { sl@0: //g_print ("init %p\n", test); sl@0: } sl@0: sl@0: static void sl@0: g_test_dispose (GObject * object) sl@0: { sl@0: GTest *test; sl@0: sl@0: test = G_TEST (object); sl@0: sl@0: g_print ("dispose %p!\n", object); sl@0: sl@0: G_OBJECT_CLASS (parent_class)->dispose (object); sl@0: } sl@0: sl@0: static void sl@0: g_test_get_property (GObject *object, sl@0: guint prop_id, sl@0: GValue *value, sl@0: GParamSpec *pspec) sl@0: { sl@0: GTest *test; sl@0: sl@0: test = G_TEST (object); sl@0: sl@0: switch (prop_id) sl@0: { sl@0: case PROP_DUMMY: sl@0: g_value_set_int (value, test->dummy); sl@0: break; sl@0: default: sl@0: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); sl@0: break; sl@0: } sl@0: } sl@0: sl@0: static void sl@0: g_test_set_property (GObject *object, sl@0: guint prop_id, sl@0: const GValue *value, sl@0: GParamSpec *pspec) sl@0: { sl@0: GTest *test; sl@0: sl@0: test = G_TEST (object); sl@0: sl@0: switch (prop_id) sl@0: { sl@0: case PROP_DUMMY: sl@0: test->dummy = g_value_get_int (value); sl@0: break; sl@0: default: sl@0: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); sl@0: break; sl@0: } sl@0: } sl@0: sl@0: static gint count = 0; sl@0: sl@0: sl@0: static void sl@0: g_test_do_property (GTest * test) sl@0: { sl@0: gint returnvalue, passedvalue=4; sl@0: GValue value1 = { 0, }; sl@0: GValue value2 = { 0, }; sl@0: sl@0: g_value_init(&value1,G_TYPE_INT); sl@0: g_value_init(&value2,G_TYPE_INT); sl@0: sl@0: g_value_set_int(&value1, passedvalue); sl@0: sl@0: sl@0: g_object_set_property (G_OBJECT(G_TEST(test)), "dummy", &value1); sl@0: g_object_get_property (G_OBJECT(G_TEST(test)), "dummy",&value2); sl@0: sl@0: returnvalue = g_value_get_int(&value2); sl@0: g_assert(returnvalue == passedvalue); sl@0: sl@0: } sl@0: sl@0: sl@0: void test_float_sink() sl@0: { sl@0: GTest *test; sl@0: GObject* obj; sl@0: test = g_object_new (G_TYPE_TEST, NULL); sl@0: obj = G_OBJECT(test); sl@0: g_object_force_floating(obj); sl@0: g_assert(g_object_is_floating(obj)); sl@0: g_object_ref_sink(obj); sl@0: g_object_unref(obj); sl@0: } sl@0: sl@0: sl@0: int sl@0: main (int argc, char **argv) sl@0: { sl@0: gint i; sl@0: gint handle_id = 0; sl@0: GTest *test; sl@0: sl@0: #ifdef SYMBIAN sl@0: sl@0: g_log_set_handler (NULL, G_LOG_FLAG_FATAL| G_LOG_FLAG_RECURSION | G_LOG_LEVEL_CRITICAL | G_LOG_LEVEL_WARNING | G_LOG_LEVEL_MESSAGE | G_LOG_LEVEL_INFO | G_LOG_LEVEL_DEBUG, &mrtLogHandler, NULL); sl@0: g_set_print_handler(mrtPrintHandler); sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: sl@0: g_type_init (); sl@0: sl@0: test = g_object_new (G_TYPE_TEST, NULL); sl@0: if(!test) sl@0: { sl@0: g_print("object_get_property.c : g_object_new is failed @ line : %d",__LINE__); sl@0: g_assert(FALSE && "properties"); sl@0: } sl@0: sl@0: g_test_do_property (test); sl@0: test_float_sink(); sl@0: sl@0: sl@0: //g_assert (count == test->dummy); sl@0: #ifdef SYMBIAN sl@0: testResultXml("object_extra_tests"); sl@0: #endif /* EMULATOR */ sl@0: sl@0: return 0; sl@0: }