gst/: put reverted patch back in

Original commit message from CVS:
2004-02-06  Benjamin Otte  <in7y118@public.uni-hamburg.de>

* gst/gstcaps.h:
* gst/gstelement.c: (gst_element_base_class_init),
(gst_element_class_set_details), (gst_element_clear_pad_caps):
* gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
(gst_pad_try_set_caps), (gst_pad_can_link_filtered),
(gst_real_pad_dispose):
* gst/gststructure.c: (gst_structure_free),
(gst_structure_from_string):
put reverted patch back in
* gst/gstelement.c: (gst_element_remove_pad):
free explicit caps if they're set
* gst/gstpad.c: (_gst_pad_default_fixate_func):
copy the structure when fixating
This commit is contained in:
Benjamin Otte 2004-02-05 23:46:13 +00:00
parent 86986ec51c
commit f3c9c3493d
5 changed files with 68 additions and 40 deletions

View file

@ -1,3 +1,19 @@
2004-02-06 Benjamin Otte <in7y118@public.uni-hamburg.de>
* gst/gstcaps.h:
* gst/gstelement.c: (gst_element_base_class_init),
(gst_element_class_set_details), (gst_element_clear_pad_caps):
* gst/gstpad.c: (gst_pad_link_intersect), (gst_pad_link_fixate),
(gst_pad_try_set_caps), (gst_pad_can_link_filtered),
(gst_real_pad_dispose):
* gst/gststructure.c: (gst_structure_free),
(gst_structure_from_string):
put reverted patch back in
* gst/gstelement.c: (gst_element_remove_pad):
free explicit caps if they're set
* gst/gstpad.c: (_gst_pad_default_fixate_func):
copy the structure when fixating
2004-02-05 David Schleef <ds@schleef.org> 2004-02-05 David Schleef <ds@schleef.org>
* gst/gstmarshal.list: * gst/gstmarshal.list:

View file

@ -58,12 +58,10 @@ struct _GstStaticCaps {
#define GST_TYPE_CAPS gst_caps_get_type() #define GST_TYPE_CAPS gst_caps_get_type()
/* FIXME Company should decide the best way to do this */ #ifndef GST_DISABLE_DEPRECATED
#define GST_DEBUG_CAPS(string, caps) do { \ #define GST_DEBUG_CAPS(string, caps) \
char *s = gst_caps_to_string(caps); \ GST_DEBUG ( string "%s: " GST_PTR_FORMAT, caps)
GST_DEBUG ( "%s: %s", (string), s); \ #endif
g_free(s); \
}while(0)
void _gst_caps_initialize (void); void _gst_caps_initialize (void);

View file

