aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOscar Fuentes <ofv@wanadoo.es>2011-03-13 04:28:29 +0000
committerOscar Fuentes <ofv@wanadoo.es>2011-03-13 04:28:29 +0000
commitd9e9b8f195b6fb2b54342dfa49fee900da67c3a3 (patch)
tree722d8e7b85dd657f9ae0333754e2f4dd5e29f247
parente9cd9c0016f103fd45d41d136d5d1084aa42eb75 (diff)
Reverting "Build libclang as a static library too."
This reverts commit r127556. It breaks the build for MSVC. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@127564 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--tools/libclang/CMakeLists.txt70
1 files changed, 28 insertions, 42 deletions
diff --git a/tools/libclang/CMakeLists.txt b/tools/libclang/CMakeLists.txt
index 128f6314a5..11759eefb6 100644
--- a/tools/libclang/CMakeLists.txt
+++ b/tools/libclang/CMakeLists.txt
@@ -1,3 +1,5 @@
+set(SHARED_LIBRARY TRUE)
+
set(LLVM_USED_LIBS
clangFrontend
clangDriver
@@ -13,7 +15,7 @@ set( LLVM_LINK_COMPONENTS
mc
)
-set(SOURCES
+add_clang_library(libclang
CIndex.cpp
CIndexCXX.cpp
CIndexCodeCompletion.cpp
@@ -25,50 +27,34 @@ set(SOURCES
CXString.cpp
CXType.cpp
../../include/clang-c/Index.h
- )
-
-if( LLVM_ENABLE_PIC AND NOT WIN32 )
- set(SHARED_LIBRARY TRUE)
- add_clang_library(libclang ${SOURCES})
-
- set_target_properties(libclang
- PROPERTIES
- OUTPUT_NAME "clang"
- VERSION ${LIBCLANG_LIBRARY_VERSION}
- DEFINE_SYMBOL _CINDEX_LIB_)
-
- if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
- # Darwin-specific linker flags
+)
- set(LIBCLANG_LINK_FLAGS "-Wl,-compatibility_version -Wl,1")
+if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
+ # Darwin-specific linker flags
- set(LIBCLANG_LINK_FLAGS
+ set(LIBCLANG_LINK_FLAGS "-Wl,-compatibility_version -Wl,1")
+
+ set(LIBCLANG_LINK_FLAGS
"${LIBCLANG_LINK_FLAGS} -Wl,-dead_strip -Wl,-seg1addr -Wl,0xE0000000")
- set_target_properties(libclang
- PROPERTIES
- LINK_FLAGS "${LIBCLANG_LINK_FLAGS}"
- INSTALL_NAME_DIR "@executable_path/../lib")
- endif()
-
- set(LIBCLANG_STATIC_TARGET_NAME libclang_static)
-else()
- set(LIBCLANG_STATIC_TARGET_NAME libclang)
-endif()
-
-if( NOT BUILD_SHARED_LIBS )
- add_clang_library(${LIBCLANG_STATIC_TARGET_NAME} STATIC ${SOURCES})
-
- set_target_properties(${LIBCLANG_STATIC_TARGET_NAME}
+ set_target_properties(libclang
PROPERTIES
- OUTPUT_NAME "clang")
-
- if(MSVC)
- # windows.h doesn't compile with /Za
- get_target_property(NON_ANSI_COMPILE_FLAGS ${LIBCLANG_STATIC_TARGET_NAME}
- COMPILE_FLAGS)
- string(REPLACE /Za "" NON_ANSI_COMPILE_FLAGS ${NON_ANSI_COMPILE_FLAGS})
- set_target_properties(${LIBCLANG_STATIC_TARGET_NAME} PROPERTIES
- COMPILE_FLAGS ${NON_ANSI_COMPILE_FLAGS})
- endif()
+ LINK_FLAGS "${LIBCLANG_LINK_FLAGS}"
+ INSTALL_NAME_DIR "@executable_path/../lib")
endif()
+
+# Versioning information
+set_target_properties(libclang PROPERTIES VERSION ${LIBCLANG_LIBRARY_VERSION})
+
+if(MSVC)
+ # windows.h doesn't compile with /Za
+ get_target_property(NON_ANSI_COMPILE_FLAGS libclang COMPILE_FLAGS)
+ string(REPLACE /Za "" NON_ANSI_COMPILE_FLAGS ${NON_ANSI_COMPILE_FLAGS})
+ set_target_properties(libclang PROPERTIES COMPILE_FLAGS ${NON_ANSI_COMPILE_FLAGS})
+endif(MSVC)
+
+set_target_properties(libclang
+ PROPERTIES
+ PREFIX "" # Otherwise we get liblibclang.so
+ LINKER_LANGUAGE CXX
+ DEFINE_SYMBOL _CINDEX_LIB_)