Commit ffa155ad authored by Tarek Ziadé's avatar Tarek Ziadé

make sure shutil checks for bz2 availability before it uses it.

parent bf043491
...@@ -238,7 +238,7 @@ Archives operations ...@@ -238,7 +238,7 @@ Archives operations
*base_name* is the name of the file to create, including the path, minus *base_name* is the name of the file to create, including the path, minus
any format-specific extension. *format* is the archive format: one of any format-specific extension. *format* is the archive format: one of
"zip", "tar", "bztar" or "gztar". "zip", "tar", "bztar" (if the :mod:`bz2` module is available) or "gztar".
*root_dir* is a directory that will be the root directory of the *root_dir* is a directory that will be the root directory of the
archive; i.e. we typically chdir into *root_dir* before creating the archive; i.e. we typically chdir into *root_dir* before creating the
...@@ -264,7 +264,7 @@ Archives operations ...@@ -264,7 +264,7 @@ Archives operations
By default :mod:`shutil` provides these formats: By default :mod:`shutil` provides these formats:
- *gztar*: gzip'ed tar-file - *gztar*: gzip'ed tar-file
- *bztar*: bzip2'ed tar-file - *bztar*: bzip2'ed tar-file (if the :mod:`bz2` module is available.)
- *tar*: uncompressed tar file - *tar*: uncompressed tar file
- *zip*: ZIP file - *zip*: ZIP file
...@@ -346,7 +346,7 @@ Archives operations ...@@ -346,7 +346,7 @@ Archives operations
By default :mod:`shutil` provides these formats: By default :mod:`shutil` provides these formats:
- *gztar*: gzip'ed tar-file - *gztar*: gzip'ed tar-file
- *bztar*: bzip2'ed tar-file - *bztar*: bzip2'ed tar-file (if the :mod:`bz2` module is available.)
- *tar*: uncompressed tar file - *tar*: uncompressed tar file
- *zip*: ZIP file - *zip*: ZIP file
......
...@@ -13,6 +13,12 @@ import collections ...@@ -13,6 +13,12 @@ import collections
import errno import errno
import tarfile import tarfile
try:
import bz2
_BZ2_SUPPORTED = True
except ImportError:
_BZ2_SUPPORTED = False
try: try:
from pwd import getpwnam from pwd import getpwnam
except ImportError: except ImportError:
...@@ -376,13 +382,17 @@ def _make_tarball(base_name, base_dir, compress="gzip", verbose=0, dry_run=0, ...@@ -376,13 +382,17 @@ def _make_tarball(base_name, base_dir, compress="gzip", verbose=0, dry_run=0,
Returns the output filename. Returns the output filename.
""" """
tar_compression = {'gzip': 'gz', 'bzip2': 'bz2', None: ''} tar_compression = {'gzip': 'gz', None: ''}
compress_ext = {'gzip': '.gz', 'bzip2': '.bz2'} compress_ext = {'gzip': '.gz'}
if _BZ2_SUPPORTED:
tar_compression['bzip2'] = 'bz2'
compress_ext['bzip2'] = '.bz2'
# flags for compression program, each element of list will be an argument # flags for compression program, each element of list will be an argument
if compress is not None and compress not in compress_ext.keys(): if compress is not None and compress not in compress_ext.keys():
raise ValueError("bad value for 'compress': must be None, 'gzip', or " raise ValueError("bad value for 'compress', or compression format not "
"'bzip2'") "supported : {0}".format(compress))
archive_name = base_name + '.tar' + compress_ext.get(compress, '') archive_name = base_name + '.tar' + compress_ext.get(compress, '')
archive_dir = os.path.dirname(archive_name) archive_dir = os.path.dirname(archive_name)
...@@ -488,6 +498,10 @@ _ARCHIVE_FORMATS = { ...@@ -488,6 +498,10 @@ _ARCHIVE_FORMATS = {
'zip': (_make_zipfile, [],"ZIP file") 'zip': (_make_zipfile, [],"ZIP file")
} }
if _BZ2_SUPPORTED:
_ARCHIVE_FORMATS['bztar'] = (_make_tarball, [('compress', 'bzip2')],
"bzip2'ed tar-file")
def get_archive_formats(): def get_archive_formats():
"""Returns a list of supported formats for archiving and unarchiving. """Returns a list of supported formats for archiving and unarchiving.
...@@ -690,11 +704,14 @@ def _unpack_tarfile(filename, extract_dir): ...@@ -690,11 +704,14 @@ def _unpack_tarfile(filename, extract_dir):
_UNPACK_FORMATS = { _UNPACK_FORMATS = {
'gztar': (['.tar.gz', '.tgz'], _unpack_tarfile, [], "gzip'ed tar-file"), 'gztar': (['.tar.gz', '.tgz'], _unpack_tarfile, [], "gzip'ed tar-file"),
'bztar': (['.bz2'], _unpack_tarfile, [], "bzip2'ed tar-file"),
'tar': (['.tar'], _unpack_tarfile, [], "uncompressed tar file"), 'tar': (['.tar'], _unpack_tarfile, [], "uncompressed tar file"),
'zip': (['.zip'], _unpack_zipfile, [], "ZIP file") 'zip': (['.zip'], _unpack_zipfile, [], "ZIP file")
} }
if _BZ2_SUPPORTED:
_UNPACK_FORMATS['bztar'] = (['.bz2'], _unpack_tarfile, [],
"bzip2'ed tar-file")
def _find_unpack_format(filename): def _find_unpack_format(filename):
for name, info in _UNPACK_FORMATS.items(): for name, info in _UNPACK_FORMATS.items():
for extension in info[0]: for extension in info[0]:
......
...@@ -22,6 +22,12 @@ import warnings ...@@ -22,6 +22,12 @@ import warnings
from test import support from test import support
from test.support import TESTFN, check_warnings, captured_stdout from test.support import TESTFN, check_warnings, captured_stdout
try:
import bz2
BZ2_SUPPORTED = True
except ImportError:
BZ2_SUPPORTED = False
TESTFN2 = TESTFN + "2" TESTFN2 = TESTFN + "2"
try: try:
...@@ -612,8 +618,11 @@ class TestShutil(unittest.TestCase): ...@@ -612,8 +618,11 @@ class TestShutil(unittest.TestCase):
@unittest.skipUnless(zlib, "Requires zlib") @unittest.skipUnless(zlib, "Requires zlib")
def test_unpack_archive(self): def test_unpack_archive(self):
formats = ['tar', 'gztar', 'zip']
if BZ2_SUPPORTED:
formats.append('bztar')
for format in ('tar', 'gztar', 'bztar', 'zip'): for format in formats:
tmpdir = self.mkdtemp() tmpdir = self.mkdtemp()
base_dir, root_dir, base_name = self._create_files() base_dir, root_dir, base_name = self._create_files()
tmpdir2 = self.mkdtemp() tmpdir2 = self.mkdtemp()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment