Fix broken flag handling for task spawning
authorMarcel Holtmann <marcel@holtmann.org>
Tue, 8 Dec 2009 23:25:23 +0000 (00:25 +0100)
committerMarcel Holtmann <marcel@holtmann.org>
Tue, 8 Dec 2009 23:25:23 +0000 (00:25 +0100)
include/task.h
src/task.c

index 2239188d4aca6694164bef179362502d72a1ddf7..0d84bab452d0cfbefaccdb641255f4b395707d05 100644 (file)
@@ -57,7 +57,7 @@ int connman_task_set_notify(struct connman_task *task, const char *member,
 
 int connman_task_run(struct connman_task *task,
                        connman_task_exit_t function, void *user_data,
-                       int *fd, int *standard_output, int *standard_error);
+                       int *stdin_fd, int *stdout_fd, int *stderr_fd);
 int connman_task_stop(struct connman_task *task);
 
 #ifdef __cplusplus
index 3997307a3db8821914b996bf1669f94667b4cf6f..74c9b8b55430f51b5b34d097016adb0e3d184627 100644 (file)
@@ -273,11 +273,10 @@ static void task_setup(gpointer user_data)
  */
 int connman_task_run(struct connman_task *task,
                        connman_task_exit_t function, void *user_data,
-                       int *fd, int *standard_output, int *standard_error)
+                       int *stdin_fd, int *stdout_fd, int *stderr_fd)
 {
+       GSpawnFlags flags = G_SPAWN_DO_NOT_REAP_CHILD;
        gboolean result;
-       GSpawnFlags flags = G_SPAWN_DO_NOT_REAP_CHILD |
-                                               G_SPAWN_STDOUT_TO_DEV_NULL;
        char **argv, **envp;
 
        DBG("task %p", task);
@@ -285,9 +284,10 @@ int connman_task_run(struct connman_task *task,
        if (task->pid > 0)
                return -EALREADY;
 
-       if (standard_output == NULL)
+       if (stdout_fd == NULL)
                flags |= G_SPAWN_STDOUT_TO_DEV_NULL;
-       if (standard_error == NULL)
+
+       if (stderr_fd == NULL)
                flags |= G_SPAWN_STDERR_TO_DEV_NULL;
 
        task->exit_func = function;
@@ -320,11 +320,9 @@ int connman_task_run(struct connman_task *task,
        argv = (char **) task->argv->pdata;
        envp = (char **) task->envp->pdata;
 
-       result = g_spawn_async_with_pipes(NULL, argv, envp,
-                                         G_SPAWN_DO_NOT_REAP_CHILD,
-                                         task_setup, task, &task->pid,
-                                         fd, standard_output,
-                                         standard_output, NULL);
+       result = g_spawn_async_with_pipes(NULL, argv, envp, flags,
+                                       task_setup, task, &task->pid,
+                                       stdin_fd, stdout_fd, stderr_fd, NULL);
        if (result == FALSE) {
                connman_error("Failed to spawn %s", argv[0]);
                return -EIO;