@ -53,7 +53,7 @@ enum {
}; };
extern void __gst_element_details_clear (GstElementDetails *dp); extern void __gst_element_details_clear (GstElementDetails *dp);
extern void __gst_element_details_set (GstElementDetails *dest, extern void __gst_element_details_copy (GstElementDetails *dest,
const GstElementDetails *src); const GstElementDetails *src);
static void gst_element_class_init (GstElementClass *klass); static void gst_element_class_init (GstElementClass *klass);
@ -172,6 +172,7 @@ gst_element_base_class_init (gpointer g_class)
gobject_class->set_property = GST_DEBUG_FUNCPTR(gst_element_real_set_property); gobject_class->set_property = GST_DEBUG_FUNCPTR(gst_element_real_set_property);
gobject_class->get_property = GST_DEBUG_FUNCPTR(gst_element_real_get_property); gobject_class->get_property = GST_DEBUG_FUNCPTR(gst_element_real_get_property);
memset (&element_class->details, 0, sizeof (GstElementDetails));
element_class->padtemplates = NULL; element_class->padtemplates = NULL;
} }
@ -1144,8 +1145,12 @@ gst_element_remove_pad (GstElement *element, GstPad *pad)
if (GST_RPAD_PEER (pad) != NULL) { if (GST_RPAD_PEER (pad) != NULL) {
gst_pad_unlink (pad, GST_PAD (GST_RPAD_PEER (pad))); gst_pad_unlink (pad, GST_PAD (GST_RPAD_PEER (pad)));
} }
<<<<<<< gstelement.c
gst_caps_replace (&GST_RPAD_EXPLICIT_CAPS (pad), NULL);
=======
} else if (GST_IS_GHOST_PAD (pad)) { } else if (GST_IS_GHOST_PAD (pad)) {
g_object_set (pad, "real-pad", NULL, NULL); g_object_set (pad, "real-pad", NULL, NULL);
>>>>>>> 1.250
} }
/* remove it from the list */ /* remove it from the list */
@ -1379,7 +1384,7 @@ gst_element_class_set_details (GstElementClass *klass, const GstElementDetails *
g_return_if_fail (GST_IS_ELEMENT_CLASS (klass)); g_return_if_fail (GST_IS_ELEMENT_CLASS (klass));
g_return_if_fail (GST_IS_ELEMENT_DETAILS (details)); g_return_if_fail (GST_IS_ELEMENT_DETAILS (details));
__gst_element_details_set (&klass->details, details); __gst_element_details_copy (&klass->details, details);
} }
/** /**
@ -2753,6 +2758,9 @@ gst_element_clear_pad_caps (GstElement *element)
GstPad *pad = GST_PAD (pads->data); GstPad *pad = GST_PAD (pads->data);
gst_pad_unnegotiate (pad); gst_pad_unnegotiate (pad);
if (GST_IS_REAL_PAD (pad)){
gst_caps_replace (&GST_RPAD_EXPLICIT_CAPS (pad), NULL);
}
pads = g_list_next (pads); pads = g_list_next (pads);
} }

View file

@ -35,9 +35,6 @@
#define GST_CAT_DEFAULT GST_CAT_PADS #define GST_CAT_DEFAULT GST_CAT_PADS
/* FIXME */
#define gst_caps_debug(a,b) GST_DEBUG_CAPS(b,a)
enum { enum {
TEMPL_PAD_CREATED, TEMPL_PAD_CREATED,
@ -1049,21 +1046,21 @@ static void gst_pad_link_intersect (GstPadLink *link)
GST_DEBUG ("intersecting link from %s:%s to %s:%s", GST_DEBUG ("intersecting link from %s:%s to %s:%s",
GST_DEBUG_PAD_NAME (link->srcpad), GST_DEBUG_PAD_NAME (link->sinkpad)); GST_DEBUG_PAD_NAME (link->srcpad), GST_DEBUG_PAD_NAME (link->sinkpad));
GST_DEBUG_CAPS ("srccaps", link->srccaps); GST_DEBUG ("srccaps " GST_PTR_FORMAT, link->srccaps);
GST_DEBUG_CAPS ("sinkcaps", link->sinkcaps); GST_DEBUG ("sinkcaps " GST_PTR_FORMAT, link->sinkcaps);
GST_DEBUG_CAPS ("filtercaps", link->filtercaps); GST_DEBUG ("filtercaps " GST_PTR_FORMAT, link->filtercaps);
pad_intersection = gst_caps_intersect (link->srccaps, link->sinkcaps); pad_intersection = gst_caps_intersect (link->srccaps, link->sinkcaps);
if (link->filtercaps) { if (link->filtercaps) {
GST_DEBUG_CAPS ("unfiltered intersection", pad_intersection); GST_DEBUG ("unfiltered intersection " GST_PTR_FORMAT, pad_intersection);
link->caps = gst_caps_intersect (pad_intersection, link->filtercaps); link->caps = gst_caps_intersect (pad_intersection, link->filtercaps);
gst_caps_free (pad_intersection); gst_caps_free (pad_intersection);
} else { } else {
link->caps = pad_intersection; link->caps = pad_intersection;
} }
GST_DEBUG_CAPS ("intersection", link->caps); GST_DEBUG ("intersection " GST_PTR_FORMAT, link->caps);
} }
static gboolean static gboolean
@ -1098,7 +1095,7 @@ gst_pad_link_fixate (GstPadLink *link)
g_return_if_fail (caps != NULL); g_return_if_fail (caps != NULL);
g_return_if_fail (!gst_caps_is_empty(caps)); g_return_if_fail (!gst_caps_is_empty(caps));
GST_DEBUG_CAPS ("trying to fixate caps", caps); GST_DEBUG ("trying to fixate caps " GST_PTR_FORMAT, caps);
while (!gst_caps_is_fixed (caps)) { while (!gst_caps_is_fixed (caps)) {
int i; int i;
@ -1109,31 +1106,31 @@ gst_pad_link_fixate (GstPadLink *link)
case 0: case 0:
g_signal_emit (G_OBJECT (link->srcpad), g_signal_emit (G_OBJECT (link->srcpad),
gst_real_pad_signals[REAL_FIXATE], 0, caps, &newcaps); gst_real_pad_signals[REAL_FIXATE], 0, caps, &newcaps);
GST_DEBUG_CAPS ("app srcpad signal fixated to", newcaps); GST_DEBUG ("app srcpad signal fixated to " GST_PTR_FORMAT, newcaps);
break; break;
case 1: case 1:
g_signal_emit (G_OBJECT (link->sinkpad), g_signal_emit (G_OBJECT (link->sinkpad),
gst_real_pad_signals[REAL_FIXATE], 0, caps, &newcaps); gst_real_pad_signals[REAL_FIXATE], 0, caps, &newcaps);
GST_DEBUG_CAPS ("app sinkpad signal fixated to", newcaps); GST_DEBUG ("app sinkpad signal fixated to " GST_PTR_FORMAT, newcaps);
break; break;
case 2: case 2:
if (GST_RPAD_FIXATEFUNC(link->srcpad)) { if (GST_RPAD_FIXATEFUNC(link->srcpad)) {
newcaps = GST_RPAD_FIXATEFUNC(link->srcpad) ( newcaps = GST_RPAD_FIXATEFUNC(link->srcpad) (
GST_PAD (link->srcpad), caps); GST_PAD (link->srcpad), caps);
GST_DEBUG_CAPS ("srcpad fixated to", newcaps); GST_DEBUG ("srcpad fixated to " GST_PTR_FORMAT, newcaps);
} }
break; break;
case 3: case 3:
if (GST_RPAD_FIXATEFUNC(link->sinkpad)) { if (GST_RPAD_FIXATEFUNC(link->sinkpad)) {
newcaps = GST_RPAD_FIXATEFUNC(link->sinkpad) ( newcaps = GST_RPAD_FIXATEFUNC(link->sinkpad) (
GST_PAD (link->sinkpad), caps); GST_PAD (link->sinkpad), caps);
GST_DEBUG_CAPS ("sinkpad fixated to", newcaps); GST_DEBUG ("sinkpad fixated to " GST_PTR_FORMAT, newcaps);
} }
break; break;
case 4: case 4:
newcaps = _gst_pad_default_fixate_func ( newcaps = _gst_pad_default_fixate_func (
GST_PAD(link->srcpad), caps); GST_PAD(link->srcpad), caps);
GST_DEBUG_CAPS ("core fixated to", newcaps); GST_DEBUG ("core fixated to GST_PTR_FORMAT", newcaps);
break; break;
} }
if (newcaps) { if (newcaps) {
@ -1335,7 +1332,7 @@ gst_pad_try_set_caps (GstPad *pad, const GstCaps *caps)
g_warning ("trying to set non fixed caps on pad %s:%s, not allowed", g_warning ("trying to set non fixed caps on pad %s:%s, not allowed",
GST_DEBUG_PAD_NAME (pad)); GST_DEBUG_PAD_NAME (pad));
gst_caps_debug (caps, "unfixed caps"); GST_DEBUG ("unfixed caps " GST_PTR_FORMAT, caps);
return GST_PAD_LINK_REFUSED; return GST_PAD_LINK_REFUSED;
} }
@ -1542,9 +1539,12 @@ gst_pad_can_link_filtered (GstPad *srcpad, GstPad *sinkpad,
if (filtercaps) link->filtercaps = gst_caps_copy (filtercaps); if (filtercaps) link->filtercaps = gst_caps_copy (filtercaps);
gst_pad_link_intersect (link); gst_pad_link_intersect (link);
if (gst_caps_is_empty (link->caps)) if (gst_caps_is_empty (link->caps)) {
gst_pad_link_free (link);
return FALSE; return FALSE;
}
gst_pad_link_free (link);
return TRUE; return TRUE;
} }
@ -1938,7 +1938,7 @@ _gst_pad_default_fixate_func (GstPad *pad, const GstCaps *caps)
} }
if (caps->structs->len > 1) { if (caps->structs->len > 1) {
return gst_caps_new_full (gst_caps_get_structure (caps, 0), NULL); return gst_caps_new_full (gst_structure_copy (gst_caps_get_structure (caps, 0)), NULL);
} }
newcaps = gst_caps_copy (caps); newcaps = gst_caps_copy (caps);
@ -2736,6 +2736,11 @@ gst_real_pad_dispose (GObject *object)
gst_element_remove_pad (GST_ELEMENT (GST_OBJECT_PARENT (pad)), pad); gst_element_remove_pad (GST_ELEMENT (GST_OBJECT_PARENT (pad)), pad);
} }
if (GST_RPAD_EXPLICIT_CAPS (pad)) {
GST_ERROR_OBJECT (pad, "still explicit caps %"GST_PTR_FORMAT" set", GST_RPAD_EXPLICIT_CAPS (pad));
g_warning ("pad %p has still explicit caps set", pad);
gst_caps_replace (&GST_RPAD_EXPLICIT_CAPS (pad), NULL);
}
G_OBJECT_CLASS (real_pad_parent_class)->dispose (object); G_OBJECT_CLASS (real_pad_parent_class)->dispose (object);
} }

