mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-03-09 21:57:20 +01:00
cmake: Generate obj/build.h
header
This commit is contained in:
parent
1f0a78edf3
commit
752747fda8
2 changed files with 138 additions and 0 deletions
115
cmake/script/GenerateBuildInfo.cmake
Normal file
115
cmake/script/GenerateBuildInfo.cmake
Normal file
|
@ -0,0 +1,115 @@
|
|||
# Copyright (c) 2023-present The Bitcoin Core developers
|
||||
# Distributed under the MIT software license, see the accompanying
|
||||
# file COPYING or https://opensource.org/license/mit/.
|
||||
|
||||
# This script is a multiplatform port of the share/genbuild.sh shell script.
|
||||
|
||||
macro(fatal_error)
|
||||
message(FATAL_ERROR "\n"
|
||||
"Usage:\n"
|
||||
" cmake -D BUILD_INFO_HEADER_PATH=<path> [-D SOURCE_DIR=<path>] -P ${CMAKE_CURRENT_LIST_FILE}\n"
|
||||
"All specified paths must be absolute ones.\n"
|
||||
)
|
||||
endmacro()
|
||||
|
||||
if(DEFINED BUILD_INFO_HEADER_PATH AND IS_ABSOLUTE "${BUILD_INFO_HEADER_PATH}")
|
||||
if(EXISTS "${BUILD_INFO_HEADER_PATH}")
|
||||
file(STRINGS ${BUILD_INFO_HEADER_PATH} INFO LIMIT_COUNT 1)
|
||||
endif()
|
||||
else()
|
||||
fatal_error()
|
||||
endif()
|
||||
|
||||
if(DEFINED SOURCE_DIR)
|
||||
if(IS_ABSOLUTE "${SOURCE_DIR}" AND IS_DIRECTORY "${SOURCE_DIR}")
|
||||
set(WORKING_DIR ${SOURCE_DIR})
|
||||
else()
|
||||
fatal_error()
|
||||
endif()
|
||||
else()
|
||||
set(WORKING_DIR ${CMAKE_CURRENT_SOURCE_DIR})
|
||||
endif()
|
||||
|
||||
set(GIT_TAG)
|
||||
set(GIT_COMMIT)
|
||||
if(NOT "$ENV{BITCOIN_GENBUILD_NO_GIT}" STREQUAL "1")
|
||||
find_package(Git QUIET)
|
||||
if(Git_FOUND)
|
||||
execute_process(
|
||||
COMMAND ${GIT_EXECUTABLE} rev-parse --is-inside-work-tree
|
||||
WORKING_DIRECTORY ${WORKING_DIR}
|
||||
OUTPUT_VARIABLE IS_INSIDE_WORK_TREE
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_QUIET
|
||||
)
|
||||
if(IS_INSIDE_WORK_TREE)
|
||||
# Clean 'dirty' status of touched files that haven't been modified.
|
||||
execute_process(
|
||||
COMMAND ${GIT_EXECUTABLE} diff
|
||||
WORKING_DIRECTORY ${WORKING_DIR}
|
||||
OUTPUT_QUIET
|
||||
ERROR_QUIET
|
||||
)
|
||||
|
||||
execute_process(
|
||||
COMMAND ${GIT_EXECUTABLE} describe --abbrev=0
|
||||
WORKING_DIRECTORY ${WORKING_DIR}
|
||||
OUTPUT_VARIABLE MOST_RECENT_TAG
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_QUIET
|
||||
)
|
||||
|
||||
execute_process(
|
||||
COMMAND ${GIT_EXECUTABLE} rev-list -1 ${MOST_RECENT_TAG}
|
||||
WORKING_DIRECTORY ${WORKING_DIR}
|
||||
OUTPUT_VARIABLE MOST_RECENT_TAG_COMMIT
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_QUIET
|
||||
)
|
||||
|
||||
execute_process(
|
||||
COMMAND ${GIT_EXECUTABLE} rev-parse HEAD
|
||||
WORKING_DIRECTORY ${WORKING_DIR}
|
||||
OUTPUT_VARIABLE HEAD_COMMIT
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_QUIET
|
||||
)
|
||||
|
||||
execute_process(
|
||||
COMMAND ${GIT_EXECUTABLE} diff-index --quiet HEAD --
|
||||
WORKING_DIRECTORY ${WORKING_DIR}
|
||||
RESULT_VARIABLE IS_DIRTY
|
||||
)
|
||||
|
||||
if(HEAD_COMMIT STREQUAL MOST_RECENT_TAG_COMMIT AND NOT IS_DIRTY)
|
||||
# If latest commit is tagged and not dirty, then use the tag name.
|
||||
set(GIT_TAG ${MOST_RECENT_TAG})
|
||||
else()
|
||||
# Otherwise, generate suffix from git, i.e. string like "0e0a5173fae3-dirty".
|
||||
execute_process(
|
||||
COMMAND ${GIT_EXECUTABLE} rev-parse --short=12 HEAD
|
||||
WORKING_DIRECTORY ${WORKING_DIR}
|
||||
OUTPUT_VARIABLE GIT_COMMIT
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||
ERROR_QUIET
|
||||
)
|
||||
if(IS_DIRTY)
|
||||
string(APPEND GIT_COMMIT "-dirty")
|
||||
endif()
|
||||
endif()
|
||||
endif()
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if(GIT_TAG)
|
||||
set(NEWINFO "#define BUILD_GIT_TAG \"${GIT_TAG}\"")
|
||||
elseif(GIT_COMMIT)
|
||||
set(NEWINFO "#define BUILD_GIT_COMMIT \"${GIT_COMMIT}\"")
|
||||
else()
|
||||
set(NEWINFO "// No build information available")
|
||||
endif()
|
||||
|
||||
# Only update the header if necessary.
|
||||
if(NOT "${INFO}" STREQUAL "${NEWINFO}")
|
||||
file(WRITE ${BUILD_INFO_HEADER_PATH} "${NEWINFO}\n")
|
||||
endif()
|
|
@ -5,6 +5,29 @@
|
|||
configure_file(${PROJECT_SOURCE_DIR}/cmake/bitcoin-config.h.in config/bitcoin-config.h @ONLY)
|
||||
include_directories(${CMAKE_CURRENT_BINARY_DIR} ${CMAKE_CURRENT_SOURCE_DIR})
|
||||
|
||||
# TODO: After the transition from Autotools to CMake, the obj/ subdirectory
|
||||
# could be dropped as its only purpose was to separate a generated header
|
||||
# from source files.
|
||||
add_custom_target(generate_build_info
|
||||
BYPRODUCTS ${PROJECT_BINARY_DIR}/src/obj/build.h
|
||||
COMMAND ${CMAKE_COMMAND} -E make_directory ${PROJECT_BINARY_DIR}/src/obj
|
||||
COMMAND ${CMAKE_COMMAND} -DBUILD_INFO_HEADER_PATH=${PROJECT_BINARY_DIR}/src/obj/build.h -DSOURCE_DIR=${PROJECT_SOURCE_DIR} -P ${PROJECT_SOURCE_DIR}/cmake/script/GenerateBuildInfo.cmake
|
||||
COMMENT "Generating obj/build.h"
|
||||
VERBATIM
|
||||
)
|
||||
add_library(bitcoin_clientversion OBJECT EXCLUDE_FROM_ALL
|
||||
clientversion.cpp
|
||||
)
|
||||
target_compile_definitions(bitcoin_clientversion
|
||||
PRIVATE
|
||||
HAVE_BUILD_INFO
|
||||
)
|
||||
target_link_libraries(bitcoin_clientversion
|
||||
PRIVATE
|
||||
core_interface
|
||||
)
|
||||
add_dependencies(bitcoin_clientversion generate_build_info)
|
||||
|
||||
#=============================
|
||||
# secp256k1 subtree
|
||||
#=============================
|
||||
|
|
Loading…
Add table
Reference in a new issue