From: Hans Wennborg Date: Tue, 13 Aug 2013 23:38:57 +0000 (+0000) Subject: clang-cl: Support /link option and set target to win32 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=5db9527a2e582c17bc835e6e2a5a8178efa5a1e8;p=clang clang-cl: Support /link option and set target to win32 This adds support for the /link option, which forwards subsequent arguments to the linker. The test for this will only work when targetting win32. Since that's the only target where clang-cl makes sense, use that target by default. Differential Revision: http://llvm-reviews.chandlerc.com/D1388 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@188331 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Driver/CLCompatOptions.td b/include/clang/Driver/CLCompatOptions.td index a4b8b61e2b..083686d0e8 100644 --- a/include/clang/Driver/CLCompatOptions.td +++ b/include/clang/Driver/CLCompatOptions.td @@ -32,6 +32,9 @@ class CLIgnoredJoined : Option<["/", "-"], name, KIND_JOINED>, class CLJoinedOrSeparate : Option<["/", "-"], name, KIND_JOINED_OR_SEPARATE>, Group, Flags<[CLOption, DriverOption]>; +class CLRemainingArgs : Option<["/", "-"], name, + KIND_REMAINING_ARGS>, Group, Flags<[CLOption, DriverOption]>; + // Aliases: def _SLASH_c : CLFlag<"c">, HelpText<"Compile only">, Alias; @@ -96,6 +99,8 @@ def _SLASH_Fe : CLJoined<"Fe">, def _SLASH_Fo : CLJoined<"Fo">, HelpText<"Set output object file, or directory (ends in / or \\)">, MetaVarName<"">; +def _SLASH_link : CLRemainingArgs<"link">, + HelpText<"Forward options to the linker">, MetaVarName<"">; def _SLASH_MD : CLFlag<"MD">, HelpText<"Use DLL run-time">; def _SLASH_MDd : CLFlag<"MDd">, diff --git a/lib/Driver/Driver.cpp b/lib/Driver/Driver.cpp index 68958047ba..32a7d1aafd 100644 --- a/lib/Driver/Driver.cpp +++ b/lib/Driver/Driver.cpp @@ -351,6 +351,12 @@ Compilation *Driver::BuildCompilation(ArrayRef ArgList) { options::OPT_ccc_pch_is_pth); // FIXME: DefaultTargetTriple is used by the target-prefixed calls to as/ld // and getToolChain is const. + if (IsCLMode()) { + // clang-cl targets Win32. + llvm::Triple T(DefaultTargetTriple); + T.setOSName(llvm::Triple::getOSTypeName(llvm::Triple::Win32)); + DefaultTargetTriple = T.str(); + } if (const Arg *A = Args->getLastArg(options::OPT_target)) DefaultTargetTriple = A->getValue(); if (const Arg *A = Args->getLastArg(options::OPT_ccc_install_dir)) diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index 2ae23aec8e..5dd6fa1eac 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -6590,12 +6590,14 @@ void visualstudio::Link::ConstructJob(Compilation &C, const JobAction &JA, CmdArgs.push_back("-nologo"); Args.AddAllArgValues(CmdArgs, options::OPT_l); + Args.AddAllArgValues(CmdArgs, options::OPT__SLASH_link); // Add filenames immediately. for (InputInfoList::const_iterator it = Inputs.begin(), ie = Inputs.end(); it != ie; ++it) { if (it->isFilename()) CmdArgs.push_back(it->getFilename()); + // FIXME: Forward -Wl, etc. } const char *Exec = diff --git a/test/Driver/cl-link.c b/test/Driver/cl-link.c new file mode 100644 index 0000000000..6de089ba0c --- /dev/null +++ b/test/Driver/cl-link.c @@ -0,0 +1,12 @@ +// Don't attempt slash switches on msys bash. +// REQUIRES: shell-preserves-root + +// Note: %s must be preceded by -- or bound to another option, otherwise it may +// be interpreted as a command-line option, e.g. on Mac where %s is commonly +// under /Users. + +// RUN: %clang_cl /Tc%s -### /link foo bar baz 2>&1 | FileCheck %s +// CHECK: link.exe +// CHECK: "foo" +// CHECK: "bar" +// CHECK: "baz"