diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 31196d8f3df..12b0d4d0ecd 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +1999-04-09 22:58 -0400 Zack Weinberg + + * cpphash.c (special_symbol): When expanding __LINE__, use the + top file buffer, not the top buffer. + Fri Apr 9 13:41:04 1999 Jim Wilson * Makefile.in (check-g++, check-gcc, check-g77, check-objc): Add diff --git a/gcc/cpphash.c b/gcc/cpphash.c index 87946f2524b..5c2d5f3d800 100644 --- a/gcc/cpphash.c +++ b/gcc/cpphash.c @@ -991,7 +991,7 @@ special_symbol (hp, pfile) case T_SPECLINE: { long line; - cpp_buf_line_and_col (CPP_BUFFER (pfile), &line, NULL); + cpp_buf_line_and_col (cpp_file_buffer (pfile), &line, NULL); CPP_RESERVE (pfile, 10); sprintf (CPP_PWRITTEN (pfile), "%ld", line); diff --git a/gcc/testsuite/gcc.dg/990409-1.c b/gcc/testsuite/gcc.dg/990409-1.c new file mode 100644 index 00000000000..faa37e0de6e --- /dev/null +++ b/gcc/testsuite/gcc.dg/990409-1.c @@ -0,0 +1,18 @@ +/* Test that __LINE__ works when embedded in a macro. */ +/* { dg-do run } */ + +#define foo() bar(__LINE__) + +void +bar(int x) +{ + if (x != 16) + abort(); +} + +int +main(void) +{ + foo(); /* This is line 16 */ + return 0; +}