X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=mimedecode.py;h=9433b0d0caad0411bca110c7024f9f5f30a0a65e;hb=bf2931c9491ed9d9155dbd97feb48ac5fb0bde49;hp=5d58333e51350c03077d90a053e29137a20e18d2;hpb=141754c6212c218c538dcadd2d79da4b5bb0fc5e;p=mimedecode.git diff --git a/mimedecode.py b/mimedecode.py index 5d58333..9433b0d 100755 --- a/mimedecode.py +++ b/mimedecode.py @@ -2,6 +2,7 @@ """Decode MIME message""" import sys, os +import subprocess from mimedecode_version import __version__, \ __author__, __copyright__, __license__ if sys.version_info[0] >= 3: @@ -243,16 +244,17 @@ def decode_body(msg, s): return s outfile = open(filename, 'wb') - if charset and isinstance(s, bytes): + if charset and bytes is not str and isinstance(s, bytes): # Python3 s = s.decode(charset, "replace") if not isinstance(s, bytes): s = s.encode(g.default_encoding, "replace") outfile.write(s) outfile.close() - pipe = os.popen(command, 'r') - new_s = pipe.read() - if pipe.close() is None: # result=0, Ok + pipe = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE) + new_s = pipe.stdout.read() + pipe.stdout.close() + if pipe.wait() == 0: # result=0, Ok s = new_s os.remove(filename)