changeset 3530:5d1828a07acf libavcodec

remove libtheora wrapper
author mru
date Mon, 31 Jul 2006 20:56:15 +0000
parents b8656dfe6b1a
children db56a7f0768a
files Makefile allcodecs.c avcodec.h oggtheora.c
diffstat 4 files changed, 1 insertions(+), 143 deletions(-) [+]
line wrap: on
line diff
--- a/Makefile	Mon Jul 31 03:32:59 2006 +0000
+++ b/Makefile	Mon Jul 31 20:56:15 2006 +0000
@@ -210,7 +210,6 @@
 OBJS-$(CONFIG_X264)                    += x264.o
 OBJS-$(CONFIG_MP3LAME)                 += mp3lameaudio.o
 OBJS-$(CONFIG_LIBVORBIS)               += oggvorbis.o
-OBJS-$(CONFIG_LIBTHEORA)               += oggtheora.o
 OBJS-$(CONFIG_LIBGSM)                  += libgsm.o
 
 # currently using liba52 for ac3 decoding
--- a/allcodecs.c	Mon Jul 31 03:32:59 2006 +0000
+++ b/allcodecs.c	Mon Jul 31 20:56:15 2006 +0000
@@ -59,11 +59,6 @@
     register_avcodec(&oggvorbis_decoder);
 #endif //CONFIG_OGGVORBIS_DECODER
 #endif
-#ifdef CONFIG_LIBTHEORA
-#ifdef CONFIG_OGGTHEORA_DECODER
-    register_avcodec(&oggtheora_decoder);
-#endif //CONFIG_OGGTHEORA_DECODER
-#endif
 #ifdef CONFIG_FAAC
 #ifdef CONFIG_FAAC_ENCODER
     register_avcodec(&faac_encoder);
@@ -375,7 +370,7 @@
 #ifdef CONFIG_VP3_DECODER
     register_avcodec(&vp3_decoder);
 #endif //CONFIG_VP3_DECODER
-#if (defined CONFIG_THEORA_DECODER && !defined CONFIG_LIBTHEORA)
+#ifdef CONFIG_THEORA_DECODER
     register_avcodec(&theora_decoder);
 #endif //CONFIG_THEORA_DECODER
 #ifdef CONFIG_ASV1_DECODER
--- a/avcodec.h	Mon Jul 31 03:32:59 2006 +0000
+++ b/avcodec.h	Mon Jul 31 20:56:15 2006 +0000
@@ -201,8 +201,6 @@
     CODEC_ID_TTA,
     CODEC_ID_SMACKAUDIO,
 
-    CODEC_ID_OGGTHEORA= 0x16000,
-
     /* subtitle codecs */
     CODEC_ID_DVD_SUBTITLE= 0x17000,
     CODEC_ID_DVB_SUBTITLE,
@@ -2186,7 +2184,6 @@
 extern AVCodec huffyuv_decoder;
 extern AVCodec ffvhuff_decoder;
 extern AVCodec oggvorbis_decoder;
-extern AVCodec oggtheora_decoder;
 extern AVCodec cyuv_decoder;
 extern AVCodec h264_decoder;
 extern AVCodec indeo3_decoder;
--- a/oggtheora.c	Mon Jul 31 03:32:59 2006 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,133 +0,0 @@
-/**
-    Copyright (C) 2005  Måns Rullgård
-
-    Permission is hereby granted, free of charge, to any person
-    obtaining a copy of this software and associated documentation
-    files (the "Software"), to deal in the Software without
-    restriction, including without limitation the rights to use, copy,
-    modify, merge, publish, distribute, sublicense, and/or sell copies
-    of the Software, and to permit persons to whom the Software is
-    furnished to do so, subject to the following conditions:
-
-    The above copyright notice and this permission notice shall be
-    included in all copies or substantial portions of the Software.
-
-    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-    EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-    NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
-    HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-    WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-    OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
-    DEALINGS IN THE SOFTWARE.
-**/
-
-#include <stdlib.h>
-#include <theora/theora.h>
-#include "avcodec.h"
-
-typedef struct TheoraContext {
-    theora_info info;
-    theora_state state;
-    theora_comment comment;
-    ogg_packet op;
-} TheoraContext;
-
-static int
-Theora_decode_frame(AVCodecContext *ctx, void *outdata, int *outdata_size,
-                    uint8_t *buf, int buf_size)
-{
-    TheoraContext *thc = ctx->priv_data;
-    AVFrame *frame = outdata;
-    yuv_buffer yuv;
-
-    thc->op.packet = buf;
-    thc->op.bytes = buf_size;
-
-    if(theora_decode_packetin(&thc->state, &thc->op))
-        return -1;
-
-    theora_decode_YUVout(&thc->state, &yuv);
-
-    frame->data[0] = yuv.y;
-    frame->data[1] = yuv.u;
-    frame->data[2] = yuv.v;
-    frame->linesize[0] = yuv.y_stride;
-    frame->linesize[1] = yuv.uv_stride;
-    frame->linesize[2] = yuv.uv_stride;
-
-    *outdata_size = sizeof(*frame);
-    return buf_size;
-}
-
-static int
-Theora_decode_end(AVCodecContext *ctx)
-{
-    TheoraContext *thc = ctx->priv_data;
-    theora_info_clear(&thc->info);
-    theora_comment_clear(&thc->comment);
-    return 0;
-}
-
-static int
-Theora_decode_init(AVCodecContext *ctx)
-{
-    TheoraContext *thc = ctx->priv_data;
-    int size, hs, i;
-    ogg_packet op;
-    uint8_t *cdp;
-
-    if(ctx->extradata_size < 6)
-        return -1;
-
-    theora_info_init(&thc->info);
-
-    memset(&op, 0, sizeof(op));
-    cdp = ctx->extradata;
-    size = ctx->extradata_size;
-
-    for(i = 0; i < 3; i++){
-        hs = *cdp++ << 8;
-        hs += *cdp++;
-        size -= 2;
-
-        if(hs > size){
-            av_log(ctx, AV_LOG_ERROR, "extradata too small: %i > %i\n",
-                   hs, size);
-            return -1;
-        }
-
-        op.packet = cdp;
-        op.bytes = hs;
-        op.b_o_s = !i;
-        if(theora_decode_header(&thc->info, &thc->comment, &op))
-            return -1;
-        op.packetno++;
-
-        cdp += hs;
-        size -= hs;
-    }
-
-    theora_decode_init(&thc->state, &thc->info);
-
-    ctx->width = thc->info.width;
-    ctx->height = thc->info.height;
-    ctx->time_base.num = thc->info.fps_denominator;
-    ctx->time_base.den = thc->info.fps_numerator;
-    ctx->pix_fmt = PIX_FMT_YUV420P; /* FIXME: others are possible */
-
-    return 0;
-}
-
-AVCodec oggtheora_decoder = {
-    "theora",
-    CODEC_TYPE_VIDEO,
-    CODEC_ID_THEORA,
-    sizeof(TheoraContext),
-    Theora_decode_init,
-    NULL,
-    Theora_decode_end,
-    Theora_decode_frame,
-    0,
-    NULL
-};