OSDN Git Service

* diagnostic.c (diagnostic_build_prefix): If USE_MAPPED_LOCATION
authorbothner <bothner@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 1 Mar 2005 16:37:45 +0000 (16:37 +0000)
committerbothner <bothner@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 1 Mar 2005 16:37:45 +0000 (16:37 +0000)
and we have a non-zero column-number, add it to the message.
Also factor out the diagnostic_kind_text.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@95746 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/diagnostic.c

index 120114c..a28f1bf 100644 (file)
@@ -1,3 +1,9 @@
+2005-03-01  Per Bothner  <per@bothner.com>
+
+       * diagnostic.c (diagnostic_build_prefix): If USE_MAPPED_LOCATION
+       and we have a non-zero column-number, add it to the message.
+       Also factor out the diagnostic_kind_text.
+
 2005-03-01  Zdenek Dvorak  <dvorakz@suse.cz>
 
        * cfgloop.c (flow_loop_entry_edges_find, flow_loop_exit_edges_find,
index b047167..39b46fc 100644 (file)
@@ -133,15 +133,18 @@ diagnostic_build_prefix (diagnostic_info *diagnostic)
 #undef DEFINE_DIAGNOSTIC_KIND
     "must-not-happen"
   };
+  const char *text = _(diagnostic_kind_text[diagnostic->kind]);
   expanded_location s = expand_location (diagnostic->location);
   gcc_assert (diagnostic->kind < DK_LAST_DIAGNOSTIC_KIND);
 
-  return s.file
-    ? build_message_string ("%s:%d: %s",
-                            s.file, s.line,
-                            _(diagnostic_kind_text[diagnostic->kind]))
-    : build_message_string ("%s: %s", progname,
-                            _(diagnostic_kind_text[diagnostic->kind]));
+  return
+    (s.file == NULL
+     ? build_message_string ("%s: %s", progname, text)
+#ifdef USE_MAPPED_LOCATION
+     : s.column != 0
+     ? build_message_string ("%s:%d:%d: %s", s.file, s.line, s.column, text)
+#endif
+     : build_message_string ("%s:%d: %s", s.file, s.line, text));
 }
 
 /* Count a diagnostic.  Return true if the message should be printed.  */