Add getter functions for the interface data symbols
Having these symbols be available as functions rather than data is occasionally more convenient. Implemented this way rather than a get-codec-by-id style to avoid creating a link-time dependency between the encoder and the decoder. Fixes issue #169 Change-Id: I319f281277033a5e7e3ee3b092b9a87cce2f463d
This commit is contained in:
parent
12651b3c2b
commit
fa7a55bb04
@ -1 +1,2 @@
|
|||||||
data vpx_codec_vp8_dx_algo
|
data vpx_codec_vp8_dx_algo
|
||||||
|
text vpx_codec_vp8_dx
|
||||||
|
@ -1 +1,2 @@
|
|||||||
data vpx_codec_vp8_cx_algo
|
data vpx_codec_vp8_cx_algo
|
||||||
|
text vpx_codec_vp8_cx
|
||||||
|
@ -1079,7 +1079,7 @@ static vpx_codec_enc_cfg_map_t vp8e_usage_cfg_map[] =
|
|||||||
#ifndef VERSION_STRING
|
#ifndef VERSION_STRING
|
||||||
#define VERSION_STRING
|
#define VERSION_STRING
|
||||||
#endif
|
#endif
|
||||||
vpx_codec_iface_t vpx_codec_vp8_cx_algo =
|
CODEC_INTERFACE(vpx_codec_vp8_cx) =
|
||||||
{
|
{
|
||||||
"WebM Project VP8 Encoder" VERSION_STRING,
|
"WebM Project VP8 Encoder" VERSION_STRING,
|
||||||
VPX_CODEC_INTERNAL_ABI_VERSION,
|
VPX_CODEC_INTERNAL_ABI_VERSION,
|
||||||
|
@ -653,7 +653,7 @@ vpx_codec_ctrl_fn_map_t vp8_ctf_maps[] =
|
|||||||
#ifndef VERSION_STRING
|
#ifndef VERSION_STRING
|
||||||
#define VERSION_STRING
|
#define VERSION_STRING
|
||||||
#endif
|
#endif
|
||||||
vpx_codec_iface_t vpx_codec_vp8_dx_algo =
|
CODEC_INTERFACE(vpx_codec_vp8_dx) =
|
||||||
{
|
{
|
||||||
"WebM Project VP8 Decoder" VERSION_STRING,
|
"WebM Project VP8 Decoder" VERSION_STRING,
|
||||||
VPX_CODEC_INTERNAL_ABI_VERSION,
|
VPX_CODEC_INTERNAL_ABI_VERSION,
|
||||||
|
@ -389,6 +389,20 @@ struct vpx_codec_priv
|
|||||||
#define RECAST(id, x) id##__convert(x)
|
#define RECAST(id, x) id##__convert(x)
|
||||||
|
|
||||||
|
|
||||||
|
/* CODEC_INTERFACE convenience macro
|
||||||
|
*
|
||||||
|
* By convention, each codec interface is a struct with extern linkage, where
|
||||||
|
* the symbol is suffixed with _algo. A getter function is also defined to
|
||||||
|
* return a pointer to the struct, since in some cases it's easier to work
|
||||||
|
* with text symbols than data symbols (see issue #169). This function has
|
||||||
|
* the same name as the struct, less the _algo suffix. The CODEC_INTERFACE
|
||||||
|
* macro is provided to define this getter function automatically.
|
||||||
|
*/
|
||||||
|
#define CODEC_INTERFACE(id)\
|
||||||
|
vpx_codec_iface_t* id(void) { return &id##_algo; }\
|
||||||
|
vpx_codec_iface_t id##_algo
|
||||||
|
|
||||||
|
|
||||||
/* Internal Utility Functions
|
/* Internal Utility Functions
|
||||||
*
|
*
|
||||||
* The following functions are indended to be used inside algorithms as
|
* The following functions are indended to be used inside algorithms as
|
||||||
|
@ -29,7 +29,8 @@
|
|||||||
* This interface provides the capability to encode raw VP8 streams, as would
|
* This interface provides the capability to encode raw VP8 streams, as would
|
||||||
* be found in AVI files.
|
* be found in AVI files.
|
||||||
*/
|
*/
|
||||||
extern vpx_codec_iface_t vpx_codec_vp8_cx_algo;
|
extern vpx_codec_iface_t vpx_codec_vp8_cx_algo;
|
||||||
|
extern vpx_codec_iface_t* vpx_codec_vp8_cx(void);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -29,7 +29,8 @@
|
|||||||
* This interface provides the capability to decode raw VP8 streams, as would
|
* This interface provides the capability to decode raw VP8 streams, as would
|
||||||
* be found in AVI files and other non-Flash uses.
|
* be found in AVI files and other non-Flash uses.
|
||||||
*/
|
*/
|
||||||
extern vpx_codec_iface_t vpx_codec_vp8_dx_algo;
|
extern vpx_codec_iface_t vpx_codec_vp8_dx_algo;
|
||||||
|
extern vpx_codec_iface_t* vpx_codec_vp8_dx(void);
|
||||||
|
|
||||||
/* Include controls common to both the encoder and decoder */
|
/* Include controls common to both the encoder and decoder */
|
||||||
#include "vp8.h"
|
#include "vp8.h"
|
||||||
|
Loading…
Reference in New Issue
Block a user