mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-07-02 19:52:01 +02:00
Merge bitcoin/bitcoin#30796: test: Use std::span and std::string_view for raw data
faecca9a85
test: Use span for raw data (MarcoFalke)fac973647d
test: Use string_view for json_tests (MarcoFalke) Pull request description: The build system converts raw data into a C++ header file for tests. This change modernizes the code to use the convenience wrappers `std::span` and `std::string_view`, so that redundant copies can be avoided. ACKs for top commit: fjahr: re-ACKfaecca9a85
TheCharlatan: ACKfaecca9a85
stickies-v: ACKfaecca9a85
hebasto: ACKfaecca9a85
, I have reviewed the code and the generated headers. Tree-SHA512: 1f4951c54aff11ba27c41fb70f2821bdb79e06ca0abae734b970bd0d64dda9d8cced824a891fd51b3e9d4e5715ee9eb49ed5d369010a45eca7c3bec9f8641235
This commit is contained in:
@ -5,10 +5,10 @@
|
||||
file(READ ${JSON_SOURCE_PATH} hex_content HEX)
|
||||
string(REGEX MATCHALL "([A-Za-z0-9][A-Za-z0-9])" bytes "${hex_content}")
|
||||
|
||||
file(WRITE ${HEADER_PATH} "#include <string>\n")
|
||||
file(WRITE ${HEADER_PATH} "#include <string_view>\n")
|
||||
file(APPEND ${HEADER_PATH} "namespace json_tests{\n")
|
||||
get_filename_component(json_source_basename ${JSON_SOURCE_PATH} NAME_WE)
|
||||
file(APPEND ${HEADER_PATH} "static const std::string ${json_source_basename}{\n")
|
||||
file(APPEND ${HEADER_PATH} "inline constexpr char detail_${json_source_basename}_bytes[]{\n")
|
||||
|
||||
set(i 0)
|
||||
foreach(byte ${bytes})
|
||||
@ -21,4 +21,6 @@ foreach(byte ${bytes})
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
file(APPEND ${HEADER_PATH} "\n};};")
|
||||
file(APPEND ${HEADER_PATH} "\n};\n")
|
||||
file(APPEND ${HEADER_PATH} "inline constexpr std::string_view ${json_source_basename}{std::begin(detail_${json_source_basename}_bytes), std::end(detail_${json_source_basename}_bytes)};")
|
||||
file(APPEND ${HEADER_PATH} "\n}")
|
||||
|
@ -5,18 +5,23 @@
|
||||
file(READ ${RAW_SOURCE_PATH} hex_content HEX)
|
||||
string(REGEX MATCHALL "([A-Za-z0-9][A-Za-z0-9])" bytes "${hex_content}")
|
||||
|
||||
file(WRITE ${HEADER_PATH} "#include <cstddef>\n")
|
||||
file(APPEND ${HEADER_PATH} "#include <span>\n")
|
||||
file(APPEND ${HEADER_PATH} "namespace ${RAW_NAMESPACE} {\n")
|
||||
get_filename_component(raw_source_basename ${RAW_SOURCE_PATH} NAME_WE)
|
||||
file(WRITE ${HEADER_PATH} "static unsigned const char ${raw_source_basename}_raw[] = {\n")
|
||||
file(APPEND ${HEADER_PATH} "inline constexpr std::byte detail_${raw_source_basename}_raw[]{\n")
|
||||
|
||||
set(i 0)
|
||||
foreach(byte ${bytes})
|
||||
math(EXPR i "${i} + 1")
|
||||
math(EXPR remainder "${i} % 8")
|
||||
if(remainder EQUAL 0)
|
||||
file(APPEND ${HEADER_PATH} "0x${byte},\n")
|
||||
file(APPEND ${HEADER_PATH} "std::byte{0x${byte}},\n")
|
||||
else()
|
||||
file(APPEND ${HEADER_PATH} "0x${byte}, ")
|
||||
file(APPEND ${HEADER_PATH} "std::byte{0x${byte}}, ")
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
file(APPEND ${HEADER_PATH} "\n};")
|
||||
file(APPEND ${HEADER_PATH} "\n};\n")
|
||||
file(APPEND ${HEADER_PATH} "inline constexpr std::span ${raw_source_basename}{detail_${raw_source_basename}_raw};\n")
|
||||
file(APPEND ${HEADER_PATH} "}")
|
||||
|
Reference in New Issue
Block a user