GitXplorerGitXplorer
r

action-my-markdown-linter

public
5 stars
3 forks
1 issues

Commits

List of commits on branch main.
Verified
882bf9978125e563453e4f52bf74b6cd3de7745e

chore(deps): update node.js to 498bf3e

mmy-renovate[bot] committed 7 days ago
Verified
7543106e5bf7a9daf372524b38aefa7b85207737

chore(deps): update actions/create-github-app-token action to v1.11.1

mmy-renovate[bot] committed a month ago
Verified
1824c08e64a5efed2555e7d98f7f353483e8223e

chore(deps): update node.js to c61b6b1

mmy-renovate[bot] committed a month ago
Verified
d887c498943d3dc4ee58a0caad5bbd66f88449cf

chore(deps): update node.js to d319827

mmy-renovate[bot] committed a month ago
Verified
ba6fa78eb61636a291d33e06ae3d7306b6a818f5

chore(deps): update actions/cache action to v4.2.0

mmy-renovate[bot] committed a month ago
Verified
66831d28550031a77291848e8c395fb3b03c5974

chore(deps): update oxsecurity/megalinter action to v8.3.0

mmy-renovate[bot] committed 2 months ago

README

The README file for this repository.

GitHub Actions: My Markdown Linter ✔

GitHub Marketplace license release GitHub release date GitHub Actions status Docker Hub Build Status

This is a GitHub Action to lint Markdown files. It's using the markdownlint-cli and fd.

See the basic GitHub Action example:

name: markdown_lint
on:
  push:

jobs:
  markdown_lint:
    name: Check Markdown files
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v2

      - name: Markdown Lint
        uses: ruzickap/action-my-markdown-linter@v1

Parameters

Variables used by action-my-markdown-linter GitHub Action:

Variable Default Description
config_file .markdownlint.yaml / .markdownlint.yml (if exists) Config file used by markdownlint-cli
debug (not defined) Enable debug mode for the entrypoint.sh script (set -x)
exclude (not defined) Exclude files or directories - see the --exclude parameter of fd command
fd_cmd_params . -0 --extension md --type f --hidden --no-ignore Set your own parameters for fd command. exclude and search_paths parameters are ignored if this is set.
search_paths (not defined) By default all *.md are checked in whole repository, but you can specify directories

Non of the parameters above are "mandatory".

Full example

GitHub Action example:

name: markdown_lint

on:
  push:
    branches:
      - main

jobs:
  markdown_lint:
  name: Check Markdown files
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v2

      - name: Markdown Lint
        uses: ruzickap/action-my-markdown-linter@v1
        with:
          config_file: my_markdownlint.yml
          debug: true
          exclude: |
            my_exclude_dir/md_files/
            my_exclude_dir_2/markdown_files/
            CHANGELOG.md
          search_paths: |
            check_dir_1/md_files/
            check_dir_2/markdown_files/

      - name: Markdown Lint - check only 'docs' directory and exclude CHANGELOG.md
        uses: ruzickap/action-my-markdown-linter@v1
        with:
          search_paths: |
            docs/
          exclude: |
            CHANGELOG.md

      - name: Markdown Lint - simple example
        uses: ruzickap/action-my-markdown-linter@v1

      - name: Markdown Lint using pre-built container
        uses: docker://peru/my-markdown-linter@v1

Running locally

It's possible to use the Markdown linter task locally using docker:

docker run --rm -t -v "${PWD}/tests/test2:/mnt" peru/my-markdown-linter

Output:

*** Start checking...
*** Running: fd . -0 --extension md --type f --hidden --no-ignore
*** Running: markdownlint  normal.md
*** Checks completed...

Or you can also use parameters:

export INPUT_EXCLUDE="CHANGELOG.md test1/excluded_file.md bad.md excluded_dir/"
export INPUT_SEARCH_PATHS="tests/"
docker run --rm -t -e INPUT_EXCLUDE -e INPUT_SEARCH_PATHS -v "${PWD}:/mnt" peru/my-markdown-linter

Output:

*** Start checking...
*** Running: fd . -0 --extension md --type f --hidden --no-ignore --exclude CHANGELOG.md --exclude test1/excluded_file.md --exclude bad.md --exclude excluded_dir/ tests/
*** Running: markdownlint  tests/test2/normal.md
*** Checks completed...

Demo:

My Markdown Linter

Examples

Real examples of My Markdown Linter usage: