ext/pango/gsttextoverlay.*: If input is plain text, escape it before passing it to pango_layout_set_markup().

Original commit message from CVS:
* ext/pango/gsttextoverlay.c: (gst_text_overlay_init),
(gst_text_overlay_setcaps_txt), (gst_text_overlay_video_chain):
* ext/pango/gsttextoverlay.h:
If input is plain text, escape it before passing it to
pango_layout_set_markup().
This commit is contained in:
Tim-Philipp Müller 2006-03-07 15:08:15 +00:00
parent ab6f99ab60
commit b80668c623
3 changed files with 41 additions and 2 deletions

View file

@ -1,3 +1,11 @@
2006-03-07 Tim-Philipp Müller <tim at centricular dot net>
* ext/pango/gsttextoverlay.c: (gst_text_overlay_init),
(gst_text_overlay_setcaps_txt), (gst_text_overlay_video_chain):
* ext/pango/gsttextoverlay.h:
If input is plain text, escape it before passing it to
pango_layout_set_markup().
2006-03-07 Tim-Philipp Müller <tim at centricular dot net> 2006-03-07 Tim-Philipp Müller <tim at centricular dot net>
* gst-libs/gst/audio/gstaudiofilter.c: (gst_audio_filter_chain): * gst-libs/gst/audio/gstaudiofilter.c: (gst_audio_filter_chain):

View file

@ -234,6 +234,7 @@ static GstStateChangeReturn gst_text_overlay_change_state (GstElement * element,
static GstCaps *gst_text_overlay_getcaps (GstPad * pad); static GstCaps *gst_text_overlay_getcaps (GstPad * pad);
static gboolean gst_text_overlay_setcaps (GstPad * pad, GstCaps * caps); static gboolean gst_text_overlay_setcaps (GstPad * pad, GstCaps * caps);
static gboolean gst_text_overlay_setcaps_txt (GstPad * pad, GstCaps * caps);
static gboolean gst_text_overlay_src_event (GstPad * pad, GstEvent * event); static gboolean gst_text_overlay_src_event (GstPad * pad, GstEvent * event);
static gboolean gst_text_overlay_video_event (GstPad * pad, GstEvent * event); static gboolean gst_text_overlay_video_event (GstPad * pad, GstEvent * event);
@ -397,6 +398,8 @@ gst_text_overlay_init (GstTextOverlay * overlay, GstTextOverlayClass * klass)
overlay->text_sinkpad = overlay->text_sinkpad =
gst_pad_new_from_template (gst_static_pad_template_get gst_pad_new_from_template (gst_static_pad_template_get
(&text_sink_template_factory), "text_sink"); (&text_sink_template_factory), "text_sink");
gst_pad_set_setcaps_function (overlay->text_sinkpad,
GST_DEBUG_FUNCPTR (gst_text_overlay_setcaps_txt));
gst_pad_set_event_function (overlay->text_sinkpad, gst_pad_set_event_function (overlay->text_sinkpad,
GST_DEBUG_FUNCPTR (gst_text_overlay_text_event)); GST_DEBUG_FUNCPTR (gst_text_overlay_text_event));
gst_pad_set_chain_function (overlay->text_sinkpad, gst_pad_set_chain_function (overlay->text_sinkpad,
@ -468,6 +471,23 @@ gst_text_overlay_update_wrap_mode (GstTextOverlay * overlay)
} }
} }
static gboolean
gst_text_overlay_setcaps_txt (GstPad * pad, GstCaps * caps)
{
GstTextOverlay *overlay;
GstStructure *structure;
overlay = GST_TEXT_OVERLAY (gst_pad_get_parent (pad));
structure = gst_caps_get_structure (caps, 0);
overlay->have_pango_markup =
gst_structure_has_name (structure, "text/x-pango-markup");
gst_object_unref (overlay);
return TRUE;
}
/* FIXME: upstream nego (e.g. when the video window is resized) */ /* FIXME: upstream nego (e.g. when the video window is resized) */
static gboolean static gboolean
@ -1256,9 +1276,18 @@ gst_text_overlay_video_chain (GstPad * pad, GstBuffer * buffer)
/* Push the video frame */ /* Push the video frame */
ret = gst_pad_push (overlay->srcpad, buffer); ret = gst_pad_push (overlay->srcpad, buffer);
} else { } else {
const gchar *in_text;
gsize in_size;
in_text = (const gchar *) GST_BUFFER_DATA (overlay->text_buffer);
in_size = GST_BUFFER_SIZE (overlay->text_buffer);
/* Get the string */ /* Get the string */
text = g_strndup ((gchar *) GST_BUFFER_DATA (overlay->text_buffer), if (overlay->have_pango_markup) {
GST_BUFFER_SIZE (overlay->text_buffer)); text = g_strndup (in_text, in_size);
} else {
text = g_markup_escape_text (in_text, in_size);
}
if (text != NULL && *text != '\0') { if (text != NULL && *text != '\0') {
gint text_len = strlen (text); gint text_len = strlen (text);

View file

@ -109,6 +109,8 @@ struct _GstTextOverlay {
gboolean need_render; gboolean need_render;
gint shading_value; /* for timeoverlay subclass */ gint shading_value; /* for timeoverlay subclass */
gboolean have_pango_markup;
}; };
struct _GstTextOverlayClass { struct _GstTextOverlayClass {