Blame gdk/x11/gdkspawn-x11.c

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"