------- Comment #3 from pault at gcc dot gnu dot org  2007-01-23 06:26 -------
(In reply to comment #2)
> > No, that means it is used possiable as null.
> > You need to check inside pure_function to see if there is a way that the 
> > second argument does not get initialized.
> 
> There is:
>   if (e->symtree != NULL
>         && e->symtree->n.sym != NULL
>         && e->symtree->n.sym->attr.proc == PROC_ST_FUNCTION)
>     return 1;
> 
> One could thus either add a line in pure_function or in "resolve_function" to
> set name to null. Or in both. Having it in "resolve_function" means we get rid
> of this warning.
> 

No, it must be


  if (e->symtree != NULL
        && e->symtree->n.sym != NULL
        && e->symtree->n.sym->attr.proc == PROC_ST_FUNCTION)
    {
      *name = e->symtree->n.sym->name;
      return 1;
    }
for consistency.

Paul

PS That was my doing, so will fix as obvious.


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=30549

Reply via email to