From aba16223d5f5b6fb702fef5aabd6589d8d6d06f2 Mon Sep 17 00:00:00 2001 From: Thorsten42 Date: Wed, 20 Sep 2023 21:43:34 +0200 Subject: [PATCH] Adjust ExtractResources script to be POSIX-compliant again Also set CMAKE to copy the extraction scripts over with the executable flag set on Linux. Co-authored-by: Dwyriel --- contrib/extractor_scripts/ExtractResources.sh | 18 +++++++++++------- contrib/mmap/CMakeLists.txt | 2 +- .../vmap_extractor/vmapextract/CMakeLists.txt | 2 +- 3 files changed, 13 insertions(+), 9 deletions(-) diff --git a/contrib/extractor_scripts/ExtractResources.sh b/contrib/extractor_scripts/ExtractResources.sh index d5522b7ce86..d3a26bbd83d 100755 --- a/contrib/extractor_scripts/ExtractResources.sh +++ b/contrib/extractor_scripts/ExtractResources.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/bin/sh set -e # This file is part of the CMaNGOS Project. See AUTHORS file for Copyright information @@ -144,8 +144,10 @@ then echo "How many CPU threads should be used for extracting mmaps? (leave empty to use all available threads)" read line echo - if [[ ! -z $line ]]; then - if [[ $line =~ ^[1-9+]$ ]]; then + # check string is there + if [ ! -z $line ]; then + # and a number greater 0 + if [ "$(expr "$line" : "^[1-9][0-9]*$")" -gt 0 ]; then NUM_THREAD=$line else echo "Only numbers are allowed!" @@ -252,8 +254,9 @@ if [ "$USE_VMAPS" = "1" ] then echo "$(date): Start extraction of vmaps..." | tee -a $LOG_FILE $PREFIX/vmap_extractor $VMAP_RES $VMAP_OPT_RES | tee -a $DETAIL_LOG_FILE - exit_code="${PIPESTATUS[0]}" - if [[ "$exit_code" -ne "0" ]]; then + # $? has the exit code of the last closed pipeline, vmap_extractor in this case + exit_code="$?" + if [ "$exit_code" -ne "0" ]; then echo "$(date): Extraction of vmaps failed with errors. Aborting extraction. See the log file for more details." exit "$exit_code" fi @@ -264,8 +267,9 @@ then fi echo "$(date): Start assembling of vmaps..." | tee -a $LOG_FILE $PREFIX/vmap_assembler ${OUTPUT_PATH:-.}/Buildings ${OUTPUT_PATH:-.}/vmaps | tee -a $DETAIL_LOG_FILE - exit_code="${PIPESTATUS[0]}" - if [[ "$exit_code" -ne "0" ]]; then + # $? has the exit code of the last closed pipeline, vmap_assembler in this case + exit_code="$?" + if [ "$exit_code" -ne "0" ]; then echo "$(date): Assembling of vmaps failed with errors. Aborting extraction. See the log file for more details." exit "$exit_code" fi diff --git a/contrib/mmap/CMakeLists.txt b/contrib/mmap/CMakeLists.txt index 64cffd33a36..1f7f7f38441 100644 --- a/contrib/mmap/CMakeLists.txt +++ b/contrib/mmap/CMakeLists.txt @@ -125,6 +125,6 @@ if (BUILD_EXTRACTORS) endif() install(TARGETS ${EXECUTABLE_NAME} DESTINATION ${BIN_DIR}/tools) - install(FILES "${CMAKE_SOURCE_DIR}/contrib/extractor_scripts/MoveMapGen.sh" DESTINATION ${BIN_DIR}/tools) + install(PROGRAMS "${CMAKE_SOURCE_DIR}/contrib/extractor_scripts/MoveMapGen.sh" DESTINATION ${BIN_DIR}/tools) install(FILES "${CMAKE_SOURCE_DIR}/contrib/extractor_scripts/offmesh.txt" DESTINATION ${BIN_DIR}/tools) endif() diff --git a/contrib/vmap_extractor/vmapextract/CMakeLists.txt b/contrib/vmap_extractor/vmapextract/CMakeLists.txt index a618d6f36e9..8f81bb17b9b 100644 --- a/contrib/vmap_extractor/vmapextract/CMakeLists.txt +++ b/contrib/vmap_extractor/vmapextract/CMakeLists.txt @@ -37,5 +37,5 @@ if(MSVC) COMMAND ${CMAKE_COMMAND} -E copy_if_different \"${CMAKE_SOURCE_DIR}/contrib/extractor_scripts/ExtractResources.sh\" \"$\") endif() -install(FILES "${CMAKE_SOURCE_DIR}/contrib/extractor_scripts/ExtractResources.sh" DESTINATION ${BIN_DIR}/tools) +install(PROGRAMS "${CMAKE_SOURCE_DIR}/contrib/extractor_scripts/ExtractResources.sh" DESTINATION ${BIN_DIR}/tools) install(TARGETS ${EXECUTABLE_NAME} DESTINATION ${BIN_DIR}/tools)