aboutsummaryrefslogtreecommitdiff
path: root/libcpp
diff options
context:
space:
mode:
authorDavid Malcolm <dmalcolm@redhat.com>2017-06-20 10:40:38 +0000
committerDavid Malcolm <dmalcolm@gcc.gnu.org>2017-06-20 10:40:38 +0000
commitc7a980b80b3a46ad24940269f6b85a75cdb94a60 (patch)
treefe86d10819506cdb8f17e6172d8ed766eb12c2fa /libcpp
parentad2f2a35d33ea79f95b70f8d96ee1445fabed402 (diff)
downloadgcc-c7a980b80b3a46ad24940269f6b85a75cdb94a60.zip
gcc-c7a980b80b3a46ad24940269f6b85a75cdb94a60.tar.gz
gcc-c7a980b80b3a46ad24940269f6b85a75cdb94a60.tar.bz2
Prevent fix-it hints from affecting more than one line
Attempts to apply a removal or replacement fix-it hint to a source range that covers multiple lines currently lead to nonsensical results from the printing code in diagnostic-show-locus.c. We were already filtering them out in edit-context.c (leading to -fdiagnostics-generate-patch not generating any output for the whole TU). Reject attempts to add such fix-it hints within rich_location, fixing the diagnostic-show-locus.c issue. gcc/ChangeLog: * diagnostic-show-locus.c (selftest::test_fixit_deletion_affecting_newline): New function. (selftest::diagnostic_show_locus_c_tests): Call it. libcpp/ChangeLog: * include/line-map.h (class rich_location): Document that attempts to delete or replace a range *affecting* multiple lines will fail. * line-map.c (rich_location::maybe_add_fixit): Implement this restriction. From-SVN: r249403
Diffstat (limited to 'libcpp')
-rw-r--r--libcpp/ChangeLog7
-rw-r--r--libcpp/include/line-map.h2
-rw-r--r--libcpp/line-map.c21
3 files changed, 28 insertions, 2 deletions
diff --git a/libcpp/ChangeLog b/libcpp/ChangeLog
index 13a33c3..9665f6e 100644
--- a/libcpp/ChangeLog
+++ b/libcpp/ChangeLog
@@ -1,3 +1,10 @@
+2017-06-20 David Malcolm <dmalcolm@redhat.com>
+
+ * include/line-map.h (class rich_location): Document that attempts
+ to delete or replace a range *affecting* multiple lines will fail.
+ * line-map.c (rich_location::maybe_add_fixit): Implement this
+ restriction.
+
2017-06-09 David Malcolm <dmalcolm@redhat.com>
* include/line-map.h
diff --git a/libcpp/include/line-map.h b/libcpp/include/line-map.h
index be3041d..f5c19e3 100644
--- a/libcpp/include/line-map.h
+++ b/libcpp/include/line-map.h
@@ -1556,6 +1556,8 @@ class fixit_hint;
inserting at the start of a line, and finishing with a newline
(with no interior newline characters). Other attempts to add
fix-it hints containing newline characters will fail.
+ Similarly, attempts to delete or replace a range *affecting* multiple
+ lines will fail.
The rich_location API handles these failures gracefully, so that
diagnostics can attempt to add fix-it hints without each needing
diff --git a/libcpp/line-map.c b/libcpp/line-map.c
index 694137a..7ba003a 100644
--- a/libcpp/line-map.c
+++ b/libcpp/line-map.c
@@ -2327,6 +2327,25 @@ rich_location::maybe_add_fixit (source_location start,
if (reject_impossible_fixit (next_loc))
return;
+ /* Only allow fix-it hints that affect a single line in one file.
+ Compare the end-points. */
+ expanded_location exploc_start
+ = linemap_client_expand_location_to_spelling_point (start);
+ expanded_location exploc_next_loc
+ = linemap_client_expand_location_to_spelling_point (next_loc);
+ /* They must be within the same file... */
+ if (exploc_start.file != exploc_next_loc.file)
+ {
+ stop_supporting_fixits ();
+ return;
+ }
+ /* ...and on the same line. */
+ if (exploc_start.line != exploc_next_loc.line)
+ {
+ stop_supporting_fixits ();
+ return;
+ }
+
const char *newline = strchr (new_content, '\n');
if (newline)
{
@@ -2342,8 +2361,6 @@ rich_location::maybe_add_fixit (source_location start,
}
/* The insertion must be at the start of a line. */
- expanded_location exploc_start
- = linemap_client_expand_location_to_spelling_point (start);
if (exploc_start.column != 1)
{
stop_supporting_fixits ();