mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 08:38:21 +00:00
added better error reporting for plugin loading
Original commit message from CVS: added better error reporting for plugin loading
This commit is contained in:
parent
b32ebdaabe
commit
b78ef6baa1
3 changed files with 60 additions and 27 deletions
|
@ -17,7 +17,11 @@ GValue implementations specific to GStreamer
|
||||||
<!-- ##### MACRO GST_MAKE_FOURCC ##### -->
|
<!-- ##### MACRO GST_MAKE_FOURCC ##### -->
|
||||||
<para>
|
<para>
|
||||||
will transform four characters into a host-endiannness guint32 fourcc:
|
will transform four characters into a host-endiannness guint32 fourcc:
|
||||||
<code>guint32 fourcc = GST_MAKE_FOURCC ('M','J','P','G');</code>
|
<informalexample>
|
||||||
|
<programlisting>
|
||||||
|
guint32 fourcc = GST_MAKE_FOURCC ('M','J','P','G');
|
||||||
|
</programlisting>
|
||||||
|
</informalexample>
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@a: the first component
|
@a: the first component
|
||||||
|
@ -28,17 +32,27 @@ will transform four characters into a host-endiannness guint32 fourcc:
|
||||||
|
|
||||||
<!-- ##### MACRO GST_STR_FOURCC ##### -->
|
<!-- ##### MACRO GST_STR_FOURCC ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Creates a fourcc from an input string. The input string should consisnt
|
||||||
|
of at least four characters (this is not checked for!).
|
||||||
|
<informalexample>
|
||||||
|
<programlisting>
|
||||||
|
guint32 fourcc = GST_STR_FOURCC("MJPG");
|
||||||
|
</programlisting>
|
||||||
|
</informalexample>
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@f:
|
@f: a string with four characters
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_FOURCC_FORMAT ##### -->
|
<!-- ##### MACRO GST_FOURCC_FORMAT ##### -->
|
||||||
<para>
|
<para>
|
||||||
Can be used to properly output a fourcc (a guint32) value in a
|
Can be used to properly output a fourcc (a guint32) value in a
|
||||||
printf()-style text message.
|
printf()-style text message.
|
||||||
<code>printf ("fourcc: %" GST_FOURCC_FORMAT "\n", GST_FOURCC_ARGS (fcc));</code>
|
<informalexample>
|
||||||
|
<programlisting>
|
||||||
|
printf ("fourcc: %" GST_FOURCC_FORMAT "\n", GST_FOURCC_ARGS (fcc));
|
||||||
|
</programlisting>
|
||||||
|
</informalexample>
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
@ -47,7 +61,11 @@ printf()-style text message.
|
||||||
<para>
|
<para>
|
||||||
Can be used to properly output a fourcc (a guint32) value in a
|
Can be used to properly output a fourcc (a guint32) value in a
|
||||||
printf()-style text message.
|
printf()-style text message.
|
||||||
<code>printf ("fourcc: %" GST_FOURCC_FORMAT "\n", GST_FOURCC_ARGS (fcc));</code>
|
<informalexample>
|
||||||
|
<programlisting>
|
||||||
|
printf ("fourcc: %" GST_FOURCC_FORMAT "\n", GST_FOURCC_ARGS (fcc));
|
||||||
|
</programlisting>
|
||||||
|
</informalexample>
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@fourcc: the fourcc value to print
|
@fourcc: the fourcc value to print
|
||||||
|
@ -55,84 +73,88 @@ printf()-style text message.
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_HOLDS_FOURCC ##### -->
|
<!-- ##### MACRO GST_VALUE_HOLDS_FOURCC ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Checks if the give GValue contains a FOURCC value.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@x:
|
@x: the #GValue to check
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_HOLDS_INT_RANGE ##### -->
|
<!-- ##### MACRO GST_VALUE_HOLDS_INT_RANGE ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Checks if the give GValue contains a INT_RANGE value.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@x:
|
@x: the #GValue to check
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_HOLDS_DOUBLE_RANGE ##### -->
|
<!-- ##### MACRO GST_VALUE_HOLDS_DOUBLE_RANGE ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Checks if the give GValue contains a DOUBLE_RANGE value.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@x:
|
@x: the #GValue to check
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_HOLDS_LIST ##### -->
|
<!-- ##### MACRO GST_VALUE_HOLDS_LIST ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Checks if the give GValue contains a LIST value.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@x:
|
@x: the #GValue to check
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_HOLDS_FIXED_LIST ##### -->
|
<!-- ##### MACRO GST_VALUE_HOLDS_FIXED_LIST ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Checks if the give GValue contains a FIXED_LIST value.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@x:
|
@x: the #GValue to check
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_HOLDS_CAPS ##### -->
|
<!-- ##### MACRO GST_VALUE_HOLDS_CAPS ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Checks if the give GValue contains a CAPS value.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@x:
|
@x: the #GValue to check
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_HOLDS_FRACTION ##### -->
|
<!-- ##### MACRO GST_VALUE_HOLDS_FRACTION ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Checks if the give GValue contains a FRACTION value.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@x:
|
@x: the #GValue to check
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_LESS_THAN ##### -->
|
<!-- ##### MACRO GST_VALUE_LESS_THAN ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Indicates that the first value provided to a comparison function
|
||||||
|
(gst_value_compare()) is lesser than the second one.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_EQUAL ##### -->
|
<!-- ##### MACRO GST_VALUE_EQUAL ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Indicates that the first value provided to a comparison function
|
||||||
|
(gst_value_compare()) is equal to the second one.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_GREATER_THAN ##### -->
|
<!-- ##### MACRO GST_VALUE_GREATER_THAN ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Indicates that the first value provided to a comparison function
|
||||||
|
(gst_value_compare()) is greater than the second one.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_VALUE_UNORDERED ##### -->
|
<!-- ##### MACRO GST_VALUE_UNORDERED ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Indicates that the comparison function (gst_value_compare()) can not
|
||||||
|
determine a order for the two provided values.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
@ -144,7 +166,8 @@ printf()-style text message.
|
||||||
|
|
||||||
@value1:
|
@value1:
|
||||||
@value2:
|
@value2:
|
||||||
@Returns:
|
@Returns: one of GST_VALUE_LESS_THAN, GST_VALUE_EQUAL,
|
||||||
|
GST_VALUE_GREATER_THAN or GST_VALUE_UNORDERED
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### USER_FUNCTION GstValueSerializeFunc ##### -->
|
<!-- ##### USER_FUNCTION GstValueSerializeFunc ##### -->
|
||||||
|
|
11
gst/gst.c
11
gst/gst.c
|
@ -409,17 +409,24 @@ load_plugin_func (gpointer data, gpointer user_data)
|
||||||
{
|
{
|
||||||
GstPlugin *plugin;
|
GstPlugin *plugin;
|
||||||
const gchar *filename;
|
const gchar *filename;
|
||||||
|
GError *err = NULL;
|
||||||
|
|
||||||
filename = (const gchar *) data;
|
filename = (const gchar *) data;
|
||||||
|
|
||||||
plugin = gst_plugin_load_file (filename, NULL);
|
plugin = gst_plugin_load_file (filename, &err);
|
||||||
|
|
||||||
if (plugin) {
|
if (plugin) {
|
||||||
GST_INFO ("Loaded plugin: \"%s\"", filename);
|
GST_INFO ("Loaded plugin: \"%s\"", filename);
|
||||||
|
|
||||||
gst_registry_pool_add_plugin (plugin);
|
gst_registry_pool_add_plugin (plugin);
|
||||||
} else {
|
} else {
|
||||||
GST_WARNING ("Failed to load plugin: \"%s\"", filename);
|
if (err) {
|
||||||
|
/* Report error to user, and free error */
|
||||||
|
GST_ERROR ("Failed to load plugin: %s\n", err->message);
|
||||||
|
g_error_free (err);
|
||||||
|
} else {
|
||||||
|
GST_WARNING ("Failed to load plugin: \"%s\"", filename);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
g_free (data);
|
g_free (data);
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
|
@ -324,7 +325,8 @@ gst_plugin_check_file (const gchar * filename, GError ** error)
|
||||||
if (stat (filename, &file_status)) {
|
if (stat (filename, &file_status)) {
|
||||||
g_set_error (error,
|
g_set_error (error,
|
||||||
GST_PLUGIN_ERROR,
|
GST_PLUGIN_ERROR,
|
||||||
GST_PLUGIN_ERROR_MODULE, "Problem opening file %s\n", filename);
|
GST_PLUGIN_ERROR_MODULE, "Problem accessing file %s: %s\n", filename,
|
||||||
|
strerror (errno));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -348,6 +350,7 @@ gst_plugin_check_file (const gchar * filename, GError ** error)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
/* it's a plugin */
|
/* it's a plugin */
|
||||||
|
GST_INFO ("looks like a gst plugin \"%s\"", filename);
|
||||||
g_module_close (module);
|
g_module_close (module);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue