aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorDodji Seketeli <dodji@gcc.gnu.org>2014-01-28 16:03:19 +0100
committerDodji Seketeli <dodji@gcc.gnu.org>2014-01-28 16:03:19 +0100
commit367c82866e7c439004f283bb45fdbe09479c0d7f (patch)
treefbc9e0ef5ef690d21749ed8b474f18cbf615fb05 /gcc
parent07ec81f958b765032f234d08623b9a23c374a09e (diff)
downloadgcc-367c82866e7c439004f283bb45fdbe09479c0d7f.zip
gcc-367c82866e7c439004f283bb45fdbe09479c0d7f.tar.gz
gcc-367c82866e7c439004f283bb45fdbe09479c0d7f.tar.bz2
PR preprocessor/59935 - caret diagnostics crashes on non-file locations
gcc/ChangeLog * input.c (location_get_source_line): Bail out on when line number is zero, and test the return value of lookup_or_add_file_to_cache_tab. gcc/testsuite/ChangeLog * c-c++-common/cpp/warning-zero-location.c: New test. * c-c++-common/cpp/warning-zero-location-2.c: Likewise. Signed-off-by: Dodji Seketeli <dodji@seketeli.org> From-SVN: r207195
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/input.c8
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/c-c++-common/cpp/warning-zero-location-2.c10
-rw-r--r--gcc/testsuite/c-c++-common/cpp/warning-zero-location.c8
5 files changed, 38 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 0dc6d60..e802cba 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2014-01-28 Jakub Jelinek <jakub@redhat.com>
+
+ PR preprocessor/59935
+ * input.c (location_get_source_line): Bail out on when line number
+ is zero, and test the return value of
+ lookup_or_add_file_to_cache_tab.
+
2014-01-28 Richard Biener <rguenther@suse.de>
PR tree-optimization/58742
diff --git a/gcc/input.c b/gcc/input.c
index 547c177..63cd062 100644
--- a/gcc/input.c
+++ b/gcc/input.c
@@ -698,7 +698,13 @@ location_get_source_line (expanded_location xloc,
static char *buffer;
static ssize_t len;
- fcache * c = lookup_or_add_file_to_cache_tab (xloc.file);
+ if (xloc.line == 0)
+ return NULL;
+
+ fcache *c = lookup_or_add_file_to_cache_tab (xloc.file);
+ if (c == NULL)
+ return NULL;
+
bool read = read_line_num (c, xloc.line, &buffer, &len);
if (read && line_len)
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index c85c2c2..30cbfa6 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2014-01-28 Dodji Seketeli <dodji@redhat.com>
+
+ PR preprocessor/59935
+ * c-c++-common/cpp/warning-zero-location.c: New test.
+ * c-c++-common/cpp/warning-zero-location-2.c: Likewise.
+
2014-01-27 Steve Ellcey <sellcey@mips.com>
* gcc.target/mips/pr52125.c: Add -mno-optgp option.
diff --git a/gcc/testsuite/c-c++-common/cpp/warning-zero-location-2.c b/gcc/testsuite/c-c++-common/cpp/warning-zero-location-2.c
new file mode 100644
index 0000000..c0e0bf7
--- /dev/null
+++ b/gcc/testsuite/c-c++-common/cpp/warning-zero-location-2.c
@@ -0,0 +1,10 @@
+/*
+ { dg-options "-D _GNU_SOURCE -fdiagnostics-show-caret" }
+ { dg-do compile }
+ */
+
+#line 4636 "configure"
+#include <xxxxxxxxxxxx.h>
+int main() { return 0; }
+
+/* { dg-error "No such file or directory" { target *-*-* } 4636 } */
diff --git a/gcc/testsuite/c-c++-common/cpp/warning-zero-location.c b/gcc/testsuite/c-c++-common/cpp/warning-zero-location.c
new file mode 100644
index 0000000..ca2e102
--- /dev/null
+++ b/gcc/testsuite/c-c++-common/cpp/warning-zero-location.c
@@ -0,0 +1,8 @@
+/*
+ { dg-options "-D _GNU_SOURCE -fdiagnostics-show-caret" }
+ { dg-do compile }
+ */
+
+#define _GNU_SOURCE /* { dg-warning "redefined" } */
+
+/* { dg-message "" "#define _GNU_SOURCE" {target *-*-* } 0 }