mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-18 14:26:43 +00:00
playbin2: use input-selector from core instead of internal copy
This commit is contained in:
parent
cfe8ffdf6e
commit
dcd4222716
6 changed files with 3 additions and 1556 deletions
|
@ -60,7 +60,7 @@ AC_LIBTOOL_WIN32_DLL
|
|||
AM_PROG_LIBTOOL
|
||||
|
||||
dnl *** required versions of GStreamer stuff ***
|
||||
GST_REQ=0.10.31
|
||||
GST_REQ=0.10.31.1
|
||||
|
||||
dnl *** autotools stuff ****
|
||||
|
||||
|
|
|
@ -17,7 +17,6 @@ libgstplaybin_la_SOURCES = \
|
|||
gstplaysink.c \
|
||||
gstplaybasebin.c \
|
||||
gstplay-enum.c \
|
||||
gstinputselector.c \
|
||||
gststreaminfo.c \
|
||||
gststreamselector.c \
|
||||
gstsubtitleoverlay.c \
|
||||
|
@ -56,7 +55,6 @@ noinst_HEADERS = \
|
|||
gstplaybasebin.h \
|
||||
gstplaysink.h \
|
||||
gststreaminfo.h \
|
||||
gstinputselector.h \
|
||||
gstplay-enum.h \
|
||||
gststreamselector.h \
|
||||
gstrawcaps.h \
|
||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,84 +0,0 @@
|
|||
/* GStreamer
|
||||
* Copyright (C) 2003 Julien Moutte <julien@moutte.net>
|
||||
* Copyright (C) 2005 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
|
||||
* Copyright (C) 2008 Nokia Corporation. (contact <stefan.kost@nokia.com>)
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Library General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Library General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Library General Public
|
||||
* License along with this library; if not, write to the
|
||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
* Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
#ifndef __GST_INPUT_SELECTOR_H__
|
||||
#define __GST_INPUT_SELECTOR_H__
|
||||
|
||||
#include <gst/gst.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
||||
#define GST_TYPE_INPUT_SELECTOR \
|
||||
(gst_input_selector_get_type())
|
||||
#define GST_INPUT_SELECTOR(obj) \
|
||||
(G_TYPE_CHECK_INSTANCE_CAST ((obj), GST_TYPE_INPUT_SELECTOR, GstInputSelector))
|
||||
#define GST_INPUT_SELECTOR_CLASS(klass) \
|
||||
(G_TYPE_CHECK_CLASS_CAST ((klass), GST_TYPE_INPUT_SELECTOR, GstInputSelectorClass))
|
||||
#define GST_IS_INPUT_SELECTOR(obj) \
|
||||
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_INPUT_SELECTOR))
|
||||
#define GST_IS_INPUT_SELECTOR_CLASS(klass) \
|
||||
(G_TYPE_CHECK_CLASS_TYPE ((klass), GST_TYPE_INPUT_SELECTOR))
|
||||
|
||||
typedef struct _GstInputSelector GstInputSelector;
|
||||
typedef struct _GstInputSelectorClass GstInputSelectorClass;
|
||||
|
||||
#define GST_INPUT_SELECTOR_GET_LOCK(sel) (((GstInputSelector*)(sel))->lock)
|
||||
#define GST_INPUT_SELECTOR_GET_COND(sel) (((GstInputSelector*)(sel))->cond)
|
||||
#define GST_INPUT_SELECTOR_LOCK(sel) (g_mutex_lock (GST_INPUT_SELECTOR_GET_LOCK(sel)))
|
||||
#define GST_INPUT_SELECTOR_UNLOCK(sel) (g_mutex_unlock (GST_INPUT_SELECTOR_GET_LOCK(sel)))
|
||||
#define GST_INPUT_SELECTOR_WAIT(sel) (g_cond_wait (GST_INPUT_SELECTOR_GET_COND(sel), \
|
||||
GST_INPUT_SELECTOR_GET_LOCK(sel)))
|
||||
#define GST_INPUT_SELECTOR_BROADCAST(sel) (g_cond_broadcast (GST_INPUT_SELECTOR_GET_COND(sel)))
|
||||
|
||||
struct _GstInputSelector {
|
||||
GstElement element;
|
||||
|
||||
GstPad *srcpad;
|
||||
|
||||
GstPad *active_sinkpad;
|
||||
guint n_pads;
|
||||
guint padcount;
|
||||
|
||||
GstSegment segment; /* the output segment */
|
||||
gboolean pending_close; /* if we should push a close first */
|
||||
|
||||
GMutex *lock;
|
||||
GCond *cond;
|
||||
gboolean blocked;
|
||||
gboolean flushing;
|
||||
|
||||
/* select all mode, send data from all input pads forward */
|
||||
gboolean select_all;
|
||||
};
|
||||
|
||||
struct _GstInputSelectorClass {
|
||||
GstElementClass parent_class;
|
||||
|
||||
gint64 (*block) (GstInputSelector *self);
|
||||
void (*switch_) (GstInputSelector *self, GstPad *pad,
|
||||
gint64 stop_time, gint64 start_time);
|
||||
};
|
||||
|
||||
GType gst_input_selector_get_type (void);
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
#endif /* __GST_INPUT_SELECTOR_H__ */
|
|
@ -8,5 +8,3 @@ BOXED:OBJECT,BOXED,BOXED
|
|||
BOXED:INT
|
||||
OBJECT:BOXED
|
||||
OBJECT:INT
|
||||
INT64:VOID
|
||||
VOID:OBJECT,INT64,INT64
|
||||
|
|
|
@ -230,7 +230,6 @@
|
|||
#include "gstplay-marshal.h"
|
||||
#include "gstplayback.h"
|
||||
#include "gstplaysink.h"
|
||||
#include "gstinputselector.h"
|
||||
#include "gstsubtitleoverlay.h"
|
||||
|
||||
GST_DEBUG_CATEGORY_STATIC (gst_play_bin_debug);
|
||||
|
@ -2456,11 +2455,8 @@ pad_added_cb (GstElement * decodebin, GstPad * pad, GstSourceGroup * group)
|
|||
GST_SOURCE_GROUP_LOCK (group);
|
||||
if (select->selector == NULL && playbin->have_selector) {
|
||||
/* no selector, create one */
|
||||
GST_DEBUG_OBJECT (playbin, "creating new selector");
|
||||
select->selector = g_object_new (GST_TYPE_INPUT_SELECTOR, NULL);
|
||||
/* the above can't fail, but we keep the error handling around for when
|
||||
* the selector plugin has moved to -base or -good and we stop using an
|
||||
* internal copy of input-selector */
|
||||
GST_DEBUG_OBJECT (playbin, "creating new input selector");
|
||||
select->selector = gst_element_factory_make ("input-selector", NULL);
|
||||
if (select->selector == NULL) {
|
||||
/* post the missing selector message only once */
|
||||
playbin->have_selector = FALSE;
|
||||
|
@ -3621,8 +3617,6 @@ gst_play_bin2_plugin_init (GstPlugin * plugin)
|
|||
{
|
||||
GST_DEBUG_CATEGORY_INIT (gst_play_bin_debug, "playbin2", 0, "play bin");
|
||||
|
||||
g_type_class_ref (gst_input_selector_get_type ());
|
||||
|
||||
return gst_element_register (plugin, "playbin2", GST_RANK_NONE,
|
||||
GST_TYPE_PLAY_BIN);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue