mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
fix refcounting of warning and error messages
Original commit message from CVS: fix refcounting of warning and error messages
This commit is contained in:
parent
3915dc69c3
commit
232b0ba690
9 changed files with 153 additions and 12 deletions
15
ChangeLog
15
ChangeLog
|
@ -1,3 +1,18 @@
|
||||||
|
2005-07-12 Thomas Vander Stichele <thomas at apestaart dot org>
|
||||||
|
|
||||||
|
* check/gst/gstelement.c: (GST_START_TEST), (gst_element_suite):
|
||||||
|
* check/gst/gstmessage.c: (GST_START_TEST):
|
||||||
|
* check/gst/gststructure.c: (GST_START_TEST),
|
||||||
|
(gst_structure_suite), (main):
|
||||||
|
more testing
|
||||||
|
* gst/gstelement.c: (gst_element_message_full):
|
||||||
|
clean up GError and debug string now that they get copied
|
||||||
|
* gst/gstmessage.c: (gst_message_new_error),
|
||||||
|
(gst_message_new_warning), (gst_message_parse_error),
|
||||||
|
(gst_message_parse_warning):
|
||||||
|
use GST_TYPE_G_ERROR for structure_new, and take copies of
|
||||||
|
arguments, so that we don't mess up refcounting
|
||||||
|
|
||||||
2005-07-12 Thomas Vander Stichele <thomas at apestaart dot org>
|
2005-07-12 Thomas Vander Stichele <thomas at apestaart dot org>
|
||||||
|
|
||||||
* check/Makefile.am:
|
* check/Makefile.am:
|
||||||
|
|
|
@ -78,6 +78,21 @@ GST_START_TEST (test_add_pad_unref_element)
|
||||||
|
|
||||||
GST_END_TEST;
|
GST_END_TEST;
|
||||||
|
|
||||||
|
GST_START_TEST (test_error_no_bus)
|
||||||
|
{
|
||||||
|
GstElement *e;
|
||||||
|
|
||||||
|
e = gst_element_factory_make ("fakesrc", "source");
|
||||||
|
|
||||||
|
/* I don't want errors shown */
|
||||||
|
gst_debug_set_default_threshold (GST_LEVEL_NONE);
|
||||||
|
|
||||||
|
GST_ELEMENT_ERROR (e, RESOURCE, OPEN_READ, ("I could not read"), ("debug"));
|
||||||
|
|
||||||
|
gst_object_unref (e);
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_END_TEST;
|
||||||
|
|
||||||
Suite *
|
Suite *
|
||||||
gst_element_suite (void)
|
gst_element_suite (void)
|
||||||
|
@ -88,6 +103,7 @@ gst_element_suite (void)
|
||||||
suite_add_tcase (s, tc_chain);
|
suite_add_tcase (s, tc_chain);
|
||||||
tcase_add_test (tc_chain, test_add_remove_pad);
|
tcase_add_test (tc_chain, test_add_remove_pad);
|
||||||
tcase_add_test (tc_chain, test_add_pad_unref_element);
|
tcase_add_test (tc_chain, test_add_pad_unref_element);
|
||||||
|
tcase_add_test (tc_chain, test_error_no_bus);
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,8 +49,11 @@ GST_START_TEST (test_parsing)
|
||||||
fail_if (message == NULL);
|
fail_if (message == NULL);
|
||||||
fail_unless (GST_MESSAGE_TYPE (message) == GST_MESSAGE_ERROR);
|
fail_unless (GST_MESSAGE_TYPE (message) == GST_MESSAGE_ERROR);
|
||||||
fail_unless (GST_MESSAGE_SRC (message) == NULL);
|
fail_unless (GST_MESSAGE_SRC (message) == NULL);
|
||||||
|
|
||||||
|
g_error_free (error);
|
||||||
error = NULL;
|
error = NULL;
|
||||||
debug = NULL;
|
debug = NULL;
|
||||||
|
|
||||||
gst_message_parse_error (message, &error, &debug);
|
gst_message_parse_error (message, &error, &debug);
|
||||||
fail_if (error == NULL);
|
fail_if (error == NULL);
|
||||||
fail_if (debug == NULL);
|
fail_if (debug == NULL);
|
||||||
|
@ -58,7 +61,10 @@ GST_START_TEST (test_parsing)
|
||||||
fail_unless (error->domain == domain);
|
fail_unless (error->domain == domain);
|
||||||
fail_unless (error->code == 10);
|
fail_unless (error->code == 10);
|
||||||
fail_unless (strcmp (debug, "error string") == 0);
|
fail_unless (strcmp (debug, "error string") == 0);
|
||||||
|
|
||||||
gst_message_unref (message);
|
gst_message_unref (message);
|
||||||
|
g_error_free (error);
|
||||||
|
g_free (debug);
|
||||||
}
|
}
|
||||||
/* GST_MESSAGE_WARNING */
|
/* GST_MESSAGE_WARNING */
|
||||||
{
|
{
|
||||||
|
@ -71,8 +77,11 @@ GST_START_TEST (test_parsing)
|
||||||
fail_if (message == NULL);
|
fail_if (message == NULL);
|
||||||
fail_unless (GST_MESSAGE_TYPE (message) == GST_MESSAGE_WARNING);
|
fail_unless (GST_MESSAGE_TYPE (message) == GST_MESSAGE_WARNING);
|
||||||
fail_unless (GST_MESSAGE_SRC (message) == NULL);
|
fail_unless (GST_MESSAGE_SRC (message) == NULL);
|
||||||
|
|
||||||
|
g_error_free (warning);
|
||||||
warning = NULL;
|
warning = NULL;
|
||||||
debug = NULL;
|
debug = NULL;
|
||||||
|
|
||||||
gst_message_parse_warning (message, &warning, &debug);
|
gst_message_parse_warning (message, &warning, &debug);
|
||||||
fail_if (warning == NULL);
|
fail_if (warning == NULL);
|
||||||
fail_if (debug == NULL);
|
fail_if (debug == NULL);
|
||||||
|
@ -80,7 +89,10 @@ GST_START_TEST (test_parsing)
|
||||||
fail_unless (warning->domain == domain);
|
fail_unless (warning->domain == domain);
|
||||||
fail_unless (warning->code == 10);
|
fail_unless (warning->code == 10);
|
||||||
fail_unless (strcmp (debug, "warning string") == 0);
|
fail_unless (strcmp (debug, "warning string") == 0);
|
||||||
|
|
||||||
gst_message_unref (message);
|
gst_message_unref (message);
|
||||||
|
g_error_free (warning);
|
||||||
|
g_free (debug);
|
||||||
}
|
}
|
||||||
/* GST_MESSAGE_INFO */
|
/* GST_MESSAGE_INFO */
|
||||||
{
|
{
|
||||||
|
@ -101,6 +113,7 @@ GST_START_TEST (test_parsing)
|
||||||
fail_if (tag == NULL);
|
fail_if (tag == NULL);
|
||||||
/* FIXME, check the actual tags */
|
/* FIXME, check the actual tags */
|
||||||
gst_message_unref (message);
|
gst_message_unref (message);
|
||||||
|
gst_tag_list_free (tag);
|
||||||
}
|
}
|
||||||
/* GST_MESSAGE_BUFFERING */
|
/* GST_MESSAGE_BUFFERING */
|
||||||
{
|
{
|
||||||
|
|
|
@ -79,12 +79,43 @@ gst_value_suite (void)
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GST_START_TEST (test_structure_new)
|
||||||
|
{
|
||||||
|
GstStructure *s;
|
||||||
|
GError *e;
|
||||||
|
GQuark domain;
|
||||||
|
|
||||||
|
s = gst_structure_new ("name", "key", G_TYPE_STRING, "value", NULL);
|
||||||
|
fail_unless (strcmp (gst_structure_get_string (s, "key"), "value") == 0);
|
||||||
|
gst_structure_free (s);
|
||||||
|
|
||||||
|
domain = g_quark_from_string ("test");
|
||||||
|
e = g_error_new (domain, 0, "a test error");
|
||||||
|
s = gst_structure_new ("name", "key", GST_TYPE_G_ERROR, e, NULL);
|
||||||
|
g_error_free (e);
|
||||||
|
gst_structure_free (s);
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_END_TEST;
|
||||||
|
|
||||||
|
Suite *
|
||||||
|
gst_structure_suite (void)
|
||||||
|
{
|
||||||
|
Suite *s = suite_create ("GstStructure");
|
||||||
|
TCase *tc_chain = tcase_create ("general");
|
||||||
|
|
||||||
|
suite_add_tcase (s, tc_chain);
|
||||||
|
tcase_add_test (tc_chain, test_from_string_int);
|
||||||
|
tcase_add_test (tc_chain, test_structure_new);
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char **argv)
|
main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
int nf;
|
int nf;
|
||||||
|
|
||||||
Suite *s = gst_value_suite ();
|
Suite *s = gst_structure_suite ();
|
||||||
SRunner *sr = srunner_create (s);
|
SRunner *sr = srunner_create (s);
|
||||||
|
|
||||||
gst_check_init (&argc, &argv);
|
gst_check_init (&argc, &argv);
|
||||||
|
|
|
@ -1356,9 +1356,11 @@ void gst_element_message_full
|
||||||
|
|
||||||
if (type == GST_MESSAGE_ERROR) {
|
if (type == GST_MESSAGE_ERROR) {
|
||||||
message = gst_message_new_error (GST_OBJECT (element), gerror, sent_debug);
|
message = gst_message_new_error (GST_OBJECT (element), gerror, sent_debug);
|
||||||
} else {
|
} else if (type == GST_MESSAGE_WARNING) {
|
||||||
message = gst_message_new_warning (GST_OBJECT (element), gerror,
|
message = gst_message_new_warning (GST_OBJECT (element), gerror,
|
||||||
sent_debug);
|
sent_debug);
|
||||||
|
} else {
|
||||||
|
g_assert_not_reached ();
|
||||||
}
|
}
|
||||||
gst_element_post_message (element, message);
|
gst_element_post_message (element, message);
|
||||||
|
|
||||||
|
@ -1366,8 +1368,9 @@ void gst_element_message_full
|
||||||
sent_text);
|
sent_text);
|
||||||
|
|
||||||
/* cleanup */
|
/* cleanup */
|
||||||
|
g_error_free (gerror);
|
||||||
|
g_free (sent_debug);
|
||||||
g_free (sent_text);
|
g_free (sent_text);
|
||||||
/* sent_debug is not part of the gerror, so don't free it here */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#include <string.h> /* memcpy */
|
#include <string.h> /* memcpy */
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
#include "gsterror.h"
|
||||||
#include "gstinfo.h"
|
#include "gstinfo.h"
|
||||||
#include "gstmemchunk.h"
|
#include "gstmemchunk.h"
|
||||||
#include "gstmessage.h"
|
#include "gstmessage.h"
|
||||||
|
@ -206,7 +207,7 @@ gst_message_new_eos (GstObject * src)
|
||||||
* @error: The GError for this message.
|
* @error: The GError for this message.
|
||||||
* @debug: A debugging string for something or other.
|
* @debug: A debugging string for something or other.
|
||||||
*
|
*
|
||||||
* Create a new error message. The message will take ownership of @error and
|
* Create a new error message. The message will copy @error and
|
||||||
* @debug.
|
* @debug.
|
||||||
*
|
*
|
||||||
* Returns: The new error message.
|
* Returns: The new error message.
|
||||||
|
@ -220,7 +221,8 @@ gst_message_new_error (GstObject * src, GError * error, gchar * debug)
|
||||||
GstStructure *s;
|
GstStructure *s;
|
||||||
|
|
||||||
message = gst_message_new (GST_MESSAGE_ERROR, src);
|
message = gst_message_new (GST_MESSAGE_ERROR, src);
|
||||||
s = gst_structure_new ("GstMessageError", "gerror", G_TYPE_POINTER, error,
|
/* gst_structure_new takes copies of the types passed in */
|
||||||
|
s = gst_structure_new ("GstMessageError", "gerror", GST_TYPE_G_ERROR, error,
|
||||||
"debug", G_TYPE_STRING, debug, NULL);
|
"debug", G_TYPE_STRING, debug, NULL);
|
||||||
gst_structure_set_parent_refcount (s, &message->mini_object.refcount);
|
gst_structure_set_parent_refcount (s, &message->mini_object.refcount);
|
||||||
message->structure = s;
|
message->structure = s;
|
||||||
|
@ -234,7 +236,7 @@ gst_message_new_error (GstObject * src, GError * error, gchar * debug)
|
||||||
* @error: The GError for this message.
|
* @error: The GError for this message.
|
||||||
* @debug: A debugging string for something or other.
|
* @debug: A debugging string for something or other.
|
||||||
*
|
*
|
||||||
* Create a new warning message. The message will take ownership of @error and
|
* Create a new warning message. The message will make copies of @error and
|
||||||
* @debug.
|
* @debug.
|
||||||
*
|
*
|
||||||
* Returns: The new warning message.
|
* Returns: The new warning message.
|
||||||
|
@ -248,7 +250,8 @@ gst_message_new_warning (GstObject * src, GError * error, gchar * debug)
|
||||||
GstStructure *s;
|
GstStructure *s;
|
||||||
|
|
||||||
message = gst_message_new (GST_MESSAGE_WARNING, src);
|
message = gst_message_new (GST_MESSAGE_WARNING, src);
|
||||||
s = gst_structure_new ("GstMessageWarning", "gerror", G_TYPE_POINTER, error,
|
/* gst_structure_new takes copies of the types passed in */
|
||||||
|
s = gst_structure_new ("GstMessageWarning", "gerror", GST_TYPE_G_ERROR, error,
|
||||||
"debug", G_TYPE_STRING, debug, NULL);
|
"debug", G_TYPE_STRING, debug, NULL);
|
||||||
gst_structure_set_parent_refcount (s, &message->mini_object.refcount);
|
gst_structure_set_parent_refcount (s, &message->mini_object.refcount);
|
||||||
message->structure = s;
|
message->structure = s;
|
||||||
|
@ -416,9 +419,9 @@ gst_message_parse_error (GstMessage * message, GError ** gerror, gchar ** debug)
|
||||||
|
|
||||||
error_gvalue = gst_structure_get_value (message->structure, "gerror");
|
error_gvalue = gst_structure_get_value (message->structure, "gerror");
|
||||||
g_return_if_fail (error_gvalue != NULL);
|
g_return_if_fail (error_gvalue != NULL);
|
||||||
g_return_if_fail (G_VALUE_TYPE (error_gvalue) == G_TYPE_POINTER);
|
g_return_if_fail (G_VALUE_TYPE (error_gvalue) == GST_TYPE_G_ERROR);
|
||||||
|
|
||||||
error_val = g_value_get_pointer (error_gvalue);
|
error_val = (GError *) g_value_get_boxed (error_gvalue);
|
||||||
if (error_val)
|
if (error_val)
|
||||||
*gerror = g_error_copy (error_val);
|
*gerror = g_error_copy (error_val);
|
||||||
else
|
else
|
||||||
|
@ -447,9 +450,9 @@ gst_message_parse_warning (GstMessage * message, GError ** gerror,
|
||||||
|
|
||||||
error_gvalue = gst_structure_get_value (message->structure, "gerror");
|
error_gvalue = gst_structure_get_value (message->structure, "gerror");
|
||||||
g_return_if_fail (error_gvalue != NULL);
|
g_return_if_fail (error_gvalue != NULL);
|
||||||
g_return_if_fail (G_VALUE_TYPE (error_gvalue) == G_TYPE_POINTER);
|
g_return_if_fail (G_VALUE_TYPE (error_gvalue) == GST_TYPE_G_ERROR);
|
||||||
|
|
||||||
error_val = g_value_get_pointer (error_gvalue);
|
error_val = (GError *) g_value_get_boxed (error_gvalue);
|
||||||
if (error_val)
|
if (error_val)
|
||||||
*gerror = g_error_copy (error_val);
|
*gerror = g_error_copy (error_val);
|
||||||
else
|
else
|
||||||
|
|
|
@ -78,6 +78,21 @@ GST_START_TEST (test_add_pad_unref_element)
|
||||||
|
|
||||||
GST_END_TEST;
|
GST_END_TEST;
|
||||||
|
|
||||||
|
GST_START_TEST (test_error_no_bus)
|
||||||
|
{
|
||||||
|
GstElement *e;
|
||||||
|
|
||||||
|
e = gst_element_factory_make ("fakesrc", "source");
|
||||||
|
|
||||||
|
/* I don't want errors shown */
|
||||||
|
gst_debug_set_default_threshold (GST_LEVEL_NONE);
|
||||||
|
|
||||||
|
GST_ELEMENT_ERROR (e, RESOURCE, OPEN_READ, ("I could not read"), ("debug"));
|
||||||
|
|
||||||
|
gst_object_unref (e);
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_END_TEST;
|
||||||
|
|
||||||
Suite *
|
Suite *
|
||||||
gst_element_suite (void)
|
gst_element_suite (void)
|
||||||
|
@ -88,6 +103,7 @@ gst_element_suite (void)
|
||||||
suite_add_tcase (s, tc_chain);
|
suite_add_tcase (s, tc_chain);
|
||||||
tcase_add_test (tc_chain, test_add_remove_pad);
|
tcase_add_test (tc_chain, test_add_remove_pad);
|
||||||
tcase_add_test (tc_chain, test_add_pad_unref_element);
|
tcase_add_test (tc_chain, test_add_pad_unref_element);
|
||||||
|
tcase_add_test (tc_chain, test_error_no_bus);
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,8 +49,11 @@ GST_START_TEST (test_parsing)
|
||||||
fail_if (message == NULL);
|
fail_if (message == NULL);
|
||||||
fail_unless (GST_MESSAGE_TYPE (message) == GST_MESSAGE_ERROR);
|
fail_unless (GST_MESSAGE_TYPE (message) == GST_MESSAGE_ERROR);
|
||||||
fail_unless (GST_MESSAGE_SRC (message) == NULL);
|
fail_unless (GST_MESSAGE_SRC (message) == NULL);
|
||||||
|
|
||||||
|
g_error_free (error);
|
||||||
error = NULL;
|
error = NULL;
|
||||||
debug = NULL;
|
debug = NULL;
|
||||||
|
|
||||||
gst_message_parse_error (message, &error, &debug);
|
gst_message_parse_error (message, &error, &debug);
|
||||||
fail_if (error == NULL);
|
fail_if (error == NULL);
|
||||||
fail_if (debug == NULL);
|
fail_if (debug == NULL);
|
||||||
|
@ -58,7 +61,10 @@ GST_START_TEST (test_parsing)
|
||||||
fail_unless (error->domain == domain);
|
fail_unless (error->domain == domain);
|
||||||
fail_unless (error->code == 10);
|
fail_unless (error->code == 10);
|
||||||
fail_unless (strcmp (debug, "error string") == 0);
|
fail_unless (strcmp (debug, "error string") == 0);
|
||||||
|
|
||||||
gst_message_unref (message);
|
gst_message_unref (message);
|
||||||
|
g_error_free (error);
|
||||||
|
g_free (debug);
|
||||||
}
|
}
|
||||||
/* GST_MESSAGE_WARNING */
|
/* GST_MESSAGE_WARNING */
|
||||||
{
|
{
|
||||||
|
@ -71,8 +77,11 @@ GST_START_TEST (test_parsing)
|
||||||
fail_if (message == NULL);
|
fail_if (message == NULL);
|
||||||
fail_unless (GST_MESSAGE_TYPE (message) == GST_MESSAGE_WARNING);
|
fail_unless (GST_MESSAGE_TYPE (message) == GST_MESSAGE_WARNING);
|
||||||
fail_unless (GST_MESSAGE_SRC (message) == NULL);
|
fail_unless (GST_MESSAGE_SRC (message) == NULL);
|
||||||
|
|
||||||
|
g_error_free (warning);
|
||||||
warning = NULL;
|
warning = NULL;
|
||||||
debug = NULL;
|
debug = NULL;
|
||||||
|
|
||||||
gst_message_parse_warning (message, &warning, &debug);
|
gst_message_parse_warning (message, &warning, &debug);
|
||||||
fail_if (warning == NULL);
|
fail_if (warning == NULL);
|
||||||
fail_if (debug == NULL);
|
fail_if (debug == NULL);
|
||||||
|
@ -80,7 +89,10 @@ GST_START_TEST (test_parsing)
|
||||||
fail_unless (warning->domain == domain);
|
fail_unless (warning->domain == domain);
|
||||||
fail_unless (warning->code == 10);
|
fail_unless (warning->code == 10);
|
||||||
fail_unless (strcmp (debug, "warning string") == 0);
|
fail_unless (strcmp (debug, "warning string") == 0);
|
||||||
|
|
||||||
gst_message_unref (message);
|
gst_message_unref (message);
|
||||||
|
g_error_free (warning);
|
||||||
|
g_free (debug);
|
||||||
}
|
}
|
||||||
/* GST_MESSAGE_INFO */
|
/* GST_MESSAGE_INFO */
|
||||||
{
|
{
|
||||||
|
@ -101,6 +113,7 @@ GST_START_TEST (test_parsing)
|
||||||
fail_if (tag == NULL);
|
fail_if (tag == NULL);
|
||||||
/* FIXME, check the actual tags */
|
/* FIXME, check the actual tags */
|
||||||
gst_message_unref (message);
|
gst_message_unref (message);
|
||||||
|
gst_tag_list_free (tag);
|
||||||
}
|
}
|
||||||
/* GST_MESSAGE_BUFFERING */
|
/* GST_MESSAGE_BUFFERING */
|
||||||
{
|
{
|
||||||
|
|
|
@ -79,12 +79,43 @@ gst_value_suite (void)
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GST_START_TEST (test_structure_new)
|
||||||
|
{
|
||||||
|
GstStructure *s;
|
||||||
|
GError *e;
|
||||||
|
GQuark domain;
|
||||||
|
|
||||||
|
s = gst_structure_new ("name", "key", G_TYPE_STRING, "value", NULL);
|
||||||
|
fail_unless (strcmp (gst_structure_get_string (s, "key"), "value") == 0);
|
||||||
|
gst_structure_free (s);
|
||||||
|
|
||||||
|
domain = g_quark_from_string ("test");
|
||||||
|
e = g_error_new (domain, 0, "a test error");
|
||||||
|
s = gst_structure_new ("name", "key", GST_TYPE_G_ERROR, e, NULL);
|
||||||
|
g_error_free (e);
|
||||||
|
gst_structure_free (s);
|
||||||
|
}
|
||||||
|
|
||||||
|
GST_END_TEST;
|
||||||
|
|
||||||
|
Suite *
|
||||||
|
gst_structure_suite (void)
|
||||||
|
{
|
||||||
|
Suite *s = suite_create ("GstStructure");
|
||||||
|
TCase *tc_chain = tcase_create ("general");
|
||||||
|
|
||||||
|
suite_add_tcase (s, tc_chain);
|
||||||
|
tcase_add_test (tc_chain, test_from_string_int);
|
||||||
|
tcase_add_test (tc_chain, test_structure_new);
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char **argv)
|
main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
int nf;
|
int nf;
|
||||||
|
|
||||||
Suite *s = gst_value_suite ();
|
Suite *s = gst_structure_suite ();
|
||||||
SRunner *sr = srunner_create (s);
|
SRunner *sr = srunner_create (s);
|
||||||
|
|
||||||
gst_check_init (&argc, &argv);
|
gst_check_init (&argc, &argv);
|
||||||
|
|
Loading…
Reference in a new issue