]> git.sur5r.net Git - openldap/commitdiff
All close and redirect stdin, stdout, stderr.
authorKurt Zeilenga <kurt@openldap.org>
Tue, 11 Jan 2000 08:04:59 +0000 (08:04 +0000)
committerKurt Zeilenga <kurt@openldap.org>
Tue, 11 Jan 2000 08:04:59 +0000 (08:04 +0000)
libraries/liblutil/detach.c

index c3081ef1f679195b061b28f288c8b1ebf3d5ba2f..924982d63598525084f12f70326c2b2205c2f20e 100644 (file)
@@ -72,32 +72,32 @@ lutil_detach( int debug, int do_close )
                        break;
                }
 
-               if ( do_close ) {
-                       if ( (sd = open( "/dev/null", O_RDWR )) != -1 ) {
-                               perror("/dev/null");
-                       }
+               if ( (sd = open( "/dev/null", O_RDWR )) != -1 ) {
+                       perror("/dev/null");
+               }
 
-                       for ( i = 0; i < nbits; i++ ) {
-                               if( i == sd ) continue;
+               /* close stdin, stdout, stderr */
+               close( STDIN_FILENO );
+               close( STDOUT_FILENO );
+               close( STDERR_FILENO );
+
+               /* redirect stdin, stdout, stderr to /dev/null */
+               dup2( sd, STDIN_FILENO );
+               dup2( sd, STDOUT_FILENO );
+               dup2( sd, STDERR_FILENO );
 
-                               close( i );
+               close( sd );
 
-                               if( i == STDIN_FILENO ||
-                                       i == STDOUT_FILENO ||
-                                       i == STDERR_FILENO )
+               if ( do_close ) {
+                       /* close everything else */
+                       for ( i = 0; i < nbits; i++ ) {
+                               if( i != STDIN_FILENO &&
+                                       i != STDOUT_FILENO && 
+                                       i != STDERR_FILENO )
                                {
-                                       /* attach /dev/null */
-                                       dup2( sd, i );
+                                       close( i );
                                }
                        }
-
-                       if( sd != STDIN_FILENO &&
-                               sd != STDOUT_FILENO && 
-                               sd != STDERR_FILENO )
-                       {
-                               /* unless stdin, stdout, or stderr, close /dev/null */
-                               close( sd );
-                       }
                }
 
                (void) chdir( "/" );