From: dalej Date: Tue, 6 Aug 2002 23:36:22 +0000 (+0000) Subject: Mark __func__ with line number 0, to avoid confusing debuggers. X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=2222b3c62cd0deb2c26a41562e8a81e0314c789b;p=thirdparty%2Fgcc.git Mark __func__ with line number 0, to avoid confusing debuggers. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@56081 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3cd7f5596a3c..2e3a9b8d47b3 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2002-08-06 Dale Johannesen + * c-common.c (fname_decl): Use line number 0 for + __func__, to avoid confusing debuggers. + 2002-08-06 Nathan Sidwell * gcov.c: Tidy. diff --git a/gcc/c-common.c b/gcc/c-common.c index 363e72f949d6..fabc18139043 100644 --- a/gcc/c-common.c +++ b/gcc/c-common.c @@ -1102,6 +1102,13 @@ fname_decl (rid, id) if (!decl) { tree saved_last_tree = last_tree; + /* If a tree is built here, it would normally have the lineno of + the current statement. Later this tree will be moved to the + beginning of the function and this line number will be wrong. + To avoid this problem set the lineno to 0 here; that prevents + it from appearing in the RTL. */ + int saved_lineno = lineno; + lineno = 0; decl = (*make_fname_decl) (id, fname_vars[ix].pretty); if (last_tree != saved_last_tree) @@ -1117,6 +1124,7 @@ fname_decl (rid, id) saved_function_name_decls); } *fname_vars[ix].decl = decl; + lineno = saved_lineno; } if (!ix && !current_function_decl) pedwarn_with_decl (decl, "`%s' is not defined outside of function scope");