Skip to main content

EPITA C/C++ Coding Style Checker - validates C and C++ code against EPITA coding standards

Project description

EPITA C/C++ Coding Style Checker

A fast C and C++ linter for EPITA coding style rules. Uses tree-sitter for robust AST-based parsing.

Features

  • C (.c, .h) and C++ (.cc, .hh, .hxx) support
  • 58 rules across file formatting, functions, exports, preprocessor, declarations, control flow, naming, and more
  • AST-based checks via tree-sitter (no regex hacks for structure)
  • clang-format integration with language-specific configs (C vs C++)
  • Configurable via TOML, presets, or CLI flags
  • Pre-commit hook support

Installation

pipx install epita-coding-style

Quick Start

epita-coding-style src/           # Check files/directories
epita-coding-style --list-rules   # List all rules with descriptions
epita-coding-style --show-config  # Show current configuration
epita-coding-style --help         # Full usage info

Supported File Extensions

Language Source Header
C .c .h
C++ .cc .hh, .hxx

C++ files using .cpp / .hpp will be checked but flagged with a file.ext violation.

Configuration

Configuration is auto-detected from (in order):

  • .epita-style
  • .epita-style.toml
  • epita-style.toml
  • [tool.epita-coding-style] in pyproject.toml

Priority: CLI flags > config file > preset > defaults

Generate a Config File

epita-coding-style --show-config --no-color > .epita-style.toml

This outputs a complete, commented TOML config you can customize.

Presets

epita-coding-style --preset 42sh src/      # 40 lines, goto/cast allowed
epita-coding-style --preset noformat src/  # Same + skip clang-format

Example Config

# .epita-style.toml
max_lines = 40

[rules]
"keyword.goto" = false  # Allow goto
"cast" = false          # Allow casts

Or in pyproject.toml:

[tool.epita-coding-style]
max_lines = 40

[tool.epita-coding-style.rules]
"keyword.goto" = false

Limits

Setting Default (C) Default (C++) Description
max_lines 30 50 Max lines per function body
max_args 4 4 Max arguments per function
max_funcs 10 Max exported functions per file (C only)
max_globals 1 Max exported globals per file (C only)

Rules Overview

Use epita-coding-style --list-rules for the full list. Key categories:

C rules (enabled by default):

  • File — line endings, trailing whitespace, blank lines, file termination
  • Style — Allman brace style
  • Functions — length, argument count, (void) for empty params
  • Exports — max exported functions/globals per .c file
  • Preprocessor — include guards, # column, #endif comments, digraphs
  • Declarations — one per line, no VLAs
  • Control — no empty loop bodies
  • Strict — no goto, no explicit casts
  • Formatting — clang-format compliance

C++ rules (auto-enabled for .cc/.hh/.hxx files):

  • File — correct extensions (.cc/.hh/.hxx, not .cpp/.hpp)
  • Preprocessor#pragma once, include order, no source includes, constexpr
  • Global — C++ casts, no malloc, nullptr, no extern "C", C++ headers, std:: functions
  • Naming — CamelCase classes/structs, lowercase namespaces with closing comments
  • Declarations&/* next to type, explicit constructors, no VLAs
  • Control — switch default case, label padding, no empty loops
  • Writing — empty braces, single-expression braces, throw/catch rules, operator overloads, enum class, function length

clang-format

The format rule uses clang-format to check code formatting. Requires clang-format to be installed.

The checker uses language-specific configs:

  • C: looks for .clang-format-c, then .clang-format
  • C++: looks for .clang-format-cxx, then .clang-format

It searches from the file's directory up to root, falling back to the bundled EPITA configs.

To disable: set "format" = false in your config, or use --preset noformat.

Pre-commit Hook

# .pre-commit-config.yaml
repos:
  - repo: https://github.com/KazeTachinuu/epita-coding-style
    rev: v3.1.0
    hooks:
      - id: epita-coding-style
        args: [--preset, 42sh]  # optional

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

epita_coding_style-3.2.3.tar.gz (36.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

epita_coding_style-3.2.3-py3-none-any.whl (28.4 kB view details)

Uploaded Python 3

File details

Details for the file epita_coding_style-3.2.3.tar.gz.

File metadata

  • Download URL: epita_coding_style-3.2.3.tar.gz
  • Upload date:
  • Size: 36.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for epita_coding_style-3.2.3.tar.gz
Algorithm Hash digest
SHA256 43084f8121a8aa5d7ff2353b46607d0eaa95956e7752e35f99068a0368cd7194
MD5 6d8921444a7a5885998b190e604b82ca
BLAKE2b-256 9d6c5517c01d3b8121bed662fe97fcc13d70db9cd22d16f22867cf0ba2d3f87b

See more details on using hashes here.

File details

Details for the file epita_coding_style-3.2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for epita_coding_style-3.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 cfb96197f6844cdbdb0de8d27678fa0eabf32c755e38d01e3003c03c049a262d
MD5 223ffc6f94e41cefc53d445499e3ad53
BLAKE2b-256 a1a6865305441a6269a42a2a307a8fcdd8b1b171faf319642d5ce3a4483d2c4f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page