summaryrefslogtreecommitdiff
path: root/t/t4034/cpp/pre
diff options
context:
space:
mode:
authorLibravatar Johannes Sixt <j6t@kdbg.org>2021-10-24 11:56:43 +0200
committerLibravatar Junio C Hamano <gitster@pobox.com>2021-10-25 08:47:44 -0700
commit386076ec92c702104cb15bc23e4521dac10c7c2d (patch)
treeb56c6f018bcce04e0c82c75758c626ac9942aa40 /t/t4034/cpp/pre
parentuserdiff-cpp: learn the C++ spaceship operator (diff)
downloadtgif-386076ec92c702104cb15bc23e4521dac10c7c2d.tar.xz
userdiff-cpp: back out the digit-separators in numbers
The implementation of digit-separating single-quotes introduced a note-worthy regression: the change of a character literal with a digit would splice the digit and the closing single-quote. For example, the change from 'a' to '2' is now tokenized as '[-a'-]{+2'+} instead of '[-a-]{+2+}'. The options to fix the regression are: - Tighten the regular expression such that the single-quote can only occur between digits (that would match the official syntax). - Remove support for digit separators. I chose to remove support, because - I have not seen a lot of code make use of digit separators. - If code does use digit separators, then the numbers are typically long. If a change in one of the segments occurs, it is actually better visible if only that segment is highlighted as the word that changed instead of the whole long number. This choice does introduce another minor regression, though, which is highlighted in the test case: when a change occurs in the second or later segment of a hexadecimal number where the segment begins with a digit, but also has letters, the segment is mistaken as consisting of a number and an identifier. I can live with that. Signed-off-by: Johannes Sixt <j6t@kdbg.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t4034/cpp/pre')
-rw-r--r--t/t4034/cpp/pre8
1 files changed, 4 insertions, 4 deletions
diff --git a/t/t4034/cpp/pre b/t/t4034/cpp/pre
index 144cd980d6..a1a09b7712 100644
--- a/t/t4034/cpp/pre
+++ b/t/t4034/cpp/pre
@@ -2,15 +2,15 @@ Foo():x(0&&1){ foo0( x.find); }
cout<<"Hello World!\n"<<endl;
1 -1e10 0xabcdef 'x'
// long double
-3.141'592'653e-10l
+3.141592653e-10l
// float
120E5f
// hex
-0xdead'beaf+8ULL
+0xdead'1eaF+8ULL
// octal
-0123'4567
+01234567
// binary
-0b10'00+e1
+0b1000+e1
// expression
1.5-e+2+f
// another one