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.
|