[PATCH] D65810: [ELF] Fix splitting messages for duplicate symbols.

Igor Kudrin via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Aug 6 08:36:35 PDT 2019


ikudrin created this revision.
ikudrin added reviewers: ruiu, grimar, MaskRay.
ikudrin added a project: lld.
Herald added subscribers: arichardson, emaste.
Herald added a reviewer: espindola.
Herald added a project: LLVM.

D65213 <https://reviews.llvm.org/D65213> does not work for the case when a source file path includes subdirectories.


Repository:
  rLLD LLVM Linker

https://reviews.llvm.org/D65810

Files:
  Common/ErrorHandler.cpp
  test/ELF/Inputs/vs-diagnostics-duplicate-split.s
  test/ELF/vs-diagnostics-duplicate-split.s


Index: test/ELF/vs-diagnostics-duplicate-split.s
===================================================================
--- /dev/null
+++ test/ELF/vs-diagnostics-duplicate-split.s
@@ -0,0 +1,40 @@
+// REQUIRES: x86
+// RUN: llvm-mc -filetype=obj -triple=x86_64 %s -o %t1.o
+// RUN: llvm-mc -filetype=obj -triple=x86_64 %S/Inputs/vs-diagnostics-duplicate-split.s -o %t2.o
+// RUN: not ld.lld --vs-diagnostics --shared %t1.o %t2.o -o /dev/null 2>&1 | FileCheck %s
+
+// CHECK:      duplicate.s(15): error: duplicate symbol: foo
+// CHECK-NEXT: >>> defined at duplicate.s:15 (/tmp/duplicate.s:15)
+// CHECK-NEXT: >>>{{.*}}1.o:(.text+0x{{.+}})
+// CHECK:      duplicate2.s(20): error: duplicate symbol: foo
+// CHECK-NEXT: >>> defined at duplicate2.s:20 (/tmp/duplicate2.s:20)
+// CHECK-NEXT: >>>{{.*}}2.o:(.text+0x{{.+}})
+
+.file 1 "/tmp" "duplicate.s"
+
+.global foo
+.text
+.loc 1 15
+foo:
+  nop
+
+.section .debug_abbrev,"", at progbits
+  .byte  1                      # Abbreviation Code
+  .byte 17                      # DW_TAG_compile_unit
+  .byte  0                      # DW_CHILDREN_no
+  .byte 16                      # DW_AT_stmt_list
+  .byte 23                      # DW_FORM_sec_offset
+  .byte  0                      # EOM(1)
+  .byte  0                      # EOM(2)
+  .byte  0                      # EOM(3)
+
+.section .debug_info,"", at progbits
+  .long .Lend0 - .Lbegin0       # Length of Unit
+.Lbegin0:
+  .short 4                      # DWARF version number
+  .long  .debug_abbrev          # Offset Into Abbrev. Section
+  .byte  8                      # Address Size (in bytes)
+  .byte  1                      # Abbrev [1] 0xb:0x1f DW_TAG_compile_unit
+  .long  .debug_line            # DW_AT_stmt_list
+.Lend0:
+  .section .debug_line,"", at progbits
Index: test/ELF/Inputs/vs-diagnostics-duplicate-split.s
===================================================================
--- /dev/null
+++ test/ELF/Inputs/vs-diagnostics-duplicate-split.s
@@ -0,0 +1,29 @@
+.file 1 "/tmp" "duplicate2.s"
+
+.global foo
+
+.text
+.loc 1 20
+foo:
+  nop
+
+.section .debug_abbrev,"", at progbits
+  .byte  1                      # Abbreviation Code
+  .byte 17                      # DW_TAG_compile_unit
+  .byte  0                      # DW_CHILDREN_no
+  .byte 16                      # DW_AT_stmt_list
+  .byte 23                      # DW_FORM_sec_offset
+  .byte  0                      # EOM(1)
+  .byte  0                      # EOM(2)
+  .byte  0                      # EOM(3)
+
+.section .debug_info,"", at progbits
+  .long .Lend0 - .Lbegin0       # Length of Unit
+.Lbegin0:
+  .short 4                      # DWARF version number
+  .long  .debug_abbrev          # Offset Into Abbrev. Section
+  .byte  8                      # Address Size (in bytes)
+  .byte  1                      # Abbrev [1] 0xb:0x1f DW_TAG_compile_unit
+  .long  .debug_line            # DW_AT_stmt_list
+.Lend0:
+  .section .debug_line,"", at progbits
Index: Common/ErrorHandler.cpp
===================================================================
--- Common/ErrorHandler.cpp
+++ Common/ErrorHandler.cpp
@@ -184,8 +184,8 @@
   if (vsDiagnostics) {
     static std::regex reDuplicateSymbol(
         R"(^(duplicate symbol: .*))"
-        R"((\n>>> defined at \S+:\d+\n>>>.*))"
-        R"((\n>>> defined at \S+:\d+\n>>>.*))");
+        R"((\n>>> defined at \S+:\d+.*\n>>>.*))"
+        R"((\n>>> defined at \S+:\d+.*\n>>>.*))");
     std::string msgStr = msg.str();
     std::smatch match;
     if (std::regex_match(msgStr, match, reDuplicateSymbol)) {


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D65810.213622.patch
Type: text/x-patch
Size: 3536 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190806/c569b320/attachment.bin>


More information about the llvm-commits mailing list