diff --git a/.github/workflows/ci.yml b/.github/workflows/linux.yml similarity index 71% rename from .github/workflows/ci.yml rename to .github/workflows/linux.yml index 835eaff0..8070a819 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/linux.yml @@ -1,10 +1,17 @@ -name: ci +name: linux on: [push, pull_request] +permissions: + contents: read + jobs: - build_linux: + # ----------------------------------------------------------------------- + # Linux build matrix + # ----------------------------------------------------------------------- + build: runs-on: ubuntu-latest + if: github.event_name == 'push' || (github.event_name == 'pull_request' && github.event.action == 'opened') defaults: run: shell: bash @@ -22,10 +29,10 @@ jobs: image: ${{ matrix.config.compiler == 'clang' && 'teeks99/clang-ubuntu' || matrix.config.compiler }}:${{ matrix.config.version }} name: "${{ matrix.config.compiler}} ${{ matrix.config.version }} (C++${{ matrix.config.cppstd }}, ${{ matrix.config.build_type }})" steps: - - uses: actions/checkout@main + - uses: actions/checkout@v4 - name: Setup run: | - apt-get update + apt-get update apt-get install -y curl git pkg-config libsystemd-dev CMAKE_VERSION="3.24.2" curl -sSL https://github.com/Kitware/CMake/releases/download/v${CMAKE_VERSION}/cmake-${CMAKE_VERSION}-linux-x86_64.sh -o install-cmake.sh @@ -53,14 +60,17 @@ jobs: -DSPDLOG_BUILD_TESTS=ON \ -DSPDLOG_BUILD_TESTS_HO=OFF \ -DSPDLOG_SANITIZE_ADDRESS=${{ matrix.config.asan || 'ON' }} - make -j2 - ctest -j2 --output-on-failure + make -j 4 + ctest -j 4 --output-on-failure + # ----------------------------------------------------------------------- + # OS X build matrix + # ----------------------------------------------------------------------- build_osx: runs-on: macOS-latest name: "OS X Clang (C++11, Release)" steps: - - uses: actions/checkout@main + - uses: actions/checkout@v4 - name: Build run: | mkdir -p build && cd build @@ -74,35 +84,6 @@ jobs: -DSPDLOG_BUILD_TESTS=ON \ -DSPDLOG_BUILD_TESTS_HO=OFF \ -DSPDLOG_SANITIZE_ADDRESS=OFF - make -j2 - ctest -j2 --output-on-failure - - build: - runs-on: windows-latest - name: "Windows MSVC 2022 (C++11, Release)" - steps: - - name: Checkout code - uses: actions/checkout@v2 - - - name: Install CMake - run: choco install cmake --installargs '"ADD_CMAKE_TO_PATH=System"' --no-progress - - - name: Configure CMake - run: | - cmake -S . -B build -G "Visual Studio 17 2022" -A x64 ` - -DCMAKE_BUILD_TYPE=Release ` - -DCMAKE_CXX_STANDARD=11 ` - -DSPDLOG_BUILD_EXAMPLE=ON ` - -DSPDLOG_BUILD_EXAMPLE_HO=ON ` - -DSPDLOG_BUILD_WARNINGS=ON ` - -DSPDLOG_BUILD_BENCH=OFF ` - -DSPDLOG_BUILD_TESTS=ON ` - -DSPDLOG_BUILD_TESTS_HO=OFF ` - -DSPDLOG_SANITIZE_ADDRESS=OFF - - - name: Build - run: cmake --build build --config Release - - - name: Run Tests - run: ctest --test-dir build -C Release --output-on-failure --verbose + make -j 4 + ctest -j 4 --output-on-failure diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml new file mode 100644 index 00000000..4318cabc --- /dev/null +++ b/.github/workflows/macos.yml @@ -0,0 +1,29 @@ +name: macos + +on: [push, pull_request] + +permissions: + contents: read + +jobs: + build: + runs-on: macOS-latest + if: github.event_name == 'push' || (github.event_name == 'pull_request' && github.event.action == 'opened') + name: "macOS Clang (C++11, Release)" + steps: + - uses: actions/checkout@v4 + - name: Build + run: | + mkdir -p build && cd build + cmake .. \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_CXX_STANDARD=11 \ + -DSPDLOG_BUILD_EXAMPLE=ON \ + -DSPDLOG_BUILD_EXAMPLE_HO=ON \ + -DSPDLOG_BUILD_WARNINGS=ON \ + -DSPDLOG_BUILD_BENCH=OFF \ + -DSPDLOG_BUILD_TESTS=ON \ + -DSPDLOG_BUILD_TESTS_HO=OFF \ + -DSPDLOG_SANITIZE_ADDRESS=OFF + make -j 4 + ctest -j 4 --output-on-failure diff --git a/.github/workflows/windows.yml b/.github/workflows/windows.yml new file mode 100644 index 00000000..f5c00409 --- /dev/null +++ b/.github/workflows/windows.yml @@ -0,0 +1,149 @@ +name: windows + +on: [push, pull_request] + +permissions: + contents: read + +jobs: + build: + runs-on: windows-latest + if: github.event_name == 'push' || (github.event_name == 'pull_request' && github.event.action == 'opened') + strategy: + fail-fast: true + matrix: + config: + - GENERATOR: "Visual Studio 17 2022" + BUILD_TYPE: Release + BUILD_SHARED: 'ON' + FATAL_ERRORS: 'ON' + WCHAR: 'OFF' + WCHAR_FILES: 'OFF' + BUILD_EXAMPLE: 'OFF' + USE_STD_FORMAT: 'ON' + CXX_STANDARD: 20 + - GENERATOR: "Visual Studio 17 2022" + BUILD_TYPE: Release + BUILD_SHARED: 'ON' + FATAL_ERRORS: 'ON' + WCHAR: 'ON' + WCHAR_FILES: 'ON' + BUILD_EXAMPLE: 'OFF' + USE_STD_FORMAT: 'ON' + CXX_STANDARD: 20 + - GENERATOR: "Visual Studio 17 2022" + BUILD_TYPE: Release + BUILD_SHARED: 'ON' + FATAL_ERRORS: 'ON' + WCHAR: 'OFF' + WCHAR_FILES: 'OFF' + BUILD_EXAMPLE: 'ON' + USE_STD_FORMAT: 'OFF' + CXX_STANDARD: 17 + + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: CMake ${{ matrix.config.GENERATOR }} CXX=${{matrix.config.CXX_STANDARD}} WCHAR=${{matrix.config.WCHAR_FILES}} STD_FORMAT=${{matrix.config.USE_STD_FORMAT}} + shell: pwsh + run: | + mkdir build + cd build + cmake -G "${{ matrix.config.GENERATOR }}" -A x64 ` + -D CMAKE_BUILD_TYPE=${{ matrix.config.BUILD_TYPE }} ` + -D BUILD_SHARED_LIBS=${{ matrix.config.BUILD_SHARED }} ` + -D SPDLOG_WCHAR_SUPPORT=${{ matrix.config.WCHAR }} ` + -D SPDLOG_WCHAR_FILENAMES=${{ matrix.config.WCHAR_FILES }} ` + -D SPDLOG_BUILD_EXAMPLE=${{ matrix.config.BUILD_EXAMPLE }} ` + -D SPDLOG_BUILD_EXAMPLE_HO=${{ matrix.config.BUILD_EXAMPLE }} ` + -D SPDLOG_BUILD_TESTS=ON ` + -D SPDLOG_BUILD_TESTS_HO=OFF ` + -D SPDLOG_BUILD_WARNINGS=${{ matrix.config.FATAL_ERRORS }} ` + -D SPDLOG_USE_STD_FORMAT=${{ matrix.config.USE_STD_FORMAT }} ` + -D CMAKE_CXX_STANDARD=${{ matrix.config.CXX_STANDARD }} .. + + - name: Build + shell: pwsh + run: | + cd build + cmake --build . --parallel --config ${{ matrix.config.BUILD_TYPE }} + + - name: Run Tests + shell: pwsh + env: + PATH: ${{ env.PATH }};${{ github.workspace }}\build\_deps\catch2-build\src\${{ matrix.config.BUILD_TYPE }};${{ github.workspace }}\build\${{ matrix.config.BUILD_TYPE }} + run: | + build\tests\${{ matrix.config.BUILD_TYPE }}\spdlog-utests.exe + + # ----------------------------------------------------------------------- + # MSVC 2019 build matrix + # ----------------------------------------------------------------------- + build_2019: + runs-on: windows-2019 + strategy: + fail-fast: true + matrix: + config: + - GENERATOR: "Visual Studio 16 2019" + BUILD_TYPE: Release + BUILD_SHARED: 'ON' + FATAL_ERRORS: 'ON' + WCHAR: 'OFF' + WCHAR_FILES: 'OFF' + BUILD_EXAMPLE: 'ON' + USE_STD_FORMAT: 'OFF' + CXX_STANDARD: 17 + - GENERATOR: "Visual Studio 16 2019" + BUILD_TYPE: Release + BUILD_SHARED: 'ON' + FATAL_ERRORS: 'ON' + WCHAR: 'OFF' + WCHAR_FILES: 'OFF' + BUILD_EXAMPLE: 'ON' + USE_STD_FORMAT: 'OFF' + CXX_STANDARD: 14 + - GENERATOR: "Visual Studio 16 2019" + BUILD_TYPE: Release + BUILD_SHARED: 'ON' + FATAL_ERRORS: 'ON' + WCHAR: 'OFF' + WCHAR_FILES: 'OFF' + BUILD_EXAMPLE: 'ON' + USE_STD_FORMAT: 'OFF' + CXX_STANDARD: 11 + + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: CMake ${{ matrix.config.GENERATOR }} CXX=${{matrix.config.CXX_STANDARD}} WCHAR=${{matrix.config.WCHAR_FILES}} STD_FORMAT=${{matrix.config.USE_STD_FORMAT}} + shell: pwsh + run: | + mkdir build + cd build + cmake -G "${{ matrix.config.GENERATOR }}" -A x64 ` + -D CMAKE_BUILD_TYPE=${{ matrix.config.BUILD_TYPE }} ` + -D BUILD_SHARED_LIBS=${{ matrix.config.BUILD_SHARED }} ` + -D SPDLOG_WCHAR_SUPPORT=${{ matrix.config.WCHAR }} ` + -D SPDLOG_WCHAR_FILENAMES=${{ matrix.config.WCHAR_FILES }} ` + -D SPDLOG_BUILD_EXAMPLE=${{ matrix.config.BUILD_EXAMPLE }} ` + -D SPDLOG_BUILD_EXAMPLE_HO=${{ matrix.config.BUILD_EXAMPLE }} ` + -D SPDLOG_BUILD_TESTS=ON ` + -D SPDLOG_BUILD_TESTS_HO=OFF ` + -D SPDLOG_BUILD_WARNINGS=${{ matrix.config.FATAL_ERRORS }} ` + -D SPDLOG_USE_STD_FORMAT=${{ matrix.config.USE_STD_FORMAT }} ` + -D CMAKE_CXX_STANDARD=${{ matrix.config.CXX_STANDARD }} .. + + - name: Build + shell: pwsh + run: | + cd build + cmake --build . --parallel --config ${{ matrix.config.BUILD_TYPE }} + + - name: Run Tests + shell: pwsh + env: + PATH: ${{ env.PATH }};${{ github.workspace }}\build\_deps\catch2-build\src\${{ matrix.config.BUILD_TYPE }};${{ github.workspace }}\build\${{ matrix.config.BUILD_TYPE }} + run: | + build\tests\${{ matrix.config.BUILD_TYPE }}\spdlog-utests.exe diff --git a/README.md b/README.md index f4619fd9..b78f12f4 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,12 @@ # spdlog -Very fast, header-only/compiled, C++ logging library. [![ci](https://github.com/gabime/spdlog/actions/workflows/ci.yml/badge.svg)](https://github.com/gabime/spdlog/actions/workflows/ci.yml)  [![Build status](https://ci.appveyor.com/api/projects/status/d2jnxclg20vd0o50?svg=true&branch=v1.x)](https://ci.appveyor.com/project/gabime/spdlog) [![Release](https://img.shields.io/github/release/gabime/spdlog.svg)](https://github.com/gabime/spdlog/releases/latest) + +[![ci](https://github.com/gabime/spdlog/actions/workflows/linux.yml/badge.svg)](https://github.com/gabime/spdlog/actions/workflows/linux.yml)  +[![ci](https://github.com/gabime/spdlog/actions/workflows/windows.yml/badge.svg)](https://github.com/gabime/spdlog/actions/workflows/windows.yml)  +[![ci](https://github.com/gabime/spdlog/actions/workflows/macos.yml/badge.svg)](https://github.com/gabime/spdlog/actions/workflows/macos.yml)  +[![Build status](https://ci.appveyor.com/api/projects/status/d2jnxclg20vd0o50?svg=true&branch=v1.x)](https://ci.appveyor.com/project/gabime/spdlog) [![Release](https://img.shields.io/github/release/gabime/spdlog.svg)](https://github.com/gabime/spdlog/releases/latest) +#### Fast, header-only/compiled, C++ logging library + ## Install #### Header-only version