Added new 'safeCommandOutput' command to Scyther/Misc and force use of Python 2.4 or later.
This commit is contained in:
parent
feb400c610
commit
7d03f22b24
@ -27,11 +27,13 @@
|
|||||||
import sys
|
import sys
|
||||||
import os.path
|
import os.path
|
||||||
try:
|
try:
|
||||||
from subprocess import Popen
|
from subprocess import Popen,PIPE
|
||||||
AvailablePopen = True
|
|
||||||
except:
|
except:
|
||||||
import os
|
panic("""
|
||||||
AvailablePopen = False
|
Cannot import 'subprocess.Popen' module.
|
||||||
|
|
||||||
|
You need at least Python 2.4 to use this program.
|
||||||
|
""")
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -69,21 +71,51 @@ def mypath(file):
|
|||||||
basedir = os.path.dirname(__file__)
|
basedir = os.path.dirname(__file__)
|
||||||
return os.path.join(basedir,file)
|
return os.path.join(basedir,file)
|
||||||
|
|
||||||
|
def getShell():
|
||||||
|
"""
|
||||||
|
Determine if we want a shell for Popen
|
||||||
|
"""
|
||||||
|
if sys.platform.startswith("win"):
|
||||||
|
shell=False
|
||||||
|
else:
|
||||||
|
# Needed to handle the string input correctly (as opposed to a sequence where the first element is the executable)
|
||||||
|
# This is not needed on Windows, where it has a different effect altogether.
|
||||||
|
# See http://docs.python.org/library/subprocess.html?highlight=subprocess#module-subprocess
|
||||||
|
shell=True
|
||||||
|
return shell
|
||||||
|
|
||||||
|
def safeCommandOutput(cmd):
|
||||||
|
""" Execute a command and return (sts,sout,serr).
|
||||||
|
Meant for short outputs, as output is stored in memory and
|
||||||
|
not written to a file.
|
||||||
|
"""
|
||||||
|
p = Popen(cmd, shell=getShell(), stdout=PIPE, stderr=PIPE)
|
||||||
|
(sout,serr) = p.communicate()
|
||||||
|
return (p.returncode,sout,serr)
|
||||||
|
|
||||||
def safeCommand(cmd):
|
def safeCommand(cmd):
|
||||||
""" Execute a command with some arguments. Safe cross-platform
|
""" Execute a command with some arguments. Safe cross-platform
|
||||||
version, I hope. """
|
version, I hope. """
|
||||||
|
|
||||||
global AvailablePopen
|
p = Popen(cmd, shell=getShell())
|
||||||
|
sts = p.wait()
|
||||||
if AvailablePopen:
|
|
||||||
if sys.platform.startswith("win"):
|
|
||||||
shell=False
|
|
||||||
else:
|
|
||||||
shell=True
|
|
||||||
p = Popen(cmd, shell=shell)
|
|
||||||
sts = p.wait()
|
|
||||||
else:
|
|
||||||
sts = os.system(cmd)
|
|
||||||
|
|
||||||
return sts
|
return sts
|
||||||
|
|
||||||
|
def panic(text):
|
||||||
|
"""
|
||||||
|
Errors that occur before we even are sure about wxPython etc. are dumped
|
||||||
|
on the command line and reported using Tkinter.
|
||||||
|
"""
|
||||||
|
|
||||||
|
import Tkinter
|
||||||
|
|
||||||
|
print text
|
||||||
|
|
||||||
|
root = Tkinter.Tk()
|
||||||
|
w = Tkinter.Label(root, text=text)
|
||||||
|
w.pack()
|
||||||
|
root.mainloop()
|
||||||
|
|
||||||
|
sys.exit(-1)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user