llvm-config: Introduce --system-libs to print SYSTEM_LIBS, and deprecate SYSTEM_LIBS in --ldflags.

Although --system-libs is expected to use after --libs, it can be used alone.

  $ bin/llvm-config --ldflags
  -L/path/to/llvm/objroot/lib

  $ bin/llvm-config --libs object
  -lLLVMObject -lLLVMSupport

  $ bin/llvm-config --system-libs
    (Blank line. "all" is assumed but nothing is printed.)
  -lrt -ldl -ltinfo -lpthread -lz

  $ bin/llvm-config --ldflags --libs --system-libs object
  -L/path/to/llvm/objroot/lib
  -lLLVMObject -lLLVMSupport
  -lrt -ldl -ltinfo -lpthread -lz

It is reimplementation of r197380, and workaround for PR3347 and PR8449.

FIXME: Each LLVM component may have its dependent system libs.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@197664 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
NAKAMURA Takumi 2013-12-19 08:46:36 +00:00
parent 722f58c6b3
commit cbce286fb9

View File

@ -147,6 +147,7 @@ Options:\n\
--cflags C compiler flags for files that include LLVM headers.\n\ --cflags C compiler flags for files that include LLVM headers.\n\
--cxxflags C++ compiler flags for files that include LLVM headers.\n\ --cxxflags C++ compiler flags for files that include LLVM headers.\n\
--ldflags Print Linker flags.\n\ --ldflags Print Linker flags.\n\
--system-libs Sytem Libraries needed to link against LLVM components.\n\
--libs Libraries needed to link against LLVM components.\n\ --libs Libraries needed to link against LLVM components.\n\
--libnames Bare library names for in-tree builds.\n\ --libnames Bare library names for in-tree builds.\n\
--libfiles Fully qualified library filenames for makefile depends.\n\ --libfiles Fully qualified library filenames for makefile depends.\n\
@ -172,6 +173,7 @@ std::string GetExecutablePath(const char *Argv0) {
int main(int argc, char **argv) { int main(int argc, char **argv) {
std::vector<StringRef> Components; std::vector<StringRef> Components;
bool PrintLibs = false, PrintLibNames = false, PrintLibFiles = false; bool PrintLibs = false, PrintLibNames = false, PrintLibFiles = false;
bool PrintSystemLibs = false;
bool HasAnyOption = false; bool HasAnyOption = false;
// llvm-config is designed to support being run both from a development tree // llvm-config is designed to support being run both from a development tree
@ -285,8 +287,9 @@ int main(int argc, char **argv) {
} else if (Arg == "--cxxflags") { } else if (Arg == "--cxxflags") {
OS << ActiveIncludeOption << ' ' << LLVM_CXXFLAGS << '\n'; OS << ActiveIncludeOption << ' ' << LLVM_CXXFLAGS << '\n';
} else if (Arg == "--ldflags") { } else if (Arg == "--ldflags") {
OS << "-L" << ActiveLibDir << ' ' << LLVM_LDFLAGS OS << "-L" << ActiveLibDir << ' ' << LLVM_LDFLAGS << '\n';
<< ' ' << LLVM_SYSTEM_LIBS << '\n'; } else if (Arg == "--system-libs") {
PrintSystemLibs = true;
} else if (Arg == "--libs") { } else if (Arg == "--libs") {
PrintLibs = true; PrintLibs = true;
} else if (Arg == "--libnames") { } else if (Arg == "--libnames") {
@ -330,7 +333,7 @@ int main(int argc, char **argv) {
if (!HasAnyOption) if (!HasAnyOption)
usage(); usage();
if (PrintLibs || PrintLibNames || PrintLibFiles) { if (PrintLibs || PrintLibNames || PrintLibFiles || PrintSystemLibs) {
// If no components were specified, default to "all". // If no components were specified, default to "all".
if (Components.empty()) if (Components.empty())
Components.push_back("all"); Components.push_back("all");
@ -361,6 +364,11 @@ int main(int argc, char **argv) {
} }
} }
OS << '\n'; OS << '\n';
// Print SYSTEM_LIBS after --libs.
// FIXME: Each LLVM component may have its dependent system libs.
if (PrintSystemLibs)
OS << LLVM_SYSTEM_LIBS << '\n';
} else if (!Components.empty()) { } else if (!Components.empty()) {
errs() << "llvm-config: error: components given, but unused\n\n"; errs() << "llvm-config: error: components given, but unused\n\n";
usage(); usage();