From 788dfd07c16a7eeabe8329fcdb4f66a63f42d2d5 Mon Sep 17 00:00:00 2001 From: XiaoBaiYun <71159641+littlewhitecloud@users.noreply.github.com> Date: Mon, 17 Jul 2023 16:05:24 +0800 Subject: [PATCH] fix #51 and also fix #52 --- tktermwidget/widgets.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/tktermwidget/widgets.py b/tktermwidget/widgets.py index dd6bbe4..ac7a0f4 100644 --- a/tktermwidget/widgets.py +++ b/tktermwidget/widgets.py @@ -203,10 +203,13 @@ def execute(self, _: Event) -> str: if cmd in ["clear", "cls"]: self.text.delete("1.0", "end") self.directory() + self.index = 1 return "break" elif cmd == "exit": self.master.quit() elif cmd.startswith("cd"): # TAG: is all platform use cd...? + # It will raise OSError instead of output a normal error + # TODO: fix it if cmd == "cd..": chdir(path.abspath(path.join(getcwd(), ".."))) else: @@ -252,8 +255,6 @@ def execute(self, _: Event) -> str: # Update the text and the index self.index = int(self.text.index("insert").split(".")[0]) self.update() - - del cmd, errors, returncode, returnlines return "break" # Prevent the default newline character insertion def newline(self) -> None: @@ -263,6 +264,8 @@ def newline(self) -> None: def update(self) -> str: """Update the text widget or the command has no output""" + # Make a newline + self.newline() # Insert the directory self.directory() # Update cursor and check if it is out of the edit range