2013-12-10 03:04:43 +08:00
|
|
|
set(LLVM_LINK_COMPONENTS
|
2014-10-16 08:12:02 +08:00
|
|
|
Core
|
2013-12-10 03:04:43 +08:00
|
|
|
MC
|
|
|
|
Support
|
|
|
|
)
|
2011-02-12 07:46:38 +08:00
|
|
|
|
2014-11-20 06:03:48 +08:00
|
|
|
# Figure out if we can track VC revisions.
|
|
|
|
function(find_first_existing_file out_var)
|
|
|
|
foreach(file ${ARGN})
|
|
|
|
if(EXISTS "${file}")
|
|
|
|
set(${out_var} "${file}" PARENT_SCOPE)
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endfunction()
|
|
|
|
|
2014-11-20 11:57:45 +08:00
|
|
|
macro(find_first_existing_vc_file out_var path)
|
|
|
|
find_first_existing_file(${out_var}
|
|
|
|
"${path}/.git/logs/HEAD" # Git
|
|
|
|
"${path}/.svn/wc.db" # SVN 1.7
|
|
|
|
"${path}/.svn/entries" # SVN 1.6
|
|
|
|
)
|
|
|
|
endmacro()
|
|
|
|
|
|
|
|
find_first_existing_vc_file(llvm_vc "${LLVM_MAIN_SRC_DIR}")
|
|
|
|
find_first_existing_vc_file(clang_vc "${CLANG_SOURCE_DIR}")
|
2014-11-20 06:03:48 +08:00
|
|
|
|
2014-12-06 06:32:49 +08:00
|
|
|
# The VC revision include that we want to generate.
|
|
|
|
set(version_inc "${CMAKE_CURRENT_BINARY_DIR}/SVNVersion.inc")
|
|
|
|
|
2014-12-10 08:03:37 +08:00
|
|
|
set(get_svn_script "${LLVM_MAIN_SRC_DIR}/cmake/modules/GetSVN.cmake")
|
|
|
|
|
2014-11-20 06:03:48 +08:00
|
|
|
if(DEFINED llvm_vc AND DEFINED clang_vc)
|
|
|
|
# Create custom target to generate the VC revision include.
|
2014-12-06 06:32:49 +08:00
|
|
|
add_custom_command(OUTPUT "${version_inc}"
|
2014-12-10 08:03:37 +08:00
|
|
|
DEPENDS "${llvm_vc}" "${clang_vc}" "${get_svn_script}"
|
2014-11-20 06:03:48 +08:00
|
|
|
COMMAND
|
|
|
|
${CMAKE_COMMAND} "-DFIRST_SOURCE_DIR=${LLVM_MAIN_SRC_DIR}"
|
|
|
|
"-DFIRST_NAME=LLVM"
|
|
|
|
"-DSECOND_SOURCE_DIR=${CLANG_SOURCE_DIR}"
|
2014-12-11 07:49:03 +08:00
|
|
|
"-DSECOND_NAME=SVN"
|
2014-12-06 06:32:49 +08:00
|
|
|
"-DHEADER_FILE=${version_inc}"
|
2014-12-10 08:03:37 +08:00
|
|
|
-P "${get_svn_script}")
|
2014-11-20 06:03:48 +08:00
|
|
|
|
|
|
|
# Mark the generated header as being generated.
|
2014-12-06 06:32:49 +08:00
|
|
|
set_source_files_properties("${version_inc}"
|
2014-11-20 06:03:48 +08:00
|
|
|
PROPERTIES GENERATED TRUE
|
|
|
|
HEADER_FILE_ONLY TRUE)
|
|
|
|
|
|
|
|
# Tell Version.cpp that it needs to build with -DHAVE_SVN_VERSION_INC.
|
|
|
|
set_source_files_properties(Version.cpp
|
|
|
|
PROPERTIES COMPILE_DEFINITIONS "HAVE_SVN_VERSION_INC")
|
|
|
|
else()
|
2014-12-06 06:32:49 +08:00
|
|
|
# Not producing a VC revision include.
|
2014-11-20 06:03:48 +08:00
|
|
|
set(version_inc)
|
|
|
|
endif()
|
|
|
|
|
2008-10-26 08:56:18 +08:00
|
|
|
add_clang_library(clangBasic
|
2014-03-31 21:14:44 +08:00
|
|
|
Attributes.cpp
|
2009-06-14 09:05:48 +08:00
|
|
|
Builtins.cpp
|
2013-02-09 06:30:22 +08:00
|
|
|
CharInfo.cpp
|
2008-10-26 08:56:18 +08:00
|
|
|
Diagnostic.cpp
|
2010-11-19 05:19:52 +08:00
|
|
|
DiagnosticIDs.cpp
|
2008-10-26 08:56:18 +08:00
|
|
|
FileManager.cpp
|
2010-11-24 03:19:34 +08:00
|
|
|
FileSystemStatCache.cpp
|
2008-10-26 08:56:18 +08:00
|
|
|
IdentifierTable.cpp
|
2011-09-14 01:21:33 +08:00
|
|
|
LangOptions.cpp
|
2011-12-01 07:21:26 +08:00
|
|
|
Module.cpp
|
2012-06-20 14:18:46 +08:00
|
|
|
ObjCRuntime.cpp
|
2013-03-22 14:34:35 +08:00
|
|
|
OpenMPKinds.cpp
|
2012-12-21 04:25:19 +08:00
|
|
|
OperatorPrecedence.cpp
|
2014-10-16 03:57:45 +08:00
|
|
|
SanitizerBlacklist.cpp
|
2014-11-11 09:26:14 +08:00
|
|
|
Sanitizers.cpp
|
2008-10-26 08:56:18 +08:00
|
|
|
SourceLocation.cpp
|
|
|
|
SourceManager.cpp
|
|
|
|
TargetInfo.cpp
|
|
|
|
Targets.cpp
|
|
|
|
TokenKinds.cpp
|
2009-10-06 04:33:49 +08:00
|
|
|
Version.cpp
|
Implement a new 'availability' attribute, that allows one to specify
which versions of an OS provide a certain facility. For example,
void foo()
__attribute__((availability(macosx,introduced=10.2,deprecated=10.4,obsoleted=10.6)));
says that the function "foo" was introduced in 10.2, deprecated in
10.4, and completely obsoleted in 10.6. This attribute ties in with
the deployment targets (e.g., -mmacosx-version-min=10.1 specifies that
we want to deploy back to Mac OS X 10.1). There are several concrete
behaviors that this attribute enables, as illustrated with the
function foo() above:
- If we choose a deployment target >= Mac OS X 10.4, uses of "foo"
will result in a deprecation warning, as if we had placed
attribute((deprecated)) on it (but with a better diagnostic)
- If we choose a deployment target >= Mac OS X 10.6, uses of "foo"
will result in an "unavailable" warning (in C)/error (in C++), as
if we had placed attribute((unavailable)) on it
- If we choose a deployment target prior to 10.2, foo() is
weak-imported (if it is a kind of entity that can be weak
imported), as if we had placed the weak_import attribute on it.
Naturally, there can be multiple availability attributes on a
declaration, for different platforms; only the current platform
matters when checking availability attributes.
The only platforms this attribute currently works for are "ios" and
"macosx", since we already have -mxxxx-version-min flags for them and we
have experience there with macro tricks translating down to the
deprecated/unavailable/weak_import attributes. The end goal is to open
this up to other platforms, and even extension to other "platforms"
that are really libraries (say, through a #pragma clang
define_system), but that hasn't yet been designed and we may want to
shake out more issues with this narrower problem first.
Addresses <rdar://problem/6690412>.
As a drive-by bug-fix, if an entity is both deprecated and
unavailable, we only emit the "unavailable" diagnostic.
llvm-svn: 128127
2011-03-23 08:50:03 +08:00
|
|
|
VersionTuple.cpp
|
2014-02-21 05:59:23 +08:00
|
|
|
VirtualFileSystem.cpp
|
2014-04-30 00:25:26 +08:00
|
|
|
Warnings.cpp
|
2014-11-20 06:03:48 +08:00
|
|
|
${version_inc}
|
2008-10-26 08:56:18 +08:00
|
|
|
)
|
2009-03-17 07:06:59 +08:00
|
|
|
|