fix zip file corruption

pull/198/head
Lex Neva 2018-06-13 20:10:22 -04:00
rodzic f9a5e4c03a
commit 4c46c2eec1
3 zmienionych plików z 32 dodań i 3 usunięć

Wyświetl plik

@ -35,12 +35,14 @@ class Output(InkstitchExtension):
# in windows, failure to close here will keep the file locked
temp_file.close()
# libembroidery likes to debug log things to stdout. No way to disable it.
save_stdout()
write_embroidery_file(temp_file.name, stitch_plan, self.document.getroot())
# inkscape will read the file contents from stdout and copy
# to the destination file that the user chose
with open(temp_file.name) as output_file:
sys.stdout.write(output_file.read())
sys.real_stdout.write(output_file.read())
# clean up the temp file
os.remove(temp_file.name)

Wyświetl plik

@ -11,6 +11,7 @@ from ..i18n import _
from ..output import write_embroidery_file
from ..stitch_plan import patches_to_stitch_plan
from ..svg import render_stitch_plan, PIXELS_PER_MM
from ..utils.io import save_stdout
class Zip(InkstitchExtension):
@ -48,12 +49,19 @@ class Zip(InkstitchExtension):
files = []
# libembroidery likes to debug log things to stdout. No way to disable it.
save_stdout()
for format in self.formats:
if getattr(self.options, format):
output_file = os.path.join(path, "%s.%s" % (base_file_name, format))
write_embroidery_file(output_file, stitch_plan, self.document.getroot())
files.append(output_file)
# I'd love to do restore_stderr() here, but if I do, libembroidery's
# stuff still prints out and corrupts the zip! That's because it uses
# C's buffered stdout, so it hasn't actually written anything to the
# real standard output yet.
if not files:
self.errormsg(_("No embroidery file formats selected."))
@ -69,7 +77,7 @@ class Zip(InkstitchExtension):
# inkscape will read the file contents from stdout and copy
# to the destination file that the user chose
with open(temp_file.name) as output_file:
sys.stdout.write(output_file.read())
sys.real_stdout.write(output_file.read())
os.remove(temp_file.name)
for file in files:

Wyświetl plik

@ -7,12 +7,31 @@ def save_stderr():
# GTK likes to spam stderr, which inkscape will show in a dialog.
null = open(os.devnull, 'w')
sys.stderr_dup = os.dup(sys.stderr.fileno())
sys.real_stderr = os.fdopen(sys.stderr_dup, 'w')
os.dup2(null.fileno(), 2)
sys.stderr_backup = sys.stderr
sys.stderr = StringIO()
def restore_stderr():
sys.real_stderr.close()
os.dup2(sys.stderr_dup, 2)
sys.stderr_backup.write(sys.stderr.getvalue())
sys.real_stderr.write(sys.stderr.getvalue())
sys.stderr = sys.stderr_backup
# It's probably possible to generalize this code, but when I tried,
# the result was incredibly unreadable.
def save_stdout():
null = open(os.devnull, 'w')
sys.stdout_dup = os.dup(sys.stdout.fileno())
sys.real_stdout = os.fdopen(sys.stdout_dup, 'w')
os.dup2(null.fileno(), 1)
sys.stdout_backup = sys.stdout
sys.stdout = StringIO()
def restore_stdout():
sys.real_stdout.close()
os.dup2(sys.stdout_dup, 1)
sys.real_stdout.write(sys.stdout.getvalue())
sys.stdout = sys.stdout_backup