(no commit message)
[vsys.git] / unixsocketwatcher.ml
index b5672b0..fa46e69 100644 (file)
@@ -36,15 +36,22 @@ let receive_event (listening_socket_spec:fname_and_fd) (_:fname_and_fd) =
         match mapping with
           |None -> logprint "Received unexpected socket event\n";()
           |Some (execpath, slice_name) ->
-              print "Execpath: %s\n" execpath;
               begin
                 let child = fork () in
                   if (child == 0) then
                     begin
                       (* Child *)
                       (* Close all fds except for the socket *)
-                      ignore(execv execpath,[execpath,sprintf "%d" (Obj.magic data_socket)]);
-                      logprint "Could not execve %s" execpath
+                      let fd = Obj.magic data_socket in
+                        let _ = 
+                          (* Close fds *)
+                          for i = 3 to 1023 do
+                            if (i != fd) then close_if_open(i)
+                          done;
+                            execv execpath [|execpath;slice_name;sprintf "%d" fd|] (*with
+                                Unix_error(num,str1,str2)->logprint "Error %d: %s (%s)" (Obj.magic num) str1 str2;raise (Unix_error(num,str1,str2))*)
+                        in
+                            logprint "Could not execve %s" execpath
                     end
               end
           | None -> ()