Skip to content

cloudpathlib.enums

Classes

FileCacheMode (str, Enum)

Enumeration of the modes available for for the cloudpathlib file cache.

Attributes:

Name Type Description
persistent str

Cache is not removed by cloudpathlib.

tmp_dir str

Cache is stored in a TemporaryDirectory which is removed when the Client object is garbage collected (or by the OS at some point if not).

cloudpath_object str

Cache for a CloudPath object is removed when __del__ for that object is called by Python garbage collection.

close_file str

Cache for a CloudPath file is removed as soon as the file is closed. Note: you must use CloudPath.open whenever opening the file for this method to function.

Modes can be set by passing them to the Client or by setting the CLOUPATHLIB_FILE_CACHE_MODE environment variable.

For more detail, see the caching documentation page.

Source code in cloudpathlib/enums.py
class FileCacheMode(str, Enum):
    """Enumeration of the modes available for for the cloudpathlib file cache.

    Attributes:
        persistent (str): Cache is not removed by `cloudpathlib`.
        tmp_dir (str): Cache is stored in a
            [`TemporaryDirectory`](https://docs.python.org/3/library/tempfile.html#tempfile.TemporaryDirectory)
            which is removed when the Client object is garbage collected (or by the OS at some point if not).
        cloudpath_object (str): Cache for a `CloudPath` object is removed when `__del__` for that object is
            called by Python garbage collection.
        close_file (str): Cache for a `CloudPath` file is removed as soon as the file is closed. Note: you must
            use `CloudPath.open` whenever opening the file for this method to function.

    Modes can be set by passing them to the Client or by setting the `CLOUPATHLIB_FILE_CACHE_MODE`
    environment variable.

    For more detail, see the [caching documentation page](../../caching).
    """

    persistent = "persistent"  # cache stays as long as dir on OS does
    tmp_dir = "tmp_dir"  # DEFAULT: handled by deleting client, Python, or OS (usually on machine restart)
    cloudpath_object = "cloudpath_object"  # __del__ called on the CloudPath object
    close_file = "close_file"  # cache is cleared when file is closed

    @classmethod
    def from_environment(cls) -> Optional["FileCacheMode"]:
        """Parses the environment variable `CLOUPATHLIB_FILE_CACHE_MODE` into
        an instance of this Enum.

        Returns:
            FileCacheMode enum value if the env var is defined, else None.
        """
        env_string = os.environ.get("CLOUPATHLIB_FILE_CACHE_MODE", "").lower()

        if not env_string:
            return None
        else:
            return cls(env_string)
close_file
cloudpath_object
persistent
tmp_dir