From: Alexandre Petit-Bianco Date: Fri, 15 May 1998 17:32:40 +0000 (+0000) Subject: Patch from Alex Petit-Bianco. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=b24f65cddd02f22d6ae7f3d7a89904fe3041b9ae;p=gcc.git Patch from Alex Petit-Bianco. * expr.c (expand_expr, case EXPR_WITH_FILE_LOCATION): Save/restore input_filename and lineno around expand_expr call. Set them to values in WFL before expand_expr call. From-SVN: r19778 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 725b7e36a94..d4023bec82d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +Fri May 15 17:26:18 1998 Alexandre Petit-Bianco + + * expr.c (expand_expr, case EXPR_WITH_FILE_LOCATION): Save/restore + input_filename and lineno around expand_expr call. Set them to values + in WFL before expand_expr call. + Fri May 15 12:44:57 1998 Benjamin Kosnik * stor-layout.c (set_sizetype): Set TYPE_NAME on bitsizetype. diff --git a/gcc/expr.c b/gcc/expr.c index dcbde150588..34f744db7f3 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -5171,9 +5171,20 @@ expand_expr (exp, target, tmode, modifier) return TREE_CST_RTL (exp); case EXPR_WITH_FILE_LOCATION: - if (EXPR_WFL_EMIT_LINE_NOTE (exp)) - emit_line_note (EXPR_WFL_FILENAME (exp), EXPR_WFL_LINENO (exp)); - return expand_expr (EXPR_WFL_NODE (exp), target, tmode, modifier); + { + rtx to_return; + char *saved_input_filename = input_filename; + int saved_lineno = lineno; + input_filename = EXPR_WFL_FILENAME (exp); + lineno = EXPR_WFL_LINENO (exp); + if (EXPR_WFL_EMIT_LINE_NOTE (exp)) + emit_line_note (input_filename, lineno); + /* Possibly avoid switching back and force here */ + to_return = expand_expr (EXPR_WFL_NODE (exp), target, tmode, modifier); + input_filename = saved_input_filename; + lineno = saved_lineno; + return to_return; + } case SAVE_EXPR: context = decl_function_context (exp);