summaryrefslogtreecommitdiff
path: root/ARCHITECTURE.md
blob: 26ecdd843b71fa0e3a4ca9f8c6e6060545015e7b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# Ccache architecture

## Code structure

### Top-level directories

* `ci`: Utility scripts used in CI.
* `cmake`: CMake scripts.
* `doc`: Documentation.
* `dockerfiles`: Dockerfiles that specify different environments of interest for
  ccache.
* `misc`: Miscellaneous utility scripts, example files, etc.
* `src`: Source code. See below.
* `test`: Integration test suite which tests the ccache binary in different
  scenarios.
* `unittest`: Unit test suite which typically tests individual functions.

### Subdirectories of `src`

This section describes the directory structure that the project aims to
transform the `src` directory into in the long run to make the code base easier
to understand and work with. In other words, this is work in progress.

* `compiler`: Knowledge about things like compiler options, compiler behavior,
  preprocessor output format, etc. Ideally this code should in the future be
  refactored into compiler-specific frontends, such as GCC, Clang, NVCC, MSVC,
  etc.
* `core`: Everything not part of other directories.
* `storage`: Storage backends.
* `storage/local`: Code for the local storage backend.
* `storage/remote`: Code for remote storage backends.
* `third_party`: Bundled third party code.
* `util`: Generic utility functionality that does not depend on ccache-specific
  things.