stamd

Static Markdown Page Generator
git clone git://git.dimitrijedobrota.com/stamd.git
Log | Files | Refs | README | LICENSE

commit 19b2b8c73dfa62137dd776e15ff1aff0dc9ea06e
parent b014ac73d73be5ae8a85f2ff3d43ff07134e6714
Author: Dimitrije Dobrota <mail@dimitrijedobrota.com>
Date:   Thu, 27 Jun 2024 17:45:06 +0200

Update README.md

* Remove github workflow

Diffstat:
D.github/workflows/ci.yml | 186-------------------------------------------------------------------------------
MCMakeLists.txt | 2+-
MREADME.md | 52++++++++++++++++++++++++++++++++++++++++++++++++----
3 files changed, 49 insertions(+), 191 deletions(-)

diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml @@ -1,186 +0,0 @@ -name: Continuous Integration - -on: - push: - branches: - - master - - pull_request: - branches: - - master - -jobs: - lint: - runs-on: ubuntu-22.04 - - steps: - - uses: actions/checkout@v4 - - - uses: actions/setup-python@v5 - with: { python-version: "3.12" } - - - name: Install codespell - run: pip3 install codespell - - - name: Lint - run: cmake -D FORMAT_COMMAND=clang-format-14 -P cmake/lint.cmake - - - name: Spell check - if: always() - run: cmake -P cmake/spell.cmake - - coverage: - needs: [lint] - - runs-on: ubuntu-22.04 - - # To enable coverage, delete the last line from the conditional below and - # edit the "<name>" placeholder to your GitHub name. - # If you do not wish to use codecov, then simply delete this job from the - # workflow. - if: github.repository_owner == '<name>' - && false - - steps: - - uses: actions/checkout@v4 - - - name: Install LCov - run: sudo apt-get update -q - && sudo apt-get install lcov -q -y - - - name: Configure - run: cmake --preset=ci-coverage - - - name: Build - run: cmake --build build/coverage -j 2 - - - name: Test - working-directory: build/coverage - run: ctest --output-on-failure --no-tests=error -j 2 - - - name: Process coverage info - run: cmake --build build/coverage -t coverage - - - name: Submit to codecov.io - uses: codecov/codecov-action@v4 - with: - file: build/coverage/coverage.info - token: ${{ secrets.CODECOV_TOKEN }} - - sanitize: - needs: [lint] - - runs-on: ubuntu-22.04 - - env: { CXX: clang++-14 } - - steps: - - uses: actions/checkout@v4 - - - name: Configure - run: cmake --preset=ci-sanitize - - - name: Build - run: cmake --build build/sanitize -j 2 - - - name: Test - working-directory: build/sanitize - env: - ASAN_OPTIONS: "strict_string_checks=1:\ - detect_stack_use_after_return=1:\ - check_initialization_order=1:\ - strict_init_order=1:\ - detect_leaks=1:\ - halt_on_error=1" - UBSAN_OPTIONS: "print_stacktrace=1:\ - halt_on_error=1" - run: ctest --output-on-failure --no-tests=error -j 2 - - test: - needs: [lint] - - strategy: - matrix: - os: [macos-14, ubuntu-22.04, windows-2022] - - runs-on: ${{ matrix.os }} - - steps: - - uses: actions/checkout@v4 - - - name: Install static analyzers - if: matrix.os == 'ubuntu-22.04' - run: >- - sudo apt-get install clang-tidy-14 cppcheck -y -q - - sudo update-alternatives --install - /usr/bin/clang-tidy clang-tidy - /usr/bin/clang-tidy-14 140 - - - name: Setup MultiToolTask - if: matrix.os == 'windows-2022' - run: | - Add-Content "$env:GITHUB_ENV" 'UseMultiToolTask=true' - Add-Content "$env:GITHUB_ENV" 'EnforceProcessCountAcrossBuilds=true' - - - name: Configure - shell: pwsh - run: cmake "--preset=ci-$("${{ matrix.os }}".split("-")[0])" - - - name: Build - run: cmake --build build --config Release -j 2 - - - name: Install - run: cmake --install build --config Release --prefix prefix - - - name: Test - working-directory: build - run: ctest --output-on-failure --no-tests=error -C Release -j 2 - - docs: - # Deploy docs only when builds succeed - needs: [sanitize, test] - - runs-on: ubuntu-22.04 - - # To enable, first you have to create an orphaned gh-pages branch: - # - # git switch --orphan gh-pages - # git commit --allow-empty -m "Initial commit" - # git push -u origin gh-pages - # - # Edit the <name> placeholder below to your GitHub name, so this action - # runs only in your repository and no one else's fork. After these, delete - # this comment and the last line in the conditional below. - # If you do not wish to use GitHub Pages for deploying documentation, then - # simply delete this job similarly to the coverage one. - if: github.ref == 'refs/heads/master' - && github.event_name == 'push' - && github.repository_owner == '<name>' - && false - - permissions: - contents: write - - steps: - - uses: actions/checkout@v4 - - - uses: actions/setup-python@v5 - with: { python-version: "3.12" } - - - name: Install m.css dependencies - run: pip3 install jinja2 Pygments - - - name: Install Doxygen - run: sudo apt-get update -q - && sudo apt-get install doxygen -q -y - - - name: Build docs - run: cmake "-DPROJECT_SOURCE_DIR=$PWD" "-DPROJECT_BINARY_DIR=$PWD/build" - -P cmake/docs-ci.cmake - - - name: Deploy docs - uses: peaceiris/actions-gh-pages@v4 - with: - github_token: ${{ secrets.GITHUB_TOKEN }} - publish_dir: build/docs/html diff --git a/CMakeLists.txt b/CMakeLists.txt @@ -4,7 +4,7 @@ include(cmake/prelude.cmake) project( stamd - VERSION 0.2.6 + VERSION 0.2.7 DESCRIPTION "Static Markdown Page Generator" HOMEPAGE_URL "https://git.dimitrijedobrota.com/stamd.git" LANGUAGES CXX diff --git a/README.md b/README.md @@ -1,15 +1,59 @@ # stamd -This is the stamd project. +Static Markdown blogging platform that generates everything you need -# Building and installing +## Description + +With this project you can seamlessly turn a collection of .md files into a +static webpage, with auto generated indexes for categories, rss and atom feeds, +sitemap.xml and robots.txt. + +It's configured to make pages for my [personal website](https://dimitrijedobrota.com/), +but as generation code is self documenting , it can be easily adopted to fit +your needs, all you have to do is change write_header and write_footer methods +as you see fit. + +As of now most of the heavy lifting is done by md4c library, until I find time +to develop sophisticated Markdown to HTML converter. + + +## Dependencies + +* CMake 3.14 or latter +* Compiler with C++20 support (tested: clang 16.0.5, gcc 13.2.0) +* [Poafloc latest](https://github.com/DimitrijeDobrota/poafloc) +* [Hemplate latest](https://github.com/DimitrijeDobrota/hemplate) +* [md4c](https://github.com/mity/md4c) + + +## Building and installing See the [BUILDING](BUILDING.md) document. -# Contributing + +## Usage + +> Please reference [cabin-deploy.sh](https://github.com/DimitrijeDobrota/cabin) for relevant usage example + + +## Version History + +- 0.2 + * C++ rewrite + * Improved stability + * Improve readability + * Generate sitemap.xml and robots.txt + +- 0.1 + * Quick and dirty proof of concept written in C + + +## Contributing See the [CONTRIBUTING](CONTRIBUTING.md) document. + # Licensing -This project is licensed under the MIT License - see the [LICENSE](LICENSE.md) document for details +This project is licensed under the MIT License +- see the [LICENSE](LICENSE.md) document for details