Commit dffb24a6 authored by froydnj's avatar froydnj
Browse files

remove some TYPE_ARG_TYPES usage in objc/

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


git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@173977 138bc75d-0d04-0410-961f-82ee72b054a4
parent e0ae2fe2
2011-05-20 Nathan Froyd <froydnj@codesourcery.com>
* objc-act.c (objc_compare_types): Use function_args_iterator
instead of TYPE_ARG_TYPES to compare function argument types.
2011-05-13 Toon Moene <toon@moene.org>
* objc-next-runtime-abi-02.c (newabi_append_ro):
......
......@@ -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,
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment