mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-09 08:55:33 +00:00
tools/gst-launch.c (main): Handle err == NULL. gst/gst.c (init_post, ensure_current_registry) (ensure_current_registr...
Original commit message from CVS: 2006-07-08 Andy Wingo <wingo@pobox.com> * tools/gst-launch.c (main): Handle err == NULL. * gst/gst.c (init_post, ensure_current_registry) (ensure_current_registry_forking) (ensure_current_registry_nonforking): Reduce #ifdef ratnest by factoring out the registry scanning into separate functions. Don't fork for the rescan is GST_REGISTRY_FORK=no; useful in debugging. Better environment var name/interface suggestions accepted.
This commit is contained in:
parent
ea60952f06
commit
2ef04375e6
4 changed files with 123 additions and 82 deletions
11
ChangeLog
11
ChangeLog
|
@ -1,3 +1,14 @@
|
||||||
|
2006-07-08 Andy Wingo <wingo@pobox.com>
|
||||||
|
|
||||||
|
* tools/gst-launch.c (main): Handle err == NULL.
|
||||||
|
|
||||||
|
* gst/gst.c (init_post, ensure_current_registry)
|
||||||
|
(ensure_current_registry_forking)
|
||||||
|
(ensure_current_registry_nonforking): Reduce #ifdef ratnest by
|
||||||
|
factoring out the registry scanning into separate functions. Don't
|
||||||
|
fork for the rescan is GST_REGISTRY_FORK=no; useful in debugging.
|
||||||
|
Better environment var name/interface suggestions accepted.
|
||||||
|
|
||||||
2006-07-07 Tim-Philipp Müller <tim at centricular dot net>
|
2006-07-07 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
* gst/gstobject.c: (gst_object_set_name_default),
|
* gst/gstobject.c: (gst_object_set_name_default),
|
||||||
|
|
187
gst/gst.c
187
gst/gst.c
|
@ -634,6 +634,111 @@ scan_and_update_registry (GstRegistry * default_registry,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
ensure_current_registry_nonforking (GstRegistry * default_registry,
|
||||||
|
const gchar * registry_file)
|
||||||
|
{
|
||||||
|
/* fork() not available */
|
||||||
|
GST_DEBUG ("updating registry cache");
|
||||||
|
scan_and_update_registry (default_registry, registry_file, TRUE);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_FORK
|
||||||
|
static gboolean
|
||||||
|
ensure_current_registry_forking (GstRegistry * default_registry,
|
||||||
|
const gchar * registry_file)
|
||||||
|
{
|
||||||
|
pid_t pid;
|
||||||
|
|
||||||
|
/* We fork here, and let the child read and possibly rebuild the registry.
|
||||||
|
* After that, the parent will re-read the freshly generated registry. */
|
||||||
|
|
||||||
|
GST_DEBUG ("forking");
|
||||||
|
pid = fork ();
|
||||||
|
if (pid == -1) {
|
||||||
|
GST_ERROR ("Failed to fork()");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pid == 0) {
|
||||||
|
gboolean res;
|
||||||
|
|
||||||
|
/* this is the child */
|
||||||
|
GST_DEBUG ("child reading registry cache");
|
||||||
|
res = scan_and_update_registry (default_registry, registry_file, TRUE);
|
||||||
|
_gst_registry_remove_cache_plugins (default_registry);
|
||||||
|
|
||||||
|
/* need to use _exit, so that any exit handlers registered don't
|
||||||
|
* bring down the main program */
|
||||||
|
GST_DEBUG ("child exiting: %s", (res) ? "SUCCESS" : "FAILURE");
|
||||||
|
_exit ((res) ? EXIT_SUCCESS : EXIT_FAILURE);
|
||||||
|
} else {
|
||||||
|
/* parent */
|
||||||
|
int status;
|
||||||
|
pid_t ret;
|
||||||
|
|
||||||
|
GST_DEBUG ("parent waiting on child");
|
||||||
|
ret = waitpid (pid, &status, 0);
|
||||||
|
GST_DEBUG ("parent done waiting on child");
|
||||||
|
if (ret == -1) {
|
||||||
|
GST_ERROR ("error during waitpid: %s", g_strerror (errno));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!WIFEXITED (status)) {
|
||||||
|
GST_ERROR ("child did not exit normally, status: %d", status);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_DEBUG ("child exited normally with return value %d",
|
||||||
|
WEXITSTATUS (status));
|
||||||
|
|
||||||
|
if (WEXITSTATUS (status) == EXIT_SUCCESS) {
|
||||||
|
GST_DEBUG ("parent reading registry cache");
|
||||||
|
gst_registry_xml_read_cache (default_registry, registry_file);
|
||||||
|
} else {
|
||||||
|
GST_DEBUG ("parent re-scanning registry");
|
||||||
|
scan_and_update_registry (default_registry, registry_file, FALSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
#endif /* HAVE_FORK */
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
ensure_current_registry (void)
|
||||||
|
{
|
||||||
|
char *registry_file;
|
||||||
|
GstRegistry *default_registry;
|
||||||
|
gboolean ret;
|
||||||
|
|
||||||
|
default_registry = gst_registry_get_default ();
|
||||||
|
registry_file = g_strdup (g_getenv ("GST_REGISTRY"));
|
||||||
|
if (registry_file == NULL) {
|
||||||
|
registry_file = g_build_filename (g_get_home_dir (),
|
||||||
|
".gstreamer-" GST_MAJORMINOR, "registry." HOST_CPU ".xml", NULL);
|
||||||
|
}
|
||||||
|
#ifdef HAVE_FORK
|
||||||
|
if (g_getenv ("GST_REGISTRY_FORK") == NULL
|
||||||
|
|| strcmp (g_getenv ("GST_REGISTRY_FORK"), "no") != 0) {
|
||||||
|
ret = ensure_current_registry_forking (default_registry, registry_file);
|
||||||
|
} else {
|
||||||
|
GST_DEBUG ("requested not to fork");
|
||||||
|
#endif /* HAVE_FORK */
|
||||||
|
|
||||||
|
ret = ensure_current_registry_nonforking (default_registry, registry_file);
|
||||||
|
|
||||||
|
#ifdef HAVE_FORK
|
||||||
|
}
|
||||||
|
#endif /* HAVE_FORK */
|
||||||
|
|
||||||
|
g_free (registry_file);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* GST_DISABLE_REGISTRY */
|
#endif /* GST_DISABLE_REGISTRY */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -689,86 +794,8 @@ init_post (void)
|
||||||
_gst_plugin_initialize ();
|
_gst_plugin_initialize ();
|
||||||
|
|
||||||
#ifndef GST_DISABLE_REGISTRY
|
#ifndef GST_DISABLE_REGISTRY
|
||||||
{
|
if (!ensure_current_registry ())
|
||||||
char *registry_file;
|
return FALSE;
|
||||||
GstRegistry *default_registry;
|
|
||||||
|
|
||||||
#ifdef HAVE_FORK
|
|
||||||
pid_t pid;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
default_registry = gst_registry_get_default ();
|
|
||||||
registry_file = g_strdup (g_getenv ("GST_REGISTRY"));
|
|
||||||
if (registry_file == NULL) {
|
|
||||||
registry_file = g_build_filename (g_get_home_dir (),
|
|
||||||
".gstreamer-" GST_MAJORMINOR, "registry." HOST_CPU ".xml", NULL);
|
|
||||||
}
|
|
||||||
#ifdef HAVE_FORK
|
|
||||||
/* We fork here, and let the child read and possibly rebuild the registry.
|
|
||||||
* After that, the parent will re-read the freshly generated registry. */
|
|
||||||
|
|
||||||
GST_DEBUG ("forking");
|
|
||||||
pid = fork ();
|
|
||||||
if (pid == -1) {
|
|
||||||
GST_ERROR ("Failed to fork()");
|
|
||||||
g_free (registry_file);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pid == 0) {
|
|
||||||
gboolean res;
|
|
||||||
|
|
||||||
/* this is the child */
|
|
||||||
GST_DEBUG ("child reading registry cache");
|
|
||||||
res = scan_and_update_registry (default_registry, registry_file, TRUE);
|
|
||||||
_gst_registry_remove_cache_plugins (default_registry);
|
|
||||||
g_free (registry_file);
|
|
||||||
|
|
||||||
/* need to use _exit, so that any exit handlers registered don't
|
|
||||||
* bring down the main program */
|
|
||||||
GST_DEBUG ("child exiting: %s", (res) ? "SUCCESS" : "FAILURE");
|
|
||||||
_exit ((res) ? EXIT_SUCCESS : EXIT_FAILURE);
|
|
||||||
} else {
|
|
||||||
/* parent */
|
|
||||||
int status;
|
|
||||||
pid_t ret;
|
|
||||||
|
|
||||||
GST_DEBUG ("parent waiting on child");
|
|
||||||
ret = waitpid (pid, &status, 0);
|
|
||||||
GST_DEBUG ("parent done waiting on child");
|
|
||||||
if (ret == -1) {
|
|
||||||
GST_ERROR ("error during waitpid: %s", g_strerror (errno));
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!WIFEXITED (status)) {
|
|
||||||
GST_ERROR ("child did not exit normally, status: %d", status);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
GST_DEBUG ("child exited normally with return value %d",
|
|
||||||
WEXITSTATUS (status));
|
|
||||||
|
|
||||||
if (WEXITSTATUS (status) == EXIT_SUCCESS) {
|
|
||||||
GST_DEBUG ("parent reading registry cache");
|
|
||||||
gst_registry_xml_read_cache (default_registry, registry_file);
|
|
||||||
} else {
|
|
||||||
GST_DEBUG ("parent re-scanning registry");
|
|
||||||
scan_and_update_registry (default_registry, registry_file, FALSE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#else /* HAVE_FORK */
|
|
||||||
|
|
||||||
/* fork() not available */
|
|
||||||
GST_DEBUG ("updating registry cache");
|
|
||||||
scan_and_update_registry (default_registry, registry_file, TRUE);
|
|
||||||
|
|
||||||
#endif /* HAVE_FORK */
|
|
||||||
|
|
||||||
g_free (registry_file);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* GST_DISABLE_REGISTRY */
|
#endif /* GST_DISABLE_REGISTRY */
|
||||||
|
|
||||||
/* if we need to preload plugins */
|
/* if we need to preload plugins */
|
||||||
|
|
|
@ -547,7 +547,10 @@ main (int argc, char *argv[])
|
||||||
g_option_context_add_main_entries (ctx, options, GETTEXT_PACKAGE);
|
g_option_context_add_main_entries (ctx, options, GETTEXT_PACKAGE);
|
||||||
g_option_context_add_group (ctx, gst_init_get_option_group ());
|
g_option_context_add_group (ctx, gst_init_get_option_group ());
|
||||||
if (!g_option_context_parse (ctx, &argc, &argv, &err)) {
|
if (!g_option_context_parse (ctx, &argc, &argv, &err)) {
|
||||||
g_print ("Error initializing: %s\n", GST_STR_NULL (err->message));
|
if (err)
|
||||||
|
g_print ("Error initializing: %s\n", GST_STR_NULL (err->message));
|
||||||
|
else
|
||||||
|
g_print ("Error initializing: Unknown error!\n");
|
||||||
exit (1);
|
exit (1);
|
||||||
}
|
}
|
||||||
g_option_context_free (ctx);
|
g_option_context_free (ctx);
|
||||||
|
|
|
@ -175,7 +175,7 @@
|
||||||
#define HAVE_WIN32 1
|
#define HAVE_WIN32 1
|
||||||
|
|
||||||
/* Define host CPU */
|
/* Define host CPU */
|
||||||
#define HOST_CPU "i686"
|
#define HOST_CPU "powerpc"
|
||||||
|
|
||||||
/* library dir */
|
/* library dir */
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
|
|
Loading…
Reference in a new issue