X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-remote.git/blobdiff_plain/51608285d0fde6c6b4555d17c152830053804097..ed9def75e564a551201fd64e338eda4c12fab5be:/files/usr/sbin/sipb-xen-remote-listvms diff --git a/files/usr/sbin/sipb-xen-remote-listvms b/files/usr/sbin/sipb-xen-remote-listvms index 55f8fd9..81722e9 100755 --- a/files/usr/sbin/sipb-xen-remote-listvms +++ b/files/usr/sbin/sipb-xen-remote-listvms @@ -6,19 +6,6 @@ suite. """ from subprocess import PIPE, Popen -try: - from subprocess import CalledProcessError -except ImportError: - # Python 2.4 doesn't implement CalledProcessError - class CalledProcessError(Exception): - """This exception is raised when a process run by check_call() returns - a non-zero exit status. The exit status will be stored in the - returncode attribute.""" - def __init__(self, returncode, cmd): - self.returncode = returncode - self.cmd = cmd - def __str__(self): - return "Command '%s' returned non-zero exit status %d" % (self.cmd, self.returncode) import sys import yaml @@ -35,7 +22,8 @@ def main(argv): outputs = [p.communicate()[0] for p in pipes] for p in pipes: if p.returncode != 0: - raise CalledProcessError(p.returncode, cmd) + raise RuntimeError("Command '%s' returned non-zero exit status %d" + % ('remctl', p.returncode)) results = [yaml.load(o, yaml.CSafeLoader) for o in outputs] results = filter(lambda x: x is not None, results) @@ -43,9 +31,10 @@ def main(argv): merged = {} for result in results: merged.update(result) - print yaml.dump(merged, Dumper=yaml.CDumper, default_flow_style=False) + + print yaml.dump(merged, Dumper=yaml.CSafeDumper, default_flow_style=False) if __name__ == '__main__': main(sys.argv) -# vim:et:sw=2:ts=4 +# vim:et:sw=4:ts=4