public inbox for gcc-patches@gcc.gnu.org
 help / color / mirror / Atom feed
* [PATCH] remove some TYPE_ARG_TYPES usage in objc/
@ 2011-05-20 14:38 Nathan Froyd
  2011-05-20 16:35 ` Mike Stump
  0 siblings, 1 reply; 2+ messages in thread
From: Nathan Froyd @ 2011-05-20 14:38 UTC (permalink / raw)
  To: gcc-patches

This patch removes one of the two remaining uses of TYPE_ARG_TYPES in
the ObjC/C++ frontends.  (The other one should be addressed in a
different manner.)  Given the constraints of the function_args_iterator
interface, I thought rewriting the logic of the loop would make things
slightly clearer.

Tested on x86_64-unknown-linux-gnu with ObjC/C++.  OK to commit?

-Nathan

gcc/objc/
	* objc-act.c (objc_compare_types): Use function_args_iterator
	instead of TYPE_ARG_TYPES to compare function argument types.

diff --git a/gcc/objc/objc-act.c b/gcc/objc/objc-act.c
index 7e69b0d..0e15fe5 100644
--- a/gcc/objc/objc-act.c
+++ b/gcc/objc/objc-act.c
@@ -2420,6 +2420,8 @@ objc_compare_types (tree ltyp, tree rtyp, int argno, tree callee)
      lenient than C or C++ on this.  */
   if (TREE_CODE (ltyp) == FUNCTION_TYPE && TREE_CODE (rtyp) == FUNCTION_TYPE)
     {
+      function_args_iterator liter, riter;
+
       /* Return types must be covariant.  */
       if (!comptypes (TREE_TYPE (ltyp), TREE_TYPE (rtyp))
 	  && !objc_compare_types (TREE_TYPE (ltyp), TREE_TYPE (rtyp),
@@ -2427,16 +2429,31 @@ objc_compare_types (tree ltyp, tree rtyp, int argno, tree callee)
       return false;
 
       /* Argument types must be contravariant.  */
-      for (ltyp = TYPE_ARG_TYPES (ltyp), rtyp = TYPE_ARG_TYPES (rtyp);
-	   ltyp && rtyp; ltyp = TREE_CHAIN (ltyp), rtyp = TREE_CHAIN (rtyp))
+      function_args_iter_init (&liter, ltyp);
+      function_args_iter_init (&riter, rtyp);
+
+      while (1)
 	{
-	  if (!comptypes (TREE_VALUE (rtyp), TREE_VALUE (ltyp))
-	      && !objc_compare_types (TREE_VALUE (rtyp), TREE_VALUE (ltyp),
-				      argno, callee))
+	  ltyp = function_args_iter_cond (&liter);
+	  rtyp = function_args_iter_cond (&riter);
+
+	  /* If we've exhaused both lists simulateously, we're done.  */
+	  if (ltyp == NULL_TREE && rtyp == NULL_TREE)
+	    break;
+
+	  /* If one list is shorter than the other, they fail to match.  */
+	  if (ltyp == NULL_TREE || rtyp == NULL_TREE)
 	    return false;
-      }
 
-      return (ltyp == rtyp);
+	  if (!comptypes (rtyp, ltyp)
+	      && !objc_compare_types (rtyp, ltyp, argno, callee))
+	    return false;
+
+	  function_args_iter_next (&liter);
+	  function_args_iter_next (&riter);
+	}
+
+      return true;
     }
 
   /* Past this point, we are only interested in ObjC class instances,

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [PATCH] remove some TYPE_ARG_TYPES usage in objc/
  2011-05-20 14:38 [PATCH] remove some TYPE_ARG_TYPES usage in objc/ Nathan Froyd
@ 2011-05-20 16:35 ` Mike Stump
  0 siblings, 0 replies; 2+ messages in thread
From: Mike Stump @ 2011-05-20 16:35 UTC (permalink / raw)
  To: Nathan Froyd; +Cc: gcc-patches

On May 20, 2011, at 6:58 AM, Nathan Froyd wrote:
> This patch removes one of the two remaining uses of TYPE_ARG_TYPES in
> the ObjC/C++ frontends.  (The other one should be addressed in a
> different manner.)  Given the constraints of the function_args_iterator
> interface, I thought rewriting the logic of the loop would make things
> slightly clearer.
> 
> Tested on x86_64-unknown-linux-gnu with ObjC/C++.  OK to commit?

Ok.

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2011-05-20 15:44 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2011-05-20 14:38 [PATCH] remove some TYPE_ARG_TYPES usage in objc/ Nathan Froyd
2011-05-20 16:35 ` Mike Stump

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).