|
Packit Service |
fb6fa5 |
/*
|
|
Packit Service |
fb6fa5 |
* Copyright (C) 2003 Sun Microsystems Inc.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* This library is free software; you can redistribute it and/or
|
|
Packit Service |
fb6fa5 |
* modify it under the terms of the GNU Library General Public
|
|
Packit Service |
fb6fa5 |
* License as published by the Free Software Foundation; either
|
|
Packit Service |
fb6fa5 |
* version 2 of the License, or (at your option) any later version.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* This library is distributed in the hope that it will be useful,
|
|
Packit Service |
fb6fa5 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit Service |
fb6fa5 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit Service |
fb6fa5 |
* Library General Public License for more details.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* You should have received a copy of the GNU Library General Public
|
|
Packit Service |
fb6fa5 |
* License along with this library; if not, write to the
|
|
Packit Service |
fb6fa5 |
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
Packit Service |
fb6fa5 |
* Boston, MA 02111-1307, USA.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Authors: Mark McLoughlin <mark@skynet.ie>
|
|
Packit Service |
fb6fa5 |
*/
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
#include "config.h"
|
|
Packit Service |
fb6fa5 |
#include <string.h>
|
|
Packit Service |
fb6fa5 |
#include <stdlib.h>
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
#include "gdkspawn.h"
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
#include <glib.h>
|
|
Packit Service |
fb6fa5 |
#include <gdk/gdk.h>
|
|
Packit Service |
fb6fa5 |
#include "gdkalias.h"
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
typedef struct {
|
|
Packit Service |
fb6fa5 |
char *display;
|
|
Packit Service |
fb6fa5 |
GSpawnChildSetupFunc child_setup;
|
|
Packit Service |
fb6fa5 |
gpointer user_data;
|
|
Packit Service |
fb6fa5 |
} UserChildSetup;
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
/*
|
|
Packit Service |
fb6fa5 |
* Set the DISPLAY variable, and then call the user-specified child setup
|
|
Packit Service |
fb6fa5 |
* function. This is required so that applications can use gdk_spawn_* and
|
|
Packit Service |
fb6fa5 |
* call putenv() in their child_setup functions.
|
|
Packit Service |
fb6fa5 |
*/
|
|
Packit Service |
fb6fa5 |
static void
|
|
Packit Service |
fb6fa5 |
set_environment (gpointer user_data)
|
|
Packit Service |
fb6fa5 |
{
|
|
Packit Service |
fb6fa5 |
UserChildSetup *setup = user_data;
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
g_setenv ("DISPLAY", setup->display, TRUE);
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
if (setup->child_setup)
|
|
Packit Service |
fb6fa5 |
setup->child_setup (setup->user_data);
|
|
Packit Service |
fb6fa5 |
}
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
/**
|
|
Packit Service |
fb6fa5 |
* gdk_spawn_on_screen:
|
|
Packit Service |
fb6fa5 |
* @screen: a #GdkScreen
|
|
Packit Service |
fb6fa5 |
* @working_directory: child's current working directory, or %NULL to
|
|
Packit Service |
fb6fa5 |
* inherit parent's
|
|
Packit Service |
fb6fa5 |
* @argv: child's argument vector
|
|
Packit Service |
fb6fa5 |
* @envp: child's environment, or %NULL to inherit parent's
|
|
Packit Service |
fb6fa5 |
* @flags: flags from #GSpawnFlags
|
|
Packit Service |
fb6fa5 |
* @child_setup: function to run in the child just before exec()
|
|
Packit Service |
fb6fa5 |
* @user_data: user data for @child_setup
|
|
Packit Service |
fb6fa5 |
* @child_pid: return location for child process ID, or %NULL
|
|
Packit Service |
fb6fa5 |
* @error: return location for error
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Like g_spawn_async(), except the child process is spawned in such
|
|
Packit Service |
fb6fa5 |
* an environment that on calling gdk_display_open() it would be
|
|
Packit Service |
fb6fa5 |
* returned a #GdkDisplay with @screen as the default screen.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* This is useful for applications which wish to launch an application
|
|
Packit Service |
fb6fa5 |
* on a specific screen.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Return value: %TRUE on success, %FALSE if error is set
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Since: 2.4
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Deprecated: 2.24: This function is being removed in 3.0. Use
|
|
Packit Service |
fb6fa5 |
* either g_spawn_sync(), g_spawn_async(), or #GdkAppLaunchContext instead.
|
|
Packit Service |
fb6fa5 |
**/
|
|
Packit Service |
fb6fa5 |
gboolean
|
|
Packit Service |
fb6fa5 |
gdk_spawn_on_screen (GdkScreen *screen,
|
|
Packit Service |
fb6fa5 |
const gchar *working_directory,
|
|
Packit Service |
fb6fa5 |
gchar **argv,
|
|
Packit Service |
fb6fa5 |
gchar **envp,
|
|
Packit Service |
fb6fa5 |
GSpawnFlags flags,
|
|
Packit Service |
fb6fa5 |
GSpawnChildSetupFunc child_setup,
|
|
Packit Service |
fb6fa5 |
gpointer user_data,
|
|
Packit Service |
fb6fa5 |
gint *child_pid,
|
|
Packit Service |
fb6fa5 |
GError **error)
|
|
Packit Service |
fb6fa5 |
{
|
|
Packit Service |
fb6fa5 |
UserChildSetup setup_data;
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
g_return_val_if_fail (GDK_IS_SCREEN (screen), FALSE);
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
setup_data.display = gdk_screen_make_display_name (screen);
|
|
Packit Service |
fb6fa5 |
setup_data.child_setup = child_setup;
|
|
Packit Service |
fb6fa5 |
setup_data.user_data = user_data;
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
return g_spawn_async (working_directory,
|
|
Packit Service |
fb6fa5 |
argv,
|
|
Packit Service |
fb6fa5 |
envp,
|
|
Packit Service |
fb6fa5 |
flags,
|
|
Packit Service |
fb6fa5 |
set_environment,
|
|
Packit Service |
fb6fa5 |
&setup_data,
|
|
Packit Service |
fb6fa5 |
child_pid,
|
|
Packit Service |
fb6fa5 |
error);
|
|
Packit Service |
fb6fa5 |
}
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
/**
|
|
Packit Service |
fb6fa5 |
* gdk_spawn_on_screen_with_pipes:
|
|
Packit Service |
fb6fa5 |
* @screen: a #GdkScreen
|
|
Packit Service |
fb6fa5 |
* @working_directory: child's current working directory, or %NULL to
|
|
Packit Service |
fb6fa5 |
* inherit parent's
|
|
Packit Service |
fb6fa5 |
* @argv: child's argument vector
|
|
Packit Service |
fb6fa5 |
* @envp: child's environment, or %NULL to inherit parent's
|
|
Packit Service |
fb6fa5 |
* @flags: flags from #GSpawnFlags
|
|
Packit Service |
fb6fa5 |
* @child_setup: function to run in the child just before exec()
|
|
Packit Service |
fb6fa5 |
* @user_data: user data for @child_setup
|
|
Packit Service |
fb6fa5 |
* @child_pid: return location for child process ID, or %NULL
|
|
Packit Service |
fb6fa5 |
* @standard_input: return location for file descriptor to write to
|
|
Packit Service |
fb6fa5 |
* child's stdin, or %NULL
|
|
Packit Service |
fb6fa5 |
* @standard_output: return location for file descriptor to read child's
|
|
Packit Service |
fb6fa5 |
* stdout, or %NULL
|
|
Packit Service |
fb6fa5 |
* @standard_error: return location for file descriptor to read child's
|
|
Packit Service |
fb6fa5 |
* stderr, or %NULL
|
|
Packit Service |
fb6fa5 |
* @error: return location for error
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Like g_spawn_async_with_pipes(), except the child process is
|
|
Packit Service |
fb6fa5 |
* spawned in such an environment that on calling gdk_display_open()
|
|
Packit Service |
fb6fa5 |
* it would be returned a #GdkDisplay with @screen as the default
|
|
Packit Service |
fb6fa5 |
* screen.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* This is useful for applications which wish to launch an application
|
|
Packit Service |
fb6fa5 |
* on a specific screen.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Return value: %TRUE on success, %FALSE if an error was set
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Since: 2.4
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Deprecated: 2.24: This function is being removed in 3.0. Use
|
|
Packit Service |
fb6fa5 |
* either g_spawn_async_with_pipes() or #GdkAppLaunchContext instead.
|
|
Packit Service |
fb6fa5 |
**/
|
|
Packit Service |
fb6fa5 |
gboolean
|
|
Packit Service |
fb6fa5 |
gdk_spawn_on_screen_with_pipes (GdkScreen *screen,
|
|
Packit Service |
fb6fa5 |
const gchar *working_directory,
|
|
Packit Service |
fb6fa5 |
gchar **argv,
|
|
Packit Service |
fb6fa5 |
gchar **envp,
|
|
Packit Service |
fb6fa5 |
GSpawnFlags flags,
|
|
Packit Service |
fb6fa5 |
GSpawnChildSetupFunc child_setup,
|
|
Packit Service |
fb6fa5 |
gpointer user_data,
|
|
Packit Service |
fb6fa5 |
gint *child_pid,
|
|
Packit Service |
fb6fa5 |
gint *standard_input,
|
|
Packit Service |
fb6fa5 |
gint *standard_output,
|
|
Packit Service |
fb6fa5 |
gint *standard_error,
|
|
Packit Service |
fb6fa5 |
GError **error)
|
|
Packit Service |
fb6fa5 |
{
|
|
Packit Service |
fb6fa5 |
UserChildSetup setup_data;
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
g_return_val_if_fail (GDK_IS_SCREEN (screen), FALSE);
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
setup_data.display = gdk_screen_make_display_name (screen);
|
|
Packit Service |
fb6fa5 |
setup_data.child_setup = child_setup;
|
|
Packit Service |
fb6fa5 |
setup_data.user_data = user_data;
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
return g_spawn_async_with_pipes (working_directory,
|
|
Packit Service |
fb6fa5 |
argv,
|
|
Packit Service |
fb6fa5 |
envp,
|
|
Packit Service |
fb6fa5 |
flags,
|
|
Packit Service |
fb6fa5 |
set_environment,
|
|
Packit Service |
fb6fa5 |
&setup_data,
|
|
Packit Service |
fb6fa5 |
child_pid,
|
|
Packit Service |
fb6fa5 |
standard_input,
|
|
Packit Service |
fb6fa5 |
standard_output,
|
|
Packit Service |
fb6fa5 |
standard_error,
|
|
Packit Service |
fb6fa5 |
error);
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
}
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
/**
|
|
Packit Service |
fb6fa5 |
* gdk_spawn_command_line_on_screen:
|
|
Packit Service |
fb6fa5 |
* @screen: a #GdkScreen
|
|
Packit Service |
fb6fa5 |
* @command_line: a command line
|
|
Packit Service |
fb6fa5 |
* @error: return location for errors
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Like g_spawn_command_line_async(), except the child process is
|
|
Packit Service |
fb6fa5 |
* spawned in such an environment that on calling gdk_display_open()
|
|
Packit Service |
fb6fa5 |
* it would be returned a #GdkDisplay with @screen as the default
|
|
Packit Service |
fb6fa5 |
* screen.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* This is useful for applications which wish to launch an application
|
|
Packit Service |
fb6fa5 |
* on a specific screen.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Return value: %TRUE on success, %FALSE if error is set.
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Since: 2.4
|
|
Packit Service |
fb6fa5 |
*
|
|
Packit Service |
fb6fa5 |
* Deprecated: 2.24: This function is being removed in 3.0. Use
|
|
Packit Service |
fb6fa5 |
* either g_spawn_command_line_sync(), g_spawn_command_line_async() or
|
|
Packit Service |
fb6fa5 |
* #GdkAppLaunchContext instead.
|
|
Packit Service |
fb6fa5 |
**/
|
|
Packit Service |
fb6fa5 |
gboolean
|
|
Packit Service |
fb6fa5 |
gdk_spawn_command_line_on_screen (GdkScreen *screen,
|
|
Packit Service |
fb6fa5 |
const gchar *command_line,
|
|
Packit Service |
fb6fa5 |
GError **error)
|
|
Packit Service |
fb6fa5 |
{
|
|
Packit Service |
fb6fa5 |
gchar **argv = NULL;
|
|
Packit Service |
fb6fa5 |
gboolean retval;
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
g_return_val_if_fail (command_line != NULL, FALSE);
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
if (!g_shell_parse_argv (command_line,
|
|
Packit Service |
fb6fa5 |
NULL, &argv,
|
|
Packit Service |
fb6fa5 |
error))
|
|
Packit Service |
fb6fa5 |
return FALSE;
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
retval = gdk_spawn_on_screen (screen,
|
|
Packit Service |
fb6fa5 |
NULL, argv, NULL,
|
|
Packit Service |
fb6fa5 |
G_SPAWN_SEARCH_PATH,
|
|
Packit Service |
fb6fa5 |
NULL, NULL, NULL,
|
|
Packit Service |
fb6fa5 |
error);
|
|
Packit Service |
fb6fa5 |
g_strfreev (argv);
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
return retval;
|
|
Packit Service |
fb6fa5 |
}
|
|
Packit Service |
fb6fa5 |
|
|
Packit Service |
fb6fa5 |
#define __GDK_SPAWN_X11_C__
|
|
Packit Service |
fb6fa5 |
#include "gdkaliasdef.c"
|