From 54479250d5f9fce71e4261be548176eda30506a6 Mon Sep 17 00:00:00 2001 From: Christian Vogelgsang Date: Tue, 10 Mar 2020 20:09:24 +0100 Subject: [PATCH] improved fh setup from fobj --- amitools/vamos/lib/dos/FileManager.py | 27 +++++++++++++++++---------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/amitools/vamos/lib/dos/FileManager.py b/amitools/vamos/lib/dos/FileManager.py index bb0c870a..c14801e3 100644 --- a/amitools/vamos/lib/dos/FileManager.py +++ b/amitools/vamos/lib/dos/FileManager.py @@ -23,19 +23,26 @@ def __init__(self, path_mgr, alloc, mem): self.umask = os.umask(0) os.umask(self.umask) - def _create_fh(self, fileno, mode, ami_name, sys_name): - # create unbuffered raw stream if its a tty - if os.isatty(fileno): - fobj = open(fileno, mode, buffering=0) - else: - fobj = open(fileno, mode) - return FileHandle(fobj, ami_name, sys_name, need_close=True) + def _create_fh(self, fobj, mode, ami_name, sys_name): + # by default use the raw buffer of the fobj + raw_fobj = fobj.buffer + need_close = False + # try to get a fd from fobj + try: + fileno = fobj.fileno() + # create unbuffered raw stream if its a tty + if os.isatty(fileno): + raw_fobj = open(fileno, mode, buffering=0) + need_close = True + except: + pass + return FileHandle(raw_fobj, ami_name, sys_name, need_close=need_close) def setup(self, fs_handler_port): self.fs_handler_port = fs_handler_port # setup std input/output - self.std_input = self._create_fh(sys.stdin.fileno(), 'rb', '', '/dev/stdin') - self.std_output = self._create_fh(sys.stdout.fileno(), 'wb', '', '/dev/stdout') + self.std_input = self._create_fh(sys.stdin, 'rb', '', '/dev/stdin') + self.std_output = self._create_fh(sys.stdout, 'wb', '', '/dev/stdout') self._register_file(self.std_input) self._register_file(self.std_output) @@ -82,7 +89,7 @@ def open(self, lock, ami_path, f_mode): fh = FileHandle(fobj, ami_path, sys_name, is_nil = True) elif uname == '*' or uname.startswith('CONSOLE:'): sys_name = '' - fh = self._create_fh(sys.stdout.fileno(), 'wb', '*', '') + fh = self._create_fh(sys.stdout, 'wb', '*', '') else: # map to system path sys_path = self.path_mgr.ami_to_sys_path(lock,ami_path,searchMulti=True)