<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Wed, Nov 19, 2014 at 5:24 PM, Nico Weber <span dir="ltr"><<a href="mailto:thakis@chromium.org" target="_blank">thakis@chromium.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr">Nice!<div><br></div><div>But .svn/entries doesn't seem to be touched when I `svn up` my llvm checkout.</div></div></blockquote><div><br></div><div>(sorry, I tried to paste the following but triggered "send message" somehow.)</div><div><br></div><div><div>llvm-rw$ ls -l .svn/entries </div><div>-rw-r--r-- 1 thakis staff 3 Dec 28 2013 .svn/entries</div></div><div><br></div><div>This I tried `svn up` with various revisions close to trunk, which didn't update this timestamp (…and hence, `ninja clang-format` didn't build anything.)</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div class=""><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Nov 19, 2014 at 2:03 PM, Jordan Rose <span dir="ltr"><<a href="mailto:jordan_rose@apple.com" target="_blank">jordan_rose@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">Author: jrose<br>
Date: Wed Nov 19 16:03:48 2014<br>
New Revision: 222393<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=222393&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=222393&view=rev</a><br>
Log:<br>
[CMake] Always include the Clang repo version, just like the autoconf build.<br>
<br>
Now that LLVM's helper script GetSVN.cmake actually works consistently,<br>
there's no reason not to use it. We avoid having to regenerate SVNVersion.inc<br>
every time by marking it as dependent on Git's reflog or SVN's entries file.<br>
<br>
This should end most of the issues of the AST format changing and breaking<br>
old module files: CMake-Clang should now detect that the version changed just<br>
like Autoconf-Clang has.<br>
<br>
Based on r190557. Depends on LLVM r222391.<br>
<br>
Modified:<br>
cfe/trunk/lib/Basic/CMakeLists.txt<br>
<br>
Modified: cfe/trunk/lib/Basic/CMakeLists.txt<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Basic/CMakeLists.txt?rev=222393&r1=222392&r2=222393&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Basic/CMakeLists.txt?rev=222393&r1=222392&r2=222393&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/lib/Basic/CMakeLists.txt (original)<br>
+++ cfe/trunk/lib/Basic/CMakeLists.txt Wed Nov 19 16:03:48 2014<br>
@@ -4,6 +4,48 @@ set(LLVM_LINK_COMPONENTS<br>
Support<br>
)<br>
<br>
+# Figure out if we can track VC revisions.<br>
+function(find_first_existing_file out_var)<br>
+ foreach(file ${ARGN})<br>
+ if(EXISTS "${file}")<br>
+ set(${out_var} "${file}" PARENT_SCOPE)<br>
+ return()<br>
+ endif()<br>
+ endforeach()<br>
+endfunction()<br>
+<br>
+find_first_existing_file(llvm_vc<br>
+ "${LLVM_MAIN_SRC_DIR}/.git/logs/HEAD"<br>
+ "${LLVM_MAIN_SRC_DIR}/.svn/entries")<br>
+find_first_existing_file(clang_vc<br>
+ "${CLANG_SOURCE_DIR}/.git/logs/HEAD"<br>
+ "${CLANG_SOURCE_DIR}/.svn/entries")<br>
+<br>
+if(DEFINED llvm_vc AND DEFINED clang_vc)<br>
+ # Create custom target to generate the VC revision include.<br>
+ add_custom_command(OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/SVNVersion.inc"<br>
+ DEPENDS "${llvm_vc}" "${clang_vc}"<br>
+ COMMAND<br>
+ ${CMAKE_COMMAND} "-DFIRST_SOURCE_DIR=${LLVM_MAIN_SRC_DIR}"<br>
+ "-DFIRST_NAME=LLVM"<br>
+ "-DSECOND_SOURCE_DIR=${CLANG_SOURCE_DIR}"<br>
+ "-DSECOND_NAME=SVN"<br>
+ "-DHEADER_FILE=${CMAKE_CURRENT_BINARY_DIR}/SVNVersion.inc"<br>
+ -P "${LLVM_MAIN_SRC_DIR}/cmake/modules/GetSVN.cmake")<br>
+<br>
+ # Mark the generated header as being generated.<br>
+ set_source_files_properties("${CMAKE_CURRENT_BINARY_DIR}/SVNVersion.inc"<br>
+ PROPERTIES GENERATED TRUE<br>
+ HEADER_FILE_ONLY TRUE)<br>
+<br>
+ # Tell Version.cpp that it needs to build with -DHAVE_SVN_VERSION_INC.<br>
+ set_source_files_properties(Version.cpp<br>
+ PROPERTIES COMPILE_DEFINITIONS "HAVE_SVN_VERSION_INC")<br>
+ set(version_inc "${CMAKE_CURRENT_BINARY_DIR}/SVNVersion.inc")<br>
+else()<br>
+ set(version_inc)<br>
+endif()<br>
+<br>
add_clang_library(clangBasic<br>
Attributes.cpp<br>
Builtins.cpp<br>
@@ -29,30 +71,6 @@ add_clang_library(clangBasic<br>
VersionTuple.cpp<br>
VirtualFileSystem.cpp<br>
Warnings.cpp<br>
+ ${version_inc}<br>
)<br>
<br>
-# Determine Subversion revision.<br>
-# FIXME: This only gets updated when CMake is run, so this revision number<br>
-# may be out-of-date!<br>
-if( NOT IS_SYMLINK "${CLANG_SOURCE_DIR}" ) # See PR 8437<br>
- find_package(Subversion)<br>
-endif()<br>
-if (Subversion_FOUND AND EXISTS "${CLANG_SOURCE_DIR}/.svn")<br>
- set(FIRST_SOURCE_DIR ${LLVM_MAIN_SRC_DIR})<br>
- set(FIRST_REPOSITORY LLVM_REPOSITORY)<br>
- set(SECOND_SOURCE_DIR ${CLANG_SOURCE_DIR})<br>
- set(SECOND_REPOSITORY SVN_REPOSITORY)<br>
- set(HEADER_FILE ${CMAKE_CURRENT_BINARY_DIR}/SVNVersion.inc)<br>
- include(GetSVN)<br>
-<br>
- # Mark the generated header as being generated.<br>
- message(STATUS "Expecting header to go in ${CMAKE_CURRENT_BINARY_DIR}/SVNVersion.inc")<br>
- set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/SVNVersion.inc<br>
- PROPERTIES GENERATED TRUE<br>
- HEADER_FILE_ONLY TRUE)<br>
-<br>
- # Tell Version.cpp that it needs to build with -DHAVE_SVN_VERSION_INC.<br>
- set_source_files_properties(Version.cpp<br>
- PROPERTIES COMPILE_DEFINITIONS "HAVE_SVN_VERSION_INC")<br>
-<br>
-endif()<br>
<br>
<br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
</blockquote></div><br></div>
</div></div></blockquote></div><br></div></div>