ccache 3.2.1
------------
Release date: 2014-12-10
Bug fixes
~~~~~~~~~
- Fixed regression in temporary file handling, which lead to incorrect
permissions for stats, manifest and ccache.conf files in the cache.
- `CACHEDIR.TAG` files are now created in the [0-9a-f] subdirectories so that
ccache.conf is not lost in backups.
- Made the default cache size suffix `G`, as previously documented.
- `-fdiagnostics-color=auto` is now passed to the compiler even if stderr is
redirected. This fixes a problem when, for instance, a configure test probes
if the compiler (wrapped via ccache) supports `-fdiagnostics-color=auto`.
- Added missing documentation for `max_files` and `max_size` configuration
options.
New features and improvements
- Added support for configuring ccache via one or several configuration files
instead of via environment variables. Environment variables still have
priority but are no longer the recommended way of customizing ccache
behavior. See the manual for more information.
- Added support for compiler error/warning messages with color.
- Made creation of temporary directories and cache directories smarter to avoid
unnecessary `stat` calls.
- Improved efficiency of the algorithm that scans for `__DATE_` and `__TIME__`
tokens in the hashed source code.
- Added support for several binaries (separated by space) in `CCACHE_PREFIX`.
- The `-c` option is no longer passed to the preprocessor. This fixes problems
with clang and Solaris's C++ compiler.
- ccache no longer passes preprocessor options like `-D` and `-I` to the
compiler when compiling preprocessed output. This fixes warnings emitted by
clang.
- Compiler options `-fprofile-generate`, `-fprofile-arcs`, `-fprofile-use` and
`-fbranch-probabilities` are now handled without bailing.
- Added support for clang's `--serialize-diagnostic` option, storing the
diagnostic file (`.dia`) in the cache.
- Added support for precompiled headers when using clang.
- Added support for clang `.pth` (pretokenized header) files.
- Changed the `-x` language option to use the new objective C standard for GCC
and clang.
- On a cache miss, ccache now instructs the compiler to create the object file
at the real destination and then copies the file into the cache instead of
the other way around. This is needed to support compiler options like
`-fprofile-arcs` and `--serialize-diagnostics`.
- ccache now checks that included files' ctimes aren't too new. This check can
be turned off by adding `include_file_ctime` to the ``ccache sloppiness''
setting.
- Added possibility to get cache hits based on filename, size, mtime and ctime
only. On other words, source code files are not even read, only stat-ed. This
operation mode is opt-in by adding `file_stat_matches` to the ``ccache
sloppiness'' setting.
- The filename part of options like `-Wp,-MDfilename` is no longer included in
the hash since the filename doesn't have any bearing on the result.
- Added a ``read-only direct'' configuration setting, which is like the
ordinary read-only setting except that ccache will only try to retrieve
results from the cache using the direct mode, not the preprocessor mode.
- The display and interpretation of cache size has been changed to use SI
units.
- Default cache size is now 5 GB (was previously 1 GiB).
- Added configuration option to set the compression level of compressed object
files in the cache.
- Added support for `@file` and `-@file` arguments (reading options from a
file).
- `-Wl,` options are no longer included in the hash since they don't affect
compilation.
- Bail out on too hard compiler option `-Wp,-P`.
- Optimized MD4 calculation code on little-endian systems.
- Various improvements and fixes on win32.
- Improved logging to the ccache log file.
- Added `--dump-manifest` command-line option for debugging purposes.
- Added `--with-bundled-zlib` configure option.
- Upgraded bundled zlib to version 1.2.8.
- Improved `dev.mk` to be more platform independent.
- Made the test suite work with clang and gcc-llvm on OS X.
- Various other improvements of the test suite.
Bug fixes
- Any previous `.stderr` is now removed from the cache when recaching.
- Fixed an issue when handling the `-arch` compiler option with an argument.
- Fixed race condition when creating the initial cache directory.
- Fixed test suite failures when `CC` is a ccache-wrapped compiler.
New features and improvements:
* Added support for the -Xclang compiler option.
* Improved handling of exit code of internally executed processes.
* Zero length object files in the cache are now rejected as invalid.
* Bail out on option -gsplit-dwarf (since it produces multiple output files).
* Compiler option -fdebug-prefix-map is now ignored (not part of the hash). (The -fdebug-prefix-map option may be used in combination with CCACHE_BASEDIR to reuse results across different directories.)
* Added note in documentation that --ccache-skip currently does not mean “don’t hash the following option”.
* To enable support for precompiled headers (PCH), CCACHE_SLOPPINESS now also needs to include the new pch_defines sloppiness. This is because ccache can’t detect changes in the source code when only defined macros have been changed.
* Stale files in the internal temporary directory (<ccache_dir>/tmp) are now cleaned up if they are older than one hour.
Bug fixes:
* Fixed path canonicalization in make_relative_path() when path doesn’t exist.
* Fixed bug in common_dir_prefix_length(). This corrects the CCACHE_BASEDIR behavior.
* ccache no longer tries to create the cache directory when CCACHE_DISABLE is set.
* Fixed bug when reading manifests with a very large number of file info entries.
* Fixed problem with logging of current working directory.
ccache 3.1.9
------------
Release date: 2013-01-06
Bug fixes
~~~~~~~~~
- The EAGAIN signal is now handled correctly when emitting cached stderr
output. This fixes a problem triggered by large error outputs from the
compiler.
- Subdirectories in the cache are no longer created in read-only mode.
- Fixed so that ccache's log file descriptor is not made available to the
compiler.
- Improved error reporting when failing to create temporary stdout/stderr
files when executing the compiler.
- Disappearing temporary stdout/stderr files are now handled gracefully.
Other
~~~~~
- Fixed test suite to work on ecryptfs.
ccache 3.1.8
------------
Release date: 2012-08-11
New features and improvements
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- Made paths to dependency files relative in order to increase cache hits.
- Added work-around to make ccache work with buggy GCC 4.1 when creating a
pre-compiled header.
- Clang plugins are now hashed to catch plugin upgrades.
Bug fixes
~~~~~~~~~
- Fixed crash when the current working directory has been removed.
- Fixed crash when stderr is closed.
- Corrected a corner case when parsing backslash escapes in string
literals.
- Paths are now correctly canonicalized when computing paths relative to
the base directory.
Other
~~~~~
- Made git version macro work when compiling outside of the source
directory.
- Fixed `static_assert` macro definition clash with GCC 4.7.
ccache 3.1.7
------------
Release date: 2012-01-08
Bug fixes
~~~~~~~~~
- Non-writable `CCACHE_DIR` is now handled gracefully when
`CCACHE_READONLY` is set.
- Made failure to create files (typically due to bad directory permissions)
in the cache directory fatal. Previously, such failures were silently and
erroneously flagged as "compiler produced stdout".
- Both the `-specs=file` and `--specs=file` forms are now recognized.
- Added recognition and hashing of GCC plugins specified with
`-fplugin=file`.
- `CCACHE_COMPILERCHECK` now also determines how to hash explicit specs
files (`-specs=file`).
- Added `CPATH`, `C_INCLUDE_PATH` and similar environment variables to the
hash to avoid false cache hits when such variables have changed.
- Corrected log message when unify mode is enabled.
- Reverted the GCC bug compatibility introduced in ccache 3.1.5 for
`-MT`/`-MQ` options with concatenated arguments. (The bug is fixed in
recent GCC versions.)
Other
~~~~~
- Corrected license header for `mdfour.c`.
- Improved documentation on how to fix bad object files in the cache.
ccache 3.1.6
------------
Release date: 2011-08-21
New features and improvements
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- Rewrite argument to `--sysroot` if `CCACHE_BASEDIR` is used.
Bug fixes
~~~~~~~~~
- Don't crash if `getcwd()` fails.
- Fixed alignment of ``called for preprocessing'' counter.
ccache 3.1.5
------------
Release date: 2011-05-29
New features and improvements
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- Added a new statistics counter named ``called for preprocessing''.
- The original command line is now logged to the file specified with
`CCACHE_LOGFILE`.
- Improved error logging when system calls fail.
- Added support for rewriting absolute paths in `-F`/`-iframework` GCC
options.
- Improved order of statistics counters in `ccache -s` output.
Bug fixes
~~~~~~~~~
- The `-MF`/`-MT`/`-MQ` options with concatenated argument are now handled
correctly when they are last on the command line.
- ccache is now bug compatible with GCC for the `-MT`/`-MQ` options with
concatenated arguments.
- Fixed a minor memory leak.
- Systems that lack (and don't need to be linked with) libm are now
supported.
ccache 3.1.4
Bug fixes
ccache 3.1.3
Bug and portability fixes
ccache 3.1.2
Bug fixes
ccache 3.1.1
Bug fixes
ccache 3.1
New features and improvements
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- Added support for hashing the output of a custom command (e.g.
`%compiler% --version`) to identify the compiler instead of stat-ing or
hashing the compiler binary. This can improve robustness when the
compiler (as seen by ccache) actually isn't the real compiler but another
compiler wrapper.
- Added support for caching compilations that use precompiled headers. (See
the manual for important instructions regarding this.)
- Locking of the files containing statistics counters is now done using
symlinks instead of POSIX locks. This should make ccache behave a lot
better on file systems where POSIX locks are slow or broken (e.g. NFS on
some systems).
- Manifest files are now updated without the need of taking locks.
- Updates of statistics counters are now always done in one of the
sub-level statistics files. This reduces lock contention, which
especially improves performance on slow NFS mounts.
- Reading and writing of statistics counters has been made
forward-compatible (unknown counters are retained).
- Files are now read without using mmap(). This has two benefits: it's more
robust against file changes during reading and it improves performance on
poor systems where mmap() doesn't use the disk cache.
- Added `.cp` and `.CP` as known C++ suffixes.
- Improved logging.
- Added `-install_name` as an option known to take an argument. (This
improves statistics when using the Darwin linker.)
Bug fixes
ccache 3.0.1
Bug fixes
ccache 3.0
General
~~~~~~~
- ccache is now licensed under the GNU General Public License (GPL) version
3 or later.
Upgrade notes
~~~~~~~~~~~~~
- The way the hashes are calculated has changed, so you won't get cache
hits for compilation results stored by older ccache versions. Because of
this, you might as well clear the old cache directory with `ccache
--clear` if you want, unless you plan to keep using an older ccache
version.
New features and improvements
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- ccache now has a ``direct mode'' where it computes a hash of the source
code (including all included files) and compiler options without
running the preprocessor. By not running the preprocessor, CPU usage is
reduced; the speed is somewhere between 1 and 5 times that of ccache
running in traditional mode, depending on the circumstances. The speedup
will be higher when I/O is fast (e.g., when files are in the disk cache).
The direct mode can be disabled by setting +CCACHE_NODIRECT+.
- Support has been added for rewriting absolute paths to relative paths
when hashing, in order to increase cache hit rate when building the same
source code in different directories even when compiling with `-g` and
when using absolute include directory paths. This is done by setting the
`CCACHE_BASEDIR` environment variable to an absolute path that specifies
which paths to rewrite.
- Object files are now optionally stored compressed in the cache. The
runtime cost is negligible, and more files will fit in the ccache
directory and in the disk cache. Set `CCACHE_COMPRESS` to enable object
file compression. Note that you can't use compression in combination with
the hard link feature.
- A `CCACHE_COMPILERCHECK` option has been added. This option tells ccache
what compiler-identifying information to hash to ensure that results
retrieved from the cache are accurate. Possible values are: none (don't
hash anything), mtime (hash the compiler's mtime and size) and content
(hash the content of the compiler binary). The default is mtime.
- It is now possible to specify extra files whose contents should be
included in the hash sum by setting the `CCACHE_EXTRAFILES` option.
- Added support for Objective-C and Objective-C\+\+. The statistics counter
``not a C/C++ file'' has been renamed to ``unsupported source language''.
- Added support for the `-x` compiler option.
- Added support for long command-line options.
- A `CACHEDIR.TAG` file is now created in the cache directory. See
<http://www.brynosaurus.com/cachedir/>.
- Messages printed to the debug log (specified by `CCACHE_LOGFILE`) have
been improved.
- You can relax some checks that ccache does in direct mode by setting
`CCACHE_SLOPPINESS`. See the manual for more information.
- `CCACHE_TEMPDIR` no longer needs to be on the same filesystem as
`CCACHE_DIR`.
- The default value of `CCACHE_TEMPDIR` has been changed to
`$CCACHE_DIR/tmp` to avoid cluttering the top directory.
- Temporary files that later will be moved into the cache are now created
in the cache directory they will end up in. This makes ccache more
friendly to Linux's directory layout.
- Improved the test suite and added tests for most of the new
functionality. It's now also possible to specify a subset of tests to
run.
- Standard error output from the compiler is now only stored in the cache
if it's non-empty.
- If the compiler produces no object file or an empty object file, but
gives a zero exit status (could be due to a file system problem, a buggy
program specified by `CCACHE_PREFIX`, etc.), ccache copes with it
properly.
- Added `installcheck` and `distcheck` make targets.
- Clarified cache size limit options' and cleanup semantics.
- Improved display of cache max size values.
- The following options are no longer hashed in the preprocessor mode:
`-imacros`, `-imultilib`, `-iprefix`, `-iquote`, `-isysroot`,
`-iwithprefix`, `-iwithprefixbefore`, `-nostdinc`, `-nostdinc++` and
`-U`.
Changes:
* Added CCACHE_READONLY option.
* Added CCACHE_TEMPDIR option.
* Fixed handling of hard-linked compiler on AIX.
* Added O_BINARY support, to try and support win32 compiles.
* Show cache directory in stats output.
* Fixed handling of HOME environment variable.
NOTE: This release changes the hash input slighly, so you will probably
find that you will not get any hits against your existing cache when
you upgrade.
a new environment variable CCACHE_HASHCC whose value may be used to
override the compiler-specific addition to the hash value used to
distinguish between two compiles. This is useful where the compiler is
a shell script generated on-the-fly that executes the real compiler.
This allows ccache to function correctly within the pkgsrc
infrastructure.
Added CCACHE_UMASK option
Added support for compilation of .i files
Fixed bug with DEPENDENCIES_OUTPUT flag
Added support for more -Mx options
Added separate stderr channel for distcc
Improved test suite
However changes since 2.1.1 include:
# added a test suite
# better integration with distcc
# added CCACHE_PREFIX option
# disabled hard links by default
# recognise some more gcc options (eg. profiling)
# added --ccache-skip option
- fixed warning output line numbers
- added some more C++ extensions
- fixed a minor md4 hashing bug
- added support for some of the -M compiler options