*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
+ * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
*/
/**
* N_("Output tags (also known as metadata)"), NULL},
* {NULL}
* };
- * // must initialise the threading system before using any other GLib funtion
- * if (!g_thread_supported ())
- * g_thread_init (NULL);
* ctx = g_option_context_new ("[ADDITIONAL ARGUMENTS]");
* g_option_context_add_main_entries (ctx, options, GETTEXT_PACKAGE);
* g_option_context_add_group (ctx, gst_init_get_option_group ());
#include <locale.h> /* for LC_ALL */
#include "gst.h"
+#include "gsttrace.h"
#define GST_CAT_DEFAULT GST_CAT_GST_INIT
#endif
#ifndef GST_DISABLE_GST_DEBUG
-extern const gchar *priv_gst_dump_dot_dir;
+const gchar *priv_gst_dump_dot_dir;
#endif
/* defaults */
* val ::= [0-5]
*/
-#ifndef NUL
-#define NUL '\0'
-#endif
-
-#ifndef GST_DISABLE_GST_DEBUG
-static gboolean
-parse_debug_category (gchar * str, const gchar ** category)
-{
- if (!str)
- return FALSE;
-
- /* works in place */
- g_strstrip (str);
-
- if (str[0] != NUL) {
- *category = str;
- return TRUE;
- }
-
- return FALSE;
-}
-
-static gboolean
-parse_debug_level (gchar * str, GstDebugLevel * level)
-{
- if (!str)
- return FALSE;
-
- /* works in place */
- g_strstrip (str);
-
- if (str[0] != NUL && str[1] == NUL
- && str[0] >= '0' && str[0] < '0' + GST_LEVEL_COUNT) {
- *level = (GstDebugLevel) (str[0] - '0');
- return TRUE;
- }
-
- return FALSE;
-}
-
-static void
-parse_debug_list (const gchar * list)
-{
- gchar **split;
- gchar **walk;
-
- g_assert (list);
-
- split = g_strsplit (list, ",", 0);
-
- for (walk = split; *walk; walk++) {
- if (strchr (*walk, ':')) {
- gchar **values = g_strsplit (*walk, ":", 2);
-
- if (values[0] && values[1]) {
- GstDebugLevel level;
- const gchar *category;
-
- if (parse_debug_category (values[0], &category)
- && parse_debug_level (values[1], &level))
- gst_debug_set_threshold_for_name (category, level);
- }
-
- g_strfreev (values);
- } else {
- GstDebugLevel level;
-
- if (parse_debug_level (*walk, &level))
- gst_debug_set_default_threshold (level);
- }
- }
-
- g_strfreev (split);
-}
-#endif
-
#ifdef G_OS_WIN32
BOOL WINAPI DllMain (HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved);
BOOL WINAPI
{NULL}
};
- /* Since GLib 2.23.2 calling g_thread_init() 'late' is allowed and is
- * automatically done as part of g_type_init() */
- if (glib_check_version (2, 23, 3)) {
- /* The GLib threading system must be initialised before calling any other
- * GLib function according to the documentation; if the application hasn't
- * called gst_init() yet or initialised the threading system otherwise, we
- * better issue a warning here (since chances are high that the application
- * has already called other GLib functions such as g_option_context_new() */
- if (!g_thread_get_initialized ()) {
- g_warning ("The GStreamer function gst_init_get_option_group() was\n"
- "\tcalled, but the GLib threading system has not been initialised\n"
- "\tyet, something that must happen before any other GLib function\n"
- "\tis called. The application needs to be fixed so that it calls\n"
- "\t if (!g_thread_get_initialized ()) g_thread_init(NULL);\n"
- "\tas very first thing in its main() function. Please file a bug\n"
- "\tagainst this application.");
- g_thread_init (NULL);
- }
- } else {
- /* GLib >= 2.23.2 */
- }
-
group = g_option_group_new ("gst", _("GStreamer Options"),
_("Show GStreamer Options"), NULL, NULL);
g_option_group_set_parse_hooks (group, (GOptionParseFunc) init_pre,
* for some reason. If you want your program to fail fatally,
* use gst_init() instead.
*
- * This function should be called before calling any other GLib functions. If
- * this is not an option, your program must initialise the GLib thread system
- * using g_thread_init() before any other GLib functions are called.
- *
* Returns: %TRUE if GStreamer could be initialized.
*/
gboolean
#endif
gboolean res;
- if (!g_thread_get_initialized ())
- g_thread_init (NULL);
-
if (gst_initialized) {
GST_DEBUG ("already initialized gst");
return TRUE;
#ifndef GST_DISABLE_OPTION_PARSING
ctx = g_option_context_new ("- GStreamer initialization");
g_option_context_set_ignore_unknown_options (ctx, TRUE);
+ g_option_context_set_help_enabled (ctx, FALSE);
group = gst_init_get_option_group ();
g_option_context_add_group (ctx, group);
res = g_option_context_parse (ctx, argc, argv, err);
* <link linkend="gst-running">Running GStreamer Applications</link>
* for how to disable automatic registry updates.
*
- * This function should be called before calling any other GLib functions. If
- * this is not an option, your program must initialise the GLib thread system
- * using g_thread_init() before any other GLib functions are called.
- *
* <note><para>
* This function will terminate your program if it was unable to initialize
* GStreamer for some reason. If you want your program to fall back,
* or gst_init_check().
*
* Returns: TRUE if initialization has been done, FALSE otherwise.
- *
- * Since: 0.10.31
*/
gboolean
gst_is_initialized (void)
GST_DEBUG ("already initialized");
return TRUE;
}
-
+#if !GLIB_CHECK_VERSION(2, 35, 0)
g_type_init ();
-
- /* we need threading to be enabled right here */
- g_assert (g_thread_get_initialized ());
+#endif
#ifndef GST_DISABLE_GST_DEBUG
_priv_gst_debug_init ();
#endif
#ifdef ENABLE_NLS
- setlocale (LC_ALL, "");
bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR);
bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
#endif /* ENABLE_NLS */
debug_list = g_getenv ("GST_DEBUG");
if (debug_list) {
- parse_debug_list (debug_list);
+ gst_debug_set_threshold_from_string (debug_list, FALSE);
}
}
}
#endif
+#ifndef G_ATOMIC_LOCK_FREE
+ GST_CAT_WARNING (GST_CAT_PERFORMANCE, "GLib atomic operations are NOT "
+ "implemented using real hardware atomic operations!");
+#endif
+
return TRUE;
}
{
GLogLevelFlags llf;
-#ifndef GST_DISABLE_TRACE
- GstTrace *gst_trace;
-#endif /* GST_DISABLE_TRACE */
-
if (gst_initialized) {
GST_DEBUG ("already initialized");
return TRUE;
llf = G_LOG_LEVEL_CRITICAL | G_LOG_LEVEL_ERROR | G_LOG_FLAG_FATAL;
g_log_set_handler (g_log_domain_gstreamer, llf, debug_log_handler, NULL);
+#ifndef GST_DISABLE_TRACE
+ _priv_gst_alloc_trace_initialize ();
+#endif
+
+ _priv_gst_mini_object_initialize ();
_priv_gst_quarks_initialize ();
_priv_gst_memory_initialize ();
_priv_gst_format_initialize ();
_priv_gst_query_initialize ();
_priv_gst_structure_initialize ();
_priv_gst_caps_initialize ();
+ _priv_gst_caps_features_initialize ();
_priv_gst_meta_initialize ();
g_type_class_ref (gst_object_get_type ());
g_type_class_ref (gst_task_get_type ());
g_type_class_ref (gst_clock_get_type ());
- g_type_class_ref (gst_index_factory_get_type ());
gst_uri_handler_get_type ();
g_type_class_ref (gst_object_flags_get_type ());
g_type_class_ref (gst_seek_flags_get_type ());
g_type_class_ref (gst_qos_type_get_type ());
g_type_class_ref (gst_format_get_type ());
- g_type_class_ref (gst_index_certainty_get_type ());
- g_type_class_ref (gst_index_entry_type_get_type ());
- g_type_class_ref (gst_index_lookup_method_get_type ());
- g_type_class_ref (gst_assoc_flags_get_type ());
- g_type_class_ref (gst_index_resolver_method_get_type ());
- g_type_class_ref (gst_index_flags_get_type ());
g_type_class_ref (gst_debug_level_get_type ());
g_type_class_ref (gst_debug_color_flags_get_type ());
g_type_class_ref (gst_iterator_result_get_type ());
g_type_class_ref (gst_plugin_flags_get_type ());
g_type_class_ref (gst_plugin_dependency_flags_get_type ());
g_type_class_ref (gst_rank_get_type ());
+ g_type_class_ref (gst_query_type_flags_get_type ());
g_type_class_ref (gst_query_type_get_type ());
g_type_class_ref (gst_buffering_mode_get_type ());
g_type_class_ref (gst_stream_status_type_get_type ());
g_type_class_ref (gst_structure_change_type_get_type ());
g_type_class_ref (gst_tag_merge_mode_get_type ());
g_type_class_ref (gst_tag_flag_get_type ());
+ g_type_class_ref (gst_tag_scope_get_type ());
g_type_class_ref (gst_task_pool_get_type ());
g_type_class_ref (gst_task_state_get_type ());
- g_type_class_ref (gst_alloc_trace_flags_get_type ());
+ g_type_class_ref (gst_toc_entry_type_get_type ());
g_type_class_ref (gst_type_find_probability_get_type ());
g_type_class_ref (gst_uri_error_get_type ());
g_type_class_ref (gst_uri_type_get_type ());
g_type_class_ref (gst_parse_flags_get_type ());
g_type_class_ref (gst_search_mode_get_type ());
g_type_class_ref (gst_progress_type_get_type ());
- g_type_class_ref (gst_buffer_pool_flags_get_type ());
+ g_type_class_ref (gst_buffer_pool_acquire_flags_get_type ());
g_type_class_ref (gst_memory_flags_get_type ());
g_type_class_ref (gst_map_flags_get_type ());
g_type_class_ref (gst_caps_intersect_mode_get_type ());
g_type_class_ref (gst_pad_probe_return_get_type ());
g_type_class_ref (gst_segment_flags_get_type ());
g_type_class_ref (gst_scheduling_flags_get_type ());
+ g_type_class_ref (gst_meta_flags_get_type ());
+ g_type_class_ref (gst_toc_entry_type_get_type ());
+ g_type_class_ref (gst_toc_scope_get_type ());
+ g_type_class_ref (gst_control_binding_get_type ());
+ g_type_class_ref (gst_control_source_get_type ());
+ g_type_class_ref (gst_lock_flags_get_type ());
+ g_type_class_ref (gst_allocator_flags_get_type ());
+ g_type_class_ref (gst_stream_flags_get_type ());
_priv_gst_event_initialize ();
_priv_gst_buffer_initialize ();
_priv_gst_message_initialize ();
_priv_gst_buffer_list_initialize ();
+ _priv_gst_sample_initialize ();
_priv_gst_value_initialize ();
+ _priv_gst_context_initialize ();
+
g_type_class_ref (gst_param_spec_fraction_get_type ());
_priv_gst_tag_initialize ();
gst_parse_context_get_type ();
_priv_gst_plugin_initialize ();
- gst_g_error_get_type ();
-
/* register core plugins */
gst_plugin_register_static (GST_VERSION_MAJOR, GST_VERSION_MINOR,
"staticelements", "core elements linked into the GStreamer library",
if (!gst_update_registry ())
return FALSE;
-#ifndef GST_DISABLE_TRACE
- _gst_trace_on = 0;
- if (_gst_trace_on) {
- gst_trace = gst_trace_new ("gst.trace", 1024);
- gst_trace_set_default (gst_trace);
- }
-#endif /* GST_DISABLE_TRACE */
-
GST_INFO ("GLib runtime version: %d.%d.%d", glib_major_version,
glib_minor_version, glib_micro_version);
GST_INFO ("GLib headers version: %d.%d.%d", GLIB_MAJOR_VERSION,
if (!init_post (NULL, NULL, NULL, NULL))
exit (1);
- list2 = gst_registry_plugin_filter (gst_registry_get_default (),
+ list2 = gst_registry_plugin_filter (gst_registry_get (),
select_all, FALSE, NULL);
/* FIXME this is gross. why don't debug have categories PluginFeatures? */
GstDebugLevel tmp = GST_LEVEL_NONE;
tmp = (GstDebugLevel) strtol (arg, NULL, 0);
- if (tmp >= 0 && tmp < GST_LEVEL_COUNT) {
+ if (((guint) tmp) < GST_LEVEL_COUNT) {
gst_debug_set_default_threshold (tmp);
}
break;
}
case ARG_DEBUG:
- parse_debug_list (arg);
+ gst_debug_set_threshold_from_string (arg, FALSE);
break;
case ARG_DEBUG_NO_COLOR:
gst_debug_set_colored (FALSE);
_priv_gst_registry_cleanup ();
+#ifndef GST_DISABLE_TRACE
+ _priv_gst_alloc_trace_deinit ();
+#endif
+
g_type_class_unref (g_type_class_peek (gst_object_get_type ()));
g_type_class_unref (g_type_class_peek (gst_pad_get_type ()));
g_type_class_unref (g_type_class_peek (gst_element_factory_get_type ()));
g_type_class_unref (g_type_class_peek (gst_bin_get_type ()));
g_type_class_unref (g_type_class_peek (gst_bus_get_type ()));
g_type_class_unref (g_type_class_peek (gst_task_get_type ()));
- g_type_class_unref (g_type_class_peek (gst_index_factory_get_type ()));
g_type_class_unref (g_type_class_peek (gst_object_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_bin_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_buffer_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_seek_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_qos_type_get_type ()));
g_type_class_unref (g_type_class_peek (gst_format_get_type ()));
- g_type_class_unref (g_type_class_peek (gst_index_certainty_get_type ()));
- g_type_class_unref (g_type_class_peek (gst_index_entry_type_get_type ()));
- g_type_class_unref (g_type_class_peek (gst_index_lookup_method_get_type ()));
- g_type_class_unref (g_type_class_peek (gst_assoc_flags_get_type ()));
- g_type_class_unref (g_type_class_peek (gst_index_resolver_method_get_type
- ()));
- g_type_class_unref (g_type_class_peek (gst_index_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_debug_level_get_type ()));
g_type_class_unref (g_type_class_peek (gst_debug_color_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_iterator_result_get_type ()));
g_type_class_unref (g_type_class_peek (gst_iterator_item_get_type ()));
g_type_class_unref (g_type_class_peek (gst_message_type_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_meta_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_mini_object_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_pad_link_return_get_type ()));
g_type_class_unref (g_type_class_peek (gst_pad_link_check_get_type ()));
g_type_class_unref (g_type_class_peek (gst_plugin_error_get_type ()));
g_type_class_unref (g_type_class_peek (gst_plugin_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_rank_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_query_type_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_query_type_get_type ()));
g_type_class_unref (g_type_class_peek (gst_buffering_mode_get_type ()));
g_type_class_unref (g_type_class_peek (gst_tag_merge_mode_get_type ()));
g_type_class_unref (g_type_class_peek (gst_tag_flag_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_tag_scope_get_type ()));
g_type_class_unref (g_type_class_peek (gst_task_state_get_type ()));
- g_type_class_unref (g_type_class_peek (gst_alloc_trace_flags_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_toc_entry_type_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_toc_scope_get_type ()));
g_type_class_unref (g_type_class_peek (gst_type_find_probability_get_type
()));
g_type_class_unref (g_type_class_peek (gst_uri_type_get_type ()));
g_type_class_unref (g_type_class_peek (gst_parse_error_get_type ()));
g_type_class_unref (g_type_class_peek (gst_param_spec_fraction_get_type ()));
g_type_class_unref (g_type_class_peek (gst_progress_type_get_type ()));
- g_type_class_unref (g_type_class_peek (gst_buffer_pool_flags_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_buffer_pool_acquire_flags_get_type
+ ()));
g_type_class_unref (g_type_class_peek (gst_memory_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_map_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_caps_intersect_mode_get_type ()));
g_type_class_unref (g_type_class_peek (gst_segment_flags_get_type ()));
g_type_class_unref (g_type_class_peek (gst_scheduling_flags_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_control_binding_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_control_source_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_toc_entry_type_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_lock_flags_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_allocator_flags_get_type ()));
+ g_type_class_unref (g_type_class_peek (gst_stream_flags_get_type ()));
+
+
gst_deinitialized = TRUE;
GST_INFO ("deinitialized GStreamer");
}
* wants to install its own handler without GStreamer interfering.
*
* Returns: %TRUE if GStreamer is allowed to install a custom SIGSEGV handler.
- *
- * Since: 0.10.10
*/
gboolean
gst_segtrap_is_enabled (void)
*
* Applications might want to disable/enable the SIGSEGV handling of
* the GStreamer core. See gst_segtrap_is_enabled() for more information.
- *
- * Since: 0.10.10
*/
void
gst_segtrap_set_enabled (gboolean enabled)