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.1.3.tar.gz (35.4 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.1.3-py3-none-any.whl (27.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: epita_coding_style-3.1.3.tar.gz
  • Upload date:
  • Size: 35.4 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.1.3.tar.gz
Algorithm Hash digest
SHA256 b5e9fc81ea60bd26a5c1b7ff75f189fa1d1b5bbb8fe25ca93da4e2b5da71e7d7
MD5 6ef7b8e38af715ee9699863adc31433e
BLAKE2b-256 911e169e08b2861cf980cd831fea5cad91065bfa204b34283c586620e67f065c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for epita_coding_style-3.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 83c766c5da87848a0d42173a25aff3627d81780e506788e285e1d0ed90635ee6
MD5 1b0994bb30c5c221ed8d9e6291925a53
BLAKE2b-256 6e3204bbd61e00726b6e182f8b418f88a6db30d92eeea816b70a5908f59f4dd3

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