WIP: need to verify the result archive
This commit is contained in:
parent
70d2200706
commit
8790e0c8b0
28
tarroot.py
28
tarroot.py
|
@ -13,7 +13,7 @@ class TarRoot:
|
||||||
def __init__(self, arguments):
|
def __init__(self, arguments):
|
||||||
self.debug = arguments.debug
|
self.debug = arguments.debug
|
||||||
self.target_dir = arguments.target_dir
|
self.target_dir = arguments.target_dir
|
||||||
self.tar = tarfile.open(arguments.target_tar, "w:gz")
|
self.tar = tarfile.open(arguments.target_tar, "w:gz", compresslevel=6)
|
||||||
|
|
||||||
def debug_print(self, *arguments):
|
def debug_print(self, *arguments):
|
||||||
if self.debug:
|
if self.debug:
|
||||||
|
@ -29,21 +29,24 @@ class TarRoot:
|
||||||
self._run('.')
|
self._run('.')
|
||||||
self.debug_print("returning to original dir: ", start_dir)
|
self.debug_print("returning to original dir: ", start_dir)
|
||||||
os.chdir(start_dir)
|
os.chdir(start_dir)
|
||||||
|
self.tar.close()
|
||||||
|
|
||||||
|
def _append_symlink(self, entry, *parent):
|
||||||
|
path = entry.name
|
||||||
|
if len(parent) > 0:
|
||||||
|
path = parent[0] + os.sep + path
|
||||||
|
self.debug_print("adding symlink {0}".format(path))
|
||||||
|
ti = self.tar.gettarinfo(name=path)
|
||||||
|
self.tar.addfile(ti)
|
||||||
|
|
||||||
def _append_dir(self, entry, *parent):
|
def _append_dir(self, entry, *parent):
|
||||||
path = entry.name
|
path = entry.name
|
||||||
if len(parent) > 0:
|
if len(parent) > 0:
|
||||||
path = parent[0] + os.sep + path
|
path = parent[0] + os.sep + path
|
||||||
self.debug_print("adding directory {0}".format(path))
|
self.debug_print("adding directory {0}".format(path))
|
||||||
ti = tarfile.TarInfo(path)
|
ti = self.tar.gettarinfo(name=path)
|
||||||
ti.type = tarfile.DIRTYPE
|
# self.debug_print("directory attribute", ti)
|
||||||
stat_result = entry.stat(follow_symlinks=False)
|
self.tar.addfile(tarinfo=ti)
|
||||||
ti.mode = stat.S_IMODE(stat_result.st_mode)
|
|
||||||
ti.uid = stat_result.st_uid
|
|
||||||
ti.gid = stat_result.st_gid
|
|
||||||
ti.mtime = stat_result.st_mtime
|
|
||||||
self.debug_print("writing tar info ", ti)
|
|
||||||
self.tar.addfile(ti)
|
|
||||||
|
|
||||||
def _append_file(self, entry, *parent):
|
def _append_file(self, entry, *parent):
|
||||||
path = entry.name
|
path = entry.name
|
||||||
|
@ -53,12 +56,13 @@ class TarRoot:
|
||||||
self.tar.add(path)
|
self.tar.add(path)
|
||||||
|
|
||||||
def _run(self, running_dir):
|
def _run(self, running_dir):
|
||||||
symlinks = []
|
# symlinks = []
|
||||||
with os.scandir(running_dir) as it:
|
with os.scandir(running_dir) as it:
|
||||||
for entry in it:
|
for entry in it:
|
||||||
if entry.is_symlink():
|
if entry.is_symlink():
|
||||||
self.debug_print("appending symlink ", entry)
|
self.debug_print("appending symlink ", entry)
|
||||||
symlinks.append(entry)
|
# symlinks.append(entry)
|
||||||
|
self._append_symlink(entry, running_dir) if running_dir != "." else self._append_symlink(entry)
|
||||||
elif entry.is_dir():
|
elif entry.is_dir():
|
||||||
self._append_dir(entry, running_dir) if running_dir != "." else self._append_dir(entry)
|
self._append_dir(entry, running_dir) if running_dir != "." else self._append_dir(entry)
|
||||||
self.debug_print("going recursive")
|
self.debug_print("going recursive")
|
||||||
|
|
Loading…
Reference in New Issue