diff --git a/terminatorlib/terminal.py b/terminatorlib/terminal.py index c7babe3c..7bb78a15 100644 --- a/terminatorlib/terminal.py +++ b/terminatorlib/terminal.py @@ -1505,14 +1505,37 @@ def spawn_child(self, widget=None, respawn=False, debugserver=False, init_comman dbg('Forking shell: "%s" with args: %s' % (shell, args)) args.insert(0, shell) - result, self.pid = self.vte.spawn_sync(Vte.PtyFlags.DEFAULT, - self.cwd, - args, - envv, - GLib.SpawnFlags.FILE_AND_ARGV_ZERO, - None, - None, - None) + + if util.is_flatpak(): + dbg('Flatpak detected') + args = util.get_flatpak_args(args, envv, self.cwd) + dbg('Forking shell: "%s" with args: %s via flatpak-spawn' % (shell, args)) + + self.pid = self.vte.spawn_async( + Vte.PtyFlags.NO_CTTY, + self.cwd, + args, + envv, + 0, + None, + None, + -1, + None, + None, + None, + ) + else: + result, self.pid = self.vte.spawn_sync( + Vte.PtyFlags.DEFAULT, + self.cwd, + args, + envv, + GLib.SpawnFlags.FILE_AND_ARGV_ZERO, + None, + None, + None + ) + self.command = shell self.titlebar.update() diff --git a/terminatorlib/util.py b/terminatorlib/util.py index 4c4a72d4..eda14ced 100644 --- a/terminatorlib/util.py +++ b/terminatorlib/util.py @@ -43,6 +43,9 @@ # list of methods to show debugging for. empty list means show all methods DEBUGMETHODS = [] +def is_flatpak(): + return os.path.exists("/.flatpak-info") + def dbg(log = ""): """Print a message if debugging is enabled""" if DEBUG: @@ -144,6 +147,13 @@ def path_lookup(command): def shell_lookup(): """Find an appropriate shell for the user""" + if is_flatpak(): + getent = subprocess.check_output([ + 'flatpak-spawn', '--host', 'getent', 'passwd', + pwd.getpwuid(os.getuid())[0] + ]).decode(encoding='UTF-8').rstrip('\n') + shell = getent.split(':')[6] + return shell try: usershell = pwd.getpwuid(os.getuid())[6] except KeyError: @@ -394,3 +404,22 @@ def update_config_to_cell_height(filename): except Exception as ex: err('Unable to open ā€˜%sā€™ for reading and/or writting.\n(%s)' % (filename, ex)) + +def get_flatpak_args(args, envv, cwd): + """Contruct args to be executed via flatpak-spawn""" + flatpak_args = None + env_args = ['--env={}'.format(env) for env in envv] + flatpak_spawn = [ + "flatpak-spawn", "--host", "--watch-bus", "--forward-fd=1", + "--forward-fd=2", "--directory={}".format(cwd) + ] + # Detect and remove duplicate shell in args + # to work around vte.spawn_sync() requirement. + if len(set([args[0], args[1]])) == 1: + del args[0] + + flatpak_args = flatpak_spawn + env_args + args + + dbg('returned flatpak args: %s' % flatpak_args) + + return flatpak_args