# HG changeset patch # User aurel # Date 1188167628 0 # Node ID d92fa6e5fc8cf1223ca473a631f11929445eab21 # Parent 8691652d9dcee5a5a28c495d2642d3025ce820e8 move get_unary() to its own file diff -r 8691652d9dce -r d92fa6e5fc8c bitstream.h --- a/bitstream.h Sun Aug 26 22:06:40 2007 +0000 +++ b/bitstream.h Sun Aug 26 22:33:48 2007 +0000 @@ -950,50 +950,4 @@ return get_bits1(gb) + 1; } -/** - * Get unary code of limited length - * @todo FIXME Slow and ugly - * @param gb GetBitContext - * @param[in] stop The bitstop value (unary code of 1's or 0's) - * @param[in] len Maximum length - * @return Unary length/index - */ -static int get_unary(GetBitContext *gb, int stop, int len) -{ -#if 1 - int i; - - for(i = 0; i < len && get_bits1(gb) != stop; i++); - return i; -/* int i = 0, tmp = !stop; - - while (i != len && tmp != stop) - { - tmp = get_bits(gb, 1); - i++; - } - if (i == len && tmp != stop) return len+1; - return i;*/ -#else - unsigned int buf; - int log; - - OPEN_READER(re, gb); - UPDATE_CACHE(re, gb); - buf=GET_CACHE(re, gb); //Still not sure - if (stop) buf = ~buf; - - log= av_log2(-buf); //FIXME: -? - if (log < limit){ - LAST_SKIP_BITS(re, gb, log+1); - CLOSE_READER(re, gb); - return log; - } - - LAST_SKIP_BITS(re, gb, limit); - CLOSE_READER(re, gb); - return limit; -#endif -} - #endif /* BITSTREAM_H */ diff -r 8691652d9dce -r d92fa6e5fc8c unary.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/unary.h Sun Aug 26 22:33:48 2007 +0000 @@ -0,0 +1,72 @@ +/* + * copyright (c) 2004 Michael Niedermayer + * + * This file is part of FFmpeg. + * + * FFmpeg is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * FFmpeg 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 + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with FFmpeg; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#ifndef AVCODEC_UNARY_H +#define AVCODEC_UNARY_H + +#include "bitstream.h" + +/** + * Get unary code of limited length + * @todo FIXME Slow and ugly + * @param gb GetBitContext + * @param[in] stop The bitstop value (unary code of 1's or 0's) + * @param[in] len Maximum length + * @return Unary length/index + */ +static int get_unary(GetBitContext *gb, int stop, int len) +{ +#if 1 + int i; + + for(i = 0; i < len && get_bits1(gb) != stop; i++); + return i; +/* int i = 0, tmp = !stop; + + while (i != len && tmp != stop) + { + tmp = get_bits(gb, 1); + i++; + } + if (i == len && tmp != stop) return len+1; + return i;*/ +#else + unsigned int buf; + int log; + + OPEN_READER(re, gb); + UPDATE_CACHE(re, gb); + buf=GET_CACHE(re, gb); //Still not sure + if (stop) buf = ~buf; + + log= av_log2(-buf); //FIXME: -? + if (log < limit){ + LAST_SKIP_BITS(re, gb, log+1); + CLOSE_READER(re, gb); + return log; + } + + LAST_SKIP_BITS(re, gb, limit); + CLOSE_READER(re, gb); + return limit; +#endif +} + +#endif /* AVCODEC_UNARY_H */ diff -r 8691652d9dce -r d92fa6e5fc8c vc1.c --- a/vc1.c Sun Aug 26 22:06:40 2007 +0000 +++ b/vc1.c Sun Aug 26 22:33:48 2007 +0000 @@ -32,6 +32,7 @@ #include "vc1data.h" #include "vc1acdata.h" #include "msmpeg4data.h" +#include "unary.h" #undef NDEBUG #include diff -r 8691652d9dce -r d92fa6e5fc8c wavpack.c --- a/wavpack.c Sun Aug 26 22:06:40 2007 +0000 +++ b/wavpack.c Sun Aug 26 22:33:48 2007 +0000 @@ -21,6 +21,7 @@ #define ALT_BITSTREAM_READER_LE #include "avcodec.h" #include "bitstream.h" +#include "unary.h" /** * @file wavpack.c