X-Git-Url: https://git.tld-linux.org/?a=blobdiff_plain;f=TLD_Builder%2Fbqueue.py;h=131b911e74037f176ac569d670094358e7326138;hb=9ea122b00e3a99b16246e1e38576916a2e25c0aa;hp=d5b183f8c8aac24fb85662c5af38012103380f7e;hpb=3a6296fff210d498302ce0a2da6beed689466347;p=tld-builder.git diff --git a/TLD_Builder/bqueue.py b/TLD_Builder/bqueue.py index d5b183f..131b911 100644 --- a/TLD_Builder/bqueue.py +++ b/TLD_Builder/bqueue.py @@ -4,14 +4,12 @@ import re import gzip import time import sys -if sys.version_info[0] == 2: - import StringIO -else: - from io import StringIO +from io import StringIO import os import fcntl import string import tempfile +import shutil # TLD_Builder: import gpg @@ -131,21 +129,26 @@ class B_Queue: sio = StringIO() self._write_to(sio) sio.seek(0) - sio.write(gpg.sign(sio.read())) + sio.write(util.to_str(gpg.sign(sio.read()))) sio.seek(0) (fdno, tmpname) = tempfile.mkstemp(dir=os.path.dirname(name)) f = os.fdopen(fdno, "w") - if re.search(r"\.gz$", name): - fgz = gzip.GzipFile(filename=name, mode="w", compresslevel=6, fileobj=f) - util.sendfile(sio, fgz) - fgz.close() - else: - util.sendfile(sio, f) + util.sendfile(sio, f) f.flush() os.fsync(f.fileno()) f.close() - os.chmod(tmpname, 0o0644) - os.rename(tmpname, name) + if re.search(r"\.gz$", name): + f_in = open(tmpname, 'rb') + f_out = gzip.open(name, 'wb') + shutil.copyfileobj(f_in, f_out) + f_in.close(); + f_out.flush(); + os.fsync(f_out.fileno()) + f_out.close(); + os.remove(tmpname) + else: + os.rename(tmpname, name) + os.chmod(name, 0o0644) def add(self, req): self.requests.append(req)