mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 02:15:31 +00:00
Update from swfdec.
Original commit message from CVS: * configure.ac: * ext/swfdec/gstswfdec.c: Update from swfdec.
This commit is contained in:
parent
3ac31471aa
commit
edbd3adf7d
3 changed files with 27 additions and 26 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
2006-01-21 David Schleef <ds@schleef.org>
|
||||||
|
|
||||||
|
* configure.ac:
|
||||||
|
* ext/swfdec/gstswfdec.c: Update from swfdec.
|
||||||
|
|
||||||
2006-01-21 Tim-Philipp Müller <tim at centricular dot net>
|
2006-01-21 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
* gst/qtdemux/qtdemux.c: (qtdemux_parse_trak),
|
* gst/qtdemux/qtdemux.c: (qtdemux_parse_trak),
|
||||||
|
|
|
@ -495,7 +495,7 @@ GST_CHECK_FEATURE(SDL, [SDL plug-in], sdlvideosink sdlaudiosink, [
|
||||||
dnl *** swfdec ***
|
dnl *** swfdec ***
|
||||||
translit(dnm, m, l) AM_CONDITIONAL(USE_SWFDEC, true)
|
translit(dnm, m, l) AM_CONDITIONAL(USE_SWFDEC, true)
|
||||||
GST_CHECK_FEATURE(SWFDEC, [swfdec plug-in], swfdec, [
|
GST_CHECK_FEATURE(SWFDEC, [swfdec plug-in], swfdec, [
|
||||||
PKG_CHECK_MODULES(SWFDEC, swfdec-0.3 >= 0.3.3, HAVE_SWFDEC=yes, HAVE_SWFDEC=no)
|
PKG_CHECK_MODULES(SWFDEC, swfdec-0.3 >= 0.3.6, HAVE_SWFDEC=yes, HAVE_SWFDEC=no)
|
||||||
AC_SUBST(SWFDEC_CFLAGS)
|
AC_SUBST(SWFDEC_CFLAGS)
|
||||||
AC_SUBST(SWFDEC_LIBS)
|
AC_SUBST(SWFDEC_LIBS)
|
||||||
])
|
])
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
* Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu>
|
* Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu>
|
||||||
* Copyright (C) <2002,2003> David A. Schleef <ds@schleef.org>
|
* Copyright (C) 2002,2003,2006 David A. Schleef <ds@schleef.org>
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
@ -25,6 +25,7 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gst/video/video.h>
|
#include <gst/video/video.h>
|
||||||
#include <swfdec_buffer.h>
|
#include <swfdec_buffer.h>
|
||||||
|
#include <swfdec_decoder.h>
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_STATIC (swfdec_debug);
|
GST_DEBUG_CATEGORY_STATIC (swfdec_debug);
|
||||||
#define GST_CAT_DEFAULT swfdec_debug
|
#define GST_CAT_DEFAULT swfdec_debug
|
||||||
|
@ -39,7 +40,6 @@ GST_ELEMENT_DETAILS ("SWF video decoder",
|
||||||
/* Swfdec signals and args */
|
/* Swfdec signals and args */
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
SIGNAL_EMBED_URL,
|
|
||||||
/* FILL ME */
|
/* FILL ME */
|
||||||
LAST_SIGNAL
|
LAST_SIGNAL
|
||||||
};
|
};
|
||||||
|
@ -114,7 +114,8 @@ static GstFlowReturn gst_swfdec_chain (GstPad * pad, GstBuffer * buffer);
|
||||||
static void gst_swfdec_render (GstSwfdec * swfdec, int ret);
|
static void gst_swfdec_render (GstSwfdec * swfdec, int ret);
|
||||||
|
|
||||||
static GstElementClass *parent_class = NULL;
|
static GstElementClass *parent_class = NULL;
|
||||||
static guint gst_swfdec_signals[LAST_SIGNAL];
|
|
||||||
|
//static guint gst_swfdec_signals[LAST_SIGNAL];
|
||||||
|
|
||||||
|
|
||||||
/* GstSwfdecBuffer */
|
/* GstSwfdecBuffer */
|
||||||
|
@ -241,12 +242,6 @@ gst_swfdec_class_init (GstSwfdecClass * klass)
|
||||||
|
|
||||||
gstelement_class->change_state = gst_swfdec_change_state;
|
gstelement_class->change_state = gst_swfdec_change_state;
|
||||||
|
|
||||||
gst_swfdec_signals[SIGNAL_EMBED_URL] =
|
|
||||||
g_signal_new ("embed-url", G_TYPE_FROM_CLASS (klass),
|
|
||||||
G_SIGNAL_RUN_LAST,
|
|
||||||
G_STRUCT_OFFSET (GstSwfdecClass, embed_url), NULL, NULL,
|
|
||||||
g_cclosure_marshal_VOID__STRING, G_TYPE_NONE, 1, G_TYPE_STRING);
|
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_INIT (swfdec_debug, "swfdec", 0, "Flash decoder plugin");
|
GST_DEBUG_CATEGORY_INIT (swfdec_debug, "swfdec", 0, "Flash decoder plugin");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -364,10 +359,7 @@ gst_swfdec_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
GstCaps *caps;
|
GstCaps *caps;
|
||||||
double rate;
|
double rate;
|
||||||
|
|
||||||
/* Let's not depend on features that are only in CVS */
|
|
||||||
#ifdef HAVE_SWFDEC_0_3_5
|
|
||||||
GstTagList *taglist;
|
GstTagList *taglist;
|
||||||
#endif
|
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (swfdec, "SWF_CHANGE");
|
GST_DEBUG_OBJECT (swfdec, "SWF_CHANGE");
|
||||||
gst_adapter_push (swfdec->adapter, buffer);
|
gst_adapter_push (swfdec->adapter, buffer);
|
||||||
|
@ -408,15 +400,11 @@ gst_swfdec_chain (GstPad * pad, GstBuffer * buffer)
|
||||||
gst_caps_unref (caps);
|
gst_caps_unref (caps);
|
||||||
|
|
||||||
|
|
||||||
#ifdef HAVE_SWFDEC_0_3_5
|
|
||||||
taglist = gst_tag_list_new ();
|
taglist = gst_tag_list_new ();
|
||||||
gst_tag_list_add (taglist, GST_TAG_MERGE_REPLACE,
|
gst_tag_list_add (taglist, GST_TAG_MERGE_REPLACE,
|
||||||
GST_TAG_ENCODER_VERSION, swfdec_decoder_get_version (swfdec->decoder),
|
GST_TAG_ENCODER_VERSION, swfdec_decoder_get_version (swfdec->decoder),
|
||||||
NULL);
|
NULL);
|
||||||
gst_element_found_tags (GST_ELEMENT (swfdec), taglist);
|
gst_element_found_tags (GST_ELEMENT (swfdec), taglist);
|
||||||
gst_tag_list_free (taglist);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
} else if (ret == SWF_EOF) {
|
} else if (ret == SWF_EOF) {
|
||||||
GST_DEBUG_OBJECT (swfdec, "SWF_EOF");
|
GST_DEBUG_OBJECT (swfdec, "SWF_EOF");
|
||||||
gst_swfdec_render (swfdec, ret);
|
gst_swfdec_render (swfdec, ret);
|
||||||
|
@ -456,6 +444,13 @@ gst_swfdec_render (GstSwfdec * swfdec, int ret)
|
||||||
|
|
||||||
ret = swfdec_render_iterate (swfdec->decoder);
|
ret = swfdec_render_iterate (swfdec->decoder);
|
||||||
|
|
||||||
|
if (swfdec->decoder->using_experimental) {
|
||||||
|
GST_ELEMENT_ERROR (swfdec, LIBRARY, FAILED,
|
||||||
|
("SWF file contains features known to trigger bugs."),
|
||||||
|
("SWF file contains features known to trigger bugs."));
|
||||||
|
gst_task_stop (swfdec->task);
|
||||||
|
}
|
||||||
|
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
gst_task_stop (swfdec->task);
|
gst_task_stop (swfdec->task);
|
||||||
res = gst_pad_push_event (swfdec->videopad, gst_event_new_eos ());
|
res = gst_pad_push_event (swfdec->videopad, gst_event_new_eos ());
|
||||||
|
@ -525,8 +520,13 @@ gst_swfdec_render (GstSwfdec * swfdec, int ret)
|
||||||
|
|
||||||
url = swfdec_decoder_get_url (swfdec->decoder);
|
url = swfdec_decoder_get_url (swfdec->decoder);
|
||||||
if (url) {
|
if (url) {
|
||||||
g_signal_emit (G_OBJECT (swfdec), gst_swfdec_signals[SIGNAL_EMBED_URL],
|
GstStructure *s;
|
||||||
0, url);
|
GstMessage *msg;
|
||||||
|
|
||||||
|
s = gst_structure_new ("embedded-url", "url", G_TYPE_STRING, url,
|
||||||
|
"target", G_TYPE_STRING, "_self", NULL);
|
||||||
|
msg = gst_message_new_element (GST_OBJECT (swfdec), s);
|
||||||
|
gst_element_post_message (GST_ELEMENT (swfdec), msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -730,6 +730,7 @@ gst_swfdec_src_event (GstPad * pad, GstEvent * event)
|
||||||
swfdec = GST_SWFDEC (gst_pad_get_parent (pad));
|
swfdec = GST_SWFDEC (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
switch (GST_EVENT_TYPE (event)) {
|
switch (GST_EVENT_TYPE (event)) {
|
||||||
|
#if 0
|
||||||
/* the all-formats seek logic */
|
/* the all-formats seek logic */
|
||||||
case GST_EVENT_SEEK:
|
case GST_EVENT_SEEK:
|
||||||
{
|
{
|
||||||
|
@ -769,6 +770,7 @@ gst_swfdec_src_event (GstPad * pad, GstEvent * event)
|
||||||
res = TRUE;
|
res = TRUE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
case GST_EVENT_NAVIGATION:
|
case GST_EVENT_NAVIGATION:
|
||||||
{
|
{
|
||||||
const GstStructure *structure = gst_event_get_structure (event);
|
const GstStructure *structure = gst_event_get_structure (event);
|
||||||
|
@ -899,12 +901,6 @@ gst_swfdec_get_property (GObject * object, guint prop_id, GValue * value,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
art_warn (const char *fmt, ...)
|
|
||||||
{
|
|
||||||
GST_LOG ("caught art_warn");
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
plugin_init (GstPlugin * plugin)
|
plugin_init (GstPlugin * plugin)
|
||||||
{
|
{
|
||||||
|
@ -912,7 +908,7 @@ plugin_init (GstPlugin * plugin)
|
||||||
GST_TYPE_SWFDEC);
|
GST_TYPE_SWFDEC);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_PLUGIN_DEFINE (GST_VERSION_MAJOR,
|
GST_PLUGIN_DEFINE_STATIC (GST_VERSION_MAJOR,
|
||||||
GST_VERSION_MINOR,
|
GST_VERSION_MINOR,
|
||||||
"swfdec",
|
"swfdec",
|
||||||
"Uses libswfdec to decode Flash video streams",
|
"Uses libswfdec to decode Flash video streams",
|
||||||
|
|
Loading…
Reference in a new issue