shell_command: refactor output parsing
Separate output by line, and execute the output callback once per line. Signed-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
116c1e9f29
commit
093b8c14d6
|
@ -12,7 +12,7 @@ from tornado import gen
|
||||||
from tornado.ioloop import IOLoop
|
from tornado.ioloop import IOLoop
|
||||||
|
|
||||||
class ShellCommand:
|
class ShellCommand:
|
||||||
def __init__(self, cmd, callback=None):
|
def __init__(self, cmd, callback):
|
||||||
self.io_loop = IOLoop.current()
|
self.io_loop = IOLoop.current()
|
||||||
self.name = cmd
|
self.name = cmd
|
||||||
self.output_cb = callback
|
self.output_cb = callback
|
||||||
|
@ -29,15 +29,11 @@ class ShellCommand:
|
||||||
except Exception:
|
except Exception:
|
||||||
return
|
return
|
||||||
data = self.partial_output + data
|
data = self.partial_output + data
|
||||||
if b'\n' not in data:
|
lines = data.split(b'\n')
|
||||||
self.partial_output = data
|
self.partial_output = lines.pop()
|
||||||
return
|
for line in lines:
|
||||||
elif data[-1] != b'\n':
|
|
||||||
split = data.rfind(b'\n') + 1
|
|
||||||
self.partial_output = data[split:]
|
|
||||||
data = data[:split]
|
|
||||||
try:
|
try:
|
||||||
self.output_cb(data)
|
self.output_cb(line)
|
||||||
except Exception:
|
except Exception:
|
||||||
logging.exception("Error writing command output")
|
logging.exception("Error writing command output")
|
||||||
|
|
||||||
|
@ -108,7 +104,7 @@ class ShellCommand:
|
||||||
|
|
||||||
|
|
||||||
class ShellCommandFactory:
|
class ShellCommandFactory:
|
||||||
def build_shell_command(self, cmd, callback):
|
def build_shell_command(self, cmd, callback=None):
|
||||||
return ShellCommand(cmd, callback)
|
return ShellCommand(cmd, callback)
|
||||||
|
|
||||||
def load_plugin(config):
|
def load_plugin(config):
|
||||||
|
|
Loading…
Reference in New Issue