summaryrefslogtreecommitdiff
path: root/doc/MANUAL.adoc
blob: dc7c75f30b8135ea77dc2287312a0a0a3a9e0284 (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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
= ccache(1)
:mansource: Ccache {revnumber}

== Name

ccache - a fast C/C++ compiler cache


== Synopsis

[verse]
*ccache* [_ccache options_]
*ccache* [_KEY_=_VALUE_ ...] _compiler_ [_compiler options_]
_compiler_ [_compiler options_]

The first form takes options described in <<Command line options>> below. The
second form invokes the compiler, optionally using <<Configuration,configuration
options>> as _KEY_=_VALUE_ arguments. In the third form, ccache is masquerading
as the compiler as described in <<Run modes>>.


== Description

Ccache is a compiler cache. It speeds up recompilation by caching the result of
previous compilations and detecting when the same compilation is being done
again.

Ccache has been carefully written to always produce exactly the same compiler
output that you would get without the cache. The only way you should be able to
tell that you are using ccache is the speed. Currently known exceptions to this
goal are listed under _<<Caveats>>_. If you discover an undocumented case where
ccache changes the output of your compiler, please let us know.


== Run modes

There are two different ways to use ccache to cache a compilation:

1. Prefix your compilation command with `ccache`. This method is most convenient
   if you just want to try out ccache or wish to use it for some specific
   projects. Example:
+
-------------------------------------------------------------------------------
ccache gcc -c example.c
-------------------------------------------------------------------------------
+
2. Let ccache masquerade as the compiler. This method is most useful when you
   wish to use ccache for all your compilations. To do this, create a symbolic
   link to ccache named as the compiler. For example, here is set up ccache to
   masquerade as `gcc` and `g++`:
+
-------------------------------------------------------------------------------
cp ccache /usr/local/bin/
ln -s ccache /usr/local/bin/gcc
ln -s ccache /usr/local/bin/g++
-------------------------------------------------------------------------------
+
On platforms that don't support symbolic links you can simply copy ccache to the
compiler name instead for a similar effect:
+
-------------------------------------------------------------------------------
cp ccache /usr/local/bin/gcc
cp ccache /usr/local/bin/g++
-------------------------------------------------------------------------------
+
And so forth. This will work as long as the directory with symbolic links or
ccache copies comes before the directory with the compiler (typically
`/usr/bin`) in `PATH`.
+
WARNING: The technique of letting ccache masquerade as the compiler works well,
but currently doesn't interact well with other tools that do the same thing. See
_<<Using ccache with other compiler wrappers>>_.


== Command line options

These command line options only apply when you invoke ccache as "`ccache`". When
ccache masquerades as a compiler (as described in the previous section), the
normal compiler options apply and you should refer to the compiler's
documentation.


=== Common options

*-c*, *--cleanup*::

    Clean up the cache by removing old cached files until the specified file
    number and cache size limits are not exceeded. This also recalculates the
    cache file count and size totals. Normally, there is no need to initiate
    cleanup manually as ccache keeps the cache below the specified limits at
    runtime and keeps statistics up to date on each compilation. Forcing a
    cleanup is mostly useful if you have modified the cache contents manually or
    believe that the cache size statistics may be inaccurate.

*-C*, *--clear*::

    Clear the entire cache, removing all cached files, but keeping the
    configuration file.

*--config-path* _PATH_::

    Let the command line options operate on configuration file _PATH_ instead of
    the default. Using this option has the same effect as setting (overriding)
    the environment variable `CCACHE_CONFIGPATH` temporarily.

*-d*, *--dir* _PATH_::

    Let the command line options operate on cache directory _PATH_ instead of
    the default. For example, to show statistics for a cache directory at
    `/shared/ccache` you can run `ccache -d /shared/ccache -s`. Using this option
    has the same effect as setting the environment variable `CCACHE_DIR`
    temporarily.

*--evict-namespace* _NAMESPACE_::

    Remove files created in the given <<config_namespace,*namespace*>> from the
    cache.

*--evict-older-than* _AGE_::

    Remove files older than _AGE_ from the cache. _AGE_ should be an unsigned
    integer with a `d` (days) or `s` (seconds) suffix. If combined with
    `--evict-namespace`, only remove old files within that namespace.

*-h*, *--help*::

    Print a summary of command line options.

*-F* _NUM_, *--max-files* _NUM_::

    Set the maximum number of files allowed in the cache to _NUM_. Use 0 for no
    limit. The value is stored in a configuration file in the cache directory
    and applies to all future compilations.

*-M* _SIZE_, *--max-size* _SIZE_::

    Set the maximum size of the files stored in the cache. _SIZE_ should be a
    number followed by an optional suffix: kB, MB, GB, TB (decimal), KiB, MiB,
    GiB or TiB (binary). The default suffix is GiB. Use 0 for no limit. The
    value is stored in a configuration file in the cache directory and applies
    to all future compilations.

*-X* _LEVEL_, *--recompress* _LEVEL_::

    Recompress the cache to level _LEVEL_ using the Zstandard algorithm. The
    level can be an integer, with the same semantics as the
    <<config_compression_level,*compression_level*>> configuration option, or
    the special value *uncompressed* for no compression. See _<<Cache
    compression>>_ for more information. This can potentially take a long time
    since all files in the cache need to be visited. Only files that are
    currently compressed with a different level than _LEVEL_ will be
    recompressed.

*--recompress-threads* _THREADS_::

    Use up to _THREADS_ threads when recompressing the cache. The default is to
    use one thread per CPU.

*-o* _KEY=VALUE_, *--set-config* _KEY_=_VALUE_::

    Set configuration option _KEY_ to _VALUE_. See _<<Configuration>>_ for more
    information.

*-x*, *--show-compression*::

    Print cache compression statistics. See _<<Cache compression>>_ for more
    information. This can potentially take a long time since all files in the
    cache need to be visited.

*-p*, *--show-config*::

    Print current configuration options and from where they originate
    (environment variable, configuration file or compile-time default) in
    human-readable format.

*--show-log-stats*::

    Print statistics counters from the stats log in human-readable format. See
    <<config_stats_log,*stats_log*>>. Use `-v`/`--verbose` once or twice for
    more details.

*-s*, *--show-stats*::

    Print a summary of configuration and statistics counters in human-readable
    format. Use `-v`/`--verbose` once or twice for more details.

*-v*, *--verbose*::

    Increase verbosity. The option can be given multiple times.

*-V*, *--version*::

    Print version and copyright information.

*-z*, *--zero-stats*::

    Zero the cache statistics (but not the configuration options).


=== Options for remote file-based storage

*--trim-dir* _PATH_::

    Remove old files from directory _PATH_ until it is at most the size
    specified by `--trim-max-size`.
+
WARNING: Don't use this option to trim the local cache. To trim the local cache
directory to a certain size, use `CCACHE_MAXSIZE=_SIZE_ ccache -c`.

*--trim-max-size* _SIZE_::

    Specify the maximum size for `--trim-dir`. _SIZE_ should be a number
    followed by an optional suffix: kB, MB, GB, TB (decimal), KiB, MiB, GiB or
    TiB (binary). The default suffix is GiB.

*--trim-method* _METHOD_::

    Specify the method to trim a directory with `--trim-dir`. Possible values
    are:
+
--
*atime*::
    LRU (least recently used) using the file access timestamp. This is the
    default.
*mtime*::
    LRU (least recently used) using the file modification timestamp.
--

*--trim-recompress* _LEVEL_::

    Recompress to level _LEVEL_ using the Zstandard algorithm when using
    `--trim-dir`. The level can be an integer, with the same semantics as the
    <<config_compression_level,*compression_level*>> configuration option, or
    the special value *uncompressed* for no compression. See _<<Cache
    compression>>_ for more information. This can potentially take a long time
    since all files in the cache need to be visited. Only files that are
    currently compressed with a different level than _LEVEL_ will be
    recompressed.

*--trim-recompress-threads* _THREADS_::

    Recompress using up to _THREADS_ threads with `--trim-recompress`. The
    default is to use one thread per CPU.


=== Options for scripting or debugging

*--checksum-file* _PATH_::

    Print the checksum (128 bit XXH3) of the file at _PATH_ (`-` for standard
    input).

*--extract-result* _PATH_::

    Extract data stored in the result file at _PATH_ (`-` for standard input).
    The data will be written to `ccache-result.*` files in to the current
    working directory. This option is only useful when debugging ccache and its
    behavior.

*-k* _KEY_, *--get-config* _KEY_::

    Print the value of configuration option _KEY_. See _<<Configuration>>_ for
    more information.

*--hash-file* _PATH_::

    Print the hash (160 bit BLAKE3) of the file at _PATH_ (`-` for standard
    input). This is only useful when debugging ccache and its behavior.

*--inspect* _PATH_::

    Print the content of a result or manifest file at _PATH_ (`-` for standard
    input) to standard output in human-readable format. File content embedded in
    a result file will however not be printed; use `--extract-result` to extract
    the file content. This option is only useful when debugging ccache and its
    behavior.

*--print-stats*::

    Print statistics counter IDs and corresponding values in machine-parsable
    (tab-separated) format.



=== Extra options

When run as a compiler, ccache usually just takes the same command line options
as the compiler you are using. The only exception to this is the option
`--ccache-skip`. That option can be used to tell ccache to avoid interpreting
the next option in any way and to pass it along to the compiler as-is.

NOTE: `--ccache-skip` currently only tells ccache not to interpret the next
option as a special compiler option -- the option will still be included in the
direct mode hash.

The reason this can be important is that ccache does need to parse the command
line and determine what is an input filename and what is a compiler option, as
it needs the input filename to determine the name of the resulting object file
(among other things). The heuristic ccache uses when parsing the command line
is that any argument that exists as a file is treated as an input file name. By
using `--ccache-skip` you can force an option to not be treated as an input
file name and instead be passed along to the compiler as a command line option.

Another case where `--ccache-skip` can be useful is if ccache interprets an
option specially but shouldn't, since the option has another meaning for your
compiler than what ccache thinks.


== Configuration

Ccache's default behavior can be overridden by options in configuration files,
which in turn can be overridden by environment variables with names starting
with `CCACHE_`. Ccache normally reads configuration from two files: first a
system-level configuration file and secondly a cache-specific configuration
file. The priorities of configuration options are as follows (where 1 is
highest):

1. Command line settings in _KEY_=_VALUE_ form. Example:
+
-------------------------------------------------------------------------------
ccache debug=true compiler_check="%compiler% --version" gcc -c example.c
-------------------------------------------------------------------------------
2. Environment variables.
3. The cache-specific configuration file (see below).
4. The system (read-only) configuration file `<sysconfdir>/ccache.conf`
   (typically `/etc/ccache.conf` or `/usr/local/etc/ccache.conf`).
5. Compile-time defaults.

As a special case, if the environment variable `CCACHE_CONFIGPATH` is set it
specifies the configuration file, and the system configuration file won't be
read.


=== Location of the configuration file

The location of the cache-specific configuration file is determined like this on
non-Windows systems:

1. If `CCACHE_CONFIGPATH` is set, use that path.
2. Otherwise, if the environment variable `CCACHE_DIR` is set then use
   `$CCACHE_DIR/ccache.conf`.
3. Otherwise, if <<config_cache_dir,*cache_dir*>> is set in the system
   configuration file then use `<cache_dir>/ccache.conf`.
4. Otherwise, if there is a legacy `$HOME/.ccache` directory then use
   `$HOME/.ccache/ccache.conf`.
5. Otherwise, if `XDG_CONFIG_HOME` is set then use
   `$XDG_CONFIG_HOME/ccache/ccache.conf`.
6. Otherwise, use
   `$HOME/Library/Preferences/ccache/ccache.conf` (macOS) or
   `$HOME/.config/ccache/ccache.conf` (other systems).

On Windows, this is the method used to find the configuration file:

1. If `CCACHE_CONFIGPATH` is set, use that path.
2. Otherwise, if the environment variable `CCACHE_DIR` is set then use
   `%CCACHE_DIR%/ccache.conf`.
3. Otherwise, if <<config_cache_dir,*cache_dir*>> is set in the system
   configuration file then use `<cache_dir>\ccache.conf`. The
   system-wide configuration on Windows is
   `%ALLUSERSPROFILE%\ccache\ccache.conf` by default. The `ALLUSERSPROFILE`
   environment variable is usually `C:\ProgramData`.
4. Otherwise, if there is a legacy `%USERPROFILE%\.ccache` directory then use
   `%USERPROFILE%\.ccache\ccache.conf`.
5. Otherwise, use `%LOCALAPPDATA%\ccache\ccache.conf` if it exists.
6. Otherwise, use `%APPDATA%\ccache\ccache.conf`.

See also the <<config_cache_dir,*cache_dir*>> configuration option for how the
cache directory location is determined.


=== Configuration file syntax

Configuration files are in a simple "`key = value`" format, one option per
line. Lines starting with a hash sign are comments. Blank lines are ignored, as
is whitespace surrounding keys and values. Example:

-------------------------------------------------------------------------------
# Set maximum cache size to 10 GB:
max_size = 10G
-------------------------------------------------------------------------------


=== Boolean values

Some configuration options are boolean values (i.e. truth values). In a
configuration file, such values must be set to the string *true* or *false*.
For the corresponding environment variables, the semantics are a bit different:

* A set environment variable means "`true`" (even if set to the empty string).
* The following case-insensitive negative values are considered an error
  (instead of surprising the user): *0*, *false*, *disable* and *no*.
* An unset environment variable means "`false`".

Each boolean environment variable also has a negated form starting with
`CCACHE_NO`. For example, `CCACHE_COMPRESS` can be set to force compression and
`CCACHE_NOCOMPRESS` can be set to force no compression.


=== Configuration options

Below is a list of available configuration options. The corresponding
environment variable name is indicated in parentheses after each configuration
option key.

[#config_absolute_paths_in_stderr]
*absolute_paths_in_stderr* (*CCACHE_ABSSTDERR*)::

    This option specifies whether ccache should rewrite relative paths in the
    compiler's standard error output to absolute paths. This can be useful if
    you use <<config_base_dir,*base_dir*>> with a build system (e.g. CMake with
    the "Unix Makefiles" generator) that executes the compiler in a different
    working directory, which makes relative paths in compiler errors or
    warnings incorrect. The default is false.

[#config_base_dir]
*base_dir* (*CCACHE_BASEDIR*)::

    This option should be an absolute path to a directory. If set, ccache will
    rewrite absolute paths into paths relative to the current working directory,
    but only absolute paths that begin with *base_dir*. Cache results can then
    be shared for compilations in different directories even if the project uses
    absolute paths in the compiler command line. See also the discussion under
    _<<Compiling in different directories>>_. If set to the empty string (which
    is the default), no rewriting is done.
+
A typical path to use as *base_dir* is your home directory or another directory
that is a parent of your project directories. Don't use `/` as the base
directory since that will make ccache also rewrite paths to system header
files, which typically is contraproductive.
+
For example, say that Alice's current working directory is
`/home/alice/project1/build` and that she compiles like this:
+
-------------------------------------------------------------------------------
ccache gcc -I/usr/include/example -I/home/alice/project2/include -c /home/alice/project1/src/example.c
-------------------------------------------------------------------------------
+
Here is what ccache will actually execute for different *base_dir* values:
+
-------------------------------------------------------------------------------
# Current working directory: /home/alice/project1/build

# With base_dir = /:
gcc -I../../../../usr/include/example -I../../project2/include -c ../src/example.c

# With base_dir = /home or /home/alice:
gcc -I/usr/include/example -I../../project2/include -c ../src/example.c

# With base_dir = /home/alice/project1 or /home/alice/project1/src:
gcc -I/usr/include/example -I/home/alice/project2/include -c ../src/example.c
-------------------------------------------------------------------------------
+
If Bob has put `project1` and `project2` in `/home/bob/stuff` and both users
have set *base_dir* to `/home` or `/home/$USER`, then Bob will get a cache hit
(if they share ccache directory) since the actual command line will be
identical to that of Alice:
+
-------------------------------------------------------------------------------
# Current working directory: /home/bob/stuff/project1/build

# With base_dir = /home or /home/bob:
gcc -I/usr/include/example -I../../project2/include -c ../src/example.c
-------------------------------------------------------------------------------
+
Without *base_dir* there will be a cache miss since the absolute paths will
differ. With *base_dir* set to `/` there will be a cache miss since the
relative path to `/usr/include/example` will be different. With *base_dir* set
to `/home/bob/stuff/project1` there will a cache miss since the path to
project2 will be a different absolute path.
+
WARNING: Rewriting absolute paths to relative is kind of a brittle hack. It
works OK in many cases, but there might be cases where things break. One known
issue is that absolute paths are not reproduced in dependency files, which can
mess up dependency detection in tools like Make and Ninja. If possible, use
relative paths in the first place instead instead of using *base_dir*.

[#config_cache_dir]
*cache_dir* (*CCACHE_DIR*)::

    This option specifies where ccache will keep its cached compiler outputs.
+
On non-Windows systems, the default is `$HOME/.ccache` if such a directory
exists, otherwise `$XDG_CACHE_HOME/ccache` if `XDG_CACHE_HOME` is set, otherwise
`$HOME/Library/Caches/ccache` (macOS) or `$HOME/.config/ccache` (other systems).
+
On Windows, the default is `%USERPROFILE%\.ccache` if such a directory exists,
otherwise `%LOCALAPPDATA%\ccache`.
+
WARNING: Previous ccache versions defaulted to storing the cache in
`%APPDATA%\ccache` on Windows. This can result in large network file transfers
of the cache in domain environments and similar problems. Please check this
directory for cache directories and either delete them or the whole directory,
or move them to the `%LOCALAPPDATA%\ccache` directory.
+
See also _<<Location of the configuration file>>_.

[#config_compiler]
*compiler* (*CCACHE_COMPILER* or (deprecated) *CCACHE_CC*)::

    This option can be used to force the name of the compiler to use. If set to
    the empty string (which is the default), ccache works it out from the
    command line.

[#config_compiler_check]
*compiler_check* (*CCACHE_COMPILERCHECK*)::

    By default, ccache includes the modification time ("`mtime`") and size of
    the compiler in the hash to ensure that results retrieved from the cache
    are accurate. If compiler plugins are used, these plugins will also be
    added to the hash. This option can be used to select another strategy.
    Possible values are:
+
--
*content*::
    Hash the content of the compiler binary. This makes ccache very slightly
    slower compared to *mtime*, but makes it cope better with compiler upgrades
    during a build bootstrapping process.
*mtime*::
    Hash the compiler's mtime and size, which is fast. This is the default.
*none*::
    Don't hash anything. This may be good for situations where you can safely
    use the cached results even though the compiler's mtime or size has changed
    (e.g. if the compiler is built as part of your build system and the
    compiler's source has not changed, or if the compiler only has changes that
    don't affect code generation). You should only use *none* if you know what
    you are doing.
*string:value*::
    Hash *value*. This can for instance be a compiler revision number or
    another string that the build system generates to identify the compiler.
_a command string_::
    Hash the standard output and standard error output of the specified
    command. The string will be split on whitespace to find out the command and
    arguments to run. No other interpretation of the command string will be
    done, except that the special word *%compiler%* will be replaced with the
    path to the compiler. Several commands can be specified with semicolon as
    separator. Examples:
+
----
%compiler% -v
----
+
----
%compiler% -dumpmachine; %compiler% -dumpversion
----
+
You should make sure that the specified command is as fast as possible since it
will be run once for each ccache invocation.
+
Identifying the compiler using a command is useful if you want to avoid cache
misses when the compiler has been rebuilt but not changed.
+
Another case is when the compiler (as seen by ccache) actually isn't the real
compiler but another compiler wrapper -- in that case, the default *mtime*
method will hash the mtime and size of the other compiler wrapper, which means
that ccache won't be able to detect a compiler upgrade. Using a suitable command
to identify the compiler is thus safer, but it's also slower, so you should
consider continue using the *mtime* method in combination with the
*prefix_command* option if possible. See
_<<Using ccache with other compiler wrappers>>_.
--

[#config_compiler_type]
*compiler_type* (*CCACHE_COMPILERTYPE*)::

    Ccache normally guesses the compiler type based on the compiler name. The
    *compiler_type* option lets you force a compiler type. This can be useful
    if the compiler has a non-standard name but is actually one of the known
    compiler types. Possible values are:
+
--
*auto*::
    Guess one of the types below based on the compiler name (following
    symlinks). This is the default.
*clang*::
    Clang-based compiler.
*clang-cl*::
    clang-cl.
*gcc*::
    GCC-based compiler.
*icl*::
    Intel compiler on Windows.
*msvc*::
    Microsoft Visual C++ (MSVC).
*nvcc*::
    NVCC (CUDA) compiler.
*other*::
    Any compiler other than the known types.
--

[#config_compression]
*compression* (*CCACHE_COMPRESS* or *CCACHE_NOCOMPRESS*, see _<<Boolean values>>_ above)::

    If true, ccache will compress data it puts in the cache. However, this
    option has no effect on how files are retrieved from the cache; compressed
    and uncompressed results will still be usable regardless of this option.
    The default is true.
+
Compression is done using the Zstandard algorithm. The algorithm is fast enough
that there should be little reason to turn off compression to gain performance.
One exception is if the cache is located on a compressed file system, in which
case the compression performed by ccache of course is redundant.
+
Compression will be disabled if file cloning (the
<<config_file_clone,*file_clone*>> option) or hard linking (the
<<config_hard_link,*hard_link*>> option) is enabled.

[#config_compression_level]
*compression_level* (*CCACHE_COMPRESSLEVEL*)::

    This option determines the level at which ccache will compress object files
    using the real-time compression algorithm Zstandard. It only has effect if
    <<config_compression,*compression*>> is enabled (which it is by default).
    Zstandard is extremely fast for decompression and very fast for compression
    for lower compression levels. The default is 0.
+
Semantics of *compression_level*:
+
--
*> 0*::
    A positive value corresponds to normal Zstandard compression levels. Lower
    levels (e.g. *1*) mean faster compression but worse compression ratio.
    Higher levels (e.g. *19*) mean slower compression but better compression
    ratio. The maximum possible value depends on the libzstd version, but at
    least up to 19 is available for all versions. Decompression speed is
    essentially the same for all levels. As a rule of thumb, use level 5 or
    lower since higher levels may slow down compilations noticeably. Higher
    levels are however useful when recompressing the cache with command line
    option `-X`/`--recompress`.
*< 0*::
    A negative value corresponds to Zstandard's "`ultra-fast`" compression
    levels, which are even faster than level 1 but with less good compression
    ratios. For instance, level *-3* corresponds to `--fast=3` for the `zstd`
    command line tool. In practice, there is little use for levels lower than
    *-5* or so.
*0* (default)::
    The value *0* means that ccache will choose a suitable level, currently
    *1*.
--
+
See the http://zstd.net[Zstandard documentation] for more information.

[#config_cpp_extension]
*cpp_extension* (*CCACHE_EXTENSION*)::

    This option can be used to force a certain extension for the intermediate
    preprocessed file. The default is to automatically determine the extension
    to use for intermediate preprocessor files based on the type of file being
    compiled, but that sometimes doesn't work. For example, when using the
    "`aCC`" compiler on HP-UX, set the cpp extension to *i*.

[#config_debug]
*debug* (*CCACHE_DEBUG* or *CCACHE_NODEBUG*, see _<<Boolean values>>_ above)::

    If true, enable the debug mode. The debug mode creates per-object debug
    files that are helpful when debugging unexpected cache misses. Note however
    that ccache performance will be reduced slightly. See _<<Cache debugging>>_
    for more information. The default is false.

[#config_debug_dir]
*debug_dir* (*CCACHE_DEBUGDIR*)::

    Specifies where to write per-object debug files if the <<config_debug,debug
    mode>> is enabled. If set to the empty string, the files will be written
    next to the object file. If set to a directory, the debug files will be
    written with full absolute paths in that directory, creating it if needed.
    The default is the empty string.
+
For example, if *debug_dir* is set to `/example`, the current working directory
is `/home/user` and the object file is `build/output.o` then the debug log will
be written to `/example/home/user/build/output.o.ccache-log`. See also
_<<Cache debugging>>_.

[#config_depend_mode]
*depend_mode* (*CCACHE_DEPEND* or *CCACHE_NODEPEND*, see _<<Boolean values>>_ above)::

    If true, the depend mode will be used. The default is false. See
    _<<The depend mode>>_.

[#config_direct_mode]
*direct_mode* (*CCACHE_DIRECT* or *CCACHE_NODIRECT*, see _<<Boolean values>>_ above)::

    If true, the direct mode will be used. The default is true. See
    _<<The direct mode>>_.

[#config_disable]
*disable* (*CCACHE_DISABLE* or *CCACHE_NODISABLE*, see _<<Boolean values>>_ above)::

    When true, ccache will just call the real compiler, bypassing the cache
    completely. The default is false.
+
It is also possible to disable ccache for a specific source code file by adding
the string `ccache:disable` in a comment in the first 4096 bytes of the file.

[#config_extra_files_to_hash]
*extra_files_to_hash* (*CCACHE_EXTRAFILES*)::

    This option is a list of paths to files that ccache will include in the the
    hash sum that identifies the build. The list separator is semicolon on
    Windows systems and colon on other systems.

[#config_file_clone]
*file_clone* (*CCACHE_FILECLONE* or *CCACHE_NOFILECLONE*, see _<<Boolean values>>_ above)::

    If true, ccache will attempt to use file cloning (also known as "`copy on
    write`", "`CoW`" or "`reflinks`") to store and fetch cached compiler
    results. *file_clone* has priority over <<config_hard_link,*hard_link*>>.
    The default is false.
+
Files stored by cloning cannot be compressed, so the cache size will likely be
significantly larger if this option is enabled. However, performance may be
improved depending on the use case.
+
Unlike the <<config_hard_link,*hard_link*>> option, *file_clone* is completely
safe to use, but not all file systems support the feature. For such file
systems, ccache will fall back to use plain copying (or hard links if
<<config_hard_link,*hard_link*>> is enabled).

[#config_hard_link]
*hard_link* (*CCACHE_HARDLINK* or *CCACHE_NOHARDLINK*, see _<<Boolean values>>_ above)::

    If true, ccache will attempt to use hard links to store and fetch cached
    object files. The default is false.
+
Files stored via hard links cannot be compressed, so the cache size will likely
be significantly larger if this option is enabled. However, performance may be
improved depending on the use case.
+
WARNING: Do not enable this option unless you are aware of these caveats:
+
* If the resulting file is modified, the file in the cache will also be
  modified since they share content, which corrupts the cache entry. As of
  version 4.0, ccache makes stored and fetched object files read-only as a
  safety measure. Furthermore, a simple integrity check is made for cached
  object files by verifying that their sizes are correct. This means that
  mistakes like `strip file.o` or `echo >file.o` will be detected even if the
  object file is made writable, but a modification that doesn't change the file
  size will not.
* Programs that don't expect that files from two different identical
  compilations are hard links to each other can fail.
* Programs that rely on modification times (like `make`) can be confused if
  several users (or one user with several build trees) use the same cache
  directory. The reason for this is that the object files share i-nodes and
  therefore modification times. If `file.o` is in build tree *A* (hard-linked
  from the cache) and `file.o` then is produced by ccache in build tree *B* by
  hard-linking from the cache, the modification timestamp will be updated for
  `file.o` in build tree *A* as well. This can retrigger relinking in build tree
  *A* even though nothing really has changed.

[#config_hash_dir]
*hash_dir* (*CCACHE_HASHDIR* or *CCACHE_NOHASHDIR*, see _<<Boolean values>>_ above)::

    If true (which is the default), ccache will include the current working
    directory (CWD) in the hash that is used to distinguish two compilations
    when generating debug info (compiler option `-g` with variations).
    Exception: The CWD will not be included in the hash if
    <<config_base_dir,*base_dir*>> is set (and matches the CWD) and the
    compiler option `-fdebug-prefix-map` is used. See also the discussion under
    _<<Compiling in different directories>>_.
+
The reason for including the CWD in the hash by default is to prevent a problem
with the storage of the current working directory in the debug info of an
object file, which can lead ccache to return a cached object file that has the
working directory in the debug info set incorrectly.
+
You can disable this option to get cache hits when compiling the same source
code in different directories if you don't mind that CWD in the debug info
might be incorrect.

[#config_ignore_headers_in_manifest]
*ignore_headers_in_manifest* (*CCACHE_IGNOREHEADERS*)::

    This option is a list of paths to files (or directories with headers) that
    ccache will *not* include in the manifest list that makes up the direct
    mode. Note that this can cause stale cache hits if those headers do indeed
    change. The list separator is semicolon on Windows systems and colon on
    other systems.

[#config_ignore_options]
*ignore_options* (*CCACHE_IGNOREOPTIONS*)::

    This option is a space-delimited list of compiler options that ccache will
    exclude from the hash. Excluding a compiler option from the hash can be
    useful when you know it doesn't affect the result (but ccache doesn't know
    that), or when it does and you don't care. If a compiler option in the list
    is suffixed with an asterisk (`*`) it will be matched as a prefix. For
    example, `+-fmessage-length=*+` will match both `-fmessage-length=20` and
    `-fmessage-length=70`.

[#config_inode_cache]
*inode_cache* (*CCACHE_INODECACHE* or *CCACHE_NOINODECACHE*, see _<<Boolean values>>_ above)::

    If true, ccache will cache source file hashes based on device, inode and
    timestamps. This reduces the time spent on hashing include files since the
    result can be reused between compilations. The default is true. The feature
    requires <<config_temporary_dir,*temporary_dir*>> to be located on a local
    filesystem of a supported type.
+
NOTE: The inode cache feature is currently not available on Windows.

[#config_keep_comments_cpp]
*keep_comments_cpp* (*CCACHE_COMMENTS* or *CCACHE_NOCOMMENTS*, see _<<Boolean values>>_ above)::

    If true, ccache will not discard the comments before hashing preprocessor
    output. The default is false. This can be used to check documentation with
    `-Wdocumentation`.

[#config_log_file]
*log_file* (*CCACHE_LOGFILE*)::

    If set to a file path, ccache will write information on what it is doing to
    the specified file. This is useful for tracking down problems.
+
If set to *syslog*, ccache will log using `syslog()` instead of to a file. If
you use rsyslogd, you can add something like this to `/etc/rsyslog.conf` or a
file in `/etc/rsyslog.d`:
+
-------------------------------------------------------------------------------
# log ccache to file
:programname, isequal, "ccache"         /var/log/ccache
# remove from syslog
& ~
-------------------------------------------------------------------------------

[#config_max_files]
*max_files* (*CCACHE_MAXFILES*)::

    This option specifies the maximum number of files to keep in the cache. Use
    0 for no limit (which is the default). See also _<<Cache size management>>_.

[#config_max_size]
*max_size* (*CCACHE_MAXSIZE*)::

    This option specifies the maximum size of the cache. Use 0 for no limit. The
    default value is 5G. Available suffixes: k, M, G, T (decimal) and Ki, Mi,
    Gi, Ti (binary). The default suffix is G. See also
    _<<Cache size management>>_.

[#config_msvc_dep_prefix]
*msvc_dep_prefix* (*CCACHE_MSVC_DEP_PREFIX*)::

    This option specifies the prefix of included files output for MSVC compiler.
    The default prefix is "`Note: including file:`". If you use a localized
    compiler, this should be set accordingly.

[#config_namespace]
*namespace* (*CCACHE_NAMESPACE*)::

    If set, the namespace string will be added to the hashed data for each
    compilation. This will make the associated cache entries logically separate
    from cache entries with other namespaces, but they will still share the same
    storage space. Cache entries can also be selectively removed from the local
    cache with the command line option `--evict-namespace`, potentially in
    combination with `--evict-older-than`.
+
For instance, if you use the same local cache for several disparate projects,
you can use a unique namespace string for each one. This allows you to remove
cache entries that belong to a certain project if you stop working with that
project.

[#config_path]
*path* (*CCACHE_PATH*)::

    If set, ccache will search directories in this list when looking for the
    real compiler. The list separator is semicolon on Windows systems and colon
    on other systems. If not set, ccache will look for the first executable
    matching the compiler name in the normal `PATH` that isn't a symbolic link
    to ccache itself.

[#config_pch_external_checksum]
*pch_external_checksum* (*CCACHE_PCH_EXTSUM* or *CCACHE_NOPCH_EXTSUM*, see _<<Boolean values>>_ above)::

    When this option is set, and ccache finds a precompiled header file,
    ccache will look for a file with the extension "`.sum`" added
    (e.g. "`pre.h.gch.sum`"), and if found, it will hash this file instead
    of the precompiled header itself to work around the performance
    penalty of hashing very large files.

[#config_prefix_command]
*prefix_command* (*CCACHE_PREFIX*)::

    This option adds a list of prefixes (separated by space) to the command line
    that ccache uses when invoking the compiler. See also
    _<<Using ccache with other compiler wrappers>>_.

[#config_prefix_command_cpp]
*prefix_command_cpp* (*CCACHE_PREFIX_CPP*)::

    This option adds a list of prefixes (separated by space) to the command
    line that ccache uses when invoking the preprocessor.

[#config_read_only]
*read_only* (*CCACHE_READONLY* or *CCACHE_NOREADONLY*, see _<<Boolean values>>_ above)::

    If true, ccache will attempt to use existing cached results, but it will not
    add new results to any cache backend. Statistics counters will still be
    updated, though, unless the <<config_stats,*stats*>> option is set to
    *false*.
+
If you are using this because your ccache directory is read-only, you need to
set <<config_temporary_dir,*temporary_dir*>> since ccache will fail to create
temporary files otherwise. You may also want to set <<config_stats,*stats*>> to
*false* make ccache not even try to update stats files.

[#config_read_only_direct]
*read_only_direct* (*CCACHE_READONLY_DIRECT* or *CCACHE_NOREADONLY_DIRECT*, see _<<Boolean values>>_ above)::

    Just like <<config_read_only,*read_only*>> except that ccache will only try
    to retrieve results from the cache using the direct mode, not the
    preprocessor mode. See documentation for <<config_read_only,*read_only*>>
    regarding using a read-only ccache directory.

[#config_recache]
*recache* (*CCACHE_RECACHE* or *CCACHE_NORECACHE*, see _<<Boolean values>>_ above)::

    If true, ccache will not use any previously stored result. New results will
    still be cached, possibly overwriting any pre-existing results.

[#config_remote_only]
*remote_only* (*CCACHE_REMOTE_ONLY* or *CCACHE_NOREMOTE_ONLY*, see _<<Boolean values>>_ above)::

    If true, ccache will only use <<config_remote_storage,remote storage>>. The
    default is false. Note that cache statistics counters will still be kept in
    the local cache directory unless <<config_stats,*stats*>> is false. See also
    _<<Storage interaction>>_.

[#config_remote_storage]
*remote_storage* (*CCACHE_REMOTE_STORAGE*)::

    This option specifies one or several storage backends (separated by space)
    to query after checking the local cache (unless
    <<config_remote_only,*remote_only*>> is true). See
    _<<Remote storage backends>>_ for documentation of syntax and available
    backends.
+
Examples:
+
* `+file:/shared/nfs/directory+`
* `+file:///shared/nfs/one|read-only file:///shared/nfs/two+`
* `+http://example.com/cache+`
* `+redis://example.com+`
+
NOTE: In previous ccache versions this option was called *secondary_storage*
(*CCACHE_SECONDARY_STORAGE*), which can still be used as an alias.

[#config_reshare]
*reshare* (*CCACHE_RESHARE* or *CCACHE_NORESHARE*, see _<<Boolean values>>_ above)::

    If true, ccache will write results to remote storage even for local storage
    cache hits. The default is false.

[#config_run_second_cpp]
*run_second_cpp* (*CCACHE_CPP2* or *CCACHE_NOCPP2*, see _<<Boolean values>>_ above)::

    If true, ccache will first run the preprocessor to preprocess the source
    code (see _<<The preprocessor mode>>_) and then on a cache miss run the
    compiler on the source code to get hold of the object file. This is the
    default.
+
If false, ccache will first run preprocessor to preprocess the source code and
then on a cache miss run the compiler on the _preprocessed source code_ instead
of the original source code. This makes cache misses slightly faster since the
source code only has to be preprocessed once. The downside is that some
compilers won't produce the same result (for instance diagnostics warnings)
when compiling preprocessed source code.
+
A solution to the above mentioned downside is to set *run_second_cpp* to false
and pass `-fdirectives-only` (for GCC) or `-frewrite-includes` (for Clang) to
the compiler. This will cause the compiler to leave the macros and other
preprocessor information, and only process the *#include* directives. When run
in this way, the preprocessor arguments will be passed to the compiler since it
still has to do _some_ preprocessing (like macros).
+
This option is ignored with MSVC, as there is no way to make it compile without
preprocessing first.

[#config_sloppiness]
*sloppiness* (*CCACHE_SLOPPINESS*)::

    By default, ccache tries to give as few false cache hits as possible.
    However, in certain situations it's possible that you know things that
    ccache can't take for granted. This option makes it possible to tell
    ccache to relax some checks in order to increase the hit rate. The value
    should be a comma-separated string with one or several of the following
    values:
+
--
*clang_index_store*::
    Ignore the Clang compiler option `-index-store-path` and its argument when
    computing the manifest hash. This is useful if you use Xcode, which uses an
    index store path derived from the local project path. Note that the index
    store won't be updated correctly on cache hits if you enable this
    sloppiness.
*file_stat_matches*::
    Ccache normally examines a file's contents to determine whether it matches
    the cached version. With this sloppiness set, ccache will consider a file
    as matching its cached version if the mtimes and ctimes match.
*file_stat_matches_ctime*::
    Ignore ctimes when *file_stat_matches* is enabled. This can be useful when
    backdating files' mtimes in a controlled way.
*gcno_cwd*::
    By default, ccache will include the current working directory in the hash
    when producing a `.gcno` file (when compiling with `-ftest-coverage` or
    `--coverage`). This is because GCC 9+ includes the current working directory
    in the `.gcno` file. The *gcno_cwd* sloppiness makes ccache not hash the
    current working directory so that you can get cache hits when compiling in
    different directories, with the tradeoff of potentially getting an incorrect
    directory in the `.gcno` file. *gcno_cwd* also disables hashing of the
    current working directory if `-fprofile-abs-path` is used.
*include_file_ctime*::
    By default, ccache will disable the direct mode if an include file has too
    new ctime. This sloppiness disables that check. See also _<<Handling of
    newly created header files>>_.
*include_file_mtime*::
    By default, ccache will disable the direct mode if an include file has too
    new mtime. This sloppiness disables that check. See also _<<Handling of
    newly created header files>>_.
*ivfsoverlay*::
    Ignore the Clang compiler option `-ivfsoverlay` and its argument. This is
    useful if you use Xcode, which uses a virtual file system (VFS) for things
    like combining Objective-C and Swift code.
*locale*::
    Ccache includes the environment variables `LANG`, `LC_ALL`, `LC_CTYPE` and
    `LC_MESSAGES` in the hash by default since they may affect localization of
    compiler warning messages. Set this sloppiness to tell ccache not to do
    that.
*modules*::
    By default, ccache will not cache compilations if `-fmodules` is used since
    it cannot hash the state of compiler's internal representation of relevant
    modules. This sloppiness allows caching in such a case. See
    _<<C++ modules>>_ for more information.
*pch_defines*::
    Be sloppy about `#define` directives when precompiling a header file. See
    _<<Precompiled headers>>_ for more information.
*random_seed*::
    Ignore the `-frandom-seed` option and its arguments when computing the input
    hash. This is useful if your build system generates different seeds between
    builds and you are OK with reusing cached results.
*system_headers*::
    By default, ccache will also include all system headers in the manifest.
    With this sloppiness set, ccache will only include system headers in the
    hash but not add the system header files to the list of include files.
*time_macros*::
    Ignore `+__DATE__+`, `+__TIME__+` and `+__TIMESTAMP__+` being present in the
    source code.
--
+
See the discussion under _<<Troubleshooting>>_ for more information.

[#config_stats]
*stats* (*CCACHE_STATS* or *CCACHE_NOSTATS*, see _<<Boolean values>>_ above)::

    If true, ccache will update the statistics counters on each compilation. The
    default is true. If false, _<<automatic cleanup>>_ will be disabled as well.

[#config_stats_log]
*stats_log* (*CCACHE_STATSLOG*)::

    If set to a file path, ccache will write statistics counter updates to the
    specified file. This is useful for getting statistics for individual builds.
    To show a summary of the current stats log, use `ccache --show-log-stats`.
+
NOTE: Lines in the stats log starting with a hash sign (`#`) are comments.

[#config_temporary_dir]
*temporary_dir* (*CCACHE_TEMPDIR*)::

    This option specifies where ccache will put temporary files. The default is
    `$XDG_RUNTIME_DIR/ccache-tmp` (typically `/run/user/<UID>/ccache-tmp`) if
    `XDG_RUNTIME_DIR` is set and the directory exists, otherwise
    `<cache_dir>/tmp`.
+
NOTE: In previous versions of ccache, *CCACHE_TEMPDIR* had to be on the same
filesystem as the `CCACHE_DIR` path, but this requirement has been relaxed.

[#config_umask]
*umask* (*CCACHE_UMASK*)::

    This option (an octal integer) specifies the umask for files and directories
    in the cache directory. This is mostly useful when you wish to share your
    cache with other users.


=== Disabling ccache

To disable ccache completely for all invocations, set <<config_disable,*disable
= true*>> (`CCACHE_DISABLE=1`). You can also disable ccache for a certain source
code file by adding the string `ccache:disable` in a comment in the first 4096
bytes of the file. In the latter case the `Ccache disabled` statistics counter
will be increased.


== Remote storage backends

The <<config_remote_storage,*remote_storage*>> option lets you configure ccache
to use one or several remote storage backends. By default, the local cache
directory located in <<config_cache_dir,*cache_dir*>> will be queried first and
remote storage second, but <<config_remote_only,*remote_only*>> can be set to
true to disable local storage. Note that cache statistics counters will still be
kept in the local cache directory -- remote storage backends only store
compilation results and manifests.

A remote storage backend is specified with a URL, optionally followed by a pipe
(`|`) and a pipe-separated list of attributes. An attribute is _key_=_value_ or
just _key_ as a short form of _key_=*true*. Attribute values must be
https://en.wikipedia.org/wiki/Percent-encoding[percent-encoded] if they contain
percent, pipe or space characters.

=== Attributes for all backends

These optional attributes are available for all remote storage backends:

* *read-only*: If *true*, only read from this backend, don't write. The default
  is *false*.
* *shards*: A comma-separated list of names for sharding (partitioning) the
  cache entries using
  https://en.wikipedia.org/wiki/Rendezvous_hashing[Rendezvous hashing],
  typically to spread the cache over a server cluster. When set, the storage URL
  must contain an asterisk (`+*+`), which will be replaced by one of the shard
  names to form a real URL. A shard name can optionally have an appended weight
  within parentheses to indicate how much of the key space should be associated
  with that shard. A shard with weight *w* will contain *w*/*S* of the cache,
  where *S* is the sum of all shard weights. A weight could for instance be set
  to represent the available memory for a memory cache on a specific server. The
  default weight is *1*.
+
Examples:
+
--
* `+redis://cache-*.example.com|shards=a(3),b(1),c(1.5)+` will put 55% (3/5.5)
  of the cache on `+redis://cache-a.example.com+`, 18% (1/5.5) on
  `+redis://cache-b.example.com+` and 27% (1.5/5.5) on
  `+redis://cache-c.example.com+`.
* `+http://example.com/*|shards=alpha,beta+` will put 50% of the cache on
  `+http://example.com/alpha+` and 50% on `+http://example.com/beta+`.
--


=== Storage interaction

The table below describes the interaction between local and remote storage on
cache hits and misses if <<config_remote_only,*remote_only*>> is false (which is
the default):

[options="header",cols="20%,20%,60%"]
|==============================================================================
| *Local storage* | *Remote storage* | *What happens*

| miss | miss | Compile, write to local, write to remote^[1]^
| miss | hit  | Read from remote, write to local
| hit  | -    | Read from local, don't write to remote^[2]^

|==============================================================================

^[1]^ Unless remote storage has attribute `read-only=true`. +
^[2]^ Unless local storage is set to share its cache hits with the
<<config_reshare,*reshare*>> option.

If <<config_remote_only,*remote_only*>> is true:

[options="header",cols="20%,20%,60%"]
|==============================================================================
| *Local storage* | *Remote storage* | *What happens*

| - | miss | Compile, write to remote, don't write to local
| - | hit  | Read from remote, don't write to local

|==============================================================================

=== File storage backend

URL format: `+file:DIRECTORY+` or `+file://[HOST]DIRECTORY+`

This backend stores data as separate files in a directory structure below
*DIRECTORY*, similar (but not identical) to the local cache storage. A typical
use case for this backend would be sharing a cache on an NFS directory.
*DIRECTORY* must start with a slash. *HOST* can be the empty string or
localhost. On Windows, *HOST* can also be the name of a server hosting a shared
folder.

IMPORTANT: ccache will not perform any cleanup of the storage -- that has to be
done by other means, for instance by running `ccache --trim-dir` periodically.

Examples:

* `+file:/shared/nfs/directory+`
* `+file:///shared/nfs/directory|umask=002|update-mtime=true+`
* `+file://example.com/shared/folder+`

Optional attributes:

* *layout*: How to store file under the cache directory. Available values:
+
--
* *flat*: Store all files directly under the cache directory.
* *subdirs*: Store files in 256 subdirectories of the cache directory.
--
+
The default is *subdirs*.
* *umask*: This attribute (an octal integer) overrides the umask to use for
  files and directories in the cache directory.
* *update-mtime*: If *true*, update the modification time (mtime) of cache
  entries that are read. The default is *false*.


=== HTTP storage backend

URL format: `+http://HOST[:PORT][/PATH]+`

This backend stores data in an HTTP-compatible server. The required HTTP methods
are `GET`, `PUT` and `DELETE`.

IMPORTANT: ccache will not perform any cleanup of the storage -- that has to be
done by other means, for instance by running `ccache --trim-dir` periodically.

NOTE: HTTPS is not supported.

TIP: See https://ccache.dev/howto/http-storage.html[How to set up HTTP storage]
for hints on how to set up an HTTP server for use with ccache.

Examples:

* `+http://localhost+`
* `+http://someusername:p4ssw0rd@example.com/cache/+`
* `+http://localhost:8080|layout=bazel|connect-timeout=50+`

Optional attributes:

* *bearer-token*: Bearer token used to authorize the HTTP requests.
* *connect-timeout*: Timeout (in ms) for network connection. The default is 100.
* *keep-alive*: If *true*, keep the HTTP connection to the storage server open
  to avoid reconnects. The default is *true*.
* *layout*: How to map key names to the path part of the URL. Available values:
+
--
* *bazel*: Store values in a format compatible with the Bazel HTTP caching
   protocol. More specifically, the entries will be stored as 64 hex digits
   under the `/ac/` part of the cache.
+
NOTE: You may have to disable verification of action cache values in the server
for this to work since ccache entries are not valid action result metadata
values.
* *flat*: Append the key directly to the path part of the URL (with a leading
   slash if needed).
* *subdirs*: Append the first two characters of the key to the URL (with a
  leading slash if needed), followed by a slash and the rest of the key. This
  divides the entries into 256 buckets.
--
+
The default is *subdirs*.
* *operation-timeout*: Timeout (in ms) for HTTP requests. The default is 10000.


=== Redis storage backend

URL formats:

`+redis://[[USERNAME:]PASSWORD@]HOST[:PORT][/DBNUMBER]+` +
`+redis+unix:SOCKET_PATH[?db=DBNUMBER]+` +
`+redis+unix://[[USERNAME:]PASSWORD@localhost]SOCKET_PATH[?db=DBNUMBER]+`

This backend stores data in a https://redis.io[Redis] (or Redis-compatible)
server. There are implementations for both memory-based and disk-based storage.
*PORT* defaults to *6379* and *DBNUMBER* defaults to *0*.

NOTE: ccache will not perform any cleanup of the Redis storage, but you can
https://redis.io/topics/lru-cache[configure LRU eviction].

TIP: See https://ccache.dev/howto/redis-storage.html[How to set up Redis
storage] for hints on setting up a Redis server for use with ccache.

TIP: You can set up a cluster of Redis servers using the `shards` attribute
described in _<<Remote storage backends>>_.

Examples:

* `+redis://localhost+`
* `+redis://p4ssw0rd@cache.example.com:6379/0|connect-timeout=50+`
* `+redis+unix:/run/redis.sock+`
* `+redis+unix:///run/redis.sock+`
* `+redis+unix://p4ssw0rd@localhost/run/redis.sock?db=0+`

Optional attributes:

* *connect-timeout*: Timeout (in ms) for network connection. The default is 100.
* *operation-timeout*: Timeout (in ms) for Redis commands. The default is 10000.


== Cache size management

By default, ccache has a 5 GB limit on the total size of files in the cache and
no limit on the number of files. You can set different limits using the command
line options `-M`/`--max-size` and `-F`/`--max-files`. Use the
`-s`/`--show-stats` option to see the cache size and the currently configured
limits (in addition to other various statistics).

Cleanup can be triggered in two different ways: automatic and manual.


=== Automatic cleanup

After a new compilation result has been written to the local cache, ccache will
trigger an automatic cleanup if <<config_max_size,*max_size*>> or
<<config_max_files,*max_files*>> is exceeded. The cleanup removes cache entries
in LRU (least recently used) order based on the modification time (mtime) of
files in the cache. For this reason, ccache updates mtime of the cache files
read on a cache hit to mark them as recently used.


=== Manual cleanup

You can run `ccache -c/--cleanup` to force cleanup of the whole cache. This will
recalculate the cache size information and also make sure that the cache size
does not exceed <<config_max_size,*max_size*>> and
<<config_max_files,*max_files*>>.


== Cache compression

Ccache will by default compress all data it puts into the cache using the
compression algorithm http://zstd.net[Zstandard] (zstd) using compression level
1. The algorithm is fast enough that there should be little reason to turn off
compression to gain performance. One exception is if the cache is located on a
compressed file system, in which case the compression performed by ccache of
course is redundant. See the documentation for the configuration options
<<config_compression,*compression*>> and
<<config_compression_level,*compression_level*>> for more information.

You can use the command line option `-x`/`--show-compression` to print
information related to compression. Example:

-------------------------------------------------------------------------------
Total data:           14.8 GB (16.0 GB disk blocks)
Compressed data:      11.3 GB (30.6% of original size)
  Original size:      36.9 GB
  Compression ratio: 3.267 x  (69.4% space savings)
Incompressible data:   3.5 GB
-------------------------------------------------------------------------------

Notes:

* The "`disk blocks`" size is the cache size when taking disk block size into
  account. This value should match the "`Cache size`" value from "`ccache
  --show-stats`". The other size numbers refer to actual content sizes.
* "`Compressed data`" refers to result and manifest files stored in the cache.
* "`Incompressible data`" refers to files that are always stored uncompressed
  (triggered by enabling <<config_file_clone,*file_clone*>> or
  <<config_hard_link,*hard_link*>>) or unknown files (for instance files
  created by older ccache versions).
* The compression ratio is affected by
  <<config_compression_level,*compression_level*>>.

The cache data can also be recompressed to another compression level (or made
uncompressed) with the command line option `-X`/`--recompress`. If you choose to
disable compression by default or to use a low compression level, you can
(re)compress newly cached data with a higher compression level after the build
or at another time when there are more CPU cycles available, for instance every
night. Full recompression potentially takes a lot of time, but only files that
are currently compressed with a different level than the target level will be
recompressed.


== Cache statistics

`ccache --show-stats` shows a summary of statistics, including cache size,
cleanups (number of performed cleanups, either implicitly due to a cache size
limit being reached or due to explicit `ccache -c` calls), overall hit rate, hit
rate for <<The direct mode,direct>>/<<The preprocessor mode,preprocessed>> modes
and hit rate for local and <<config_remote_storage,remote storage>>.

The summary also includes counters called "`Errors`" and "`Uncacheable`", which
are sums of more detailed counters. To see those detailed counters, use the
`-v`/`--verbose` flag. The verbose mode can show the following counters:

[options="header",cols="30%,70%"]
|==============================================================================
| *Counter* | *Description*

| Autoconf compile/link |
Uncacheable compilation or linking by an Autoconf test.

| Bad compiler arguments |
Malformed compiler argument, e.g. missing a value for a compiler option that
requires an argument or failure to read a file specified by a compiler option
argument.

| Called for linking |
The compiler was called for linking, not compiling. Ccache only supports
compilation of a single file, i.e. calling the compiler with the `-c` option to
produce a single object file from a single source file.

| Called for preprocessing |
The compiler was called for preprocessing, not compiling.

| Ccache disabled |
Ccache was disabled by a `ccache:disable` string in the source code file.

| Could not use modules |
Preconditions for using <<C++ modules>> were not fulfilled.

| Could not use precompiled header |
Preconditions for using <<Precompiled headers,precompiled headers>> were not
fulfilled.

| Could not write to output file |
The output path specified with `-o` could not be written to.

| Compilation failed |
The compilation failed. No result stored in the cache.

| Compiler check failed |
A compiler check program specified by
<<config_compiler_check,*compiler_check*>> (*CCACHE_COMPILERCHECK*) failed.

| Compiler output file missing |
One of the files expected to be produced by the compiler was missing after
compilation.

| Compiler produced empty output |
The compiler's output file (typically an object file) was empty after
compilation.

| Could not find the compiler |
The compiler to execute could not be found.

| Error hashing extra file |
Failure reading a file specified by
<<config_extra_files_to_hash,*extra_files_to_hash*>> (*CCACHE_EXTRAFILES*).

| Forced recache |
<<config_recache,*CCACHE_RECACHE*>> was used to overwrite an existing result.

| Internal error |
Unexpected failure, e.g. due to problems reading/writing the cache.

| Missing cache file |
A file was unexpectedly missing from the cache. This only happens in rare
situations, e.g. if one ccache instance is about to get a file from the cache
while another instance removed the file as part of cache cleanup.

| Multiple source files |
The compiler was called to compile multiple source files in one go. This is not
supported by ccache.

| No input file |
No input file was specified to the compiler.

| Output to stdout |
The compiler was instructed to write its output to standard output using `-o -`.
This is not supported by ccache.

| Preprocessing failed |
Preprocessing the source code using the compiler's `-E` option failed.

| Unsupported code directive |
Code like the assembler `.incbin` directive was found. This is not supported
by ccache.

| Unsupported compiler option |
A compiler option not supported by ccache was found.

| Unsupported environment variable |
An environment variable not supported by ccache was set.

| Unsupported source language |
A source language e.g. specified with `-x` was unsupported by ccache.

|==============================================================================


== How ccache works

The basic idea is to detect when you are compiling exactly the same code a
second time and reuse the previously produced output. The detection is done by
hashing different kinds of information that should be unique for the
compilation and then using the hash sum to identify the cached output. Ccache
uses BLAKE3, a very fast cryptographic hash algorithm, for the hashing. On a
cache hit, ccache is able to supply all of the correct compiler outputs
(including all warnings, dependency file, etc) from the cache. Data stored in
the cache is checksummed with XXH3, an extremely fast non-cryptographic
algorithm, to detect corruption.

Ccache has two ways of gathering information used to look up results in the
cache:

* the *preprocessor mode*, where ccache runs the preprocessor on the source
  code and hashes the result
* the *direct mode*, where ccache hashes the source code and include files
  directly

The direct mode is generally faster since running the preprocessor has some
overhead.

If no previous result is detected (i.e., there is a cache miss) using the direct
mode, ccache will fall back to the preprocessor mode unless the *depend mode* is
enabled. In the depend mode, ccache never runs the preprocessor, not even on
cache misses. Read more in _<<The depend mode>>_ below.


=== Common hashed information

The following information is always included in the hash:

* the extension used by the compiler for a file with preprocessor output
  (normally `.i` for C code and `.ii` for C++ code)
* the compiler's size and modification time (or other compiler-specific
  information specified by <<config_compiler_check,*compiler_check*>>)
* the name of the compiler
* the current directory (if <<config_hash_dir,*hash_dir*>> is enabled)
* contents of files specified by
  <<config_extra_files_to_hash,*extra_files_to_hash*>> (if any)


=== The preprocessor mode

In the preprocessor mode, the hash is formed of the common information and:

* the preprocessor output from running the compiler with `-E`
* the command line options except those that affect include files (`-I`,
  `-include`, `-D`, etc; the theory is that these command line options will
  change the preprocessor output if they have any effect at all)
* any standard error output generated by the preprocessor

Based on the hash, the cached compilation result can be looked up directly in
the cache.


=== The direct mode

In the direct mode, the hash is formed of the common information and:

* the input source file
* the compiler options

Based on the hash, a data structure called "`manifest`" is looked up in the
cache. The manifest contains:

* references to cached compilation results (object file, dependency file, etc)
  that were produced by previous compilations that matched the hash
* paths to the include files that were read at the time the compilation results
  were stored in the cache
* hash sums of the include files at the time the compilation results were
  stored in the cache

The current contents of the include files are then hashed and compared to the
information in the manifest. If there is a match, ccache knows the result of
the compilation. If there is no match, ccache falls back to running the
preprocessor. The output from the preprocessor is parsed to find the include
files that were read. The paths and hash sums of those include files are then
stored in the manifest along with information about the produced compilation
result.

There is a catch with the direct mode: header files that were used by the
compiler are recorded, but header files that were *not* used, but would have
been used if they existed, are not. So, when ccache checks if a result can be
taken from the cache, it currently can't check if the existence of a new header
file should invalidate the result. In practice, the direct mode is safe to use
in the absolute majority of cases.

The direct mode will be disabled if any of the following holds:

* <<config_direct_mode,*direct_mode*>> is false
* a modification time of one of the include files is too new (needed to avoid a
  race condition)
* a compiler option not supported by the direct mode is used:
** a `-Wp,++*++` compiler option other than `-Wp,-MD,<path>`, `-Wp,-MMD,<path>`,
   `-Wp,-D<macro[=defn]>` or `-Wp,-U<macro>`
** `-Xpreprocessor`
* the string `+__TIME__+` is present in the source code


=== The depend mode

If the depend mode is enabled, ccache will not use the preprocessor at all. The
hash used to identify results in the cache will be based on the direct mode
hash described above plus information about include files read from the
dependency list generated by MSVC with `/showIncludes`, or the dependency file
generated by other compilers with `-MD` or `-MMD`.

Advantages:

* The ccache overhead of a cache miss will be much smaller.
* Not running the preprocessor at all can be good if compilation is performed
  remotely, for instance when using distcc or similar; ccache then won't make
  potentially costly preprocessor calls on the local machine.

Disadvantages:

* The cache hit rate will likely be lower since any change to compiler options
  or source code will make the hash different. Compare this with the default
  setup where ccache will fall back to the preprocessor mode, which is tolerant
  to some types of changes of compiler options and source code changes.
* If `-MD` is used, the manifest entries will include system header files as
  well, thus slowing down cache hits slightly, just as using `-MD` slows down
  make. This is also the case for MSVC with `/showIncludes`.
* If `-MMD` is used, the manifest entries will not include system header files,
  which means ccache will ignore changes in them.

The depend mode will be disabled if any of the following holds:

* <<config_depend_mode,*depend_mode*>> is false.
* <<config_run_second_cpp,*run_second_cpp*>> is false.
* The compiler is not generating dependencies using `-MD` or `-MMD` (for MSVC,
  `/showIncludes` is added automatically if not specified by the user).


== Handling of newly created header files

If modification time (mtime) or status change time (ctime) of one of the include
files is equal to (or newer than) the time compilation is being done, ccache
disables the direct mode (or, in the case of a <<Precompiled headers,precompiled
header>>, disables caching completely). This done as a safety measure to avoid a
race condition (see below).

To be able to use a newly created header files in direct mode (or use a newly
precompiled header), either:

* create the include file earlier in the build process, or
* set <<config_sloppiness,*sloppiness*>> to
  *include_file_ctime,include_file_mtime* if you are willing to take the risk,
  for instance if you know that your build system is robust enough not to
  trigger the race condition.

For reference, the race condition mentioned above consists of these events:

1. The preprocessor is run.
2. An include file is modified by someone.
3. The new include file is hashed by ccache.
4. The real compiler is run on the preprocessor's output, which contains data
   from the old header file.
5. The wrong object file is stored in the cache.


== Cache debugging

To find out what information ccache actually is hashing, you can enable the
debug mode via the configuration option <<config_debug,*debug*>> or by setting
`CCACHE_DEBUG` in the environment. This can be useful if you are investigating
why you don't get cache hits. Note that performance will be reduced slightly.

When the debug mode is enabled, ccache will create up to five additional files
next to the object file:

[options="header",cols="30%,70%"]
|==============================================================================
| *Filename* | *Description*

| `<objectfile>.<timestamp>.ccache-input-c` |
Binary input hashed by both the direct mode and the preprocessor mode.

| `<objectfile>.<timestamp>.ccache-input-d` |
Binary input only hashed by the direct mode.

| `<objectfile>.<timestamp>.ccache-input-p` |
Binary input only hashed by the preprocessor mode.

| `<objectfile>.<timestamp>.ccache-input-text` |
Human-readable combined diffable text version of the three files above.

| `<objectfile>.<timestamp>.ccache-log` |
Log for this object file.

|==============================================================================

 The timestamp format is
`<year><month><day>_<hour><minute><second>_<microsecond>`.

If <<config_debug_dir,*debug_dir*>> (environment variable `CCACHE_DEBUGDIR`) is
set, the files above will be written to that directory with full absolute paths
instead of next to the object file.

In the direct mode, ccache uses the 160 bit BLAKE3 hash of the
"`ccache-input-c`" + "`ccache-input-d`" data (where *+* means concatenation),
while the "`ccache-input-c`" + "`ccache-input-p`" data is used in the
preprocessor mode.

The "`ccache-input-text`" file is a combined text version of the three binary
input files. It has three sections ("`COMMON`", "`DIRECT MODE`" and
"`PREPROCESSOR MODE`"), which is turn contain annotations that say what kind of
data comes next.

To debug why you don't get an expected cache hit for an object file, you can do
something like this:

1. Enable `debug` (`CCACHE_DEBUG`).
2. Build.
3. Clean and build again.
4. Compare the `<objectfile>.<timestamp>.ccache-input-text` files for the two
   builds. This together with the `<objectfile>.<timestamp>.ccache-log` files
   should give you some clues about what is happening.


== Compiling in different directories

Some information included in the hash that identifies a unique compilation can
contain absolute paths:

* The preprocessed source code may contain absolute paths to include files if
  the compiler option `-g` is used or if absolute paths are given to `-I` and
  similar compiler options.
* Paths specified by compiler options (such as `-I`, `-MF`, etc) on the command
  line may be absolute.
* The source code file path may be absolute, and that path may substituted for
  `+__FILE__+` macros in the source code or included in warnings emitted to
  standard error by the preprocessor.

This means that if you compile the same code in different locations, you can't
share compilation results between the different build directories since you get
cache misses because of the absolute build directory paths that are part of the
hash.

Here's what can be done to enable cache hits between different build
directories:

* If you build with `-g` (or similar) to add debug information to the object
  file, you must either:
** use the compiler option `-fdebug-prefix-map=<old>=<new>` for relocating
   debug info to a common prefix (e.g. `-fdebug-prefix-map=$PWD=.`); or
** set *hash_dir = false*.
* If you use absolute paths anywhere on the command line (e.g. the source code
  file path or an argument to compiler options like `-I` and `-MF`), you must
  set <<config_base_dir,*base_dir*>> to an absolute path to a "`base
  directory`". Ccache will then rewrite absolute paths under that directory to
  relative before computing the hash.


== Precompiled headers

Ccache has support for precompiled headers with GCC and Clang. However, you have
to do some things to make it work properly:

* You must set <<config_sloppiness,*sloppiness*>> to *pch_defines,time_macros*.
  The reason is that ccache can't tell whether `+__TIME__+`, `+__DATE__+` or
  `+__TIMESTAMP__+` is used when using a precompiled header. Further, it can't
  detect changes in ``#define``s in the source code because of how preprocessing
  works in combination with precompiled headers.
* You may also want to include *include_file_mtime,include_file_ctime* in
  <<config_sloppiness,*sloppiness*>>. See
  _<<Handling of newly created header files>>_.
* You must either:
+
--
* use the compiler option `-include` to include the precompiled header (i.e.,
   don't use `#include` in the source code to include the header; the filename
   itself must be sufficient to find the header, i.e. `-I` paths are not
   searched); or
* (for the Clang compiler) use the compiler option `-include-pch` to include
   the PCH file generated from the precompiled header; or
* (for the GCC compiler) add the compiler option `-fpch-preprocess` when
   compiling.
--
+
* If you use Clang, you must compile with `-fno-pch-timestamp`.

If you don't do this, either the non-precompiled version of the header file will
be used (if available) or ccache will fall back to running the real compiler and
increase the statistics counter "`Preprocessing failed`" (if the non-precompiled
header file is not available).


== C++ modules

Ccache has support for Clang's `-fmodules` option. In practice ccache only
additionally hashes `module.modulemap` files; it does not know how Clang
handles its cached binary form of modules so those are ignored. This should not
matter in practice: as long as everything else (including `module.modulemap`
files) is the same the cached result should work. Still, you must set
<<config_sloppiness,*sloppiness*>> to *modules* to allow caching.

You must use both <<The direct mode,*direct mode*>> and
<<The depend mode,*depend mode*>>. When using
<<The preprocessor mode,the preprocessor mode>> Clang does not provide enough
information to allow hashing of `module.modulemap` files.


== Sharing a local cache

A group of developers can increase the cache hit rate by sharing a local cache
directory. To share a local cache without unpleasant side effects, the following
conditions should to be met:

* Use the same cache directory.
* Make sure that the configuration option <<config_hard_link,*hard_link*>> is
  false (which is the default).
* Make sure that all users are in the same group.
* Set the configuration option <<config_umask,*umask*>> to *002*. This ensures
  that cached files are accessible to everyone in the group.
* Make sure that all users have write permission in the entire cache directory
  (and that you trust all users of the shared cache).
* Make sure that the setgid bit is set on all directories in the cache. This
  tells the filesystem to inherit group ownership for new directories. The
  following command might be useful for this:
+
----
find $CCACHE_DIR -type d | xargs chmod g+s
----

The reason to avoid the hard link mode is that the hard links cause unwanted
side effects, as all links to a cached file share the file's modification
timestamp. This results in false dependencies to be triggered by
timestamp-based build systems whenever another user links to an existing file.
Typically, users will see that their libraries and binaries are relinked
without reason.

You may also want to make sure that a base directory is set appropriately, as
discussed in a previous section.


== Sharing a cache on NFS

It is possible to put the cache directory on an NFS filesystem (or similar
filesystems), but keep in mind that:

* Having the cache on NFS may slow down compilation. Make sure to do some
  benchmarking to see if it's worth it.
* Ccache hasn't been tested very thoroughly on NFS.

A tip is to set <<config_temporary_dir,*temporary_dir*>> to a directory on the
local host to avoid NFS traffic for temporary files.

It is recommended to use the same operating system version when using a shared
cache. If operating system versions are different then system include files
will likely be different and there will be few or no cache hits between the
systems. One way of improving cache hit rate in that case is to set
<<config_sloppiness,*sloppiness*>> to *system_headers* to ignore system
headers.

An alternative to putting the main cache directory on NFS is to set up a
<<config_remote_storage,remote storage>> file cache.


== Using ccache with other compiler wrappers

The recommended way of combining ccache with another compiler wrapper (such as
"`distcc`") is by letting ccache execute the compiler wrapper. This is
accomplished by defining <<config_prefix_command,*prefix_command*>>, for
example by setting the environment variable `CCACHE_PREFIX` to the name of the
wrapper (e.g. `distcc`). Ccache will then prefix the command line with the
specified command when running the compiler. To specify several prefix
commands, set <<config_prefix_command,*prefix_command*>> to a colon-separated
list of commands.

Unless you set <<config_compiler_check,*compiler_check*>> to a suitable command
(see the description of that configuration option), it is not recommended to use
the form `ccache anotherwrapper compiler args` as the compilation command. It's
also not recommended to use the masquerading technique for the other compiler
wrapper. The reason is that by default, ccache will in both cases hash the mtime
and size of the other wrapper instead of the real compiler, which means that:

* Compiler upgrades will not be detected properly.
* The cached results will not be shared between compilations with and without
  the other wrapper.

Another minor thing is that if <<config_prefix_command,*prefix_command*>> is
used, ccache will not invoke the other wrapper when running the preprocessor,
which increases performance. You can use
<<config_prefix_command_cpp,*prefix_command_cpp*>> if you also want to invoke
the other wrapper when doing preprocessing (normally by adding `-E`).


== Caveats

* The direct mode fails to pick up new header files in some rare scenarios. See
  _<<The direct mode>>_ above.


== Troubleshooting

=== General

A general tip for getting information about what ccache is doing is to enable
debug logging by setting the configuration option <<config_debug,*debug*>> (or
the environment variable *CCACHE_DEBUG*); see _<<Cache debugging>>_
for more information. Another way of keeping track of what is
happening is to check the output of *ccache -s*.


=== Performance

Ccache has been written to perform well out of the box, but sometimes you may
have to do some adjustments of how you use the compiler and ccache in order to
improve performance.

Since ccache works best when I/O is fast, put the cache directory on a fast
storage device if possible. Having lots of free memory so that files in the
cache directory stay in the disk cache is also preferable.

A good way of monitoring how well ccache works is to run `ccache -s` before and
after your build and then compare the statistics counters. Here are some common
problems and what may be done to increase the hit rate:

* If the counter for preprocessed cache hits has been incremented instead of the
  one for direct cache hits, ccache has fallen back to preprocessor mode, which
  is generally slower. Some possible reasons are:
** The source code has been modified in such a way that the preprocessor output
   is not affected.
** Compiler arguments that are hashed in the direct mode but not in the
   preprocessor mode have changed (`-I`, `-include`, `-D`, etc) and they didn't
   affect the preprocessor output.
** The compiler option `-Xpreprocessor` or `-Wp,++*++` (except `-Wp,-MD,<path>`,
   `-Wp,-MMD,<path>`, and `-Wp,-D<define>`) is used.
** This was the first compilation with a new value of the
   <<config_base_dir,base directory>>.
** A modification or status change time of one of the include files is too new
   (created the same second as the compilation is being done). See
   _<<Handling of newly created header files>>_.
** The `+__TIME__+` preprocessor macro is (potentially) being used. Ccache turns
   off direct mode if `+__TIME__+` is present in the source code. This is done
   as a safety measure since the string indicates that a `+__TIME__+` macro
   _may_ affect the output. (To be sure, ccache would have to run the
   preprocessor, but the sole point of the direct mode is to avoid that.) If you
   know that `+__TIME__+` isn't used in practise, or don't care if ccache
   produces objects where `+__TIME__+` is expanded to something in the past, you
   can set <<config_sloppiness,*sloppiness*>> to *time_macros*.
** The `+__DATE__+` preprocessor macro is (potentially) being used and the date
   has changed. This is similar to how `+__TIME__+` is handled. If `+__DATE__+`
   is present in the source code, ccache hashes the current date in order to be
   able to produce the correct object file if the `+__DATE__+` macro affects the
   output. If you know that `+__DATE__+` isn't used in practise, or don't care
   if ccache produces objects where `+__DATE__+` is expanded to something in the
   past, you can set <<config_sloppiness,*sloppiness*>> to *time_macros*.
** The `+__TIMESTAMP__+` preprocessor macro is (potentially) being used and the
   source file's modification time has changed. This is similar to how
   `+__TIME__+` is handled. If `+__TIMESTAMP__+` is present in the source code,
   ccache hashes the string representation of the source file's modification
   time in order to be able to produce the correct object file if the
   `+__TIMESTAMP__+` macro affects the output. If you know that
   `+__TIMESTAMP__+` isn't used in practise, or don't care if ccache produces
   objects where `+__TIMESTAMP__+` is expanded to something in the past, you can
   set <<config_sloppiness,*sloppiness*>> to *time_macros*.
** The input file path has changed. Ccache includes the input file path in the
   direct mode hash to be able to take relative include files into account and
   to produce a correct object file if the source code includes a `+__FILE__+`
   macro.
* If a cache hit counter was not incremented even though the same code has been
  compiled and cached before, ccache has either detected that something has
  changed anyway or a cleanup has been performed (either explicitly or
  implicitly when a cache limit has been reached). Some perhaps unobvious things
  that may result in a cache miss are usage of `+__TIME__+`, `+__DATE__+` or
  `+__TIMESTAMP__+` macros, or use of automatically generated code that contains
  a timestamp, build counter or other volatile information.
* If "`Multiple source files`" has been incremented, it's an indication that the
  compiler has been invoked on several source code files at once. Ccache doesn't
  support that. Compile the source code files separately if possible.
* If "`Unsupported compiler option`" has been incremented, enable debug logging
  and check which compiler option was rejected.
* If "`Preprocessing failed`" has been incremented, one possible reason is that
  precompiled headers are being used. See _<<Precompiled headers>>_ for how to
  remedy this.
* If "`Could not use precompiled header`" has been incremented, see
  _<<Precompiled headers>>_.
* If "`Could not use modules`" has been incremented, see _<<C++ modules>>_.


=== Corrupt object files

It should be noted that ccache is susceptible to general storage problems. If a
bad object file sneaks into the cache for some reason, it will of course stay
bad. Some possible reasons for erroneous object files are bad hardware (disk
drive, disk controller, memory, etc), buggy drivers or file systems, a bad
<<config_prefix_command,*prefix_command*>> or compiler wrapper. If this
happens, the easiest way of fixing it is this:

1. Build so that the bad object file ends up in the build tree.
2. Remove the bad object file from the build tree.
3. Rebuild with `CCACHE_RECACHE` set.

An alternative is to clear the whole cache with `ccache -C` if you don't mind
losing other cached results.

There are no reported issues about ccache producing broken object files
reproducibly. That doesn't mean it can't happen, so if you find a repeatable
case, please report it.


== More information

Credits, mailing list information, bug reporting instructions, source code,
etc, can be found on ccache's web site: <https://ccache.dev>.


== Author

Ccache was originally written by Andrew Tridgell and is currently developed and
maintained by Joel Rosdahl. See AUTHORS.txt or AUTHORS.html and
<https://ccache.dev/credits.html> for a list of contributors.