summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLex Neva <github.com@lexneva.name>2018-06-13 20:45:51 -0400
committerLex Neva <github.com@lexneva.name>2018-06-15 21:44:52 -0400
commitb674c192ee5ff7b3bbc48837379d1cea5f61b3bc (patch)
tree8979c545a2b0b12c9c68b5e250bd42ddc9279463
parent4c46c2eec1fb7cf9e85617030214bcb170b8b533 (diff)
fix issue with input plugin
-rw-r--r--lib/extensions/input.py6
-rw-r--r--lib/utils/io.py8
2 files changed, 7 insertions, 7 deletions
diff --git a/lib/extensions/input.py b/lib/extensions/input.py
index 251859c5..21248dd9 100644
--- a/lib/extensions/input.py
+++ b/lib/extensions/input.py
@@ -14,6 +14,7 @@ from ..svg import PIXELS_PER_MM, render_stitch_plan
from ..svg.tags import INKSCAPE_LABEL
from ..i18n import _
from ..stitch_plan import StitchPlan
+from ..utils.io import save_stdout
class Input(object):
@@ -25,6 +26,9 @@ class Input(object):
def affect(self, args):
+ # libembroidery likes to dump a bunch of debugging stuff to stdout
+ save_stdout()
+
embroidery_file = args[0]
pattern = embPattern_create()
embPattern_read(pattern, embroidery_file)
@@ -65,4 +69,4 @@ class Input(object):
# Note: this is NOT the same as centering the design in the canvas!
layer.set('transform', 'translate(%s,%s)' % (extents[0], extents[1]))
- print etree.tostring(svg)
+ print >> sys.real_stdout, etree.tostring(svg)
diff --git a/lib/utils/io.py b/lib/utils/io.py
index 44d48c2a..e5a246f3 100644
--- a/lib/utils/io.py
+++ b/lib/utils/io.py
@@ -9,15 +9,13 @@ def save_stderr():
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.real_stderr.write(sys.stderr.getvalue())
- sys.stderr = sys.stderr_backup
+ sys.stderr = sys.real_stderr
# It's probably possible to generalize this code, but when I tried,
# the result was incredibly unreadable.
@@ -26,12 +24,10 @@ def save_stdout():
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
+ sys.stdout = sys.real_stdout