diff options
author | lat9nq <22451773+lat9nq@users.noreply.github.com> | 2023-06-03 19:18:51 +0200 |
---|---|---|
committer | lat9nq <22451773+lat9nq@users.noreply.github.com> | 2023-06-05 21:15:22 +0200 |
commit | 73036c83a3805e5a0460cd5871743c88fe9405a5 (patch) | |
tree | c2f6e12af6ddeb38fd06f8549517a30ed0b4c7b7 /externals/nx_tzdb/CMakeLists.txt | |
parent | time: Implement missing services (diff) | |
download | yuzu-73036c83a3805e5a0460cd5871743c88fe9405a5.tar yuzu-73036c83a3805e5a0460cd5871743c88fe9405a5.tar.gz yuzu-73036c83a3805e5a0460cd5871743c88fe9405a5.tar.bz2 yuzu-73036c83a3805e5a0460cd5871743c88fe9405a5.tar.lz yuzu-73036c83a3805e5a0460cd5871743c88fe9405a5.tar.xz yuzu-73036c83a3805e5a0460cd5871743c88fe9405a5.tar.zst yuzu-73036c83a3805e5a0460cd5871743c88fe9405a5.zip |
Diffstat (limited to '')
-rw-r--r-- | externals/nx_tzdb/CMakeLists.txt | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/externals/nx_tzdb/CMakeLists.txt b/externals/nx_tzdb/CMakeLists.txt new file mode 100644 index 000000000..2f625c108 --- /dev/null +++ b/externals/nx_tzdb/CMakeLists.txt @@ -0,0 +1,65 @@ +# SPDX-FileCopyrightText: 2023 yuzu Emulator Project +# SPDX-License-Identifier: GPL-2.0-or-later + +set(NX_TZDB_VERSION "220816") +set(NX_TZDB_DOWNLOAD_URL "https://github.com/lat9nq/tzdb_to_nx/releases/download/${NX_TZDB_VERSION}/${NX_TZDB_VERSION}.zip") + +set(NX_TZDB_ARCHIVE "${CMAKE_CURRENT_BINARY_DIR}/${NX_TZDB_VERSION}.zip") +set(NX_TZDB_DIR "${CMAKE_CURRENT_BINARY_DIR}/nx_tzdb") + +set(NX_TZDB_INCLUDE_DIR "${CMAKE_CURRENT_BINARY_DIR}/include") + +if (NOT EXISTS ${NX_TZDB_ARCHIVE}) + file(DOWNLOAD ${NX_TZDB_DOWNLOAD_URL} ${NX_TZDB_ARCHIVE}) + file(ARCHIVE_EXTRACT + INPUT + ${NX_TZDB_ARCHIVE} + DESTINATION + ${NX_TZDB_DIR}) +endif() + +add_library(nx_tzdb INTERFACE) +target_include_directories(nx_tzdb + INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}/include + INTERFACE ${NX_TZDB_INCLUDE_DIR}) + +function(CreateHeader ZONE_PATH HEADER_NAME) + set(HEADER_PATH "${NX_TZDB_INCLUDE_DIR}/nx_tzdb/${HEADER_NAME}.h") + add_custom_command( + OUTPUT + ${NX_TZDB_INCLUDE_DIR}/nx_tzdb/${HEADER_NAME}.h + COMMAND + ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_SOURCE_DIR}/NxTzdbCreateHeader.cmake + ${ZONE_PATH} + ${HEADER_NAME} + ${NX_TZDB_INCLUDE_DIR} + ${CMAKE_CURRENT_SOURCE_DIR} + DEPENDS + tzdb_template.h.in + NxTzdbCreateHeader.cmake) + + target_sources(nx_tzdb PRIVATE ${HEADER_PATH}) +endfunction() + +CreateHeader(${NX_TZDB_DIR} base) +CreateHeader(${NX_TZDB_DIR}/zoneinfo zoneinfo) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Africa africa) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/America america) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/America/Argentina america_argentina) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/America/Indiana america_indiana) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/America/Kentucky america_kentucky) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/America/North_Dakota america_north_dakota) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Antartica antartica) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Arctic arctic) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Asia asia) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Atlantic atlantic) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Australia australia) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Brazil brazil) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Canada canada) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Chile chile) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Etc etc) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Europe europe) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Indian indian) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Mexico mexico) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/Pacific pacific) +CreateHeader(${NX_TZDB_DIR}/zoneinfo/US us) |