aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJanne Grunau <janne-ffmpeg@jannau.net>2010-05-29 14:33:02 +0000
committerReinhard Tartler <siretart@tauware.de>2010-05-29 14:33:02 +0000
commit3fa19f68287be4fc06776a4a52a7415e47822876 (patch)
tree508932d8e9323e128fb89a617d67a157a76536aa
parent4e62a6738972275ab4cda625304f1cd25d8a0772 (diff)
downloadffmpeg-3fa19f68287be4fc06776a4a52a7415e47822876.tar.gz
Add CODEC_CAP_EXPERIMENTAL and prefer encoders without it.
Patch by Janne Grunau, janne-ffmpeg jannau net backport r23334,23337-23338 by cehoyos and stefano Originally committed as revision 23379 to svn://svn.ffmpeg.org/ffmpeg/branches/0.6
-rw-r--r--Changelog1
-rw-r--r--doc/APIchanges3
-rw-r--r--libavcodec/avcodec.h7
-rw-r--r--libavcodec/utils.c12
4 files changed, 18 insertions, 5 deletions
diff --git a/Changelog b/Changelog
index 1febc493a6..187264d1cd 100644
--- a/Changelog
+++ b/Changelog
@@ -79,6 +79,7 @@ version 0.6:
- low overhead Ogg muxing
- WebM support in Matroska demuxer
- VP8 decoding via libvpx
+- CODEC_CAP_EXPERIMENTAL added
diff --git a/doc/APIchanges b/doc/APIchanges
index d521b59e29..4d574108b8 100644
--- a/doc/APIchanges
+++ b/doc/APIchanges
@@ -12,6 +12,9 @@ libavutil: 2009-03-08
API changes, most recent first:
+2010-05-26 - r23334 - lavc 52.72.0 - CODEC_CAP_EXPERIMENTAL
+ Add CODEC_CAP_EXPERIMENTAL flag.
+
2010-05-18 - r23161 - lavf 52.63.0 - AVFMT_FLAG_RTP_HINT
Add AVFMT_FLAG_RTP_HINT as possible value for AVFormatContext.flags
diff --git a/libavcodec/avcodec.h b/libavcodec/avcodec.h
index 996bc15b70..8832014a72 100644
--- a/libavcodec/avcodec.h
+++ b/libavcodec/avcodec.h
@@ -30,7 +30,7 @@
#include "libavutil/avutil.h"
#define LIBAVCODEC_VERSION_MAJOR 52
-#define LIBAVCODEC_VERSION_MINOR 69
+#define LIBAVCODEC_VERSION_MINOR 72
#define LIBAVCODEC_VERSION_MICRO 1
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
@@ -644,6 +644,11 @@ typedef struct RcOverride{
* as a last resort.
*/
#define CODEC_CAP_SUBFRAMES 0x0100
+/**
+ * Codec is experimental and is thus avoided in favor of non experimental
+ * encoders
+ */
+#define CODEC_CAP_EXPERIMENTAL 0x0200
//The following defines may change, don't expect compatibility if you use them.
#define MB_TYPE_INTRA4x4 0x0001
diff --git a/libavcodec/utils.c b/libavcodec/utils.c
index 87facec8f4..014427d59f 100644
--- a/libavcodec/utils.c
+++ b/libavcodec/utils.c
@@ -724,14 +724,18 @@ av_cold int avcodec_close(AVCodecContext *avctx)
AVCodec *avcodec_find_encoder(enum CodecID id)
{
- AVCodec *p;
+ AVCodec *p, *experimental=NULL;
p = first_avcodec;
while (p) {
- if (p->encode != NULL && p->id == id)
- return p;
+ if (p->encode != NULL && p->id == id) {
+ if (p->capabilities & CODEC_CAP_EXPERIMENTAL && !experimental) {
+ experimental = p;
+ } else
+ return p;
+ }
p = p->next;
}
- return NULL;
+ return experimental;
}
AVCodec *avcodec_find_encoder_by_name(const char *name)