mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-18 02:16:43 +00:00
Fix quoting of #pragma comment for MS compat, LLVM part.
For #pragma comment(linker, ...) MSVC expects the comment string to be quoted, but for #pragma comment(lib, ...) the compiler itself quotes the library name. Since this distinction disappears by the time the directive reaches the backend, move quoting for the "lib" version to the frontend. Differential Revision: http://reviews.llvm.org/D7652 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@229375 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
29679ccc12
commit
012d5929f1
@ -933,21 +933,10 @@ emitModuleFlags(MCStreamer &Streamer,
|
|||||||
MDNode *MDOptions = cast<MDNode>(LinkerOptions->getOperand(i));
|
MDNode *MDOptions = cast<MDNode>(LinkerOptions->getOperand(i));
|
||||||
for (unsigned ii = 0, ie = MDOptions->getNumOperands(); ii != ie; ++ii) {
|
for (unsigned ii = 0, ie = MDOptions->getNumOperands(); ii != ie; ++ii) {
|
||||||
MDString *MDOption = cast<MDString>(MDOptions->getOperand(ii));
|
MDString *MDOption = cast<MDString>(MDOptions->getOperand(ii));
|
||||||
StringRef Op = MDOption->getString();
|
|
||||||
// Lead with a space for consistency with our dllexport implementation.
|
// Lead with a space for consistency with our dllexport implementation.
|
||||||
std::string Escaped(" ");
|
std::string Directive(" ");
|
||||||
if (!Op.startswith("\"") && (Op.find(" ") != StringRef::npos)) {
|
Directive.append(MDOption->getString());
|
||||||
// The PE-COFF spec says args with spaces must be quoted. It doesn't say
|
Streamer.EmitBytes(Directive);
|
||||||
// how to escape quotes, but it probably uses this algorithm:
|
|
||||||
// http://msdn.microsoft.com/en-us/library/17w5ykft(v=vs.85).aspx
|
|
||||||
// FIXME: Reuse escaping code from Support/Windows/Program.inc
|
|
||||||
Escaped.push_back('\"');
|
|
||||||
Escaped.append(Op);
|
|
||||||
Escaped.push_back('\"');
|
|
||||||
} else {
|
|
||||||
Escaped.append(Op);
|
|
||||||
}
|
|
||||||
Streamer.EmitBytes(Escaped);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
; RUN: llc -O0 -mtriple=i386-pc-win32 -filetype=asm -o - %s | FileCheck %s
|
; RUN: llc -O0 -mtriple=i386-pc-win32 -filetype=asm -o - %s | FileCheck %s
|
||||||
|
|
||||||
!0 = !{i32 6, !"Linker Options", !{!{!"/DEFAULTLIB:msvcrt.lib"}, !{!"/DEFAULTLIB:msvcrt.lib", !"/DEFAULTLIB:secur32.lib"}, !{!"/DEFAULTLIB:C:\5Cpath to\5Casan_rt.lib"}, !{!"/with spaces"}, !{!"\22/quoted spaces\22"}}}
|
!0 = !{i32 6, !"Linker Options", !{!{!"/DEFAULTLIB:msvcrt.lib"}, !{!"/DEFAULTLIB:msvcrt.lib", !"/DEFAULTLIB:secur32.lib"}, !{!"/DEFAULTLIB:\22C:\5Cpath to\5Casan_rt.lib\22"}, !{!"\22/with spaces\22"}}}
|
||||||
|
|
||||||
!llvm.module.flags = !{ !0 }
|
!llvm.module.flags = !{ !0 }
|
||||||
|
|
||||||
@ -12,7 +12,6 @@ define dllexport void @foo() {
|
|||||||
; CHECK: .ascii " /DEFAULTLIB:msvcrt.lib"
|
; CHECK: .ascii " /DEFAULTLIB:msvcrt.lib"
|
||||||
; CHECK: .ascii " /DEFAULTLIB:msvcrt.lib"
|
; CHECK: .ascii " /DEFAULTLIB:msvcrt.lib"
|
||||||
; CHECK: .ascii " /DEFAULTLIB:secur32.lib"
|
; CHECK: .ascii " /DEFAULTLIB:secur32.lib"
|
||||||
; CHECK: .ascii " \"/DEFAULTLIB:C:\\path to\\asan_rt.lib\""
|
; CHECK: .ascii " /DEFAULTLIB:\"C:\\path to\\asan_rt.lib\""
|
||||||
; CHECK: .ascii " \"/with spaces\""
|
; CHECK: .ascii " \"/with spaces\""
|
||||||
; CHECK: .ascii " \"/quoted spaces\""
|
|
||||||
; CHECK: .ascii " /EXPORT:_foo"
|
; CHECK: .ascii " /EXPORT:_foo"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user