summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorÉric Araujo <merwok@netwok.org>2011-08-08 14:51:11 (GMT)
committerÉric Araujo <merwok@netwok.org>2011-08-08 14:51:11 (GMT)
commite4d5b8e6463126852443123e27af1a2b737f841b (patch)
treeb7118735c36b963beaa94b285c6f557513212514
parent7dc76fdeb14e0a2bf1248d78c2439b5a244f8885 (diff)
downloadcpython-e4d5b8e6463126852443123e27af1a2b737f841b.zip
cpython-e4d5b8e6463126852443123e27af1a2b737f841b.tar.gz
cpython-e4d5b8e6463126852443123e27af1a2b737f841b.tar.bz2
Clean up shutil.disk_usage.
- Move a test from call time to define time - Add the function name to __all__ - Improve docstring and docs A few lines are now duplicated (named tuple definition and docstring) but I think the end result reads better.
-rw-r--r--Doc/library/shutil.rst5
-rw-r--r--Lib/shutil.py44
2 files changed, 33 insertions, 16 deletions
diff --git a/Doc/library/shutil.rst b/Doc/library/shutil.rst
index 6f70206..0d80913 100644
--- a/Doc/library/shutil.rst
+++ b/Doc/library/shutil.rst
@@ -175,8 +175,9 @@ Directory and files operations
.. function:: disk_usage(path)
- Return disk usage statistics about the given path as a namedtuple including
- total, used and free space expressed in bytes.
+ Return disk usage statistics about the given path as a :term:`named tuple`
+ with the attributes *total*, *used* and *free*, which are the amount of
+ total, used and free space, in bytes.
.. versionadded:: 3.3
diff --git a/Lib/shutil.py b/Lib/shutil.py
index 0af9fa5..329add0 100644
--- a/Lib/shutil.py
+++ b/Lib/shutil.py
@@ -12,7 +12,6 @@ import fnmatch
import collections
import errno
import tarfile
-from collections import namedtuple
try:
import bz2
@@ -36,6 +35,7 @@ __all__ = ["copyfileobj", "copyfile", "copymode", "copystat", "copy", "copy2",
"register_archive_format", "unregister_archive_format",
"get_unpack_formats", "register_unpack_format",
"unregister_unpack_format", "unpack_archive"]
+ # disk_usage is added later, if available on the platform
class Error(EnvironmentError):
pass
@@ -756,20 +756,36 @@ def unpack_archive(filename, extract_dir=None, format=None):
kwargs = dict(_UNPACK_FORMATS[format][2])
func(filename, extract_dir, **kwargs)
-if hasattr(os, "statvfs") or os.name == 'nt':
- _ntuple_diskusage = namedtuple('usage', 'total used free')
+
+if hasattr(os, 'statvfs'):
+
+ __all__.append('disk_usage')
+ _ntuple_diskusage = collections.namedtuple('usage', 'total used free')
def disk_usage(path):
- """Return disk usage statistics about the given path as a namedtuple
- including total, used and free space expressed in bytes.
+ """Return disk usage statistics about the given path.
+
+ Returned valus is a named tuple with attributes 'total', 'used' and
+ 'free', which are the amount of total, used and free space, in bytes.
"""
- if hasattr(os, "statvfs"):
- st = os.statvfs(path)
- free = (st.f_bavail * st.f_frsize)
- total = (st.f_blocks * st.f_frsize)
- used = (st.f_blocks - st.f_bfree) * st.f_frsize
- else:
- import nt
- total, free = nt._getdiskusage(path)
- used = total - free
+ st = os.statvfs(path)
+ free = st.f_bavail * st.f_frsize
+ total = st.f_blocks * st.f_frsize
+ used = (st.f_blocks - st.f_bfree) * st.f_frsize
+ return _ntuple_diskusage(total, used, free)
+
+elif os.name == 'nt':
+
+ import nt
+ __all__.append('disk_usage')
+ _ntuple_diskusage = collections.namedtuple('usage', 'total used free')
+
+ def disk_usage(path):
+ """Return disk usage statistics about the given path.
+
+ Returned valus is a named tuple with attributes 'total', 'used' and
+ 'free', which are the amount of total, used and free space, in bytes.
+ """
+ total, free = nt._getdiskusage(path)
+ used = total - free
return _ntuple_diskusage(total, used, free)