#!/usr/bin/env bash set -e # --- Defaults --- userFlag=0 testsFlag=0 runTestsFlag=0 buildDir="build" installDir="$HOME/.local/4DSSE" # --- Help Menu --- show_help() { cat <> "$LOGFILE" } if [[ -f "$LOGFILE" ]]; then # Get the calendar datetime of the log file creation. # convert UNIX timestamp to human-readable date rm "$LOGFILE" log "${BLUE}[Info] Old log file removed.${NC}" fi touch "$LOGFILE" # --- Check if Clang or GCC is installed --- log "${BLUE}[Info] Checking if Clang or GCC is installed...${NC}" if ! command -v clang &> /dev/null && ! command -v gcc &> /dev/null; then log "${RED}[Error] Clang or GCC is not installed. Exiting...${NC}" log "${YELLOW}[Info] Please install Clang or GCC and try again.${NC}" exit 1 else log "${MAGENTA}[Success] Clang or GCC is installed. Continuing...${NC}" fi # --- Check if MESON is installed --- log "${BLUE}[Info] Checking if Meson is installed...${NC}" if ! command -v meson &> /dev/null; then log "${RED}[Error] Meson is not installed. Exiting...${NC}" log "${YELLOW}[Info] Please install Meson and try again.${NC}" exit 1 else log "${MAGENTA}[Success] Meson is installed. Continuing...${NC}" fi # --- Check if NINJA is installed --- log "${BLUE}[Info] Checking if Ninja is installed...${NC}" if ! command -v ninja &> /dev/null; then log "${RED}[Error] Ninja is not installed. Exiting...${NC}" log "${YELLOW}[Info] Please install Ninja and try again.${NC}" exit 1 else log "${MAGENTA}[Success] Ninja is installed. Continuing...${NC}" fi # --- Build 4DSSE --- log "${BLUE}[Info] Building 4DSSE...${NC}" if [[ $userFlag -eq 1 ]]; then log "${BLUE}[Info] Installing 4DSSE in user mode...${NC}" else log "${BLUE}[Info] Installing 4DSSE for developers...${NC}" fi if [[ $testsFlag -eq 0 ]]; then log "${BLUE}[Info] Building with tests...${NC}" else log "${BLUE}[Info] Building without tests...${NC}" fi # --- First check Boost status --- log "${BLUE}[Info] Checking Boost status...${NC}" # if the following script exists with anything other than a 0 status the script will exit if [[ -f ./build-config/boost/.boost_installed ]]; then log "${MAGENTA}[Succsess] Boost already installed. Skipping...${NC}" else log "${BLUE}[Info] Installing Boost...${NC}" if ! ./build-config/boost/install.sh; then log "${RED}[Error] Boost check failed. Exiting...${NC}" exit 1 else touch ./build-config/boost/.boost_installed log "${GREEN}[Success] Boost check passed.${NC}" fi fi #check if the last build flags are the same as the current build flags # if the flags are the same skip the configuration step # if they are different then reconfigure the build directory # do not use grep -oP as it is not POSIX compliant doReconfigure=1 log "${BLUE}[Info] Checking last build flags...${NC}" if [[ -f $buildDir/.last_build_flags ]]; then lastUserFlag=$(grep -Eo 'userFlag=[0-9]+' $buildDir/.last_build_flags | cut -d'=' -f2) lastTestsFlag=$(grep -Eo 'testsFlag=[0-9]+' $buildDir/.last_build_flags | cut -d'=' -f2) if [[ $lastUserFlag -eq $userFlag && $lastTestsFlag -eq $testsFlag ]]; then log "${MAGENTA}[Succsess] Last build flags match current build flags. Skipping configuration...${NC}" doReconfigure=0 else log "${YELLOW}[Info] Last build flags do not match current build flags. Reconfiguring...${NC}" rm -rf $buildDir fi else log "${BLUE}[Info] Last build flags not found. Reconfiguring...${NC}" fi # --- Check if the build dir has been configured with the correct flags --- if [[ $doReconfigure -eq 1 ]]; then log "${BLUE}[Info] Configuring build directory...${NC}" if [ -f "$buildDir/build.ninja" ]; then log "${MAGENTA}[Succsess] Build directory already configured. Skipping...${NC}" else if [[ $userFlag -eq 1 ]]; then meson setup "$buildDir" -Duser_mode=true --buildtype=release else if [[ $testsFlag -eq 0 ]]; then meson setup "$buildDir" --buildtype=debug else meson setup "$buildDir" --buildtype=debug -Dbuild_tests=false fi fi log "${GREEN}[Success] Build directory configured successfully.${NC}" fi log "${BLUE}[Info] Caching last build flags...${NC}" # --- Cache the last build flags --- if [[ $userFlag -eq 1 ]]; then echo "userFlag=1" > $buildDir/.last_build_flags else echo "userFlag=0" > $buildDir/.last_build_flags fi if [[ $testsFlag -eq 1 ]]; then echo "testsFlag=1" >> $buildDir/.last_build_flags else echo "testsFlag=0" >> $buildDir/.last_build_flags fi log "${GREEN}[Success] Last build flags cached.${NC}" fi log "${BLUE}[Info] Building 4DSSE...${NC}" meson compile -C "$buildDir" # --- Install 4DSSE --- if [[ $userFlag -eq 1 ]]; then log "${BLUE}[Info] Installing 4DSSE in user mode...${NC}" meson install -C "$buildDir" fi if [[ $runTestsFlag -eq 1 ]]; then log "${BLUE}[Info] Running tests...${NC}" meson test -C "$buildDir" fi if [[ $userFlag -eq 1 ]]; then log "${GREEN}[Success] 4DSSE built and installed successfully.${NC}" else log "${GREEN}[Success] 4DSSE built successfully.${NC}" fi log "${GREEN}[Success] 4DSSE mk script complete.${NC}"