default_language_version:
  python: python3

repos:
  - repo: XXXX
    rev: v5.0.0
    hooks:
      # list of supported hooks: XXXX
      - id: trailing-whitespace
      - id: end-of-file-fixer
      - id: check-docstring-first
      - id: check-yaml
      - id: debug-statements
      - id: detect-private-key
      - id: check-executables-have-shebangs
      - id: check-toml
      - id: check-case-conflict
      - id: check-added-large-files

  # python code formatting
  - repo: XXXX
    rev: 25.1.0
    hooks:
      - id: black
        args: [--line-length, "99"]
        exclude: |
          (?x)(
            ^.+\.ipynb$ |
            ^.+\.sample$ |
            ^.+\.git/.* |
            ^.+\.bak$ |
            ^.+\.tmp$ |
          )

  # # python docstring formatting
  # - repo: XXXX
  #   rev: v1.7.5
  #   hooks:
  #     - id: docformatter
  #       language: python
  #       args:
  #         [
  #           --in-place,
  #           --wrap-summaries=99,
  #           --wrap-descriptions=99,
  #           --style=sphinx,
  #           --black,
  #         ]

  # python docstring coverage checking
  - repo: XXXX
    rev: 1.7.0 # or master if you're bold
    hooks:
      - id: interrogate
        args:
          [
            --verbose,
            --fail-under=50,
            --ignore-init-module,
            --ignore-init-method,
            --ignore-module,
            --ignore-nested-functions,
            -vv,
          ]

  # python security linter
  - repo: XXXX
    rev: "1.8.3"
    hooks:
      - id: bandit
        args: ["-s", "B101,B301,B403"]

  # yaml formatting
  - repo: XXXX
    rev: v4.0.0-alpha.8
    hooks:
      - id: prettier
        types: [yaml]
        exclude: "environment.yaml"

  # shell scripts linter
  - repo: XXXX
    rev: v0.10.0.1
    hooks:
      - id: shellcheck
        exclude: |
          (?x)(
            ^.+\.ipynb$ |
            ^.+\.sample$ |
            ^.+\.git/.* |
            ^.+\.bak$ |
            ^.+\.tmp$ |
          )

  # word spelling linter
  - repo: XXXX
    rev: v2.4.1
    hooks:
      - id: codespell
        args:
          - --skip=logs/**,data/**,*.ipynb
          - --ignore-words-list=ot,struc

  # jupyter notebook cell output clearing
  - repo: XXXX
    rev: 0.8.1
    hooks:
      - id: nbstripout

  # jupyter notebook linting
  # - repo: XXXX
  #   rev: 1.9.1
  #   hooks:
  #     - id: nbqa-black
  #       args: ["--line-length=99"]
  #     - id: nbqa-flake8
  #       args:
  #         [
  #           "--extend-ignore=E203,E402,E501,F401,F841",
  #           "--exclude=logs/*,data/*",
  #         ]
  #       exclude: |
  #         (?x)(
  #           ^.+\.ipynb$ |
  #           ^.+\.sample$ |
  #           ^.+\.git/.* |
  #           ^.+\.bak$ |
  #           ^.+\.tmp$ |
  #         )

  # Ruff linter
  - repo: XXXX
    rev: v0.9.10 # Use the latest version
    hooks:
      - id: ruff
        args: [--fix, --exit-non-zero-on-fix]
      - id: ruff-format
