diff options
author | Neil Booth <neilb@earthling.net> | 2000-11-01 20:21:13 +0000 |
---|---|---|
committer | Neil Booth <neil@gcc.gnu.org> | 2000-11-01 20:21:13 +0000 |
commit | a0a9606d4b5b7545b6dcabaa9a8a915ab96bd166 (patch) | |
tree | ad692a7f6210d539ee8ff1304361b204914f4b9e /gcc/cpplib.c | |
parent | fc05d51600acbf3cc72646e985db62b45b6f377f (diff) | |
download | gcc-a0a9606d4b5b7545b6dcabaa9a8a915ab96bd166.zip gcc-a0a9606d4b5b7545b6dcabaa9a8a915ab96bd166.tar.gz gcc-a0a9606d4b5b7545b6dcabaa9a8a915ab96bd166.tar.bz2 |
cpplib.c (run_directive): Use correct line number for output of _Pragma.
* cpplib.c (run_directive): Use correct line number for output
of _Pragma. Remember any in-progress directive.
* gcc.dg/cpp/vararg2.c, gcc.dg/cpp/_Pragm1.c: New tests.
From-SVN: r37194
Diffstat (limited to 'gcc/cpplib.c')
-rw-r--r-- | gcc/cpplib.c | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/gcc/cpplib.c b/gcc/cpplib.c index cd14ba4..738b1ba 100644 --- a/gcc/cpplib.c +++ b/gcc/cpplib.c @@ -349,9 +349,12 @@ run_directive (pfile, dir_no, buf, count, name) size_t count; const char *name; { + unsigned int output_line = pfile->lexer_pos.output_line; + if (cpp_push_buffer (pfile, (const U_CHAR *) buf, count) != NULL) { - const struct directive *dir = &dtable[dir_no]; + const struct directive *dir = &dtable[dir_no], *orig_dir; + unsigned char orig_in_directive; if (name) CPP_BUFFER (pfile)->nominal_fname = name; @@ -360,7 +363,11 @@ run_directive (pfile, dir_no, buf, count, name) /* A kludge to avoid line markers for _Pragma. */ if (dir_no == T_PRAGMA) - pfile->lexer_pos.output_line = CPP_BUFFER (pfile)->prev->lineno; + pfile->lexer_pos.output_line = output_line; + + /* Save any in-process directive; _Pragma can appear in one. */ + orig_dir = pfile->directive; + orig_in_directive = pfile->state.in_directive; /* For _Pragma, the text is passed through preprocessing stage 3 only, i.e. no trigraphs, no escaped newline removal, and no @@ -371,8 +378,8 @@ run_directive (pfile, dir_no, buf, count, name) pfile->state.prevent_expansion++; (void) (*dir->handler) (pfile); pfile->state.prevent_expansion--; - pfile->directive = 0; - pfile->state.in_directive = 0; + pfile->directive = orig_dir; + pfile->state.in_directive = orig_in_directive; skip_rest_of_line (pfile); if (pfile->buffer->cur != pfile->buffer->rlimit) |