[vlc-devel] [V2 05/14] codec: spudec: prepare to put pf_packetize and pf_decode into a union
Zhao Zhili
quinkblack at foxmail.com
Fri Jun 8 11:47:11 CEST 2018
---
modules/codec/spudec/spudec.c | 52 ++++++++++++++++---------------------------
1 file changed, 19 insertions(+), 33 deletions(-)
diff --git a/modules/codec/spudec/spudec.c b/modules/codec/spudec/spudec.c
index 6be4ab9..9e757cc 100644
--- a/modules/codec/spudec/spudec.c
+++ b/modules/codec/spudec/spudec.c
@@ -69,13 +69,7 @@ static block_t * Reassemble( decoder_t *, block_t * );
static int Decode ( decoder_t *, block_t * );
static block_t * Packetize ( decoder_t *, block_t ** );
-/*****************************************************************************
- * DecoderOpen
- *****************************************************************************
- * Tries to launch a decoder and return score so that the interface is able
- * to chose.
- *****************************************************************************/
-static int DecoderOpen( vlc_object_t *p_this )
+static int OpenCommon( vlc_object_t *p_this, bool b_packetizer )
{
decoder_t *p_dec = (decoder_t*)p_this;
decoder_sys_t *p_sys;
@@ -85,43 +79,35 @@ static int DecoderOpen( vlc_object_t *p_this )
p_dec->p_sys = p_sys = malloc( sizeof( decoder_sys_t ) );
- p_sys->b_packetizer = false;
+ p_sys->b_packetizer = b_packetizer;
p_sys->b_disabletrans = var_InheritBool( p_dec, "dvdsub-transparency" );
p_sys->i_spu_size = 0;
p_sys->i_spu = 0;
p_sys->p_block = NULL;
- p_dec->fmt_out.i_codec = VLC_CODEC_SPU;
-
- p_dec->pf_decode = Decode;
- p_dec->pf_packetize = NULL;
+ if( b_packetizer )
+ {
+ p_dec->pf_packetize = Packetize;
+ es_format_Copy( &p_dec->fmt_out, &p_dec->fmt_in );
+ p_dec->fmt_out.i_codec = VLC_CODEC_SPU;
+ }
+ else
+ {
+ p_dec->fmt_out.i_codec = VLC_CODEC_SPU;
+ p_dec->pf_decode = Decode;
+ }
return VLC_SUCCESS;
}
-/*****************************************************************************
- * PacketizerOpen
- *****************************************************************************
- * Tries to launch a decoder and return score so that the interface is able
- * to chose.
- *****************************************************************************/
-static int PacketizerOpen( vlc_object_t *p_this )
+static int DecoderOpen( vlc_object_t *p_this )
{
- decoder_t *p_dec = (decoder_t*)p_this;
-
- if( DecoderOpen( p_this ) )
- {
- return VLC_EGENERIC;
- }
-
- decoder_sys_t *p_sys = p_dec->p_sys;
-
- p_dec->pf_packetize = Packetize;
- p_sys->b_packetizer = true;
- es_format_Copy( &p_dec->fmt_out, &p_dec->fmt_in );
- p_dec->fmt_out.i_codec = VLC_CODEC_SPU;
+ return OpenCommon( p_this, false );
+}
- return VLC_SUCCESS;
+static int PacketizerOpen( vlc_object_t *p_this )
+{
+ return OpenCommon( p_this, true );
}
/*****************************************************************************
--
2.9.5
More information about the vlc-devel
mailing list