Skip to content

Commit

Permalink
Support pex3 cache prune --older-than ....
Browse files Browse the repository at this point in the history
  • Loading branch information
jsirois committed Oct 7, 2024
1 parent 22c254c commit 8497e05
Show file tree
Hide file tree
Showing 12 changed files with 925 additions and 40 deletions.
31 changes: 30 additions & 1 deletion pex/cache/access.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,20 @@
from __future__ import absolute_import, print_function

import fcntl
import itertools
import os
import time
from contextlib import contextmanager
from datetime import datetime

from pex.common import safe_mkdir
from pex.typing import TYPE_CHECKING
from pex.variables import ENV

if TYPE_CHECKING:
from typing import Iterator, Optional, Tuple
from typing import Iterator, Optional, Tuple, Union

from pex.cache.dirs import AtomicCacheDir, UnzipDir, VenvDirs # noqa


# N.B.: The lock file path is last in the lock state tuple to allow for a simple encoding scheme in
Expand Down Expand Up @@ -99,3 +104,27 @@ def await_delete_lock():
lock_file = _lock(exclusive=False)
yield lock_file
_lock(exclusive=True)


def record_access(atomic_cache_dir):
# type: (AtomicCacheDir) -> None

# N.B.: We explicitly set atime and do not rely on the filesystem implicitly setting it when the
# directory is read since filesystems may be mounted noatime, nodiratime or relatime on Linux
# and similar toggles exist, at least in part, for some macOS file systems.
atime = time.time()
mtime = os.stat(atomic_cache_dir.path).st_mtime
os.utime(atomic_cache_dir.path, (atime, mtime))


def last_access_before(cutoff):
# type: (datetime) -> Iterator[Union[UnzipDir, VenvDirs]]

from pex.cache.dirs import UnzipDir, VenvDirs

pex_dirs = itertools.chain(
UnzipDir.iter_all(), VenvDirs.iter_all()
) # type: Iterator[Union[UnzipDir, VenvDirs]]
for pex_dir in pex_dirs:
if datetime.fromtimestamp(os.stat(pex_dir.path).st_atime) < cutoff:
yield pex_dir
Loading

0 comments on commit 8497e05

Please sign in to comment.