Thanks for your interest in contributing! This guide covers the basics to get you productive quickly.

Getting started

Project structure

Code style

  • C: C99, two-space indent, no tabs. Keep functions short and focused.
  • Fun: two-space indent, snake_case for functions, PascalCase for classes/constructors.
  • Prefer clear names over abbreviations. See style-guide/.

Development workflow

  1. Create a small, focused branch.
  2. Add/adjust tests for behavior changes (see writing-tests).
  3. Update docs if user-visible behavior changes.
  4. Submit a PR with a clear description and rationale.

Commit/PR guidelines

  • Keep commits atomic; include test updates with the change.
  • Reference related issues.
  • Include benchmarks only when meaningful and reproducible.

Reporting bugs

Please include:

  • Reproducer script (minimal), expected vs. actual behavior
  • Build options and platform
  • fun --version output

Code of Conduct

Be respectful and inclusive. See https://git.xw3.org/fun/fun/src/branch/main/CODE_OF_CONDUCT.md in the repository root.

Comments