From 78a32abfcc92461c19c859e796b78ecd09bc9509 Mon Sep 17 00:00:00 2001 From: Hollow Man Date: Tue, 7 Jul 2020 23:06:37 +0800 Subject: [PATCH] Terminal: Listen to sub-process status to exit --- app/terminal/buffer.py | 13 ++++++------- app/terminal/index.html | 20 +++----------------- app/terminal/server.js | 3 ++- 3 files changed, 11 insertions(+), 25 deletions(-) diff --git a/app/terminal/buffer.py b/app/terminal/buffer.py index f45a3e3..f0c4692 100644 --- a/app/terminal/buffer.py +++ b/app/terminal/buffer.py @@ -65,7 +65,7 @@ class AppBuffer(BrowserBuffer): self.timer=QTimer() self.timer.start(250) - self.timer.timeout.connect(self.on_change_directory) + self.timer.timeout.connect(self.checking_status) def focus_terminal(self): event = QMouseEvent(QEvent.MouseButtonPress, QPointF(0, 0), Qt.LeftButton, Qt.LeftButton, Qt.NoModifier) @@ -81,19 +81,18 @@ class AppBuffer(BrowserBuffer): html = f.read().replace("%1", str(self.port)).replace("%2", "file://" + os.path.join(os.path.dirname(__file__))).replace("%3", theme).replace("%4", self.emacs_var_dict["eaf-terminal-font-size"]).replace("%5", self.current_directory) self.buffer_widget.setHtml(html) - def on_change_directory(self): + def checking_status(self): changed_directory = str(self.buffer_widget.execute_js("title")) if not changed_directory == self.current_directory: - self.update_title() + self.change_title(changed_directory) self.eval_in_emacs.emit('''(setq default-directory "'''+ changed_directory +'''")''') self.current_directory = changed_directory - - def update_title(self): - self.change_title(str(self.buffer_widget.execute_js("title"))) + if subprocess.Popen.poll(self.background_process) is not None: + self.destroy_buffer() def destroy_buffer(self): - os.kill(self.background_process.pid, signal.SIGKILL) super().destroy_buffer() + self.close_buffer() self.timer.stop() @interactive() diff --git a/app/terminal/index.html b/app/terminal/index.html index 8b1c457..54a27fe 100644 --- a/app/terminal/index.html +++ b/app/terminal/index.html @@ -33,14 +33,12 @@
diff --git a/app/terminal/server.js b/app/terminal/server.js index 242c424..e515c9a 100644 --- a/app/terminal/server.js +++ b/app/terminal/server.js @@ -2,12 +2,13 @@ this.Pty = require("node-pty"); this.Websocket = require("ws").Server; this.onclosed = () => { - ws.send("ESCAPED|-- CLOSED"); + process.exit() }; this.onopened = () => {}; this.onresize = () => {}; this.ondisconnected = () => {}; + var port = process.argv.slice(2)[0] var dir = process.argv.slice(3)[0] var commands = process.argv.slice(4)[0].split(" ")