X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=libspi%2Ftable.c;h=593522e2af5ea27d28ef0e147236871b8fa2868a;hb=262e6e147178e8744ddb24296a3d41f889400590;hp=98c704c4fe638da16875c4aec79373023cfa3c8e;hpb=e07aeb10fff4c7802393f5cbe8460d1097cbec18;p=platform%2Fcore%2Fuifw%2Fat-spi2-atk.git diff --git a/libspi/table.c b/libspi/table.c index 98c704c..593522e 100644 --- a/libspi/table.c +++ b/libspi/table.c @@ -208,16 +208,18 @@ static void table_finalize (GObject *obj) { Table *table = TABLE (obj); - table->atk_table = NULL; + g_object_unref (table->atko); + table->atko = NULL; parent_class->finalize (obj); } Table * -table_new (AtkTable *table) +table_interface_new (AtkObject *obj) { Table *new_table = TABLE(g_object_new (TABLE_TYPE, NULL)); - new_table->atk_table = table; + new_table->atko = obj; + g_object_ref (obj); return new_table; } @@ -231,8 +233,7 @@ impl__get_caption (PortableServer_Servant _servant, AtkObject *atk_object; Accessibility_Accessible rv; - atk_object = g_object_new (ATK_TYPE_OBJECT, NULL); - atk_object_set_name (atk_object, atk_table_get_caption (table->atk_table)); + atk_object = atk_table_get_caption (ATK_TABLE(table-> atko)); rv = bonobo_object_corba_objref (BONOBO_OBJECT(accessible_new(atk_object))); return rv; } @@ -247,7 +248,7 @@ impl__get_summary (PortableServer_Servant _servant, AtkObject *atk_object; Accessibility_Accessible rv; - atk_object = atk_table_get_summary (table->atk_table); + atk_object = atk_table_get_summary (ATK_TABLE(table->atko)); rv = bonobo_object_corba_objref (BONOBO_OBJECT(accessible_new(atk_object))); return rv; } @@ -260,7 +261,7 @@ impl__get_nRows (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_long) - atk_table_get_n_rows (table->atk_table); + atk_table_get_n_rows (ATK_TABLE(table->atko) ); } @@ -271,7 +272,7 @@ impl__get_nColumns (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_long) - atk_table_get_n_columns (table->atk_table); + atk_table_get_n_columns (ATK_TABLE(table->atko)); } @@ -286,7 +287,7 @@ impl_getAccessibleAt (PortableServer_Servant _servant, AtkObject *atk_object; Accessibility_Accessible rv; - atk_object = atk_table_ref_at (table->atk_table, + atk_object = atk_table_ref_at (ATK_TABLE(table->atko), (gint) row, (gint) column); rv = bonobo_object_corba_objref (BONOBO_OBJECT(accessible_new(atk_object))); return rv; @@ -301,7 +302,7 @@ impl_getIndexAt (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_long) - atk_table_get_index_at (table->atk_table, + atk_table_get_index_at (ATK_TABLE(table->atko), (gint) row, (gint) column); } @@ -314,7 +315,7 @@ impl_getRowAtIndex (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_long) - atk_table_get_row_at_index (table->atk_table, (gint) index); + atk_table_get_row_at_index (ATK_TABLE(table->atko), (gint) index); } @@ -326,7 +327,7 @@ impl_getColumnAtIndex (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_long) - atk_table_get_column_at_index (table->atk_table, (gint) index); + atk_table_get_column_at_index (ATK_TABLE(table->atko), (gint) index); } @@ -337,8 +338,13 @@ impl_getRowDescription (PortableServer_Servant _servant, CORBA_Environment * ev) { Table *table = TABLE (bonobo_object_from_servant (_servant)); - return CORBA_string_dup ( - atk_table_get_row_description (table->atk_table, (gint) row)); + CORBA_char *rv; + + rv = atk_table_get_row_description (ATK_TABLE(table->atko), (gint) row); + if (rv) + return CORBA_string_dup (rv); + else + return CORBA_string_dup (""); } @@ -349,8 +355,13 @@ impl_getColumnDescription (PortableServer_Servant _servant, CORBA_Environment * ev) { Table *table = TABLE (bonobo_object_from_servant (_servant)); - return CORBA_string_dup ( - atk_table_get_column_description (table->atk_table, (gint) column)); + CORBA_char *rv; + + rv = atk_table_get_column_description (ATK_TABLE(table->atko), (gint) column); + if (rv) + return CORBA_string_dup (rv); + else + return CORBA_string_dup (""); } @@ -363,7 +374,7 @@ impl_getRowExtentAt (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_long) - atk_table_get_row_extent_at (table->atk_table, + atk_table_get_row_extent_at (ATK_TABLE(table->atko), (gint) row, (gint) column); } @@ -377,7 +388,7 @@ impl_getColumnExtentAt (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_long) - atk_table_get_column_extent_at (table->atk_table, + atk_table_get_column_extent_at (ATK_TABLE(table->atko), (gint) row, (gint) column); } @@ -392,7 +403,7 @@ impl_getRowHeader (PortableServer_Servant _servant, AtkObject *header; Accessibility_Table rv; - header = atk_table_get_row_header (table->atk_table, (gint) row); + header = atk_table_get_row_header (ATK_TABLE(table->atko), (gint) row); rv = bonobo_object_corba_objref (BONOBO_OBJECT(accessible_new(header))); return rv; } @@ -408,7 +419,7 @@ impl_getColumnHeader (PortableServer_Servant _servant, AtkObject *header; Accessibility_Table rv; - header = atk_table_get_column_header (table->atk_table, (gint) column); + header = atk_table_get_column_header (ATK_TABLE(table->atko), (gint) column); rv = bonobo_object_corba_objref (BONOBO_OBJECT(accessible_new(header))); return rv; } @@ -424,7 +435,7 @@ impl_getSelectedRows (PortableServer_Servant _servant, gint length; Accessibility_LongSeq *retval; - length = atk_table_get_selected_rows (table->atk_table, &selectedRows); + length = atk_table_get_selected_rows (ATK_TABLE(table->atko), &selectedRows); g_return_val_if_fail (length, NULL); retval = Accessibility_LongSeq__alloc (); @@ -448,7 +459,7 @@ impl_getSelectedColumns (PortableServer_Servant _servant, gint length; Accessibility_LongSeq *retval; - length = atk_table_get_selected_columns (table->atk_table, &selectedColumns); + length = atk_table_get_selected_columns (ATK_TABLE(table->atko), &selectedColumns); g_return_val_if_fail (length, NULL); @@ -471,7 +482,7 @@ impl_isRowSelected (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_boolean) - atk_table_is_row_selected (table->atk_table, (gint) row); + atk_table_is_row_selected (ATK_TABLE(table->atko), (gint) row); } @@ -483,7 +494,7 @@ impl_isColumnSelected (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_boolean) - atk_table_is_column_selected (table->atk_table, (gint) column); + atk_table_is_column_selected (ATK_TABLE(table->atko), (gint) column); } @@ -496,7 +507,7 @@ impl_isSelected (PortableServer_Servant _servant, { Table *table = TABLE (bonobo_object_from_servant (_servant)); return (CORBA_boolean) - atk_table_is_selected (table->atk_table, + atk_table_is_selected (ATK_TABLE(table->atko), (gint) row, (gint) column); }