forked from OSchip/llvm-project
llvm-config: fix --libs on Linux
Summary: llvm-config --libs does not produce correct output since commit r260263 (llvm-config: Add preliminary Windows support) changed naming format of the libraries. This patch updates llvm-config to recognize new naming format and output correct linker flags. Ref: https://llvm.org/bugs/show_bug.cgi?id=26581 Patch by Vedran Miletić Reviewers: ehsan, rnk, pxli168 Subscribers: pxli168 Differential Revision: http://reviews.llvm.org/D17300 llvm-svn: 263497
This commit is contained in:
parent
64bd8df458
commit
ecb4090716
|
@ -645,17 +645,19 @@ int main(int argc, char **argv) {
|
||||||
} else if (PrintLibFiles) {
|
} else if (PrintLibFiles) {
|
||||||
OS << GetComponentLibraryPath(Lib, Shared);
|
OS << GetComponentLibraryPath(Lib, Shared);
|
||||||
} else if (PrintLibs) {
|
} else if (PrintLibs) {
|
||||||
// If this is a typical library name, include it using -l.
|
// On Windows, output full path to library without parameters.
|
||||||
StringRef LibName;
|
// Elsewhere, if this is a typical library name, include it using -l.
|
||||||
if (Lib.startswith("lib")) {
|
if (HostTriple.isWindowsMSVCEnvironment()) {
|
||||||
|
OS << GetComponentLibraryPath(Lib, Shared);
|
||||||
|
} else {
|
||||||
|
StringRef LibName;
|
||||||
if (GetComponentLibraryNameSlice(Lib, LibName)) {
|
if (GetComponentLibraryNameSlice(Lib, LibName)) {
|
||||||
|
// Extract library name (remove prefix and suffix).
|
||||||
OS << "-l" << LibName;
|
OS << "-l" << LibName;
|
||||||
} else {
|
} else {
|
||||||
OS << "-l:" << GetComponentLibraryFileName(Lib, Shared);
|
// Lib is already a library name without prefix and suffix.
|
||||||
|
OS << "-l" << Lib;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
// Otherwise, print the full path.
|
|
||||||
OS << GetComponentLibraryPath(Lib, Shared);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue