]> git.sur5r.net Git - i3/i3/commitdiff
complete-run: close all fds except for 0, 1, 2
authorMichael Stapelberg <michael@stapelberg.de>
Sun, 20 Nov 2011 10:51:21 +0000 (10:51 +0000)
committerMichael Stapelberg <michael@stapelberg.de>
Sun, 20 Nov 2011 10:51:21 +0000 (10:51 +0000)
running in a VIM subshell leads to one more fd, for example

testcases/complete-run.pl
testcases/lib/SocketActivation.pm

index e85f5bbb7e8857094d6840530b1184ce0fb43ed0..56ed01a57887f7caff2b021ed9540c5add1ad19f 100755 (executable)
@@ -24,10 +24,15 @@ use StartXDummy;
 use StatusLine;
 # the following modules are not shipped with Perl
 use AnyEvent;
+use AnyEvent::Util;
 use AnyEvent::Handle;
 use AnyEvent::I3 qw(:all);
 use X11::XCB;
 
+# Close superfluous file descriptors which were passed by running in a VIM
+# subshell or situations like that.
+AnyEvent::Util::close_all_fds_except(0, 1, 2);
+
 # We actually use AnyEvent to make sure it loads an event loop implementation.
 # Afterwards, we overwrite SIGCHLD:
 my $cv = AnyEvent->condvar;
index 01b1eb3d5f0ca94aed5be5241c8def963b19f482..da1dda33b3eb2db5a7dfe9e74e9b8d8a6e0af665 100644 (file)
@@ -7,6 +7,7 @@ use IO::Socket::UNIX; # core
 use Cwd qw(abs_path); # core
 use POSIX qw(:fcntl_h); # core
 use AnyEvent::Handle; # not core
+use AnyEvent::Util; # not core
 use Exporter 'import';
 use v5.10;
 
@@ -78,6 +79,10 @@ sub activate_i3 {
             POSIX::close(fileno($socket));
         }
 
+        # Make sure no file descriptors are open. Strangely, I got an open file
+        # descriptor pointing to AnyEvent/Impl/EV.pm when testing.
+        AnyEvent::Util::close_all_fds_except(0, 1, 2, 3);
+
         # Construct the command to launch i3. Use maximum debug level, disable
         # the interactive signalhandler to make it crash immediately instead.
         my $i3cmd = abs_path("../i3") . " -V -d all --disable-signalhandler";