added better error reporting for plugin loading

Original commit message from CVS:
added better error reporting for plugin loading
This commit is contained in:
Stefan Kost 2004-09-02 16:39:14 +00:00
parent b32ebdaabe
commit b78ef6baa1
3 changed files with 60 additions and 27 deletions

View file

@ -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 ##### -->

View file

@ -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);

View file

@ -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;
} }