Update terminalManagement
This commit is contained in:
parent
5bd250e67f
commit
bd113bb640
@ -34,7 +34,6 @@ class Terminal:
|
|||||||
|
|
||||||
def open_terminal(command="bash", columns=80, lines=24):
|
def open_terminal(command="bash", columns=80, lines=24):
|
||||||
p_pid, master_fd = pty.fork()
|
p_pid, master_fd = pty.fork()
|
||||||
print('PID',p_pid)
|
|
||||||
if p_pid == 0: # Child.
|
if p_pid == 0: # Child.
|
||||||
argv = shlex.split(command)
|
argv = shlex.split(command)
|
||||||
env = os.environ.copy()
|
env = os.environ.copy()
|
||||||
@ -47,7 +46,6 @@ def open_terminal(command="bash", columns=80, lines=24):
|
|||||||
def HandleTerminal():
|
def HandleTerminal():
|
||||||
debug = False
|
debug = False
|
||||||
running = True
|
running = True
|
||||||
#attr = termios.tcgetattr(sys.stdin.fileno())
|
|
||||||
try:
|
try:
|
||||||
old_attr = termios.tcgetattr(sys.stdin)
|
old_attr = termios.tcgetattr(sys.stdin)
|
||||||
tty.setraw(0)
|
tty.setraw(0)
|
||||||
@ -64,11 +62,9 @@ def HandleTerminal():
|
|||||||
msgBytes = read_all(p_out.fileno())
|
msgBytes = read_all(p_out.fileno())
|
||||||
except (EOFError, OSError):
|
except (EOFError, OSError):
|
||||||
running = False
|
running = False
|
||||||
break
|
break
|
||||||
#sys.exit(0)
|
terminal.feed(msgBytes)
|
||||||
os.write(sys.stdout.fileno(), msgBytes)
|
os.write(sys.stdout.fileno(), msgBytes)
|
||||||
sys.stdout.flush()
|
|
||||||
#print(terminal.screen.display)
|
|
||||||
if debug:
|
if debug:
|
||||||
print('after p_out')
|
print('after p_out')
|
||||||
if sys.stdin in r:
|
if sys.stdin in r:
|
||||||
@ -79,7 +75,7 @@ def HandleTerminal():
|
|||||||
except (EOFError, OSError):
|
except (EOFError, OSError):
|
||||||
running = False
|
running = False
|
||||||
break
|
break
|
||||||
terminal.feed(msgBytes)
|
terminal.feed(msgBytes)
|
||||||
os.write(p_out.fileno(), msgBytes)
|
os.write(p_out.fileno(), msgBytes)
|
||||||
if debug:
|
if debug:
|
||||||
print('after stdin')
|
print('after stdin')
|
||||||
@ -90,6 +86,7 @@ def HandleTerminal():
|
|||||||
os.kill(p_pid, signal.SIGTERM)
|
os.kill(p_pid, signal.SIGTERM)
|
||||||
p_out.close()
|
p_out.close()
|
||||||
termios.tcsetattr(sys.stdin, termios.TCSADRAIN, old_attr)
|
termios.tcsetattr(sys.stdin, termios.TCSADRAIN, old_attr)
|
||||||
|
sys.exit(0)
|
||||||
|
|
||||||
def get_terminal_size(fd):
|
def get_terminal_size(fd):
|
||||||
s = struct.pack('HHHH', 0, 0, 0, 0)
|
s = struct.pack('HHHH', 0, 0, 0, 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user