Laszlo Nagy b45d85e32e docs(meta): plan documentation restructure for agent workflows
Add plan.md capturing an eight-phase plan to reorganise the repo so
Claude Code (and humans) can find the right rule, write to the right
place, and keep documentation in sync with code.

The plan introduces a `docs/` parent for requirements and rationale,
single-source-of-truth files for configuration and CLI surface, sync
checks to catch drift, and a preflight phase plus recovery appendix
to make phase-by-phase execution safe.

Each subsequent commit on this branch should execute one phase.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-21 12:16:31 +00:00
2026-04-03 05:46:23 +00:00
2026-01-03 18:24:17 +11:00
2026-04-26 07:52:33 +00:00
2026-01-03 18:24:17 +11:00
2020-03-03 12:04:11 +11:00
2013-06-27 01:03:01 +02:00
2026-03-31 05:56:38 +00:00
2026-04-25 05:46:19 +00:00

Packaging status GitHub release GitHub Release Date Continuous Integration Contributors Gitter

ʕ·ᴥ·ʔ Build EAR

Bear generates a compilation database for Clang tooling.

The JSON compilation database describes how each translation unit is compiled. Clang-based tools use it to understand compiler flags, include paths, and other build settings.

Some build systems can generate a JSON compilation database directly. For build systems that cannot, Bear captures compiler invocations during the build and writes the database for you.

How to install

Bear is packaged for many distributions. Check your distribution's package manager first. Alternatively, you can build it from source.

How to use

After installation, run:

bear -- <your-build-command>

Bear writes compile_commands.json to the current working directory.

For more options, see the man page or run bear --help. Pass Bears own options before --; everything after that is treated as part of the build command.

Please be aware that some package managers still ship the 2.4.x release. In that case, please omit the extra -- or consult your local documentation.

For more information, read the man pages or the project wiki, which talks about limitations, known issues, and platform-specific usage.

When to use Bear

Use Bear when your build system does not natively support generating a JSON compilation database. If your project already uses CMake, Meson, or Bazel, prefer the built-in compilation database export those tools provide; it is usually faster and more reliable.

Supported platforms

Bear works on Linux, macOS, FreeBSD, OpenBSD, NetBSD, DragonFly BSD, and Windows.

Limitations

Bear works by intercepting compiler calls during a build. This means certain environments may need extra configuration — for example, macOS System Integrity Protection (SIP) or sandboxed builds (Nix, Flatpak). See the wiki for details and workarounds.

Problem reports

Before opening a new problem report, please check the wiki to see if your problem is a known issue with a documented workaround. It's also helpful to look at older (possibly closed) issues before opening a new one.

If you decide to report a problem, please provide as much context as possible to help reproduce the error. If you just have a question about usage, please don't be shy; ask your question in an issue or in our chat.

If you've found a bug and have a fix for it, please share it by opening a pull request.

Please follow the contribution guide when you do.

S
Description
Bear is a tool that generates a compilation database for clang tooling.
Readme 6.3 MiB
Languages
Rust 98.2%
C 1%
Shell 0.7%