Skip to content
This repository has been archived by the owner on Oct 2, 2024. It is now read-only.

set large file threshold to 4 MiB #1739

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions bin/ch-image.py.in
Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,8 @@ def main():
{ "metavar": "SIZE",
"type": lambda s: ch.positive(s) * 2**20, # internal unit: bytes
"default": ch.positive(
os.environ.get("CH_IMAGE_CACHE_LARGE", 0)) * 2**20,
"help": "large file threshold in MiB" }],
os.environ.get("CH_IMAGE_CACHE_LARGE", 4)) * 2**20,
"help": "large file threshold in MiB (default: 4)" }],
[["--debug"],
{ "action": "store_true",
"help": "add short traceback to fatal error hints" }],
Expand Down
11 changes: 5 additions & 6 deletions doc/ch-image.rst
Original file line number Diff line number Diff line change
Expand Up @@ -72,9 +72,8 @@ Common options placed before or after the sub-command:

:code:`--cache-large SIZE`
Set the cache’s large file threshold to :code:`SIZE` MiB, or :code:`0` for
no large files, which is the default. This can speed up some builds.
**Experimental.** See section :ref:`Large file threshold
<ch-image_bu-large>` for details.
no large files. The default is 4 MiB. This can speed up some builds. See
section :ref:`Large file threshold <ch-image_bu-large>` for details.

:code:`--debug`
Add a stack trace to fatal error hints. This can also be done by setting
Expand Down Expand Up @@ -458,9 +457,9 @@ somewhat like `Git Large File Storage <https://git-lfs.github.com/>`_.
needed, which is a fast metadata operation that ignores file content.

Option :code:`--cache-large` sets the threshold in MiB; if not set,
environment variable :code:`CH_IMAGE_CACHE_LARGE` is used; if that is not set
either, the default value :code:`0` indicates that no files are considered
large.
environment variable :code:`CH_IMAGE_CACHE_LARGE` is used. If that is not set
either, the default value is 4 MiB. (See our `build cache paper
<https://arxiv.org/abs/2309.00166>`_ for details on why.)

There are two trade-offs. First, large files in any image with the same path,
mode, size, and mtime (to nanosecond precision if possible) are considered
Expand Down