Bump GLib requirement to 2.20
[platform/upstream/gstreamer.git] / gst / gst.c
1 /* GStreamer
2  * Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
3  *                    2000 Wim Taymans <wtay@chello.be>
4  *
5  * gst.c: Initialization and non-pipeline operations
6  *
7  * This library is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Library General Public
9  * License as published by the Free Software Foundation; either
10  * version 2 of the License, or (at your option) any later version.
11  *
12  * This library is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Library General Public License for more details.
16  *
17  * You should have received a copy of the GNU Library General Public
18  * License along with this library; if not, write to the
19  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
20  * Boston, MA 02111-1307, USA.
21  */
22
23 /**
24  * SECTION:gst
25  * @short_description: Media library supporting arbitrary formats and filter
26  *                     graphs.
27  *
28  * GStreamer is a framework for constructing graphs of various filters
29  * (termed elements here) that will handle streaming media.  Any discreet
30  * (packetizable) media type is supported, with provisions for automatically
31  * determining source type.  Formatting/framing information is provided with
32  * a powerful negotiation framework.  Plugins are heavily used to provide for
33  * all elements, allowing one to construct plugins outside of the GST
34  * library, even released binary-only if license require (please don't).
35  * GStreamer covers a wide range of use cases including: playback, recording,
36  * editing, serving streams, voice over ip and video calls.
37  *
38  * The <application>GStreamer</application> library should be initialized with
39  * gst_init() before it can be used. You should pass pointers to the main argc
40  * and argv variables so that GStreamer can process its own command line
41  * options, as shown in the following example.
42  *
43  * <example>
44  * <title>Initializing the gstreamer library</title>
45  * <programlisting language="c">
46  * int
47  * main (int argc, char *argv[])
48  * {
49  *   // initialize the GStreamer library
50  *   gst_init (&amp;argc, &amp;argv);
51  *   ...
52  * }
53  * </programlisting>
54  * </example>
55  *
56  * It's allowed to pass two NULL pointers to gst_init() in case you don't want
57  * to pass the command line args to GStreamer.
58  *
59  * You can also use GOption to initialize your own parameters as shown in
60  * the next code fragment:
61  * <example>
62  * <title>Initializing own parameters when initializing gstreamer</title>
63  * <programlisting>
64  * static gboolean stats = FALSE;
65  * ...
66  * int
67  * main (int argc, char *argv[])
68  * {
69  *  GOptionEntry options[] = {
70  *   {"tags", 't', 0, G_OPTION_ARG_NONE, &amp;tags,
71  *       N_("Output tags (also known as metadata)"), NULL},
72  *   {NULL}
73  *  };
74  *  // must initialise the threading system before using any other GLib funtion
75  *  if (!g_thread_supported ())
76  *    g_thread_init (NULL);
77  *  ctx = g_option_context_new ("[ADDITIONAL ARGUMENTS]");
78  *  g_option_context_add_main_entries (ctx, options, GETTEXT_PACKAGE);
79  *  g_option_context_add_group (ctx, gst_init_get_option_group ());
80  *  if (!g_option_context_parse (ctx, &amp;argc, &amp;argv, &amp;err)) {
81  *    g_print ("Error initializing: &percnt;s\n", GST_STR_NULL (err->message));
82  *    exit (1);
83  *  }
84  *  g_option_context_free (ctx);
85  * ...
86  * }
87  * </programlisting>
88  * </example>
89  *
90  * Use gst_version() to query the library version at runtime or use the
91  * GST_VERSION_* macros to find the version at compile time. Optionally
92  * gst_version_string() returns a printable string.
93  *
94  * The gst_deinit() call is used to clean up all internal resources used
95  * by <application>GStreamer</application>. It is mostly used in unit tests 
96  * to check for leaks.
97  *
98  * Last reviewed on 2006-08-11 (0.10.10)
99  */
100
101 #include "gst_private.h"
102 #include "gstconfig.h"
103 #include <stdlib.h>
104 #include <stdio.h>
105 #include <sys/types.h>
106 #ifdef HAVE_SYS_UTSNAME_H
107 #include <sys/utsname.h>
108 #endif
109 #ifdef HAVE_UNISTD_H
110 #include <unistd.h>
111 #endif
112 #ifdef G_OS_WIN32
113 #define WIN32_LEAN_AND_MEAN     /* prevents from including too many things */
114 #include <windows.h>            /* GetStdHandle, windows console */
115 #endif
116
117 #include "gst-i18n-lib.h"
118 #include <locale.h>             /* for LC_ALL */
119
120 #include "gst.h"
121
122 #define GST_CAT_DEFAULT GST_CAT_GST_INIT
123
124 #define MAX_PATH_SPLIT  16
125 #define GST_PLUGIN_SEPARATOR ","
126
127 static gboolean gst_initialized = FALSE;
128 static gboolean gst_deinitialized = FALSE;
129
130 #ifdef G_OS_WIN32
131 HMODULE _priv_gst_dll_handle = NULL;
132 #endif
133
134 #ifndef GST_DISABLE_REGISTRY
135 GList *_priv_gst_plugin_paths = NULL;   /* for delayed processing in post_init */
136
137 extern gboolean _priv_gst_disable_registry_update;
138 #endif
139
140 #ifndef GST_DISABLE_GST_DEBUG
141 extern const gchar *priv_gst_dump_dot_dir;
142 #endif
143
144 /* defaults */
145
146 /* set to TRUE when segfaults need to be left as is */
147 static gboolean _gst_disable_segtrap = FALSE;
148
149 static gboolean init_pre (GOptionContext * context, GOptionGroup * group,
150     gpointer data, GError ** error);
151 static gboolean init_post (GOptionContext * context, GOptionGroup * group,
152     gpointer data, GError ** error);
153 #ifndef GST_DISABLE_OPTION_PARSING
154 static gboolean parse_goption_arg (const gchar * s_opt,
155     const gchar * arg, gpointer data, GError ** err);
156 #endif
157
158 GSList *_priv_gst_preload_plugins = NULL;
159
160 const gchar g_log_domain_gstreamer[] = "GStreamer";
161
162 static void
163 debug_log_handler (const gchar * log_domain,
164     GLogLevelFlags log_level, const gchar * message, gpointer user_data)
165 {
166   g_log_default_handler (log_domain, log_level, message, user_data);
167   /* FIXME: do we still need this ? fatal errors these days are all
168    * other than core errors */
169   /* g_on_error_query (NULL); */
170 }
171
172 enum
173 {
174   ARG_VERSION = 1,
175   ARG_FATAL_WARNINGS,
176 #ifndef GST_DISABLE_GST_DEBUG
177   ARG_DEBUG_LEVEL,
178   ARG_DEBUG,
179   ARG_DEBUG_DISABLE,
180   ARG_DEBUG_NO_COLOR,
181   ARG_DEBUG_HELP,
182 #endif
183   ARG_PLUGIN_SPEW,
184   ARG_PLUGIN_PATH,
185   ARG_PLUGIN_LOAD,
186   ARG_SEGTRAP_DISABLE,
187   ARG_REGISTRY_UPDATE_DISABLE,
188   ARG_REGISTRY_FORK_DISABLE
189 };
190
191 /* debug-spec ::= category-spec [, category-spec]*
192  * category-spec ::= category:val | val
193  * category ::= [^:]+
194  * val ::= [0-5]
195  */
196
197 #ifndef NUL
198 #define NUL '\0'
199 #endif
200
201 #ifndef GST_DISABLE_GST_DEBUG
202 static gboolean
203 parse_debug_category (gchar * str, const gchar ** category)
204 {
205   if (!str)
206     return FALSE;
207
208   /* works in place */
209   g_strstrip (str);
210
211   if (str[0] != NUL) {
212     *category = str;
213     return TRUE;
214   }
215
216   return FALSE;
217 }
218
219 static gboolean
220 parse_debug_level (gchar * str, gint * level)
221 {
222   if (!str)
223     return FALSE;
224
225   /* works in place */
226   g_strstrip (str);
227
228   if (str[0] != NUL && str[1] == NUL
229       && str[0] >= '0' && str[0] < '0' + GST_LEVEL_COUNT) {
230     *level = str[0] - '0';
231     return TRUE;
232   }
233
234   return FALSE;
235 }
236
237 static void
238 parse_debug_list (const gchar * list)
239 {
240   gchar **split;
241   gchar **walk;
242
243   g_assert (list);
244
245   split = g_strsplit (list, ",", 0);
246
247   for (walk = split; *walk; walk++) {
248     if (strchr (*walk, ':')) {
249       gchar **values = g_strsplit (*walk, ":", 2);
250
251       if (values[0] && values[1]) {
252         gint level;
253         const gchar *category;
254
255         if (parse_debug_category (values[0], &category)
256             && parse_debug_level (values[1], &level))
257           gst_debug_set_threshold_for_name (category, level);
258       }
259
260       g_strfreev (values);
261     } else {
262       gint level;
263
264       if (parse_debug_level (*walk, &level))
265         gst_debug_set_default_threshold (level);
266     }
267   }
268
269   g_strfreev (split);
270 }
271 #endif
272
273 #ifdef G_OS_WIN32
274 BOOL WINAPI DllMain (HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved);
275 BOOL WINAPI
276 DllMain (HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
277 {
278   if (fdwReason == DLL_PROCESS_ATTACH)
279     _priv_gst_dll_handle = (HMODULE) hinstDLL;
280   return TRUE;
281 }
282
283 #endif
284
285 /**
286  * gst_init_get_option_group:
287  *
288  * Returns a #GOptionGroup with GStreamer's argument specifications. The
289  * group is set up to use standard GOption callbacks, so when using this
290  * group in combination with GOption parsing methods, all argument parsing
291  * and initialization is automated.
292  *
293  * This function is useful if you want to integrate GStreamer with other
294  * libraries that use GOption (see g_option_context_add_group() ).
295  *
296  * If you use this function, you should make sure you initialise the GLib
297  * threading system as one of the very first things in your program
298  * (see the example at the beginning of this section).
299  *
300  * Returns: a pointer to GStreamer's option group.
301  */
302
303 GOptionGroup *
304 gst_init_get_option_group (void)
305 {
306 #ifndef GST_DISABLE_OPTION_PARSING
307   GOptionGroup *group;
308   static const GOptionEntry gst_args[] = {
309     {"gst-version", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
310         (gpointer) parse_goption_arg, N_("Print the GStreamer version"), NULL},
311     {"gst-fatal-warnings", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
312         (gpointer) parse_goption_arg, N_("Make all warnings fatal"), NULL},
313 #ifndef GST_DISABLE_GST_DEBUG
314     {"gst-debug-help", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
315           (gpointer) parse_goption_arg,
316           N_("Print available debug categories and exit"),
317         NULL},
318     {"gst-debug-level", 0, 0, G_OPTION_ARG_CALLBACK,
319           (gpointer) parse_goption_arg,
320           N_("Default debug level from 1 (only error) to 5 (anything) or "
321               "0 for no output"),
322         N_("LEVEL")},
323     {"gst-debug", 0, 0, G_OPTION_ARG_CALLBACK, (gpointer) parse_goption_arg,
324           N_("Comma-separated list of category_name:level pairs to set "
325               "specific levels for the individual categories. Example: "
326               "GST_AUTOPLUG:5,GST_ELEMENT_*:3"),
327         N_("LIST")},
328     {"gst-debug-no-color", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
329           (gpointer) parse_goption_arg, N_("Disable colored debugging output"),
330         NULL},
331     {"gst-debug-disable", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
332         (gpointer) parse_goption_arg, N_("Disable debugging"), NULL},
333 #endif
334     {"gst-plugin-spew", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
335           (gpointer) parse_goption_arg,
336           N_("Enable verbose plugin loading diagnostics"),
337         NULL},
338     {"gst-plugin-path", 0, 0, G_OPTION_ARG_CALLBACK,
339           (gpointer) parse_goption_arg,
340         N_("Colon-separated paths containing plugins"), N_("PATHS")},
341     {"gst-plugin-load", 0, 0, G_OPTION_ARG_CALLBACK,
342           (gpointer) parse_goption_arg,
343           N_("Comma-separated list of plugins to preload in addition to the "
344               "list stored in environment variable GST_PLUGIN_PATH"),
345         N_("PLUGINS")},
346     {"gst-disable-segtrap", 0, G_OPTION_FLAG_NO_ARG, G_OPTION_ARG_CALLBACK,
347           (gpointer) parse_goption_arg,
348           N_("Disable trapping of segmentation faults during plugin loading"),
349         NULL},
350     {"gst-disable-registry-update", 0, G_OPTION_FLAG_NO_ARG,
351           G_OPTION_ARG_CALLBACK,
352           (gpointer) parse_goption_arg,
353           N_("Disable updating the registry"),
354         NULL},
355     {"gst-disable-registry-fork", 0, G_OPTION_FLAG_NO_ARG,
356           G_OPTION_ARG_CALLBACK,
357           (gpointer) parse_goption_arg,
358           N_("Disable spawning a helper process while scanning the registry"),
359         NULL},
360     {NULL}
361   };
362
363   /* Since GLib 2.23.2 calling g_thread_init() 'late' is allowed and is
364    * automatically done as part of g_type_init() */
365   if (!glib_check_version (2, 23, 3)) {
366     /* The GLib threading system must be initialised before calling any other
367      * GLib function according to the documentation; if the application hasn't
368      * called gst_init() yet or initialised the threading system otherwise, we
369      * better issue a warning here (since chances are high that the application
370      * has already called other GLib functions such as g_option_context_new() */
371     if (!g_thread_get_initialized ()) {
372       g_warning ("The GStreamer function gst_init_get_option_group() was\n"
373           "\tcalled, but the GLib threading system has not been initialised\n"
374           "\tyet, something that must happen before any other GLib function\n"
375           "\tis called. The application needs to be fixed so that it calls\n"
376           "\t   if (!g_thread_get_initialized ()) g_thread_init(NULL);\n"
377           "\tas very first thing in its main() function. Please file a bug\n"
378           "\tagainst this application.");
379       g_thread_init (NULL);
380     }
381   } else {
382     /* GLib >= 2.23.2 */
383   }
384
385   group = g_option_group_new ("gst", _("GStreamer Options"),
386       _("Show GStreamer Options"), NULL, NULL);
387   g_option_group_set_parse_hooks (group, (GOptionParseFunc) init_pre,
388       (GOptionParseFunc) init_post);
389
390   g_option_group_add_entries (group, gst_args);
391   g_option_group_set_translation_domain (group, GETTEXT_PACKAGE);
392
393   return group;
394 #else
395   return NULL;
396 #endif
397 }
398
399 /**
400  * gst_init_check:
401  * @argc: (inout): pointer to application's argc
402  * @argv: (inout) (array length=argc) (allow-none): pointer to application's argv
403  * @err: pointer to a #GError to which a message will be posted on error
404  *
405  * Initializes the GStreamer library, setting up internal path lists,
406  * registering built-in elements, and loading standard plugins.
407  *
408  * This function will return %FALSE if GStreamer could not be initialized
409  * for some reason.  If you want your program to fail fatally,
410  * use gst_init() instead.
411  *
412  * This function should be called before calling any other GLib functions. If
413  * this is not an option, your program must initialise the GLib thread system
414  * using g_thread_init() before any other GLib functions are called.
415  *
416  * Returns: %TRUE if GStreamer could be initialized.
417  */
418 gboolean
419 gst_init_check (int *argc, char **argv[], GError ** err)
420 {
421 #ifndef GST_DISABLE_OPTION_PARSING
422   GOptionGroup *group;
423   GOptionContext *ctx;
424 #endif
425   gboolean res;
426
427   if (!g_thread_get_initialized ())
428     g_thread_init (NULL);
429
430   if (gst_initialized) {
431     GST_DEBUG ("already initialized gst");
432     return TRUE;
433   }
434 #ifndef GST_DISABLE_OPTION_PARSING
435   ctx = g_option_context_new ("- GStreamer initialization");
436   g_option_context_set_ignore_unknown_options (ctx, TRUE);
437   group = gst_init_get_option_group ();
438   g_option_context_add_group (ctx, group);
439   res = g_option_context_parse (ctx, argc, argv, err);
440   g_option_context_free (ctx);
441 #else
442   init_pre (NULL, NULL, NULL, NULL);
443   init_post (NULL, NULL, NULL, NULL);
444   res = TRUE;
445 #endif
446
447   gst_initialized = res;
448
449   if (res) {
450     GST_INFO ("initialized GStreamer successfully");
451   } else {
452     GST_INFO ("failed to initialize GStreamer");
453   }
454
455   return res;
456 }
457
458 /**
459  * gst_init:
460  * @argc: (inout): pointer to application's argc
461  * @argv: (inout) (array length=argc) (allow-none): pointer to application's argv
462  *
463  * Initializes the GStreamer library, setting up internal path lists,
464  * registering built-in elements, and loading standard plugins.
465  *
466  * Unless the plugin registry is disabled at compile time, the registry will be
467  * loaded. By default this will also check if the registry cache needs to be
468  * updated and rescan all plugins if needed. See gst_update_registry() for
469  * details and section
470  * <link linkend="gst-running">Running GStreamer Applications</link>
471  * for how to disable automatic registry updates.
472  *
473  * This function should be called before calling any other GLib functions. If
474  * this is not an option, your program must initialise the GLib thread system
475  * using g_thread_init() before any other GLib functions are called.
476  *
477  * <note><para>
478  * This function will terminate your program if it was unable to initialize
479  * GStreamer for some reason.  If you want your program to fall back,
480  * use gst_init_check() instead.
481  * </para></note>
482  *
483  * WARNING: This function does not work in the same way as corresponding
484  * functions in other glib-style libraries, such as gtk_init().  In
485  * particular, unknown command line options cause this function to
486  * abort program execution.
487  */
488 void
489 gst_init (int *argc, char **argv[])
490 {
491   GError *err = NULL;
492
493   if (!gst_init_check (argc, argv, &err)) {
494     g_print ("Could not initialize GStreamer: %s\n",
495         err ? err->message : "unknown error occurred");
496     if (err) {
497       g_error_free (err);
498     }
499     exit (1);
500   }
501 }
502
503 #ifndef GST_DISABLE_REGISTRY
504 static void
505 add_path_func (gpointer data, gpointer user_data)
506 {
507   GST_INFO ("Adding plugin path: \"%s\", will scan later", (gchar *) data);
508   _priv_gst_plugin_paths =
509       g_list_append (_priv_gst_plugin_paths, g_strdup (data));
510 }
511 #endif
512
513 #ifndef GST_DISABLE_OPTION_PARSING
514 static void
515 prepare_for_load_plugin_func (gpointer data, gpointer user_data)
516 {
517   _priv_gst_preload_plugins =
518       g_slist_prepend (_priv_gst_preload_plugins, g_strdup (data));
519 }
520 #endif
521
522 #ifndef GST_DISABLE_OPTION_PARSING
523 static void
524 split_and_iterate (const gchar * stringlist, const gchar * separator,
525     GFunc iterator, gpointer user_data)
526 {
527   gchar **strings;
528   gint j = 0;
529   gchar *lastlist = g_strdup (stringlist);
530
531   while (lastlist) {
532     strings = g_strsplit (lastlist, separator, MAX_PATH_SPLIT);
533     g_free (lastlist);
534     lastlist = NULL;
535
536     while (strings[j]) {
537       iterator (strings[j], user_data);
538       if (++j == MAX_PATH_SPLIT) {
539         lastlist = g_strdup (strings[j]);
540         j = 0;
541         break;
542       }
543     }
544     g_strfreev (strings);
545   }
546 }
547 #endif
548
549 /* we have no fail cases yet, but maybe in the future */
550 static gboolean
551 init_pre (GOptionContext * context, GOptionGroup * group, gpointer data,
552     GError ** error)
553 {
554   if (gst_initialized) {
555     GST_DEBUG ("already initialized");
556     return TRUE;
557   }
558
559   /* GStreamer was built against a GLib >= 2.8 and is therefore not doing
560    * the refcount hack. Check that it isn't being run against an older GLib */
561   if (glib_major_version < 2 ||
562       (glib_major_version == 2 && glib_minor_version < 8)) {
563     g_warning ("GStreamer was compiled against GLib %d.%d.%d but is running"
564         " against %d.%d.%d. This will cause reference counting issues",
565         GLIB_MAJOR_VERSION, GLIB_MINOR_VERSION, GLIB_MICRO_VERSION,
566         glib_major_version, glib_minor_version, glib_micro_version);
567   }
568
569   g_type_init ();
570
571   /* we need threading to be enabled right here */
572   g_assert (g_thread_get_initialized ());
573
574   _gst_debug_init ();
575
576 #ifdef ENABLE_NLS
577   setlocale (LC_ALL, "");
578   bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR);
579   bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
580 #endif /* ENABLE_NLS */
581
582 #ifndef GST_DISABLE_GST_DEBUG
583   {
584     const gchar *debug_list;
585
586     if (g_getenv ("GST_DEBUG_NO_COLOR") != NULL)
587       gst_debug_set_colored (FALSE);
588
589     debug_list = g_getenv ("GST_DEBUG");
590     if (debug_list) {
591       parse_debug_list (debug_list);
592     }
593   }
594
595   priv_gst_dump_dot_dir = g_getenv ("GST_DEBUG_DUMP_DOT_DIR");
596 #endif
597   /* This is the earliest we can make stuff show up in the logs.
598    * So give some useful info about GStreamer here */
599   GST_INFO ("Initializing GStreamer Core Library version %s", VERSION);
600   GST_INFO ("Using library installed in %s", LIBDIR);
601
602   /* Print some basic system details if possible (OS/architecture) */
603 #ifdef HAVE_SYS_UTSNAME_H
604   {
605     struct utsname sys_details;
606
607     if (uname (&sys_details) == 0) {
608       GST_INFO ("%s %s %s %s %s", sys_details.sysname,
609           sys_details.nodename, sys_details.release, sys_details.version,
610           sys_details.machine);
611     }
612   }
613 #endif
614
615   return TRUE;
616 }
617
618 static gboolean
619 gst_register_core_elements (GstPlugin * plugin)
620 {
621   /* register some standard builtin types */
622   if (!gst_element_register (plugin, "bin", GST_RANK_PRIMARY,
623           GST_TYPE_BIN) ||
624       !gst_element_register (plugin, "pipeline", GST_RANK_PRIMARY,
625           GST_TYPE_PIPELINE)
626       )
627     g_assert_not_reached ();
628
629   return TRUE;
630 }
631
632 /*
633  * this bit handles:
634  * - initalization of threads if we use them
635  * - log handler
636  * - initial output
637  * - initializes gst_format
638  * - registers a bunch of types for gst_objects
639  *
640  * - we don't have cases yet where this fails, but in the future
641  *   we might and then it's nice to be able to return that
642  */
643 static gboolean
644 init_post (GOptionContext * context, GOptionGroup * group, gpointer data,
645     GError ** error)
646 {
647   GLogLevelFlags llf;
648
649 #ifndef GST_DISABLE_TRACE
650   GstTrace *gst_trace;
651 #endif /* GST_DISABLE_TRACE */
652
653   if (gst_initialized) {
654     GST_DEBUG ("already initialized");
655     return TRUE;
656   }
657
658   llf = G_LOG_LEVEL_CRITICAL | G_LOG_LEVEL_ERROR | G_LOG_FLAG_FATAL;
659   g_log_set_handler (g_log_domain_gstreamer, llf, debug_log_handler, NULL);
660
661   _priv_gst_quarks_initialize ();
662   _gst_format_initialize ();
663   _gst_query_initialize ();
664   g_type_class_ref (gst_object_get_type ());
665   g_type_class_ref (gst_pad_get_type ());
666   g_type_class_ref (gst_element_factory_get_type ());
667   g_type_class_ref (gst_element_get_type ());
668   g_type_class_ref (gst_type_find_factory_get_type ());
669   g_type_class_ref (gst_bin_get_type ());
670   g_type_class_ref (gst_bus_get_type ());
671   g_type_class_ref (gst_task_get_type ());
672   g_type_class_ref (gst_clock_get_type ());
673
674   g_type_class_ref (gst_index_factory_get_type ());
675   gst_uri_handler_get_type ();
676
677   g_type_class_ref (gst_object_flags_get_type ());
678   g_type_class_ref (gst_bin_flags_get_type ());
679   g_type_class_ref (gst_buffer_flag_get_type ());
680   g_type_class_ref (gst_buffer_copy_flags_get_type ());
681   g_type_class_ref (gst_buffer_list_item_get_type ());
682   g_type_class_ref (gst_bus_flags_get_type ());
683   g_type_class_ref (gst_bus_sync_reply_get_type ());
684   g_type_class_ref (gst_caps_flags_get_type ());
685   g_type_class_ref (gst_clock_return_get_type ());
686   g_type_class_ref (gst_clock_entry_type_get_type ());
687   g_type_class_ref (gst_clock_flags_get_type ());
688   g_type_class_ref (gst_clock_type_get_type ());
689   g_type_class_ref (gst_debug_graph_details_get_type ());
690   g_type_class_ref (gst_state_get_type ());
691   g_type_class_ref (gst_state_change_return_get_type ());
692   g_type_class_ref (gst_state_change_get_type ());
693   g_type_class_ref (gst_element_flags_get_type ());
694   g_type_class_ref (gst_core_error_get_type ());
695   g_type_class_ref (gst_library_error_get_type ());
696   g_type_class_ref (gst_resource_error_get_type ());
697   g_type_class_ref (gst_stream_error_get_type ());
698   g_type_class_ref (gst_event_type_flags_get_type ());
699   g_type_class_ref (gst_event_type_get_type ());
700   g_type_class_ref (gst_seek_type_get_type ());
701   g_type_class_ref (gst_seek_flags_get_type ());
702   g_type_class_ref (gst_format_get_type ());
703   g_type_class_ref (gst_index_certainty_get_type ());
704   g_type_class_ref (gst_index_entry_type_get_type ());
705   g_type_class_ref (gst_index_lookup_method_get_type ());
706   g_type_class_ref (gst_assoc_flags_get_type ());
707   g_type_class_ref (gst_index_resolver_method_get_type ());
708   g_type_class_ref (gst_index_flags_get_type ());
709   g_type_class_ref (gst_debug_level_get_type ());
710   g_type_class_ref (gst_debug_color_flags_get_type ());
711   g_type_class_ref (gst_iterator_result_get_type ());
712   g_type_class_ref (gst_iterator_item_get_type ());
713   g_type_class_ref (gst_message_type_get_type ());
714   g_type_class_ref (gst_mini_object_flags_get_type ());
715   g_type_class_ref (gst_pad_link_return_get_type ());
716   g_type_class_ref (gst_flow_return_get_type ());
717   g_type_class_ref (gst_activate_mode_get_type ());
718   g_type_class_ref (gst_pad_direction_get_type ());
719   g_type_class_ref (gst_pad_flags_get_type ());
720   g_type_class_ref (gst_pad_presence_get_type ());
721   g_type_class_ref (gst_pad_template_flags_get_type ());
722   g_type_class_ref (gst_pipeline_flags_get_type ());
723   g_type_class_ref (gst_plugin_error_get_type ());
724   g_type_class_ref (gst_plugin_flags_get_type ());
725   g_type_class_ref (gst_plugin_dependency_flags_get_type ());
726   g_type_class_ref (gst_rank_get_type ());
727   g_type_class_ref (gst_query_type_get_type ());
728   g_type_class_ref (gst_buffering_mode_get_type ());
729   g_type_class_ref (gst_stream_status_type_get_type ());
730   g_type_class_ref (gst_structure_change_type_get_type ());
731   g_type_class_ref (gst_tag_merge_mode_get_type ());
732   g_type_class_ref (gst_tag_flag_get_type ());
733   g_type_class_ref (gst_task_pool_get_type ());
734   g_type_class_ref (gst_task_state_get_type ());
735   g_type_class_ref (gst_alloc_trace_flags_get_type ());
736   g_type_class_ref (gst_type_find_probability_get_type ());
737   g_type_class_ref (gst_uri_type_get_type ());
738   g_type_class_ref (gst_parse_error_get_type ());
739   g_type_class_ref (gst_parse_flags_get_type ());
740   g_type_class_ref (gst_search_mode_get_type ());
741
742   gst_structure_get_type ();
743   _gst_value_initialize ();
744   g_type_class_ref (gst_param_spec_fraction_get_type ());
745   gst_caps_get_type ();
746   _gst_event_initialize ();
747   _gst_buffer_initialize ();
748   _gst_buffer_list_initialize ();
749   _gst_message_initialize ();
750   _gst_tag_initialize ();
751
752   _gst_plugin_initialize ();
753
754   gst_g_error_get_type ();
755
756   /* register core plugins */
757   gst_plugin_register_static (GST_VERSION_MAJOR, GST_VERSION_MINOR,
758       "staticelements", "core elements linked into the GStreamer library",
759       gst_register_core_elements, VERSION, GST_LICENSE, PACKAGE,
760       GST_PACKAGE_NAME, GST_PACKAGE_ORIGIN);
761
762   /*
763    * Any errors happening below this point are non-fatal, we therefore mark
764    * gstreamer as being initialized, since it is the case from a plugin point of
765    * view.
766    *
767    * If anything fails, it will be put back to FALSE in gst_init_check().
768    * This allows some special plugins that would call gst_init() to not cause a
769    * looping effect (i.e. initializing GStreamer twice).
770    */
771   gst_initialized = TRUE;
772
773   if (!gst_update_registry ())
774     return FALSE;
775
776 #ifndef GST_DISABLE_TRACE
777   _gst_trace_on = 0;
778   if (_gst_trace_on) {
779     gst_trace = gst_trace_new ("gst.trace", 1024);
780     gst_trace_set_default (gst_trace);
781   }
782 #endif /* GST_DISABLE_TRACE */
783
784   GST_INFO ("GLib runtime version: %d.%d.%d\n", glib_major_version,
785       glib_minor_version, glib_micro_version);
786   GST_INFO ("GLib headers version: %d.%d.%d\n", GLIB_MAJOR_VERSION,
787       GLIB_MINOR_VERSION, GLIB_MICRO_VERSION);
788
789   return TRUE;
790 }
791
792 #ifndef GST_DISABLE_GST_DEBUG
793 static gboolean
794 select_all (GstPlugin * plugin, gpointer user_data)
795 {
796   return TRUE;
797 }
798
799 static gint
800 sort_by_category_name (gconstpointer a, gconstpointer b)
801 {
802   return strcmp (gst_debug_category_get_name ((GstDebugCategory *) a),
803       gst_debug_category_get_name ((GstDebugCategory *) b));
804 }
805
806 static void
807 gst_debug_help (void)
808 {
809   GSList *list, *walk;
810   GList *list2, *g;
811
812   /* Need to ensure the registry is loaded to get debug categories */
813   if (!init_post (NULL, NULL, NULL, NULL))
814     exit (1);
815
816   list2 = gst_registry_plugin_filter (gst_registry_get_default (),
817       select_all, FALSE, NULL);
818
819   /* FIXME this is gross.  why don't debug have categories PluginFeatures? */
820   for (g = list2; g; g = g_list_next (g)) {
821     GstPlugin *plugin = GST_PLUGIN_CAST (g->data);
822
823     gst_plugin_load (plugin);
824   }
825   g_list_free (list2);
826
827   list = gst_debug_get_all_categories ();
828   walk = list = g_slist_sort (list, sort_by_category_name);
829
830   g_print ("\n");
831   g_print ("name                  level    description\n");
832   g_print ("---------------------+--------+--------------------------------\n");
833
834   while (walk) {
835     GstDebugCategory *cat = (GstDebugCategory *) walk->data;
836
837     if (gst_debug_is_colored ()) {
838 #ifdef G_OS_WIN32
839       gint color = gst_debug_construct_win_color (cat->color);
840       const gint clear = FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE;
841
842       SetConsoleTextAttribute (GetStdHandle (STD_OUTPUT_HANDLE), color);
843       g_print ("%-20s", gst_debug_category_get_name (cat));
844       SetConsoleTextAttribute (GetStdHandle (STD_OUTPUT_HANDLE), clear);
845       g_print (" %1d %s ", gst_debug_category_get_threshold (cat),
846           gst_debug_level_get_name (gst_debug_category_get_threshold (cat)));
847       SetConsoleTextAttribute (GetStdHandle (STD_OUTPUT_HANDLE), color);
848       g_print ("%s", gst_debug_category_get_description (cat));
849       SetConsoleTextAttribute (GetStdHandle (STD_OUTPUT_HANDLE), clear);
850       g_print ("\n");
851 #else /* G_OS_WIN32 */
852       gchar *color = gst_debug_construct_term_color (cat->color);
853
854       g_print ("%s%-20s\033[00m  %1d %s  %s%s\033[00m\n",
855           color,
856           gst_debug_category_get_name (cat),
857           gst_debug_category_get_threshold (cat),
858           gst_debug_level_get_name (gst_debug_category_get_threshold (cat)),
859           color, gst_debug_category_get_description (cat));
860       g_free (color);
861 #endif /* G_OS_WIN32 */
862     } else {
863       g_print ("%-20s  %1d %s  %s\n", gst_debug_category_get_name (cat),
864           gst_debug_category_get_threshold (cat),
865           gst_debug_level_get_name (gst_debug_category_get_threshold (cat)),
866           gst_debug_category_get_description (cat));
867     }
868     walk = g_slist_next (walk);
869   }
870   g_slist_free (list);
871   g_print ("\n");
872 }
873 #endif
874
875 #ifndef GST_DISABLE_OPTION_PARSING
876 static gboolean
877 parse_one_option (gint opt, const gchar * arg, GError ** err)
878 {
879   switch (opt) {
880     case ARG_VERSION:
881       g_print ("GStreamer Core Library version %s\n", PACKAGE_VERSION);
882       exit (0);
883     case ARG_FATAL_WARNINGS:{
884       GLogLevelFlags fatal_mask;
885
886       fatal_mask = g_log_set_always_fatal (G_LOG_FATAL_MASK);
887       fatal_mask |= G_LOG_LEVEL_WARNING | G_LOG_LEVEL_CRITICAL;
888       g_log_set_always_fatal (fatal_mask);
889       break;
890     }
891 #ifndef GST_DISABLE_GST_DEBUG
892     case ARG_DEBUG_LEVEL:{
893       gint tmp = 0;
894
895       tmp = strtol (arg, NULL, 0);
896       if (tmp >= 0 && tmp < GST_LEVEL_COUNT) {
897         gst_debug_set_default_threshold (tmp);
898       }
899       break;
900     }
901     case ARG_DEBUG:
902       parse_debug_list (arg);
903       break;
904     case ARG_DEBUG_NO_COLOR:
905       gst_debug_set_colored (FALSE);
906       break;
907     case ARG_DEBUG_DISABLE:
908       gst_debug_set_active (FALSE);
909       break;
910     case ARG_DEBUG_HELP:
911       gst_debug_help ();
912       exit (0);
913 #endif
914     case ARG_PLUGIN_SPEW:
915       break;
916     case ARG_PLUGIN_PATH:
917 #ifndef GST_DISABLE_REGISTRY
918       split_and_iterate (arg, G_SEARCHPATH_SEPARATOR_S, add_path_func, NULL);
919 #endif /* GST_DISABLE_REGISTRY */
920       break;
921     case ARG_PLUGIN_LOAD:
922       split_and_iterate (arg, ",", prepare_for_load_plugin_func, NULL);
923       break;
924     case ARG_SEGTRAP_DISABLE:
925       _gst_disable_segtrap = TRUE;
926       break;
927     case ARG_REGISTRY_UPDATE_DISABLE:
928 #ifndef GST_DISABLE_REGISTRY
929       _priv_gst_disable_registry_update = TRUE;
930 #endif
931       break;
932     case ARG_REGISTRY_FORK_DISABLE:
933       gst_registry_fork_set_enabled (FALSE);
934       break;
935     default:
936       g_set_error (err, G_OPTION_ERROR, G_OPTION_ERROR_UNKNOWN_OPTION,
937           _("Unknown option"));
938       return FALSE;
939   }
940
941   return TRUE;
942 }
943
944 static gboolean
945 parse_goption_arg (const gchar * opt,
946     const gchar * arg, gpointer data, GError ** err)
947 {
948   static const struct
949   {
950     const gchar *opt;
951     int val;
952   } options[] = {
953     {
954     "--gst-version", ARG_VERSION}, {
955     "--gst-fatal-warnings", ARG_FATAL_WARNINGS},
956 #ifndef GST_DISABLE_GST_DEBUG
957     {
958     "--gst-debug-level", ARG_DEBUG_LEVEL}, {
959     "--gst-debug", ARG_DEBUG}, {
960     "--gst-debug-disable", ARG_DEBUG_DISABLE}, {
961     "--gst-debug-no-color", ARG_DEBUG_NO_COLOR}, {
962     "--gst-debug-help", ARG_DEBUG_HELP},
963 #endif
964     {
965     "--gst-plugin-spew", ARG_PLUGIN_SPEW}, {
966     "--gst-plugin-path", ARG_PLUGIN_PATH}, {
967     "--gst-plugin-load", ARG_PLUGIN_LOAD}, {
968     "--gst-disable-segtrap", ARG_SEGTRAP_DISABLE}, {
969     "--gst-disable-registry-update", ARG_REGISTRY_UPDATE_DISABLE}, {
970     "--gst-disable-registry-fork", ARG_REGISTRY_FORK_DISABLE}, {
971     NULL}
972   };
973   gint val = 0, n;
974
975   for (n = 0; options[n].opt; n++) {
976     if (!strcmp (opt, options[n].opt)) {
977       val = options[n].val;
978       break;
979     }
980   }
981
982   return parse_one_option (val, arg, err);
983 }
984 #endif
985
986 /**
987  * gst_deinit:
988  *
989  * Clean up any resources created by GStreamer in gst_init().
990  *
991  * It is normally not needed to call this function in a normal application
992  * as the resources will automatically be freed when the program terminates.
993  * This function is therefore mostly used by testsuites and other memory
994  * profiling tools.
995  *
996  * After this call GStreamer (including this method) should not be used anymore. 
997  */
998 void
999 gst_deinit (void)
1000 {
1001   GstClock *clock;
1002
1003   GST_INFO ("deinitializing GStreamer");
1004
1005   if (gst_deinitialized) {
1006     GST_DEBUG ("already deinitialized");
1007     return;
1008   }
1009
1010   g_slist_foreach (_priv_gst_preload_plugins, (GFunc) g_free, NULL);
1011   g_slist_free (_priv_gst_preload_plugins);
1012   _priv_gst_preload_plugins = NULL;
1013
1014 #ifndef GST_DISABLE_REGISTRY
1015   g_list_foreach (_priv_gst_plugin_paths, (GFunc) g_free, NULL);
1016   g_list_free (_priv_gst_plugin_paths);
1017   _priv_gst_plugin_paths = NULL;
1018 #endif
1019
1020   clock = gst_system_clock_obtain ();
1021   gst_object_unref (clock);
1022   gst_object_unref (clock);
1023
1024   _priv_gst_registry_cleanup ();
1025
1026   g_type_class_unref (g_type_class_peek (gst_object_get_type ()));
1027   g_type_class_unref (g_type_class_peek (gst_pad_get_type ()));
1028   g_type_class_unref (g_type_class_peek (gst_element_factory_get_type ()));
1029   g_type_class_unref (g_type_class_peek (gst_element_get_type ()));
1030   g_type_class_unref (g_type_class_peek (gst_type_find_factory_get_type ()));
1031   g_type_class_unref (g_type_class_peek (gst_bin_get_type ()));
1032   g_type_class_unref (g_type_class_peek (gst_bus_get_type ()));
1033   g_type_class_unref (g_type_class_peek (gst_task_get_type ()));
1034   g_type_class_unref (g_type_class_peek (gst_index_factory_get_type ()));
1035   g_type_class_unref (g_type_class_peek (gst_object_flags_get_type ()));
1036   g_type_class_unref (g_type_class_peek (gst_bin_flags_get_type ()));
1037   g_type_class_unref (g_type_class_peek (gst_buffer_flag_get_type ()));
1038   g_type_class_unref (g_type_class_peek (gst_buffer_copy_flags_get_type ()));
1039   g_type_class_unref (g_type_class_peek (gst_buffer_list_item_get_type ()));
1040   g_type_class_unref (g_type_class_peek (gst_bus_flags_get_type ()));
1041   g_type_class_unref (g_type_class_peek (gst_bus_sync_reply_get_type ()));
1042   g_type_class_unref (g_type_class_peek (gst_caps_flags_get_type ()));
1043   g_type_class_unref (g_type_class_peek (gst_clock_type_get_type ()));
1044   g_type_class_unref (g_type_class_peek (gst_clock_return_get_type ()));
1045   g_type_class_unref (g_type_class_peek (gst_clock_entry_type_get_type ()));
1046   g_type_class_unref (g_type_class_peek (gst_clock_flags_get_type ()));
1047   g_type_class_unref (g_type_class_peek (gst_debug_graph_details_get_type ()));
1048   g_type_class_unref (g_type_class_peek (gst_state_get_type ()));
1049   g_type_class_unref (g_type_class_peek (gst_state_change_return_get_type ()));
1050   g_type_class_unref (g_type_class_peek (gst_state_change_get_type ()));
1051   g_type_class_unref (g_type_class_peek (gst_element_flags_get_type ()));
1052   g_type_class_unref (g_type_class_peek (gst_core_error_get_type ()));
1053   g_type_class_unref (g_type_class_peek (gst_library_error_get_type ()));
1054   g_type_class_unref (g_type_class_peek (gst_plugin_dependency_flags_get_type
1055           ()));
1056   g_type_class_unref (g_type_class_peek (gst_parse_flags_get_type ()));
1057   g_type_class_unref (g_type_class_peek (gst_resource_error_get_type ()));
1058   g_type_class_unref (g_type_class_peek (gst_search_mode_get_type ()));
1059   g_type_class_unref (g_type_class_peek (gst_stream_error_get_type ()));
1060   g_type_class_unref (g_type_class_peek (gst_stream_status_type_get_type ()));
1061   g_type_class_unref (g_type_class_peek (gst_structure_change_type_get_type
1062           ()));
1063   g_type_class_unref (g_type_class_peek (gst_event_type_flags_get_type ()));
1064   g_type_class_unref (g_type_class_peek (gst_event_type_get_type ()));
1065   g_type_class_unref (g_type_class_peek (gst_seek_type_get_type ()));
1066   g_type_class_unref (g_type_class_peek (gst_seek_flags_get_type ()));
1067   g_type_class_unref (g_type_class_peek (gst_format_get_type ()));
1068   g_type_class_unref (g_type_class_peek (gst_index_certainty_get_type ()));
1069   g_type_class_unref (g_type_class_peek (gst_index_entry_type_get_type ()));
1070   g_type_class_unref (g_type_class_peek (gst_index_lookup_method_get_type ()));
1071   g_type_class_unref (g_type_class_peek (gst_assoc_flags_get_type ()));
1072   g_type_class_unref (g_type_class_peek (gst_index_resolver_method_get_type
1073           ()));
1074   g_type_class_unref (g_type_class_peek (gst_index_flags_get_type ()));
1075   g_type_class_unref (g_type_class_peek (gst_debug_level_get_type ()));
1076   g_type_class_unref (g_type_class_peek (gst_debug_color_flags_get_type ()));
1077   g_type_class_unref (g_type_class_peek (gst_iterator_result_get_type ()));
1078   g_type_class_unref (g_type_class_peek (gst_iterator_item_get_type ()));
1079   g_type_class_unref (g_type_class_peek (gst_message_type_get_type ()));
1080   g_type_class_unref (g_type_class_peek (gst_mini_object_flags_get_type ()));
1081   g_type_class_unref (g_type_class_peek (gst_pad_link_return_get_type ()));
1082   g_type_class_unref (g_type_class_peek (gst_flow_return_get_type ()));
1083   g_type_class_unref (g_type_class_peek (gst_activate_mode_get_type ()));
1084   g_type_class_unref (g_type_class_peek (gst_pad_direction_get_type ()));
1085   g_type_class_unref (g_type_class_peek (gst_pad_flags_get_type ()));
1086   g_type_class_unref (g_type_class_peek (gst_pad_presence_get_type ()));
1087   g_type_class_unref (g_type_class_peek (gst_pad_template_flags_get_type ()));
1088   g_type_class_unref (g_type_class_peek (gst_pipeline_flags_get_type ()));
1089   g_type_class_unref (g_type_class_peek (gst_plugin_error_get_type ()));
1090   g_type_class_unref (g_type_class_peek (gst_plugin_flags_get_type ()));
1091   g_type_class_unref (g_type_class_peek (gst_rank_get_type ()));
1092   g_type_class_unref (g_type_class_peek (gst_query_type_get_type ()));
1093   g_type_class_unref (g_type_class_peek (gst_buffering_mode_get_type ()));
1094   g_type_class_unref (g_type_class_peek (gst_tag_merge_mode_get_type ()));
1095   g_type_class_unref (g_type_class_peek (gst_tag_flag_get_type ()));
1096   g_type_class_unref (g_type_class_peek (gst_task_state_get_type ()));
1097   g_type_class_unref (g_type_class_peek (gst_alloc_trace_flags_get_type ()));
1098   g_type_class_unref (g_type_class_peek (gst_type_find_probability_get_type
1099           ()));
1100   g_type_class_unref (g_type_class_peek (gst_uri_type_get_type ()));
1101   g_type_class_unref (g_type_class_peek (gst_parse_error_get_type ()));
1102   g_type_class_unref (g_type_class_peek (gst_param_spec_fraction_get_type ()));
1103
1104   gst_deinitialized = TRUE;
1105   GST_INFO ("deinitialized GStreamer");
1106 }
1107
1108 /**
1109  * gst_version:
1110  * @major: pointer to a guint to store the major version number
1111  * @minor: pointer to a guint to store the minor version number
1112  * @micro: pointer to a guint to store the micro version number
1113  * @nano:  pointer to a guint to store the nano version number
1114  *
1115  * Gets the version number of the GStreamer library.
1116  */
1117 void
1118 gst_version (guint * major, guint * minor, guint * micro, guint * nano)
1119 {
1120   g_return_if_fail (major);
1121   g_return_if_fail (minor);
1122   g_return_if_fail (micro);
1123   g_return_if_fail (nano);
1124
1125   *major = GST_VERSION_MAJOR;
1126   *minor = GST_VERSION_MINOR;
1127   *micro = GST_VERSION_MICRO;
1128   *nano = GST_VERSION_NANO;
1129 }
1130
1131 /**
1132  * gst_version_string:
1133  *
1134  * This function returns a string that is useful for describing this version
1135  * of GStreamer to the outside world: user agent strings, logging, ...
1136  *
1137  * Returns: a newly allocated string describing this version of GStreamer.
1138  */
1139
1140 gchar *
1141 gst_version_string (void)
1142 {
1143   guint major, minor, micro, nano;
1144
1145   gst_version (&major, &minor, &micro, &nano);
1146   if (nano == 0)
1147     return g_strdup_printf ("GStreamer %d.%d.%d", major, minor, micro);
1148   else if (nano == 1)
1149     return g_strdup_printf ("GStreamer %d.%d.%d (GIT)", major, minor, micro);
1150   else
1151     return g_strdup_printf ("GStreamer %d.%d.%d (prerelease)", major, minor,
1152         micro);
1153 }
1154
1155 /**
1156  * gst_segtrap_is_enabled:
1157  *
1158  * Some functions in the GStreamer core might install a custom SIGSEGV handler
1159  * to better catch and report errors to the application. Currently this feature
1160  * is enabled by default when loading plugins.
1161  *
1162  * Applications might want to disable this behaviour with the
1163  * gst_segtrap_set_enabled() function. This is typically done if the application
1164  * wants to install its own handler without GStreamer interfering.
1165  *
1166  * Returns: %TRUE if GStreamer is allowed to install a custom SIGSEGV handler.
1167  *
1168  * Since: 0.10.10
1169  */
1170 gboolean
1171 gst_segtrap_is_enabled (void)
1172 {
1173   /* yeps, it's enabled when it's not disabled */
1174   return !_gst_disable_segtrap;
1175 }
1176
1177 /**
1178  * gst_segtrap_set_enabled:
1179  * @enabled: whether a custom SIGSEGV handler should be installed.
1180  *
1181  * Applications might want to disable/enable the SIGSEGV handling of
1182  * the GStreamer core. See gst_segtrap_is_enabled() for more information.
1183  *
1184  * Since: 0.10.10
1185  */
1186 void
1187 gst_segtrap_set_enabled (gboolean enabled)
1188 {
1189   _gst_disable_segtrap = !enabled;
1190 }