View file

@ -237,8 +237,6 @@ void gst_structure_free(GstStructure *structure)
GstStructureField *field; GstStructureField *field;
int i; int i;
return;
g_return_if_fail(structure != NULL); g_return_if_fail(structure != NULL);
for(i=0;i<structure->fields->len;i++){ for(i=0;i<structure->fields->len;i++){
@ -1337,9 +1335,8 @@ gst_structure_from_string (const gchar *string, gchar **end)
char *w; char *w;
char *r; char *r;
char save; char save;
GstStructure *structure; GstStructure *structure = NULL;
GstStructureField field = { 0 }; GstStructureField field = { 0 };
gboolean res;
g_return_val_if_fail(string != NULL, NULL); g_return_val_if_fail(string != NULL, NULL);
@ -1347,11 +1344,11 @@ gst_structure_from_string (const gchar *string, gchar **end)
r = copy; r = copy;
name = r; name = r;
res = _gst_structure_parse_string (r, &w, &r); if (!_gst_structure_parse_string (r, &w, &r))
if (!res) return NULL; goto error;
while (g_ascii_isspace(*r)) r++; while (g_ascii_isspace(*r)) r++;
if(*r != 0 && *r != ';' && *r != ',') return NULL; if(*r != 0 && *r != ';' && *r != ',') goto error;
save = *w; save = *w;
*w = 0; *w = 0;
@ -1359,24 +1356,28 @@ gst_structure_from_string (const gchar *string, gchar **end)
*w = save; *w = save;
while (*r && (*r != ';')){ while (*r && (*r != ';')){
if(*r != ',') { if(*r != ',')
return NULL; goto error;
}
r++; r++;
while (*r && g_ascii_isspace(*r)) r++; while (*r && g_ascii_isspace(*r)) r++;
memset(&field,0,sizeof(field)); memset(&field,0,sizeof(field));
res = _gst_structure_parse_field (r, &r, &field); if (!_gst_structure_parse_field (r, &r, &field))
if (!res) { goto error;
gst_structure_free (structure);
return NULL;
}
gst_structure_set_field(structure, &field); gst_structure_set_field(structure, &field);
while (*r && g_ascii_isspace(*r)) r++; while (*r && g_ascii_isspace(*r)) r++;
} }
if (end) *end = (char *)string + (r - copy); if (end) *end = (char *)string + (r - copy);
g_free (copy);
return structure; return structure;
error:
if (structure)
gst_structure_free (structure);
g_free (copy);
return NULL;
} }
static void static void