gobject-introspection r928 - in trunk: . girepository



Author: walters
Date: Sun Nov 16 20:58:35 2008
New Revision: 928
URL: http://svn.gnome.org/viewvc/gobject-introspection?rev=928&view=rev

Log:
Bug 560241 - Out-arguments should not be marked as being pointers in all cases

Modified:
   trunk/ChangeLog
   trunk/girepository/girparser.c

Modified: trunk/girepository/girparser.c
==============================================================================
--- trunk/girepository/girparser.c	(original)
+++ trunk/girepository/girparser.c	Sun Nov 16 20:58:35 2008
@@ -1656,18 +1656,26 @@
     }
   else
     {
-      gboolean is_pointer;
+      int pointer_depth;
       name = find_attribute ("name", attribute_names, attribute_values);
 
       if (name == NULL)
 	MISSING_ATTRIBUTE (context, error, element_name, "name");
       
+      pointer_depth = 0;
       ctype = find_attribute ("c:type", attribute_names, attribute_values);
-      if (ctype != NULL && strchr (ctype, '*'))
-	is_pointer = TRUE;
-      else
-	is_pointer = FALSE;
-
+      if (ctype != NULL)
+        {
+          const char *cp = ctype + strlen(ctype) - 1;
+          while (cp > ctype && *cp-- == '*')
+            pointer_depth++;
+        }
+      
+      if (ctx->current_typed->type == G_IR_NODE_PARAM &&
+          ((GIrNodeParam *)ctx->current_typed)->out &&
+          pointer_depth > 0)
+        pointer_depth--;
+      
       typenode = parse_type (ctx, name);
 
       /* A 'disguised' structure is one where the c:type is a typedef that
@@ -1675,10 +1683,10 @@
        */
       if (typenode->tag == GI_TYPE_TAG_INTERFACE &&
 	  is_disguised_structure (ctx, typenode->interface))
-	is_pointer = TRUE;
+	pointer_depth++;
 
-      if (is_pointer)
-	typenode->is_pointer = is_pointer;
+      if (pointer_depth > 0)
+	typenode->is_pointer = TRUE;
     }
 
   ctx->type_parameters = g_list_append (ctx->type_parameters, typenode);



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]