summaryrefslogtreecommitdiff
path: root/src/base/CMakeLists.txt
diff options
context:
space:
mode:
Diffstat (limited to 'src/base/CMakeLists.txt')
-rw-r--r--src/base/CMakeLists.txt121
1 files changed, 121 insertions, 0 deletions
diff --git a/src/base/CMakeLists.txt b/src/base/CMakeLists.txt
new file mode 100644
index 000000000..532ed475d
--- /dev/null
+++ b/src/base/CMakeLists.txt
@@ -0,0 +1,121 @@
+#-----------------------------------------------------------------------------#
+# Extract info from Git for git_versioninfo.cpp
+
+find_package(Git)
+
+set(GIT_BUILD "false")
+set(GIT_IS_DIRTY "false")
+set(GIT_SHA1 "")
+set(GIT_BRANCH "")
+
+if(GIT_FOUND)
+ # Get current git branch, result is != 0 if this is not a git repository
+ execute_process(
+ COMMAND ${GIT_EXECUTABLE} -C ${PROJECT_SOURCE_DIR} rev-parse --abbrev-ref HEAD
+ RESULT_VARIABLE GIT_RESULT
+ OUTPUT_VARIABLE GIT_BRANCH
+ OUTPUT_STRIP_TRAILING_WHITESPACE
+ )
+ if("${GIT_RESULT}" STREQUAL "0")
+ set(GIT_BUILD "true")
+ # Extract sha1 of HEAD
+ execute_process(
+ COMMAND ${GIT_EXECUTABLE} -C ${PROJECT_SOURCE_DIR} rev-parse HEAD
+ OUTPUT_VARIABLE GIT_SHA1
+ OUTPUT_STRIP_TRAILING_WHITESPACE
+ )
+ # Result is != 0 if worktree is dirty
+ execute_process(
+ COMMAND ${GIT_EXECUTABLE} -C ${PROJECT_SOURCE_DIR} diff --quiet
+ RESULT_VARIABLE GIT_RESULT
+ )
+ if(NOT "${GIT_RESULT}" STREQUAL "0")
+ set(GIT_IS_DIRTY "true")
+ endif()
+ endif()
+endif()
+
+#-----------------------------------------------------------------------------#
+# Generate git_versioninfo.cpp
+
+configure_file(git_versioninfo.cpp.in git_versioninfo.cpp)
+
+libcvc4_add_sources(
+ configuration.cpp
+ configuration.h
+ configuration_private.h
+ cvc4_assert.cpp
+ cvc4_assert.h
+ cvc4_check.cpp
+ cvc4_check.h
+ exception.cpp
+ exception.h
+ listener.cpp
+ listener.h
+ modal_exception.h
+ output.cpp
+ output.h
+)
+
+libcvc4_add_sources(GENERATED git_versioninfo.cpp)
+
+#-----------------------------------------------------------------------------#
+# Generate code for debug/trace tags
+
+set(gentmptags_script ${CMAKE_CURRENT_LIST_DIR}/gentmptags.sh)
+set(gentags_script ${CMAKE_CURRENT_LIST_DIR}/gentags.sh)
+set(genheader_script ${CMAKE_CURRENT_LIST_DIR}/genheader.sh)
+
+file(GLOB_RECURSE source_files
+ ${PROJECT_SOURCE_DIR}/src/*.cpp
+ ${PROJECT_SOURCE_DIR}/src/*.cc
+ ${PROJECT_SOURCE_DIR}/src/*.h
+ ${PROJECT_SOURCE_DIR}/src/*.g)
+string(REPLACE ";" " " source_files_list "${source_files}")
+
+# Note: gen-tags-{debug,trace} are targets since we always want to generate
+# the temporary tag files {Debug,Trace}_tags.tmp in order to check if tags
+# were added/modified/deleted.
+add_custom_target(
+ gen-tags-debug
+ COMMAND
+ ${gentmptags_script} ${CMAKE_CURRENT_LIST_DIR} Debug ${source_files_list}
+ DEPENDS mktags
+)
+
+add_custom_target(
+ gen-tags-trace
+ COMMAND
+ ${gentmptags_script} ${CMAKE_CURRENT_LIST_DIR} Trace ${source_files_list}
+ DEPENDS mktags
+)
+
+add_custom_command(
+ OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/Debug_tags
+ COMMAND ${gentags_script} Debug
+ DEPENDS gen-tags-debug ${CMAKE_CURRENT_BINARY_DIR}/Debug_tags.tmp
+)
+
+add_custom_command(
+ OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/Trace_tags
+ COMMAND ${gentags_script} Trace
+ DEPENDS gen-tags-trace ${CMAKE_CURRENT_BINARY_DIR}/Trace_tags.tmp
+)
+
+add_custom_command(
+ OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/Debug_tags.h
+ COMMAND ${genheader_script} ${CMAKE_CURRENT_LIST_DIR} Debug
+ DEPENDS mktagheaders ${CMAKE_CURRENT_BINARY_DIR}/Debug_tags
+)
+
+add_custom_command(
+ OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/Trace_tags.h
+ COMMAND ${genheader_script} ${CMAKE_CURRENT_LIST_DIR} Trace
+ DEPENDS mktagheaders ${CMAKE_CURRENT_BINARY_DIR}/Trace_tags
+)
+
+add_custom_target(gen-tags
+ DEPENDS
+ ${CMAKE_CURRENT_BINARY_DIR}/Debug_tags.h
+ ${CMAKE_CURRENT_BINARY_DIR}/Trace_tags.h
+)
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback