[diagnostic patch] PR 54941

Paolo Carlini paolo.carlini@oracle.com
Sun Sep 8 13:41:00 GMT 2013


Hi all, Gaby,

in this bug Manuel noticed that the zeros in the diagnostic lines of the 
form:

<built-in>:0:0: ....

don't provide useful information. Thus the below just avoids printing 
the zeros basing directly on the file name: admittedly, it may seem a 
bit gross, but in practice the strcmp would often fail early, and should 
be rather efficient anyway because the second argument is known at 
compile-time.

Tested x86_64-linux.

Thanks,
Paolo.

////////////////////////
-------------- next part --------------
2013-09-08  Paolo Carlini  <paolo.carlini@oracle.com>

	PR c++/54941
	* diagnostic.c (diagnostic_build_prefix): When s.file is
	"<built-in>" don't output line and column numbers.

/testsuite
2013-09-08  Paolo Carlini  <paolo.carlini@oracle.com>

	PR c++/54941
	* g++.dg/overload/new1.C: Adjust.
-------------- next part --------------
Index: diagnostic.c
===================================================================
--- diagnostic.c	(revision 202358)
+++ diagnostic.c	(working copy)
@@ -245,6 +245,9 @@ diagnostic_build_prefix (diagnostic_context *conte
     (s.file == NULL
      ? build_message_string ("%s%s:%s %s%s%s", locus_cs, progname, locus_ce,
 			     text_cs, text, text_ce)
+     : !strcmp (s.file, N_("<built-in>"))
+     ? build_message_string ("%s%s:%s %s%s%s", locus_cs, s.file, locus_ce,
+			     text_cs, text, text_ce)
      : context->show_column
      ? build_message_string ("%s%s:%d:%d:%s %s%s%s", locus_cs, s.file, s.line,
 			     s.column, locus_ce, text_cs, text, text_ce)
Index: testsuite/g++.dg/overload/new1.C
===================================================================
--- testsuite/g++.dg/overload/new1.C	(revision 202358)
+++ testsuite/g++.dg/overload/new1.C	(working copy)
@@ -17,6 +17,5 @@ void f(X *x = new (3) X(6));   // { dg-error "" }
 
 void f(X *x = new (2) X[10]);  // { dg-error "" } 
 // { dg-message "candidate" "candidate note" { target *-*-* } 18 }
-// { dg-message "operator new|candidate expects" "match candidate text" { target *-*-* } 00 }
 
 void f(X *x = new X[10][5]);   // { dg-error "" } 


More information about the Gcc-patches mailing list