From: Zac Medico Date: Wed, 11 Jun 2008 03:49:52 +0000 (-0000) Subject: Use spawn() instead of system(). (trunk r10642) X-Git-Tag: v2.1.5.5~2 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=2c0c4c8f6a1cb7a24f84a906a0f39e30fa75d838;p=portage.git Use spawn() instead of system(). (trunk r10642) svn path=/main/branches/2.1.2/; revision=10643 --- diff --git a/bin/dispatch-conf b/bin/dispatch-conf index 94e2d6cac..d2374b696 100755 --- a/bin/dispatch-conf +++ b/bin/dispatch-conf @@ -217,10 +217,12 @@ class dispatch: while 1: clear_screen() if show_new_diff: - os.system((self.options['diff']) % (conf['new'], mrgconf)) + cmd = self.options['diff'] % (conf['new'], mrgconf) + spawn_shell(cmd) show_new_diff = 0 else: - os.system((self.options['diff']) % (conf['current'], newconf)) + cmd = self.options['diff'] % (conf['current'], newconf) + spawn_shell(cmd) print print '>> (%i of %i) -- %s' % (count, len(confs), conf ['current']) @@ -392,6 +394,20 @@ def clear_screen(): pass os.system("clear 2>/dev/null") +from portage_exec import find_binary, spawn +shell = os.environ.get("SHELL") +if not shell or not os.access(shell, os.EX_OK): + shell = find_binary("sh") + +def spawn_shell(cmd): + if shell: + spawn([shell, "-c", cmd], env=os.environ, + fd_pipes = { 0 : sys.stdin.fileno(), + 1 : sys.stdout.fileno(), + 2 : sys.stderr.fileno()}) + else: + os.system(cmd) + # run d = dispatch ()