forked from OSchip/llvm-project
Add extensive tests for the mingw toolchain and remove trailing slash from Arch.
Address Richard Smith comments: remove the trailing seperator from the Arch variable, implement six mingw_* trees under tools/clangtest/Driver/Inputs and merge linux and Windows tests into a universal test that uses these trees. llvm-svn: 243098
This commit is contained in:
parent
e2afb47d1e
commit
327675baa9
|
@ -40,7 +40,7 @@ void MinGW::findGccLibDir() {
|
||||||
if (!EC) {
|
if (!EC) {
|
||||||
GccLibDir = MingwOrgEntry->path();
|
GccLibDir = MingwOrgEntry->path();
|
||||||
// Replace Arch with mingw32 arch.
|
// Replace Arch with mingw32 arch.
|
||||||
Arch = "mingw32//";
|
Arch = "mingw32";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -51,8 +51,7 @@ MinGW::MinGW(const Driver &D, const llvm::Triple &Triple, const ArgList &Args)
|
||||||
getProgramPaths().push_back(getDriver().getInstalledDir());
|
getProgramPaths().push_back(getDriver().getInstalledDir());
|
||||||
|
|
||||||
// Default Arch is mingw-w64.
|
// Default Arch is mingw-w64.
|
||||||
Arch = (getTriple().getArchName() + "-w64-mingw32" +
|
Arch = (getTriple().getArchName() + "-w64-mingw32").str();
|
||||||
llvm::sys::path::get_separator()).str();
|
|
||||||
|
|
||||||
// In Windows there aren't any standard install locations, we search
|
// In Windows there aren't any standard install locations, we search
|
||||||
// for gcc on the PATH. In Linux the base is always /usr.
|
// for gcc on the PATH. In Linux the base is always /usr.
|
||||||
|
@ -66,25 +65,23 @@ MinGW::MinGW(const Driver &D, const llvm::Triple &Triple, const ArgList &Args)
|
||||||
else
|
else
|
||||||
Base = llvm::sys::path::parent_path(getDriver().getInstalledDir());
|
Base = llvm::sys::path::parent_path(getDriver().getInstalledDir());
|
||||||
#else
|
#else
|
||||||
|
if (getDriver().SysRoot.size())
|
||||||
|
Base = getDriver().SysRoot;
|
||||||
|
else
|
||||||
Base = "/usr";
|
Base = "/usr";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Base += llvm::sys::path::get_separator();
|
Base += llvm::sys::path::get_separator();
|
||||||
if (getDriver().SysRoot.size())
|
|
||||||
GccLibDir = getDriver().SysRoot;
|
|
||||||
else
|
|
||||||
findGccLibDir();
|
findGccLibDir();
|
||||||
Ver = llvm::sys::path::filename(GccLibDir);
|
Ver = llvm::sys::path::filename(GccLibDir);
|
||||||
// GccLibDir must precede Base/lib so that the
|
// GccLibDir must precede Base/lib so that the
|
||||||
// correct crtbegin.o ,cetend.o would be found.
|
// correct crtbegin.o ,cetend.o would be found.
|
||||||
getFilePaths().push_back(GccLibDir);
|
getFilePaths().push_back(GccLibDir);
|
||||||
getFilePaths().push_back(Base + Arch + "lib");
|
getFilePaths().push_back(
|
||||||
#ifdef LLVM_ON_WIN32
|
(Base + Arch + llvm::sys::path::get_separator() + "lib").str());
|
||||||
getFilePaths().push_back(Base + "lib");
|
getFilePaths().push_back(Base + "lib");
|
||||||
#else
|
|
||||||
// openSUSE
|
// openSUSE
|
||||||
getFilePaths().push_back(Base + Arch + "sys-root/mingw/lib");
|
getFilePaths().push_back(Base + Arch + "/sys-root/mingw/lib");
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MinGW::IsIntegratedAssemblerDefault() const { return true; }
|
bool MinGW::IsIntegratedAssemblerDefault() const { return true; }
|
||||||
|
@ -197,14 +194,13 @@ void MinGW::AddClangSystemIncludeArgs(const ArgList &DriverArgs,
|
||||||
llvm::sys::path::append(IncludeDir, "include");
|
llvm::sys::path::append(IncludeDir, "include");
|
||||||
addSystemInclude(DriverArgs, CC1Args, IncludeDir.c_str());
|
addSystemInclude(DriverArgs, CC1Args, IncludeDir.c_str());
|
||||||
IncludeDir += "-fixed";
|
IncludeDir += "-fixed";
|
||||||
#ifdef LLVM_ON_UNIX
|
|
||||||
// openSUSE
|
// openSUSE
|
||||||
addSystemInclude(DriverArgs, CC1Args,
|
addSystemInclude(DriverArgs, CC1Args,
|
||||||
"/usr/x86_64-w64-mingw32/sys-root/mingw/include");
|
"/usr/x86_64-w64-mingw32/sys-root/mingw/include");
|
||||||
#endif
|
|
||||||
addSystemInclude(DriverArgs, CC1Args, IncludeDir.c_str());
|
addSystemInclude(DriverArgs, CC1Args, IncludeDir.c_str());
|
||||||
}
|
}
|
||||||
addSystemInclude(DriverArgs, CC1Args, Base + Arch + "include");
|
addSystemInclude(DriverArgs, CC1Args,
|
||||||
|
Base + Arch + llvm::sys::path::get_separator() + "include");
|
||||||
addSystemInclude(DriverArgs, CC1Args, Base + "include");
|
addSystemInclude(DriverArgs, CC1Args, Base + "include");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -216,9 +212,9 @@ void MinGW::AddClangCXXStdlibIncludeArgs(const ArgList &DriverArgs,
|
||||||
|
|
||||||
switch (GetCXXStdlibType(DriverArgs)) {
|
switch (GetCXXStdlibType(DriverArgs)) {
|
||||||
case ToolChain::CST_Libcxx:
|
case ToolChain::CST_Libcxx:
|
||||||
addSystemInclude(DriverArgs, CC1Args, Base + "include" +
|
addSystemInclude(DriverArgs, CC1Args,
|
||||||
llvm::sys::path::get_separator() + "c++" +
|
Base + "include" + llvm::sys::path::get_separator() +
|
||||||
llvm::sys::path::get_separator() + "v1");
|
"c++" + llvm::sys::path::get_separator() + "v1");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ToolChain::CST_Libstdcxx:
|
case ToolChain::CST_Libstdcxx:
|
||||||
|
@ -232,8 +228,8 @@ void MinGW::AddClangCXXStdlibIncludeArgs(const ArgList &DriverArgs,
|
||||||
CppIncludeBases.emplace_back(GccLibDir);
|
CppIncludeBases.emplace_back(GccLibDir);
|
||||||
llvm::sys::path::append(CppIncludeBases[3], "include", "c++");
|
llvm::sys::path::append(CppIncludeBases[3], "include", "c++");
|
||||||
for (auto &CppIncludeBase : CppIncludeBases) {
|
for (auto &CppIncludeBase : CppIncludeBases) {
|
||||||
CppIncludeBase += llvm::sys::path::get_separator();
|
|
||||||
addSystemInclude(DriverArgs, CC1Args, CppIncludeBase);
|
addSystemInclude(DriverArgs, CC1Args, CppIncludeBase);
|
||||||
|
CppIncludeBase += llvm::sys::path::get_separator();
|
||||||
addSystemInclude(DriverArgs, CC1Args, CppIncludeBase + Arch);
|
addSystemInclude(DriverArgs, CC1Args, CppIncludeBase + Arch);
|
||||||
addSystemInclude(DriverArgs, CC1Args, CppIncludeBase + "backward");
|
addSystemInclude(DriverArgs, CC1Args, CppIncludeBase + "backward");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,20 +0,0 @@
|
||||||
// XFAIL: system-windows
|
|
||||||
// RUN: %clang -target x86_64-pc-windows-gnu -c -### --sysroot=/dummy/x86_64-w64-mingw32/5.1.0 %s 2>&1 | FileCheck -check-prefix=CHECK %s
|
|
||||||
|
|
||||||
// CHECK: /usr/x86_64-w64-mingw32/include/c++/
|
|
||||||
// CHECK: /usr/x86_64-w64-mingw32/include/c++/x86_64-w64-mingw32/
|
|
||||||
// CHECK: /usr/x86_64-w64-mingw32/include/c++/backward
|
|
||||||
// CHECK: /usr/x86_64-w64-mingw32/include/c++/5.1.0/
|
|
||||||
// CHECK: /usr/x86_64-w64-mingw32/include/c++/5.1.0/x86_64-w64-mingw32/
|
|
||||||
// CHECK: /usr/x86_64-w64-mingw32/include/c++/5.1.0/backward
|
|
||||||
// CHECK: /usr/include/c++/5.1.0/
|
|
||||||
// CHECK: /usr/include/c++/5.1.0/x86_64-w64-mingw32/
|
|
||||||
// CHECK: /usr/include/c++/5.1.0/backward
|
|
||||||
// CHECK: /dummy/x86_64-w64-mingw32/5.1.0/include/c++/
|
|
||||||
// CHECK: /dummy/x86_64-w64-mingw32/5.1.0/include/c++/x86_64-w64-mingw32/
|
|
||||||
// CHECK: /dummy/x86_64-w64-mingw32/5.1.0/include/c++/backward
|
|
||||||
// CHECK: /dummy/x86_64-w64-mingw32/5.1.0/include
|
|
||||||
// CHECK: /usr/x86_64-w64-mingw32/sys-root/mingw/include
|
|
||||||
// CHECK: /dummy/x86_64-w64-mingw32/5.1.0/include-fixed
|
|
||||||
// CHECK: /usr/x86_64-w64-mingw32/include
|
|
||||||
// CHECK: /usr/include
|
|
|
@ -1,19 +0,0 @@
|
||||||
// REQUIRES: system-windows
|
|
||||||
// RUN: %clang -target i686-pc-windows-gnu -c -### --sysroot=c:\dummy %s 2>&1 | FileCheck -check-prefix=CHECK %s
|
|
||||||
|
|
||||||
// CHECK: c:\\dummy\\i686-w64-mingw32\\include\\c++
|
|
||||||
// CHECK: c:\\dummy\\i686-w64-mingw32\\include\\c++\\i686-w64-mingw32\\
|
|
||||||
// CHECK: c:\\dummy\\i686-w64-mingw32\\include\\c++\\backward
|
|
||||||
// CHECK: c:\\dummy\\i686-w64-mingw32\\include\\c++\\dummy\\
|
|
||||||
// CHECK: c:\\dummy\\i686-w64-mingw32\\include\\c++\\dummy\\i686-w64-mingw32\\
|
|
||||||
// CHECK: c:\\dummy\\i686-w64-mingw32\\include\\c++\\dummy\\backward
|
|
||||||
// CHECK: c:\\dummy\\include\\c++\\dummy\\
|
|
||||||
// CHECK: c:\\dummy\\include\\c++\\dummy\\i686-w64-mingw32\\
|
|
||||||
// CHECK: c:\\dummy\\include\\c++\\dummy\\backward
|
|
||||||
// CHECK: c:\\dummy\\include\\c++\\
|
|
||||||
// CHECK: c:\\dummy\\include\\c++\\i686-w64-mingw32\\
|
|
||||||
// CHECK: c:\\dummy\\include\\c++\\backward
|
|
||||||
// CHECK: c:\\dummy\\include
|
|
||||||
// CHECK: c:\\dummy\\include-fixed
|
|
||||||
// CHECK: c:\\dummy\\i686-w64-mingw32\\include
|
|
||||||
// CHECK: c:\\dummy\\include
|
|
|
@ -0,0 +1,54 @@
|
||||||
|
// RUN: %clang -target i686-pc-windows-gnu -c -### --sysroot=%S/Inputs/mingw_mingw_org_tree/mingw %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_ORG_TREE %s
|
||||||
|
// CHECK_MINGW_ORG_TREE: "{{.*}}/Inputs/mingw_mingw_org_tree/mingw{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}mingw32{{/|\\\\}}4.8.1{{/|\\\\}}include{{/|\\\\}}c++"
|
||||||
|
// CHECK_MINGW_ORG_TREE: "{{.*}}/Inputs/mingw_mingw_org_tree/mingw{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}mingw32{{/|\\\\}}4.8.1{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}mingw32"
|
||||||
|
// CHECK_MINGW_ORG_TREE: "{{.*}}{{/|\\\\}}Inputs/mingw_mingw_org_tree/mingw{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}mingw32{{/|\\\\}}4.8.1{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}backward"
|
||||||
|
// CHECK_MINGW_ORG_TREE: "{{.*}}/Inputs/mingw_mingw_org_tree/mingw{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}mingw32{{/|\\\\}}4.8.1{{/|\\\\}}include"
|
||||||
|
// CHECK_MINGW_ORG_TREE: "{{.*}}/Inputs/mingw_mingw_org_tree/mingw{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}mingw32{{/|\\\\}}4.8.1{{/|\\\\}}include-fixed"
|
||||||
|
// CHECK_MINGW_ORG_TREE: "{{.*}}/Inputs/mingw_mingw_org_tree/mingw{{/|\\\\}}mingw32{{/|\\\\}}include"
|
||||||
|
// CHECK_MINGW_ORG_TREE: {{.*}}/Inputs/mingw_mingw_org_tree/mingw{{/|\\\\}}include
|
||||||
|
|
||||||
|
|
||||||
|
// RUN: %clang -target i686-pc-windows-gnu -c -### --sysroot=%S/Inputs/mingw_mingw_builds_tree/mingw32 %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_BUILDS_TREE %s
|
||||||
|
// CHECK_MINGW_BUILDS_TREE: "{{.*}}/Inputs/mingw_mingw_builds_tree/mingw32{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include{{/|\\\\}}c++"
|
||||||
|
// CHECK_MINGW_BUILDS_TREE: "{{.*}}/Inputs/mingw_mingw_builds_tree/mingw32{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}i686-w64-mingw32"
|
||||||
|
// CHECK_MINGW_BUILDS_TREE: "{{.*}}/Inputs/mingw_mingw_builds_tree/mingw32{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}backward"
|
||||||
|
// CHECK_MINGW_BUILDS_TREE: "{{.*}}/Inputs/mingw_mingw_builds_tree/mingw32{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}4.9.1{{/|\\\\}}include"
|
||||||
|
// CHECK_MINGW_BUILDS_TREE: "{{.*}}/Inputs/mingw_mingw_builds_tree/mingw32{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}4.9.1{{/|\\\\}}include-fixed"
|
||||||
|
// CHECK_MINGW_BUILDS_TREE: "{{.*}}/Inputs/mingw_mingw_builds_tree/mingw32{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include"
|
||||||
|
|
||||||
|
|
||||||
|
// RUN: %clang -target i686-pc-windows-gnu -c -### --sysroot=%S/Inputs/mingw_msys2_tree/msys64/mingw32 %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_MSYS_TREE %s
|
||||||
|
// CHECK_MINGW_MSYS_TREE: "{{.*}}/Inputs/mingw_msys2_tree/msys64{{/|\\\\}}mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}4.9.2"
|
||||||
|
// CHECK_MINGW_MSYS_TREE: "{{.*}}/Inputs/mingw_msys2_tree/msys64/mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}4.9.2{{/|\\\\}}i686-w64-mingw32"
|
||||||
|
// CHECK_MINGW_MSYS_TREE: "{{.*}}/Inputs/mingw_msys2_tree/msys64/mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}4.9.2{{/|\\\\}}backward"
|
||||||
|
// CHECK_MINGW_MSYS_TREE: "{{.*}}/Inputs/mingw_msys2_tree/msys64/mingw32{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}4.9.2{{/|\\\\}}include"
|
||||||
|
// CHECK_MINGW_MSYS_TREE: "{{.*}}/Inputs/mingw_msys2_tree/msys64/mingw32{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}4.9.2{{/|\\\\}}include-fixed"
|
||||||
|
// CHECK_MINGW_MSYS_TREE: "{{.*}}/Inputs/mingw_msys2_tree/msys64/mingw32{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include"
|
||||||
|
// CHECK_MINGW_MSYS_TREE: "{{.*}}/Inputs/mingw_msys2_tree/msys64/mingw32{{/|\\\\}}include"
|
||||||
|
|
||||||
|
|
||||||
|
// RUN: %clang -target x86_64-pc-windows-gnu -c -### --sysroot=%S/Inputs/mingw_opensuse_tree/usr %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_OPENSUSE_TREE %s
|
||||||
|
// CHECK_MINGW_OPENSUSE_TREE: "{{.*}}/Inputs/mingw_opensuse_tree/usr{{/|\\\\}}lib64{{/|\\\\}}gcc{{/|\\\\}}x86_64-w64-mingw32{{/|\\\\}}5.1.0{{/|\\\\}}include{{/|\\\\}}c++"
|
||||||
|
// CHECK_MINGW_OPENSUSE_TREE: "{{.*}}/Inputs/mingw_opensuse_tree/usr{{/|\\\\}}lib64{{/|\\\\}}gcc{{/|\\\\}}x86_64-w64-mingw32{{/|\\\\}}5.1.0{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}x86_64-w64-mingw32"
|
||||||
|
// CHECK_MINGW_OPENSUSE_TREE: "{{.*}}/Inputs/mingw_opensuse_tree/usr{{/|\\\\}}lib64{{/|\\\\}}gcc{{/|\\\\}}x86_64-w64-mingw32{{/|\\\\}}5.1.0{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}backward"
|
||||||
|
// CHECK_MINGW_OPENSUSE_TREE: "{{.*}}/Inputs/mingw_opensuse_tree/usr{{/|\\\\}}lib64{{/|\\\\}}gcc{{/|\\\\}}x86_64-w64-mingw32{{/|\\\\}}5.1.0{{/|\\\\}}include"
|
||||||
|
// CHECK_MINGW_OPENSUSE_TREE: "/usr/x86_64-w64-mingw32/sys-root/mingw/include"
|
||||||
|
// CHECK_MINGW_OPENSUSE_TREE: "{{.*}}/Inputs/mingw_opensuse_tree/usr{{/|\\\\}}lib64{{/|\\\\}}gcc{{/|\\\\}}x86_64-w64-mingw32{{/|\\\\}}5.1.0{{/|\\\\}}include-fixed"
|
||||||
|
|
||||||
|
|
||||||
|
// RUN: %clang -target i686-pc-windows-gnu -c -### --sysroot=%S/Inputs/mingw_arch_tree/usr %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_ARCH_TREE %s
|
||||||
|
// CHECK_MINGW_ARCH_TREE: "{{.*}}/Inputs/mingw_arch_tree/usr{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}5.1.0"
|
||||||
|
// CHECK_MINGW_ARCH_TREE: "{{.*}}/Inputs/mingw_arch_tree/usr{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}5.1.0{{/|\\\\}}i686-w64-mingw32"
|
||||||
|
// CHECK_MINGW_ARCH_TREE: "{{.*}}/Inputs/mingw_arch_tree/usr{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}5.1.0{{/|\\\\}}backward"
|
||||||
|
// CHECK_MINGW_ARCH_TREE: "{{.*}}/Inputs/mingw_arch_tree/usr{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}5.1.0{{/|\\\\}}include"
|
||||||
|
// CHECK_MINGW_ARCH_TREE: "{{.*}}/Inputs/mingw_arch_tree/usr{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}5.1.0{{/|\\\\}}include-fixed"
|
||||||
|
// CHECK_MINGW_ARCH_TREE: "{{.*}}/Inputs/mingw_arch_tree/usr{{/|\\\\}}i686-w64-mingw32{{/|\\\\}}include"
|
||||||
|
|
||||||
|
|
||||||
|
// RUN: %clang -target x86_64-pc-windows-gnu -c -### --sysroot=%S/Inputs/mingw_ubuntu_tree/usr %s 2>&1 | FileCheck -check-prefix=CHECK_MINGW_UBUNTU_TREE %s
|
||||||
|
// CHECK_MINGW_UBUNTU_TREE: "{{.*}}/Inputs/mingw_ubuntu_tree/usr{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}4.8"
|
||||||
|
// CHECK_MINGW_UBUNTU_TREE: "{{.*}}/Inputs/mingw_ubuntu_tree/usr{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}4.8{{/|\\\\}}x86_64-w64-mingw32"
|
||||||
|
// CHECK_MINGW_UBUNTU_TREE: "{{.*}}/Inputs/mingw_ubuntu_tree/usr{{/|\\\\}}include{{/|\\\\}}c++{{/|\\\\}}4.8{{/|\\\\}}backward"
|
||||||
|
// CHECK_MINGW_UBUNTU_TREE: "{{.*}}/Inputs/mingw_ubuntu_tree/usr{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}x86_64-w64-mingw32{{/|\\\\}}4.8{{/|\\\\}}include"
|
||||||
|
// CHECK_MINGW_UBUNTU_TREE: "{{.*}}/Inputs/mingw_ubuntu_tree/usr{{/|\\\\}}lib{{/|\\\\}}gcc{{/|\\\\}}x86_64-w64-mingw32{{/|\\\\}}4.8{{/|\\\\}}include-fixed"
|
||||||
|
// CHECK_MINGW_UBUNTU_TREE: "{{.*}}/Inputs/mingw_ubuntu_tree/usr{{/|\\\\}}x86_64-w64-mingw32{{/|\\\\}}include"
|
Loading…
Reference in New Issue