Commit 87e37cd4 authored by Led's avatar Led

0.10.1-rc1

parent f9434227
ver 0.10.1 (2004/3/8)
1) Check to see if we need to add "-lm" when linking mpd
2) Fix issues with skipping bad frames in an mp3 (this way we get the correct samplerate and such)
3) Fix crossfading bug with ogg's
ver 0.10.0 (2004/3/3) ver 0.10.0 (2004/3/3)
1) Use UTF-8 for all client communications 1) Use UTF-8 for all client communications
2) Crossfading support 2) Crossfading support
......
#! /bin/sh #! /bin/sh
# Guess values for system-dependent variables and create Makefiles. # Guess values for system-dependent variables and create Makefiles.
# Generated by GNU Autoconf 2.58 for mpd 0.10.0. # Generated by GNU Autoconf 2.58 for mpd 0.10.1.
# #
# Report bugs to <shank@mercury.chem.pitt.edu>. # Report bugs to <shank@mercury.chem.pitt.edu>.
# #
...@@ -428,8 +428,8 @@ SHELL=${CONFIG_SHELL-/bin/sh} ...@@ -428,8 +428,8 @@ SHELL=${CONFIG_SHELL-/bin/sh}
# Identity of this package. # Identity of this package.
PACKAGE_NAME='mpd' PACKAGE_NAME='mpd'
PACKAGE_TARNAME='mpd' PACKAGE_TARNAME='mpd'
PACKAGE_VERSION='0.10.0' PACKAGE_VERSION='0.10.1'
PACKAGE_STRING='mpd 0.10.0' PACKAGE_STRING='mpd 0.10.1'
PACKAGE_BUGREPORT='shank@mercury.chem.pitt.edu' PACKAGE_BUGREPORT='shank@mercury.chem.pitt.edu'
# Factoring default headers for most tests. # Factoring default headers for most tests.
...@@ -940,7 +940,7 @@ if test "$ac_init_help" = "long"; then ...@@ -940,7 +940,7 @@ if test "$ac_init_help" = "long"; then
# Omit some internal or obsolete options to make the list less imposing. # Omit some internal or obsolete options to make the list less imposing.
# This message is too long to be a string in the A/UX 3.1 sh. # This message is too long to be a string in the A/UX 3.1 sh.
cat <<_ACEOF cat <<_ACEOF
\`configure' configures mpd 0.10.0 to adapt to many kinds of systems. \`configure' configures mpd 0.10.1 to adapt to many kinds of systems.
Usage: $0 [OPTION]... [VAR=VALUE]... Usage: $0 [OPTION]... [VAR=VALUE]...
...@@ -1006,7 +1006,7 @@ fi ...@@ -1006,7 +1006,7 @@ fi
if test -n "$ac_init_help"; then if test -n "$ac_init_help"; then
case $ac_init_help in case $ac_init_help in
short | recursive ) echo "Configuration of mpd 0.10.0:";; short | recursive ) echo "Configuration of mpd 0.10.1:";;
esac esac
cat <<\_ACEOF cat <<\_ACEOF
...@@ -1165,7 +1165,7 @@ fi ...@@ -1165,7 +1165,7 @@ fi
test -n "$ac_init_help" && exit 0 test -n "$ac_init_help" && exit 0
if $ac_init_version; then if $ac_init_version; then
cat <<\_ACEOF cat <<\_ACEOF
mpd configure 0.10.0 mpd configure 0.10.1
generated by GNU Autoconf 2.58 generated by GNU Autoconf 2.58
Copyright (C) 2003 Free Software Foundation, Inc. Copyright (C) 2003 Free Software Foundation, Inc.
...@@ -1179,7 +1179,7 @@ cat >&5 <<_ACEOF ...@@ -1179,7 +1179,7 @@ cat >&5 <<_ACEOF
This file contains any messages produced by compilers while This file contains any messages produced by compilers while
running configure, to aid debugging if configure makes a mistake. running configure, to aid debugging if configure makes a mistake.
It was created by mpd $as_me 0.10.0, which was It was created by mpd $as_me 0.10.1, which was
generated by GNU Autoconf 2.58. Invocation command line was generated by GNU Autoconf 2.58. Invocation command line was
$ $0 $@ $ $0 $@
...@@ -10351,6 +10351,75 @@ if test $ac_cv_lib_nsl_gethostbyname = yes; then ...@@ -10351,6 +10351,75 @@ if test $ac_cv_lib_nsl_gethostbyname = yes; then
fi fi
echo "$as_me:$LINENO: checking for exp in -lm" >&5
echo $ECHO_N "checking for exp in -lm... $ECHO_C" >&6
if test "${ac_cv_lib_m_exp+set}" = set; then
echo $ECHO_N "(cached) $ECHO_C" >&6
else
ac_check_lib_save_LIBS=$LIBS
LIBS="-lm $LIBS"
cat >conftest.$ac_ext <<_ACEOF
/* confdefs.h. */
_ACEOF
cat confdefs.h >>conftest.$ac_ext
cat >>conftest.$ac_ext <<_ACEOF
/* end confdefs.h. */
/* Override any gcc2 internal prototype to avoid an error. */
#ifdef __cplusplus
extern "C"
#endif
/* We use char because int might match the return type of a gcc2
builtin and then its argument prototype would still apply. */
char exp ();
int
main ()
{
exp ();
;
return 0;
}
_ACEOF
rm -f conftest.$ac_objext conftest$ac_exeext
if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5
(eval $ac_link) 2>conftest.er1
ac_status=$?
grep -v '^ *+' conftest.er1 >conftest.err
rm -f conftest.er1
cat conftest.err >&5
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); } &&
{ ac_try='test -z "$ac_c_werror_flag"
|| test ! -s conftest.err'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; } &&
{ ac_try='test -s conftest$ac_exeext'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; }; then
ac_cv_lib_m_exp=yes
else
echo "$as_me: failed program was:" >&5
sed 's/^/| /' conftest.$ac_ext >&5
ac_cv_lib_m_exp=no
fi
rm -f conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
LIBS=$ac_check_lib_save_LIBS
fi
echo "$as_me:$LINENO: result: $ac_cv_lib_m_exp" >&5
echo "${ECHO_T}$ac_cv_lib_m_exp" >&6
if test $ac_cv_lib_m_exp = yes; then
MPD_LIBS="$MPD_LIBS -lm"
fi
if test "${ac_cv_header_langinfo_h+set}" = set; then if test "${ac_cv_header_langinfo_h+set}" = set; then
echo "$as_me:$LINENO: checking for langinfo.h" >&5 echo "$as_me:$LINENO: checking for langinfo.h" >&5
echo $ECHO_N "checking for langinfo.h... $ECHO_C" >&6 echo $ECHO_N "checking for langinfo.h... $ECHO_C" >&6
...@@ -13181,7 +13250,7 @@ _ASBOX ...@@ -13181,7 +13250,7 @@ _ASBOX
} >&5 } >&5
cat >&5 <<_CSEOF cat >&5 <<_CSEOF
This file was extended by mpd $as_me 0.10.0, which was This file was extended by mpd $as_me 0.10.1, which was
generated by GNU Autoconf 2.58. Invocation command line was generated by GNU Autoconf 2.58. Invocation command line was
CONFIG_FILES = $CONFIG_FILES CONFIG_FILES = $CONFIG_FILES
...@@ -13239,7 +13308,7 @@ _ACEOF ...@@ -13239,7 +13308,7 @@ _ACEOF
cat >>$CONFIG_STATUS <<_ACEOF cat >>$CONFIG_STATUS <<_ACEOF
ac_cs_version="\\ ac_cs_version="\\
mpd config.status 0.10.0 mpd config.status 0.10.1
configured by $0, generated by GNU Autoconf 2.58, configured by $0, generated by GNU Autoconf 2.58,
with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\" with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\"
......
...@@ -2,7 +2,7 @@ dnl AC_INIT(src/main.c) ...@@ -2,7 +2,7 @@ dnl AC_INIT(src/main.c)
dnl AM_INIT_AUTOMAKE(mpd, 0.10.0) dnl AM_INIT_AUTOMAKE(mpd, 0.10.0)
AC_PREREQ(2.52) AC_PREREQ(2.52)
AC_INIT(mpd, 0.10.0, shank@mercury.chem.pitt.edu) AC_INIT(mpd, 0.10.1, shank@mercury.chem.pitt.edu)
AM_INIT_AUTOMAKE($PACKAGE_NAME, $PACKAGE_VERSION) AM_INIT_AUTOMAKE($PACKAGE_NAME, $PACKAGE_VERSION)
AC_PROG_CC AC_PROG_CC
...@@ -51,6 +51,8 @@ AC_CHECK_SIZEOF(long long) ...@@ -51,6 +51,8 @@ AC_CHECK_SIZEOF(long long)
AC_CHECK_LIB(socket,socket,MPD_LIBS="$MPD_LIBS -lsocket",) AC_CHECK_LIB(socket,socket,MPD_LIBS="$MPD_LIBS -lsocket",)
AC_CHECK_LIB(nsl,gethostbyname,MPD_LIBS="$MPD_LIBS -lnsl",) AC_CHECK_LIB(nsl,gethostbyname,MPD_LIBS="$MPD_LIBS -lnsl",)
AC_CHECK_LIB(m,exp,MPD_LIBS="$MPD_LIBS -lm",)
AC_CHECK_HEADER(langinfo.h,MPD_CFLAGS="$MPD_CFLAGS -DHAVE_LANGINFO",) AC_CHECK_HEADER(langinfo.h,MPD_CFLAGS="$MPD_CFLAGS -DHAVE_LANGINFO",)
AC_CHECK_HEADER(locale.h,MPD_CFLAGS="$MPD_CFLAGS -DHAVE_LOCALE",) AC_CHECK_HEADER(locale.h,MPD_CFLAGS="$MPD_CFLAGS -DHAVE_LOCALE",)
......
...@@ -219,17 +219,6 @@ if test -n "$prevopt"; then ...@@ -219,17 +219,6 @@ if test -n "$prevopt"; then
exit 1 exit 1
fi fi
# Mandrake: (gc) It's bad to link C++ code with GCC, so we need to use the compiler name if provided
if test "$mode" = link && test -n "$archive_cmds" && test -x "/usr/bin/perl"; then
case $nonopt in
*cc | *++ | gcc* | *-gcc* | egcs*)
archive_cmds=`echo $archive_cmds | perl -pe 's/^\S+\s+//'`
archive_cmds="$nonopt $archive_cmds"
archive_expsym_cmds=`echo $archive_expsym_cmds | perl -pe 's/^\S+\s+//'`
archive_expsym_cmds="$nonopt $archive_expsym_cmds"
esac
fi
# If this variable is set in any of the actions, the command in it # If this variable is set in any of the actions, the command in it
# will be execed at the end. This prevents here-documents from being # will be execed at the end. This prevents here-documents from being
# left over by shells. # left over by shells.
......
...@@ -47,8 +47,6 @@ ...@@ -47,8 +47,6 @@
#include <unistd.h> #include <unistd.h>
#include <string.h> #include <string.h>
#define FADE_CHUNKS 1024
int * decode_pid = NULL; int * decode_pid = NULL;
void decodeSigHandler(int sig) { void decodeSigHandler(int sig) {
...@@ -91,7 +89,7 @@ void quitDecode(PlayerControl * pc, DecoderControl * dc) { ...@@ -91,7 +89,7 @@ void quitDecode(PlayerControl * pc, DecoderControl * dc) {
} }
int calculateCrossFadeChunks(PlayerControl * pc, AudioFormat * af) { int calculateCrossFadeChunks(PlayerControl * pc, AudioFormat * af) {
int chunks; long chunks;
if(pc->crossFade<=0) return 0; if(pc->crossFade<=0) return 0;
...@@ -104,7 +102,7 @@ int calculateCrossFadeChunks(PlayerControl * pc, AudioFormat * af) { ...@@ -104,7 +102,7 @@ int calculateCrossFadeChunks(PlayerControl * pc, AudioFormat * af) {
if(chunks<0) chunks = 0; if(chunks<0) chunks = 0;
return chunks; return (int)chunks;
} }
int waitOnDecode(PlayerControl * pc, AudioFormat * af, DecoderControl * dc, int waitOnDecode(PlayerControl * pc, AudioFormat * af, DecoderControl * dc,
...@@ -347,7 +345,7 @@ void decode() { ...@@ -347,7 +345,7 @@ void decode() {
else if((cb->begin!=cb->end || cb->wrap) && else if((cb->begin!=cb->end || cb->wrap) &&
cb->begin!=cb->next) cb->begin!=cb->next)
{ {
if(doCrossFade==1 && cb->next>=0 && if(doCrossFade==1 && cb->next>=0 &&
((cb->next>cb->begin && ((cb->next>cb->begin &&
(fadePosition=cb->next-cb->begin) (fadePosition=cb->next-cb->begin)
<=crossFadeChunks) || <=crossFadeChunks) ||
...@@ -358,9 +356,9 @@ void decode() { ...@@ -358,9 +356,9 @@ void decode() {
if(nextChunk<0) { if(nextChunk<0) {
crossFadeChunks = fadePosition; crossFadeChunks = fadePosition;
} }
nextChunk = cb->begin+crossFadeChunks;
test = cb->end; test = cb->end;
if(cb->wrap) test+=buffered_chunks; if(cb->wrap) test+=buffered_chunks;
nextChunk = cb->begin+crossFadeChunks;
if(nextChunk<test) { if(nextChunk<test) {
if(nextChunk>=buffered_chunks) if(nextChunk>=buffered_chunks)
{ {
...@@ -392,10 +390,7 @@ void decode() { ...@@ -392,10 +390,7 @@ void decode() {
{ {
doCrossFade = -1; doCrossFade = -1;
} }
else { else continue;
usleep(10);
continue;
}
} }
} }
pc->elapsedTime = cb->times[cb->begin]; pc->elapsedTime = cb->times[cb->begin];
......
libid3tag - ID3 tag manipulation library libid3tag - ID3 tag manipulation library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
$Id: CHANGES,v 1.1 2003/08/14 03:57:13 shank Exp $ $Id: CHANGES,v 1.11 2004/02/17 02:04:10 rob Exp $
=============================================================================== ===============================================================================
Version 0.15.1 (beta)
* Updated to autoconf 2.59, automake 1.8.2, libtool 1.5.2.
* Fixed a potential problem in file.c when writing empty ID3v2 tags.
* Added new id3_field_gettextencoding() API routine.
Version 0.15.0 (beta) Version 0.15.0 (beta)
* Updated to autoconf 2.57, automake 1.7.5, libtool 1.4.3. * Updated to autoconf 2.57, automake 1.7.5, libtool 1.4.3.
......
libid3tag - ID3 tag manipulation library libid3tag - ID3 tag manipulation library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
......
libid3tag - ID3 tag manipulation library libid3tag - ID3 tag manipulation library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
$Id: CREDITS,v 1.1 2003/08/14 03:57:13 shank Exp $ $Id: CREDITS,v 1.2 2004/01/23 09:41:32 rob Exp $
=============================================================================== ===============================================================================
......
## ##
## libid3tag - ID3 tag manipulation library ## libid3tag - ID3 tag manipulation library
## Copyright (C) 2000-2003 Underbit Technologies, Inc. ## Copyright (C) 2000-2004 Underbit Technologies, Inc.
## ##
## This program is free software; you can redistribute it and/or modify ## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU General Public License as published by ## it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
## along with this program; if not, write to the Free Software ## along with this program; if not, write to the Free Software
## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
## ##
## $Id: Makefile.am,v 1.1 2003/08/14 03:57:13 shank Exp $ ## $Id: Makefile.am,v 1.26 2004/02/17 02:11:28 rob Exp $
## ##
## Process this file with automake to produce Makefile.in ## Process this file with automake to produce Makefile.in
...@@ -63,9 +63,9 @@ noinst_HEADERS = id3tag.h ...@@ -63,9 +63,9 @@ noinst_HEADERS = id3tag.h
## 6. If any interfaces have been removed since the last public release, ## 6. If any interfaces have been removed since the last public release,
## then set AGE to 0. ## then set AGE to 0.
version_current = 2 version_current = 3
version_revision = 0 version_revision = 0
version_age = 2 version_age = 3
version_info = $(version_current):$(version_revision):$(version_age) version_info = $(version_current):$(version_revision):$(version_age)
...@@ -90,7 +90,7 @@ EXTRA_libid3tag_la_SOURCES = \ ...@@ -90,7 +90,7 @@ EXTRA_libid3tag_la_SOURCES = \
frametype.gperf compat.gperf genre.dat.in \ frametype.gperf compat.gperf genre.dat.in \
debug.c debug.h debug.c debug.h
libid3tag_la_LDFLAGS = -version-info $(version_info) #libid3tag_la_LDFLAGS = -version-info $(version_info)
BUILT_SOURCES = frametype.c compat.c genre.dat BUILT_SOURCES = frametype.c compat.c genre.dat
......
...@@ -127,9 +127,9 @@ SUBDIRS = ...@@ -127,9 +127,9 @@ SUBDIRS =
noinst_LTLIBRARIES = libid3tag.la noinst_LTLIBRARIES = libid3tag.la
noinst_HEADERS = id3tag.h noinst_HEADERS = id3tag.h
version_current = 2 version_current = 3
version_revision = 0 version_revision = 0
version_age = 2 version_age = 3
version_info = $(version_current):$(version_revision):$(version_age) version_info = $(version_current):$(version_revision):$(version_age)
...@@ -154,8 +154,8 @@ EXTRA_libid3tag_la_SOURCES = \ ...@@ -154,8 +154,8 @@ EXTRA_libid3tag_la_SOURCES = \
debug.c debug.h debug.c debug.h
libid3tag_la_LDFLAGS = -version-info $(version_info)
#libid3tag_la_LDFLAGS = -version-info $(version_info)
BUILT_SOURCES = frametype.c compat.c genre.dat BUILT_SOURCES = frametype.c compat.c genre.dat
subdir = . subdir = .
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
...@@ -164,6 +164,7 @@ CONFIG_HEADER = config.h ...@@ -164,6 +164,7 @@ CONFIG_HEADER = config.h
CONFIG_CLEAN_FILES = libid3tag.list CONFIG_CLEAN_FILES = libid3tag.list
LTLIBRARIES = $(noinst_LTLIBRARIES) LTLIBRARIES = $(noinst_LTLIBRARIES)
libid3tag_la_LDFLAGS =
libid3tag_la_LIBADD = libid3tag_la_LIBADD =
am__libid3tag_la_SOURCES_DIST = version.c ucs4.c latin1.c utf16.c utf8.c \ am__libid3tag_la_SOURCES_DIST = version.c ucs4.c latin1.c utf16.c utf8.c \
parse.c render.c field.c frametype.c compat.c genre.c frame.c \ parse.c render.c field.c frametype.c compat.c genre.c frame.c \
......
libid3tag - ID3 tag manipulation library libid3tag - ID3 tag manipulation library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
$Id: README,v 1.1 2003/08/14 03:57:13 shank Exp $ $Id: README,v 1.5 2004/01/23 09:41:32 rob Exp $
=============================================================================== ===============================================================================
......
libid3tag - ID3 tag manipulation library libid3tag - ID3 tag manipulation library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
$Id: TODO,v 1.1 2003/08/14 03:57:13 shank Exp $ $Id: TODO,v 1.2 2004/01/23 09:41:32 rob Exp $
=============================================================================== ===============================================================================
......
0.15.0b 0.15.1b
configure.ac:24 configure.ac:24
id3tag.h:334-337 id3tag.h:338-341
msvc++/config.h:57 msvc++/config.h:59,65,71
Makefile.am:63-65 Makefile.am:63-65
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
/* Command-line: gperf -tCcTonD -K id -N id3_compat_lookup -s -3 -k '*' compat.gperf */ /* Command-line: gperf -tCcTonD -K id -N id3_compat_lookup -s -3 -k '*' compat.gperf */
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* Id: compat.gperf,v 1.1 2003/08/14 03:57:13 shank Exp * Id: compat.gperf,v 1.11 2004/01/23 09:41:32 rob Exp
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
%{ %{
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: compat.gperf,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: compat.gperf,v 1.11 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: compat.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: compat.h,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_COMPAT_H # ifndef LIBID3TAG_COMPAT_H
......
#! /bin/sh #! /bin/sh
# From configure.ac Id: configure.ac,v 1.1 2003/08/14 03:57:13 shank Exp . # From configure.ac Id: configure.ac,v 1.12 2004/01/23 23:22:46 rob Exp .
# Guess values for system-dependent variables and create Makefiles. # Guess values for system-dependent variables and create Makefiles.
# Generated by GNU Autoconf 2.58 for ID3 Tag 0.15.0b. # Generated by GNU Autoconf 2.58 for ID3 Tag 0.15.1b.
# #
# Report bugs to <support@underbit.com>. # Report bugs to <support@underbit.com>.
# #
...@@ -429,8 +429,8 @@ SHELL=${CONFIG_SHELL-/bin/sh} ...@@ -429,8 +429,8 @@ SHELL=${CONFIG_SHELL-/bin/sh}
# Identity of this package. # Identity of this package.
PACKAGE_NAME='ID3 Tag' PACKAGE_NAME='ID3 Tag'
PACKAGE_TARNAME='libid3tag' PACKAGE_TARNAME='libid3tag'
PACKAGE_VERSION='0.15.0b' PACKAGE_VERSION='0.15.1b'
PACKAGE_STRING='ID3 Tag 0.15.0b' PACKAGE_STRING='ID3 Tag 0.15.1b'
PACKAGE_BUGREPORT='support@underbit.com' PACKAGE_BUGREPORT='support@underbit.com'
ac_unique_file="id3tag.h" ac_unique_file="id3tag.h"
...@@ -940,7 +940,7 @@ if test "$ac_init_help" = "long"; then ...@@ -940,7 +940,7 @@ if test "$ac_init_help" = "long"; then
# Omit some internal or obsolete options to make the list less imposing. # Omit some internal or obsolete options to make the list less imposing.
# This message is too long to be a string in the A/UX 3.1 sh. # This message is too long to be a string in the A/UX 3.1 sh.
cat <<_ACEOF cat <<_ACEOF
\`configure' configures ID3 Tag 0.15.0b to adapt to many kinds of systems. \`configure' configures ID3 Tag 0.15.1b to adapt to many kinds of systems.
Usage: $0 [OPTION]... [VAR=VALUE]... Usage: $0 [OPTION]... [VAR=VALUE]...
...@@ -1006,7 +1006,7 @@ fi ...@@ -1006,7 +1006,7 @@ fi
if test -n "$ac_init_help"; then if test -n "$ac_init_help"; then
case $ac_init_help in case $ac_init_help in
short | recursive ) echo "Configuration of ID3 Tag 0.15.0b:";; short | recursive ) echo "Configuration of ID3 Tag 0.15.1b:";;
esac esac
cat <<\_ACEOF cat <<\_ACEOF
...@@ -1134,7 +1134,7 @@ fi ...@@ -1134,7 +1134,7 @@ fi
test -n "$ac_init_help" && exit 0 test -n "$ac_init_help" && exit 0
if $ac_init_version; then if $ac_init_version; then
cat <<\_ACEOF cat <<\_ACEOF
ID3 Tag configure 0.15.0b ID3 Tag configure 0.15.1b
generated by GNU Autoconf 2.58 generated by GNU Autoconf 2.58
Copyright (C) 2003 Free Software Foundation, Inc. Copyright (C) 2003 Free Software Foundation, Inc.
...@@ -1148,7 +1148,7 @@ cat >&5 <<_ACEOF ...@@ -1148,7 +1148,7 @@ cat >&5 <<_ACEOF
This file contains any messages produced by compilers while This file contains any messages produced by compilers while
running configure, to aid debugging if configure makes a mistake. running configure, to aid debugging if configure makes a mistake.
It was created by ID3 Tag $as_me 0.15.0b, which was It was created by ID3 Tag $as_me 0.15.1b, which was
generated by GNU Autoconf 2.58. Invocation command line was generated by GNU Autoconf 2.58. Invocation command line was
$ $0 $@ $ $0 $@
...@@ -1763,7 +1763,7 @@ fi ...@@ -1763,7 +1763,7 @@ fi
# Define the identity of the package. # Define the identity of the package.
PACKAGE='libid3tag' PACKAGE='libid3tag'
VERSION='0.15.0b' VERSION='0.15.1b'
cat >>confdefs.h <<_ACEOF cat >>confdefs.h <<_ACEOF
...@@ -9529,7 +9529,7 @@ _ASBOX ...@@ -9529,7 +9529,7 @@ _ASBOX
} >&5 } >&5
cat >&5 <<_CSEOF cat >&5 <<_CSEOF
This file was extended by ID3 Tag $as_me 0.15.0b, which was This file was extended by ID3 Tag $as_me 0.15.1b, which was
generated by GNU Autoconf 2.58. Invocation command line was generated by GNU Autoconf 2.58. Invocation command line was
CONFIG_FILES = $CONFIG_FILES CONFIG_FILES = $CONFIG_FILES
...@@ -9592,7 +9592,7 @@ _ACEOF ...@@ -9592,7 +9592,7 @@ _ACEOF
cat >>$CONFIG_STATUS <<_ACEOF cat >>$CONFIG_STATUS <<_ACEOF
ac_cs_version="\\ ac_cs_version="\\
ID3 Tag config.status 0.15.0b ID3 Tag config.status 0.15.1b
configured by $0, generated by GNU Autoconf 2.58, configured by $0, generated by GNU Autoconf 2.58,
with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\" with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\"
......
dnl -*- m4 -*- dnl -*- m4 -*-
dnl dnl
dnl libid3tag - ID3 tag manipulation library dnl libid3tag - ID3 tag manipulation library
dnl Copyright (C) 2000-2003 Underbit Technologies, Inc. dnl Copyright (C) 2000-2004 Underbit Technologies, Inc.
dnl dnl
dnl This program is free software; you can redistribute it and/or modify dnl This program is free software; you can redistribute it and/or modify
dnl it under the terms of the GNU General Public License as published by dnl it under the terms of the GNU General Public License as published by
...@@ -17,11 +17,11 @@ dnl You should have received a copy of the GNU General Public License ...@@ -17,11 +17,11 @@ dnl You should have received a copy of the GNU General Public License
dnl along with this program; if not, write to the Free Software dnl along with this program; if not, write to the Free Software
dnl Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA dnl Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
dnl dnl
AC_REVISION([$Id: configure.ac,v 1.1 2003/08/14 03:57:13 shank Exp $])dnl AC_REVISION([$Id: configure.ac,v 1.12 2004/01/23 23:22:46 rob Exp $])dnl
dnl Process this file with autoconf to produce a configure script. dnl Process this file with autoconf to produce a configure script.
AC_INIT([ID3 Tag], [0.15.0b], [support@underbit.com], [libid3tag]) AC_INIT([ID3 Tag], [0.15.1b], [support@underbit.com], [libid3tag])
AC_PREREQ(2.53) AC_PREREQ(2.53)
AC_CONFIG_SRCDIR([id3tag.h]) AC_CONFIG_SRCDIR([id3tag.h])
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: crc.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: crc.c,v 1.11 2004/02/17 02:04:10 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -104,10 +104,10 @@ unsigned long const crc_table[256] = { ...@@ -104,10 +104,10 @@ unsigned long const crc_table[256] = {
}; };
/* /*
* NAME: crc->calculate() * NAME: crc->compute()
* DESCRIPTION: compute CRC-32 value (ISO 3309) * DESCRIPTION: calculate CRC-32 value (ISO 3309)
*/ */
unsigned long id3_crc_calculate(id3_byte_t const *data, id3_length_t length) unsigned long id3_crc_compute(id3_byte_t const *data, id3_length_t length)
{ {
register unsigned long crc; register unsigned long crc;
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: crc.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: crc.h,v 1.8 2004/02/17 02:04:10 rob Exp $
*/ */
# ifndef LIBID3TAG_CRC_H # ifndef LIBID3TAG_CRC_H
...@@ -24,6 +24,6 @@ ...@@ -24,6 +24,6 @@
# include "id3tag.h" # include "id3tag.h"
unsigned long id3_crc_calculate(id3_byte_t const *, id3_length_t); unsigned long id3_crc_compute(id3_byte_t const *, id3_length_t);
# endif # endif
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: debug.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: debug.c,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: debug.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: debug.h,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_DEBUG_H # ifndef LIBID3TAG_DEBUG_H
...@@ -25,8 +25,7 @@ ...@@ -25,8 +25,7 @@
# include <stdlib.h> # include <stdlib.h>
void *id3_debug_malloc(size_t, char const *, unsigned int); void *id3_debug_malloc(size_t, char const *, unsigned int);
void *id3_debug_calloc(size_t, size_t, void *id3_debug_calloc(size_t, size_t, char const *, unsigned int);
char const *file, unsigned int line);
void *id3_debug_realloc(void *, size_t, char const *, unsigned int); void *id3_debug_realloc(void *, size_t, char const *, unsigned int);
void id3_debug_free(void *, char const *, unsigned int); void id3_debug_free(void *, char const *, unsigned int);
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: field.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: field.c,v 1.16 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -750,6 +750,21 @@ signed long id3_field_getint(union id3_field const *field) ...@@ -750,6 +750,21 @@ signed long id3_field_getint(union id3_field const *field)
} }
/* /*
* NAME: field->gettextencoding()
* DESCRIPTION: return the value of a text encoding field
*/
enum id3_field_textencoding
id3_field_gettextencoding(union id3_field const *field)
{
assert(field);
if (field->type != ID3_FIELD_TYPE_TEXTENCODING)
return -1;
return field->number.value;
}
/*
* NAME: field->getlatin1() * NAME: field->getlatin1()
* DESCRIPTION: return the value of a latin1 field * DESCRIPTION: return the value of a latin1 field
*/ */
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: field.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: field.h,v 1.9 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_FIELD_H # ifndef LIBID3TAG_FIELD_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: file.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: file.c,v 1.21 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -522,7 +522,7 @@ int v1_write(struct id3_file *file, ...@@ -522,7 +522,7 @@ int v1_write(struct id3_file *file,
if (fseek(file->iofile, (file->flags & ID3_FILE_FLAG_ID3V1) ? -128 : 0, if (fseek(file->iofile, (file->flags & ID3_FILE_FLAG_ID3V1) ? -128 : 0,
SEEK_END) == -1 || SEEK_END) == -1 ||
(location = ftell(file->iofile)) == -1 || (location = ftell(file->iofile)) == -1 ||
fwrite(data, 128, 1, file->iofile) == 0 || fwrite(data, 128, 1, file->iofile) != 1 ||
fflush(file->iofile) == EOF) fflush(file->iofile) == EOF)
return -1; return -1;
...@@ -577,13 +577,14 @@ int v2_write(struct id3_file *file, ...@@ -577,13 +577,14 @@ int v2_write(struct id3_file *file,
{ {
assert(!data || length > 0); assert(!data || length > 0);
if (((file->ntags == 1 && !(file->flags & ID3_FILE_FLAG_ID3V1)) || if (data &&
((file->ntags == 1 && !(file->flags & ID3_FILE_FLAG_ID3V1)) ||
(file->ntags == 2 && (file->flags & ID3_FILE_FLAG_ID3V1))) && (file->ntags == 2 && (file->flags & ID3_FILE_FLAG_ID3V1))) &&
file->tags[0].length == length) { file->tags[0].length == length) {
/* easy special case: rewrite existing tag in-place */ /* easy special case: rewrite existing tag in-place */
if (fseek(file->iofile, file->tags[0].location, SEEK_SET) == -1 || if (fseek(file->iofile, file->tags[0].location, SEEK_SET) == -1 ||
fwrite(data, length, 1, file->iofile) == 0 || fwrite(data, length, 1, file->iofile) != 1 ||
fflush(file->iofile) == EOF) fflush(file->iofile) == EOF)
return -1; return -1;
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: file.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: file.h,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_FILE_H # ifndef LIBID3TAG_FILE_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: frame.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: frame.c,v 1.15 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: frame.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: frame.h,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_FRAME_H # ifndef LIBID3TAG_FRAME_H
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
/* Command-line: gperf -tCcTonD -K id -N id3_frametype_lookup -s -3 -k '*' frametype.gperf */ /* Command-line: gperf -tCcTonD -K id -N id3_frametype_lookup -s -3 -k '*' frametype.gperf */
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* Id: frametype.gperf,v 1.1 2003/08/14 03:57:13 shank Exp * Id: frametype.gperf,v 1.7 2004/01/23 09:41:32 rob Exp
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
%{ %{
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: frametype.gperf,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: frametype.gperf,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: frametype.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: frametype.h,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_FRAMETYPE_H # ifndef LIBID3TAG_FRAMETYPE_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: genre.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: genre.c,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* Automatically generated from genre.dat.in */ /* Automatically generated from genre.dat.in */
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* Id: genre.dat.in,v 1.1 2003/08/14 03:57:13 shank Exp * Id: genre.dat.in,v 1.7 2004/01/23 09:41:32 rob Exp
*/ */
/* /*
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: genre.dat.in,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: genre.dat.in,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
/* /*
......
# #
# libid3tag - ID3 tag manipulation library # libid3tag - ID3 tag manipulation library
# Copyright (C) 2000-2003 Underbit Technologies, Inc. # Copyright (C) 2000-2004 Underbit Technologies, Inc.
# #
# This program is free software; you can redistribute it and/or modify # This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by # it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
# along with this program; if not, write to the Free Software # along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# #
# $Id: genre.dat.sed,v 1.1 2003/08/14 03:57:13 shank Exp $ # $Id: genre.dat.sed,v 1.10 2004/01/23 09:41:32 rob Exp $
# #
1i\ 1i\
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: genre.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: genre.h,v 1.6 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_GENRE_H # ifndef LIBID3TAG_GENRE_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: global.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: global.h,v 1.9 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_GLOBAL_H # ifndef LIBID3TAG_GLOBAL_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
* If you would like to negotiate alternate licensing terms, you may do * If you would like to negotiate alternate licensing terms, you may do
* so by contacting: Underbit Technologies, Inc. <info@underbit.com> * so by contacting: Underbit Technologies, Inc. <info@underbit.com>
* *
* $Id: id3tag.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: id3tag.h,v 1.17 2004/01/23 23:22:46 rob Exp $
*/ */
# ifndef LIBID3TAG_ID3TAG_H # ifndef LIBID3TAG_ID3TAG_H
...@@ -300,6 +300,7 @@ int id3_field_setbinarydata(union id3_field *, ...@@ -300,6 +300,7 @@ int id3_field_setbinarydata(union id3_field *,
id3_byte_t const *, id3_length_t); id3_byte_t const *, id3_length_t);
signed long id3_field_getint(union id3_field const *); signed long id3_field_getint(union id3_field const *);
enum id3_field_textencoding id3_field_gettextencoding(union id3_field const *);
id3_latin1_t const *id3_field_getlatin1(union id3_field const *); id3_latin1_t const *id3_field_getlatin1(union id3_field const *);
id3_latin1_t const *id3_field_getfulllatin1(union id3_field const *); id3_latin1_t const *id3_field_getfulllatin1(union id3_field const *);
id3_ucs4_t const *id3_field_getstring(union id3_field const *); id3_ucs4_t const *id3_field_getstring(union id3_field const *);
...@@ -336,7 +337,7 @@ id3_ucs4_t *id3_utf8_ucs4duplicate(id3_utf8_t const *); ...@@ -336,7 +337,7 @@ id3_ucs4_t *id3_utf8_ucs4duplicate(id3_utf8_t const *);
# define ID3_VERSION_MAJOR 0 # define ID3_VERSION_MAJOR 0
# define ID3_VERSION_MINOR 15 # define ID3_VERSION_MINOR 15
# define ID3_VERSION_PATCH 0 # define ID3_VERSION_PATCH 1
# define ID3_VERSION_EXTRA " (beta)" # define ID3_VERSION_EXTRA " (beta)"
# define ID3_VERSION_STRINGIZE(str) #str # define ID3_VERSION_STRINGIZE(str) #str
...@@ -347,7 +348,7 @@ id3_ucs4_t *id3_utf8_ucs4duplicate(id3_utf8_t const *); ...@@ -347,7 +348,7 @@ id3_ucs4_t *id3_utf8_ucs4duplicate(id3_utf8_t const *);
ID3_VERSION_STRING(ID3_VERSION_PATCH) \ ID3_VERSION_STRING(ID3_VERSION_PATCH) \
ID3_VERSION_EXTRA ID3_VERSION_EXTRA
# define ID3_PUBLISHYEAR "2000-2003" # define ID3_PUBLISHYEAR "2000-2004"
# define ID3_AUTHOR "Underbit Technologies, Inc." # define ID3_AUTHOR "Underbit Technologies, Inc."
# define ID3_EMAIL "info@underbit.com" # define ID3_EMAIL "info@underbit.com"
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: latin1.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: latin1.c,v 1.10 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: latin1.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: latin1.h,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_LATIN1_H # ifndef LIBID3TAG_LATIN1_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: parse.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: parse.c,v 1.9 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: parse.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: parse.h,v 1.6 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_PARSE_H # ifndef LIBID3TAG_PARSE_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: render.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: render.c,v 1.11 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: render.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: render.h,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_RENDER_H # ifndef LIBID3TAG_RENDER_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: tag.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: tag.c,v 1.20 2004/02/17 02:04:10 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -506,7 +506,7 @@ struct id3_tag *v2_parse(id3_byte_t const *ptr) ...@@ -506,7 +506,7 @@ struct id3_tag *v2_parse(id3_byte_t const *ptr)
crc = id3_parse_uint(&ehptr, 4); crc = id3_parse_uint(&ehptr, 4);
if (crc != id3_crc_calculate(ptr, end - ptr)) if (crc != id3_crc_compute(ptr, end - ptr))
goto fail; goto fail;
tag->extendedflags |= ID3_TAG_EXTENDEDFLAG_CRCDATAPRESENT; tag->extendedflags |= ID3_TAG_EXTENDEDFLAG_CRCDATAPRESENT;
...@@ -579,7 +579,7 @@ struct id3_tag *v2_parse(id3_byte_t const *ptr) ...@@ -579,7 +579,7 @@ struct id3_tag *v2_parse(id3_byte_t const *ptr)
crc = id3_parse_syncsafe(&ehptr, 5); crc = id3_parse_syncsafe(&ehptr, 5);
ehptr += bytes - 5; ehptr += bytes - 5;
if (crc != id3_crc_calculate(ptr, end - ptr)) if (crc != id3_crc_compute(ptr, end - ptr))
goto fail; goto fail;
} }
...@@ -895,7 +895,7 @@ id3_length_t id3_tag_render(struct id3_tag const *tag, id3_byte_t *buffer) ...@@ -895,7 +895,7 @@ id3_length_t id3_tag_render(struct id3_tag const *tag, id3_byte_t *buffer)
if (crc_ptr) { if (crc_ptr) {
id3_render_syncsafe(&crc_ptr, id3_render_syncsafe(&crc_ptr,
id3_crc_calculate(frames_ptr, *ptr - frames_ptr), 5); id3_crc_compute(frames_ptr, *ptr - frames_ptr), 5);
} }
/* footer */ /* footer */
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: tag.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: tag.h,v 1.10 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_TAG_H # ifndef LIBID3TAG_TAG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: ucs4.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: ucs4.c,v 1.13 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: ucs4.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: ucs4.h,v 1.11 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_UCS4_H # ifndef LIBID3TAG_UCS4_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: utf16.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: utf16.c,v 1.9 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: utf16.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: utf16.h,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_UTF16_H # ifndef LIBID3TAG_UTF16_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: utf8.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: utf8.c,v 1.9 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: utf8.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: utf8.h,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_UTF8_H # ifndef LIBID3TAG_UTF8_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: util.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: util.c,v 1.9 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: util.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: util.h,v 1.6 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_UTIL_H # ifndef LIBID3TAG_UTIL_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: version.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: version.c,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libid3tag - ID3 tag manipulation library * libid3tag - ID3 tag manipulation library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: version.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: version.h,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBID3TAG_VERSION_H # ifndef LIBID3TAG_VERSION_H
......
libmad - MPEG audio decoder library libmad - MPEG audio decoder library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
$Id: CHANGES,v 1.1 2003/08/14 03:57:13 shank Exp $ $Id: CHANGES,v 1.14 2004/02/17 02:02:03 rob Exp $
=============================================================================== ===============================================================================
Version 0.15.1 (beta)
* Updated to autoconf 2.59, automake 1.8.2, libtool 1.5.2.
* Replaced Layer III IMDCT routine with one based on a faster algorithm,
improving both speed and accuracy.
* Improved portability of the Huffman table initialization.
* Fixed a problem that could result in an assertion failure in layer3.c
due to an invalid Layer III free format bitrate.
* Improved the robustness of Layer II bitrate/mode combinations, and added
a new MAD_ERROR_BADMODE error enum. The allowability of low-bitrate
stereo streams is influenced by the --enable-strict-iso option to
`configure'.
Version 0.15.0 (beta) Version 0.15.0 (beta)
* Updated to autoconf 2.57, automake 1.7.5, libtool 1.4.3. * Updated to autoconf 2.57, automake 1.7.5, libtool 1.4.3.
...@@ -98,7 +115,7 @@ Version 0.13.0 (beta) ...@@ -98,7 +115,7 @@ Version 0.13.0 (beta)
* Eliminated `+' from asm constraints under Intel for better compatibility * Eliminated `+' from asm constraints under Intel for better compatibility
with some compilers. with some compilers.
* Fixed a PIC-related problem in libmad/imdct_l_arm.S. * Fixed a PIC-related problem in imdct_l_arm.S.
* Eliminated a static variable to make libmad thread-safe. * Eliminated a static variable to make libmad thread-safe.
...@@ -196,9 +213,9 @@ Version 0.12.0 (alpha) ...@@ -196,9 +213,9 @@ Version 0.12.0 (alpha)
* Further developed the async API; arbitrary messages can now be passed to * Further developed the async API; arbitrary messages can now be passed to
the subsidiary decoding process. the subsidiary decoding process.
* Streamlined libmad/timer.c and extended its interface. It now has * Streamlined timer.c and extended its interface. It now has support for
support for video frame/field lengths, including output support for video frame/field lengths, including output support for drop-frame
drop-frame encoding. encoding.
* Replaced many constant integer preprocessor defines with enums. * Replaced many constant integer preprocessor defines with enums.
......
libmad - MPEG audio decoder library libmad - MPEG audio decoder library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
......
libmad - MPEG audio decoder library libmad - MPEG audio decoder library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
$Id: CREDITS,v 1.1 2003/08/14 03:57:13 shank Exp $ $Id: CREDITS,v 1.5 2004/02/17 02:02:03 rob Exp $
=============================================================================== ===============================================================================
...@@ -19,12 +19,20 @@ CONTRIBUTORS ...@@ -19,12 +19,20 @@ CONTRIBUTORS
Anonymous Anonymous
2002/03/15: frame.c 2002/03/15: frame.c
- Reported problem with use of reserved emphasis value. - Reported problem with use of reserved emphasis value.
2003/08/31: layer12.c
- Suggested support for certain disallowed bitrate/mode
combinations.
Niek Albers <info@daansystems.com> Niek Albers <info@daansystems.com>
2003/04/21: layer3.c 2003/04/21: layer3.c
- Reported runtime uninitialized use of `ptr' in designating - Reported runtime uninitialized use of `ptr' in designating
ancillary bits after a decoding error. ancillary bits after a decoding error.
Christian Biere <cbiere@users.sourceforge.net>
2003/02/01: frame.c
- Reported assertion failure in layer3.c due to an
invalid/unsupported Layer III free format bitrate.
David Blythe <blythe@routefree.com> David Blythe <blythe@routefree.com>
2001/01/30: fixed.h 2001/01/30: fixed.h
- Provided initial PowerPC fixed-point assembly. - Provided initial PowerPC fixed-point assembly.
...@@ -33,6 +41,10 @@ CONTRIBUTORS ...@@ -33,6 +41,10 @@ CONTRIBUTORS
2000/09/20: imdct_l_arm.S 2000/09/20: imdct_l_arm.S
- Suggested patch for a.out compatibility. - Suggested patch for a.out compatibility.
Brian Cameron <Brian.Cameron@sun.com>
2003/07/02: huffman.c
- Suggested changes for improved portability.
Joshua Haberman <joshua@haberman.com> Joshua Haberman <joshua@haberman.com>
2001/08/10: decoder.c, huffman.c 2001/08/10: decoder.c, huffman.c
- Suggested portability fixes. - Suggested portability fixes.
...@@ -41,6 +53,10 @@ CONTRIBUTORS ...@@ -41,6 +53,10 @@ CONTRIBUTORS
2002/05/04: sf_table.dat, layer12.c 2002/05/04: sf_table.dat, layer12.c
- Reported problem with use of (missing) scalefactor index 63. - Reported problem with use of (missing) scalefactor index 63.
Felix von Leitner <felix-mad@fefe.de>
2003/01/21: fixed.h
- Suggested Intel scaling alternative for possible speedup.
Andre McCurdy <armccurdy@yahoo.co.uk> Andre McCurdy <armccurdy@yahoo.co.uk>
2000/08/10: imdct_l_arm.S 2000/08/10: imdct_l_arm.S
- ARM optimized assembly replacement for III_imdct_l(). - ARM optimized assembly replacement for III_imdct_l().
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: D.dat,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: D.dat,v 1.9 2004/01/23 09:41:32 rob Exp $
*/ */
/* /*
......
## ##
## libmad - MPEG audio decoder library ## libmad - MPEG audio decoder library
## Copyright (C) 2000-2003 Underbit Technologies, Inc. ## Copyright (C) 2000-2004 Underbit Technologies, Inc.
## ##
## This program is free software; you can redistribute it and/or modify ## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU General Public License as published by ## it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
## along with this program; if not, write to the Free Software ## along with this program; if not, write to the Free Software
## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
## ##
## $Id: Makefile.am,v 1.1 2003/08/14 03:57:13 shank Exp $ ## $Id: Makefile.am,v 1.23 2004/02/17 02:02:03 rob Exp $
## ##
## Process this file with automake to produce Makefile.in ## Process this file with automake to produce Makefile.in
...@@ -96,12 +96,12 @@ CLEANFILES = mad.h ...@@ -96,12 +96,12 @@ CLEANFILES = mad.h
## then set AGE to 0. ## then set AGE to 0.
version_current = 2 version_current = 2
version_revision = 0 version_revision = 1
version_age = 2 version_age = 2
version_info = $(version_current):$(version_revision):$(version_age) version_info = $(version_current):$(version_revision):$(version_age)
libmad_la_LDFLAGS = -version-info $(version_info) #libmad_la_LDFLAGS = -version-info $(version_info)
mad.h: config.status config.h Makefile.am \ mad.h: config.status config.h Makefile.am \
$(srcdir)/COPYRIGHT $(srcdir)/mad.h.sed $(exported_headers) $(srcdir)/COPYRIGHT $(srcdir)/mad.h.sed $(exported_headers)
......
...@@ -168,12 +168,10 @@ BUILT_SOURCES = mad.h ...@@ -168,12 +168,10 @@ BUILT_SOURCES = mad.h
CLEANFILES = mad.h CLEANFILES = mad.h
version_current = 2 version_current = 2
version_revision = 0 version_revision = 1
version_age = 2 version_age = 2
version_info = $(version_current):$(version_revision):$(version_age) version_info = $(version_current):$(version_revision):$(version_age)
libmad_la_LDFLAGS = -version-info $(version_info)
subdir = . subdir = .
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
mkinstalldirs = $(SHELL) $(top_srcdir)/../../mkinstalldirs mkinstalldirs = $(SHELL) $(top_srcdir)/../../mkinstalldirs
...@@ -181,6 +179,7 @@ CONFIG_HEADER = config.h ...@@ -181,6 +179,7 @@ CONFIG_HEADER = config.h
CONFIG_CLEAN_FILES = libmad.list CONFIG_CLEAN_FILES = libmad.list
LTLIBRARIES = $(noinst_LTLIBRARIES) LTLIBRARIES = $(noinst_LTLIBRARIES)
libmad_la_LDFLAGS =
am__objects_1 = am__objects_1 =
am__objects_2 = $(am__objects_1) am__objects_2 = $(am__objects_1)
am_libmad_la_OBJECTS = version.lo fixed.lo bit.lo timer.lo stream.lo \ am_libmad_la_OBJECTS = version.lo fixed.lo bit.lo timer.lo stream.lo \
...@@ -713,6 +712,8 @@ uninstall-info: uninstall-info-recursive ...@@ -713,6 +712,8 @@ uninstall-info: uninstall-info-recursive
uninstall-info-recursive uninstall-recursive uninstall-info-recursive uninstall-recursive
#libmad_la_LDFLAGS = -version-info $(version_info)
mad.h: config.status config.h Makefile.am \ mad.h: config.status config.h Makefile.am \
$(srcdir)/COPYRIGHT $(srcdir)/mad.h.sed $(exported_headers) $(srcdir)/COPYRIGHT $(srcdir)/mad.h.sed $(exported_headers)
(sed -e '1s|.*|/*|' -e '1b' -e '$$s|.*| */|' -e '$$b' \ (sed -e '1s|.*|/*|' -e '1b' -e '$$s|.*| */|' -e '$$b' \
......
libmad - MPEG audio decoder library libmad - MPEG audio decoder library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
$Id: README,v 1.1 2003/08/14 03:57:13 shank Exp $ $Id: README,v 1.4 2004/01/23 09:41:32 rob Exp $
=============================================================================== ===============================================================================
......
libmad - MPEG audio decoder library libmad - MPEG audio decoder library
Copyright (C) 2000-2003 Underbit Technologies, Inc. Copyright (C) 2000-2004 Underbit Technologies, Inc.
$Id: TODO,v 1.1 2003/08/14 03:57:13 shank Exp $ $Id: TODO,v 1.3 2004/02/05 09:02:39 rob Exp $
=============================================================================== ===============================================================================
...@@ -57,7 +57,6 @@ libmad Layer I: ...@@ -57,7 +57,6 @@ libmad Layer I:
- check frame length sanity - check frame length sanity
libmad Layer II: libmad Layer II:
- check legal bitrate/mode combinations
- check frame length sanity - check frame length sanity
libmad Layer III: libmad Layer III:
......
0.15.0b 0.15.1b
configure.ac:24 configure.ac:24
version.h:25-28 version.h:25-28
msvc++/config.h:115 msvc++/config.h:99,105,120
msvc++/mad.h:38-41 msvc++/mad.h:41-44
Makefile.am:89-91 Makefile.am:98-100
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: bit.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: bit.c,v 1.12 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: bit.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: bit.h,v 1.12 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBMAD_BIT_H # ifndef LIBMAD_BIT_H
......
...@@ -118,6 +118,10 @@ ...@@ -118,6 +118,10 @@
/* Version number of package */ /* Version number of package */
#undef VERSION #undef VERSION
/* Define to 1 if your processor stores words with the most significant byte
first (like Motorola and SPARC, unlike Intel and VAX). */
#undef WORDS_BIGENDIAN
/* Define to empty if `const' does not conform to ANSI C. */ /* Define to empty if `const' does not conform to ANSI C. */
#undef const #undef const
......
#! /bin/sh #! /bin/sh
# From configure.ac Id: configure.ac,v 1.1 2003/08/14 03:57:13 shank Exp . # From configure.ac Id: configure.ac,v 1.9 2004/01/23 09:41:32 rob Exp .
# Guess values for system-dependent variables and create Makefiles. # Guess values for system-dependent variables and create Makefiles.
# Generated by GNU Autoconf 2.58 for MPEG Audio Decoder 0.15.0b. # Generated by GNU Autoconf 2.58 for MPEG Audio Decoder 0.15.1b.
# #
# Report bugs to <support@underbit.com>. # Report bugs to <support@underbit.com>.
# #
...@@ -429,8 +429,8 @@ SHELL=${CONFIG_SHELL-/bin/sh} ...@@ -429,8 +429,8 @@ SHELL=${CONFIG_SHELL-/bin/sh}
# Identity of this package. # Identity of this package.
PACKAGE_NAME='MPEG Audio Decoder' PACKAGE_NAME='MPEG Audio Decoder'
PACKAGE_TARNAME='libmad' PACKAGE_TARNAME='libmad'
PACKAGE_VERSION='0.15.0b' PACKAGE_VERSION='0.15.1b'
PACKAGE_STRING='MPEG Audio Decoder 0.15.0b' PACKAGE_STRING='MPEG Audio Decoder 0.15.1b'
PACKAGE_BUGREPORT='support@underbit.com' PACKAGE_BUGREPORT='support@underbit.com'
ac_unique_file="decoder.h" ac_unique_file="decoder.h"
...@@ -940,7 +940,7 @@ if test "$ac_init_help" = "long"; then ...@@ -940,7 +940,7 @@ if test "$ac_init_help" = "long"; then
# Omit some internal or obsolete options to make the list less imposing. # Omit some internal or obsolete options to make the list less imposing.
# This message is too long to be a string in the A/UX 3.1 sh. # This message is too long to be a string in the A/UX 3.1 sh.
cat <<_ACEOF cat <<_ACEOF
\`configure' configures MPEG Audio Decoder 0.15.0b to adapt to many kinds of systems. \`configure' configures MPEG Audio Decoder 0.15.1b to adapt to many kinds of systems.
Usage: $0 [OPTION]... [VAR=VALUE]... Usage: $0 [OPTION]... [VAR=VALUE]...
...@@ -1006,7 +1006,7 @@ fi ...@@ -1006,7 +1006,7 @@ fi
if test -n "$ac_init_help"; then if test -n "$ac_init_help"; then
case $ac_init_help in case $ac_init_help in
short | recursive ) echo "Configuration of MPEG Audio Decoder 0.15.0b:";; short | recursive ) echo "Configuration of MPEG Audio Decoder 0.15.1b:";;
esac esac
cat <<\_ACEOF cat <<\_ACEOF
...@@ -1142,7 +1142,7 @@ fi ...@@ -1142,7 +1142,7 @@ fi
test -n "$ac_init_help" && exit 0 test -n "$ac_init_help" && exit 0
if $ac_init_version; then if $ac_init_version; then
cat <<\_ACEOF cat <<\_ACEOF
MPEG Audio Decoder configure 0.15.0b MPEG Audio Decoder configure 0.15.1b
generated by GNU Autoconf 2.58 generated by GNU Autoconf 2.58
Copyright (C) 2003 Free Software Foundation, Inc. Copyright (C) 2003 Free Software Foundation, Inc.
...@@ -1156,7 +1156,7 @@ cat >&5 <<_ACEOF ...@@ -1156,7 +1156,7 @@ cat >&5 <<_ACEOF
This file contains any messages produced by compilers while This file contains any messages produced by compilers while
running configure, to aid debugging if configure makes a mistake. running configure, to aid debugging if configure makes a mistake.
It was created by MPEG Audio Decoder $as_me 0.15.0b, which was It was created by MPEG Audio Decoder $as_me 0.15.1b, which was
generated by GNU Autoconf 2.58. Invocation command line was generated by GNU Autoconf 2.58. Invocation command line was
$ $0 $@ $ $0 $@
...@@ -1771,7 +1771,7 @@ fi ...@@ -1771,7 +1771,7 @@ fi
# Define the identity of the package. # Define the identity of the package.
PACKAGE='libmad' PACKAGE='libmad'
VERSION='0.15.0b' VERSION='0.15.1b'
cat >>confdefs.h <<_ACEOF cat >>confdefs.h <<_ACEOF
...@@ -8850,6 +8850,236 @@ _ACEOF ...@@ -8850,6 +8850,236 @@ _ACEOF
;; ;;
esac esac
echo "$as_me:$LINENO: checking whether byte ordering is bigendian" >&5
echo $ECHO_N "checking whether byte ordering is bigendian... $ECHO_C" >&6
if test "${ac_cv_c_bigendian+set}" = set; then
echo $ECHO_N "(cached) $ECHO_C" >&6
else
# See if sys/param.h defines the BYTE_ORDER macro.
cat >conftest.$ac_ext <<_ACEOF
/* confdefs.h. */
_ACEOF
cat confdefs.h >>conftest.$ac_ext
cat >>conftest.$ac_ext <<_ACEOF
/* end confdefs.h. */
#include <sys/types.h>
#include <sys/param.h>
int
main ()
{
#if !BYTE_ORDER || !BIG_ENDIAN || !LITTLE_ENDIAN
bogus endian macros
#endif
;
return 0;
}
_ACEOF
rm -f conftest.$ac_objext
if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
(eval $ac_compile) 2>conftest.er1
ac_status=$?
grep -v '^ *+' conftest.er1 >conftest.err
rm -f conftest.er1
cat conftest.err >&5
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); } &&
{ ac_try='test -z "$ac_c_werror_flag"
|| test ! -s conftest.err'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; } &&
{ ac_try='test -s conftest.$ac_objext'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; }; then
# It does; now see whether it defined to BIG_ENDIAN or not.
cat >conftest.$ac_ext <<_ACEOF
/* confdefs.h. */
_ACEOF
cat confdefs.h >>conftest.$ac_ext
cat >>conftest.$ac_ext <<_ACEOF
/* end confdefs.h. */
#include <sys/types.h>
#include <sys/param.h>
int
main ()
{
#if BYTE_ORDER != BIG_ENDIAN
not big endian
#endif
;
return 0;
}
_ACEOF
rm -f conftest.$ac_objext
if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
(eval $ac_compile) 2>conftest.er1
ac_status=$?
grep -v '^ *+' conftest.er1 >conftest.err
rm -f conftest.er1
cat conftest.err >&5
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); } &&
{ ac_try='test -z "$ac_c_werror_flag"
|| test ! -s conftest.err'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; } &&
{ ac_try='test -s conftest.$ac_objext'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; }; then
ac_cv_c_bigendian=yes
else
echo "$as_me: failed program was:" >&5
sed 's/^/| /' conftest.$ac_ext >&5
ac_cv_c_bigendian=no
fi
rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
else
echo "$as_me: failed program was:" >&5
sed 's/^/| /' conftest.$ac_ext >&5
# It does not; compile a test program.
if test "$cross_compiling" = yes; then
# try to guess the endianness by grepping values into an object file
ac_cv_c_bigendian=unknown
cat >conftest.$ac_ext <<_ACEOF
/* confdefs.h. */
_ACEOF
cat confdefs.h >>conftest.$ac_ext
cat >>conftest.$ac_ext <<_ACEOF
/* end confdefs.h. */
short ascii_mm[] = { 0x4249, 0x4765, 0x6E44, 0x6961, 0x6E53, 0x7953, 0 };
short ascii_ii[] = { 0x694C, 0x5454, 0x656C, 0x6E45, 0x6944, 0x6E61, 0 };
void _ascii () { char *s = (char *) ascii_mm; s = (char *) ascii_ii; }
short ebcdic_ii[] = { 0x89D3, 0xE3E3, 0x8593, 0x95C5, 0x89C4, 0x9581, 0 };
short ebcdic_mm[] = { 0xC2C9, 0xC785, 0x95C4, 0x8981, 0x95E2, 0xA8E2, 0 };
void _ebcdic () { char *s = (char *) ebcdic_mm; s = (char *) ebcdic_ii; }
int
main ()
{
_ascii (); _ebcdic ();
;
return 0;
}
_ACEOF
rm -f conftest.$ac_objext
if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
(eval $ac_compile) 2>conftest.er1
ac_status=$?
grep -v '^ *+' conftest.er1 >conftest.err
rm -f conftest.er1
cat conftest.err >&5
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); } &&
{ ac_try='test -z "$ac_c_werror_flag"
|| test ! -s conftest.err'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; } &&
{ ac_try='test -s conftest.$ac_objext'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; }; then
if grep BIGenDianSyS conftest.$ac_objext >/dev/null ; then
ac_cv_c_bigendian=yes
fi
if grep LiTTleEnDian conftest.$ac_objext >/dev/null ; then
if test "$ac_cv_c_bigendian" = unknown; then
ac_cv_c_bigendian=no
else
# finding both strings is unlikely to happen, but who knows?
ac_cv_c_bigendian=unknown
fi
fi
else
echo "$as_me: failed program was:" >&5
sed 's/^/| /' conftest.$ac_ext >&5
fi
rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
else
cat >conftest.$ac_ext <<_ACEOF
/* confdefs.h. */
_ACEOF
cat confdefs.h >>conftest.$ac_ext
cat >>conftest.$ac_ext <<_ACEOF
/* end confdefs.h. */
int
main ()
{
/* Are we little or big endian? From Harbison&Steele. */
union
{
long l;
char c[sizeof (long)];
} u;
u.l = 1;
exit (u.c[sizeof (long) - 1] == 1);
}
_ACEOF
rm -f conftest$ac_exeext
if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5
(eval $ac_link) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); } && { ac_try='./conftest$ac_exeext'
{ (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
(eval $ac_try) 2>&5
ac_status=$?
echo "$as_me:$LINENO: \$? = $ac_status" >&5
(exit $ac_status); }; }; then
ac_cv_c_bigendian=no
else
echo "$as_me: program exited with status $ac_status" >&5
echo "$as_me: failed program was:" >&5
sed 's/^/| /' conftest.$ac_ext >&5
( exit $ac_status )
ac_cv_c_bigendian=yes
fi
rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext
fi
fi
rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
fi
echo "$as_me:$LINENO: result: $ac_cv_c_bigendian" >&5
echo "${ECHO_T}$ac_cv_c_bigendian" >&6
case $ac_cv_c_bigendian in
yes)
cat >>confdefs.h <<\_ACEOF
#define WORDS_BIGENDIAN 1
_ACEOF
;;
no)
;;
*)
{ { echo "$as_me:$LINENO: error: unknown endianness
presetting ac_cv_c_bigendian=no (or yes) will help" >&5
echo "$as_me: error: unknown endianness
presetting ac_cv_c_bigendian=no (or yes) will help" >&2;}
{ (exit 1); exit 1; }; } ;;
esac
echo "$as_me:$LINENO: checking for pid_t" >&5 echo "$as_me:$LINENO: checking for pid_t" >&5
echo $ECHO_N "checking for pid_t... $ECHO_C" >&6 echo $ECHO_N "checking for pid_t... $ECHO_C" >&6
if test "${ac_cv_type_pid_t+set}" = set; then if test "${ac_cv_type_pid_t+set}" = set; then
...@@ -10955,7 +11185,7 @@ _ASBOX ...@@ -10955,7 +11185,7 @@ _ASBOX
} >&5 } >&5
cat >&5 <<_CSEOF cat >&5 <<_CSEOF
This file was extended by MPEG Audio Decoder $as_me 0.15.0b, which was This file was extended by MPEG Audio Decoder $as_me 0.15.1b, which was
generated by GNU Autoconf 2.58. Invocation command line was generated by GNU Autoconf 2.58. Invocation command line was
CONFIG_FILES = $CONFIG_FILES CONFIG_FILES = $CONFIG_FILES
...@@ -11018,7 +11248,7 @@ _ACEOF ...@@ -11018,7 +11248,7 @@ _ACEOF
cat >>$CONFIG_STATUS <<_ACEOF cat >>$CONFIG_STATUS <<_ACEOF
ac_cs_version="\\ ac_cs_version="\\
MPEG Audio Decoder config.status 0.15.0b MPEG Audio Decoder config.status 0.15.1b
configured by $0, generated by GNU Autoconf 2.58, configured by $0, generated by GNU Autoconf 2.58,
with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\" with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\"
......
dnl -*- m4 -*- dnl -*- m4 -*-
dnl dnl
dnl libmad - MPEG audio decoder library dnl libmad - MPEG audio decoder library
dnl Copyright (C) 2000-2003 Underbit Technologies, Inc. dnl Copyright (C) 2000-2004 Underbit Technologies, Inc.
dnl dnl
dnl This program is free software; you can redistribute it and/or modify dnl This program is free software; you can redistribute it and/or modify
dnl it under the terms of the GNU General Public License as published by dnl it under the terms of the GNU General Public License as published by
...@@ -17,11 +17,11 @@ dnl You should have received a copy of the GNU General Public License ...@@ -17,11 +17,11 @@ dnl You should have received a copy of the GNU General Public License
dnl along with this program; if not, write to the Free Software dnl along with this program; if not, write to the Free Software
dnl Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA dnl Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
dnl dnl
AC_REVISION([$Id: configure.ac,v 1.1 2003/08/14 03:57:13 shank Exp $])dnl AC_REVISION([$Id: configure.ac,v 1.9 2004/01/23 09:41:32 rob Exp $])dnl
dnl Process this file with autoconf to produce a configure script. dnl Process this file with autoconf to produce a configure script.
AC_INIT([MPEG Audio Decoder], [0.15.0b], [support@underbit.com], [libmad]) AC_INIT([MPEG Audio Decoder], [0.15.1b], [support@underbit.com], [libmad])
AC_PREREQ(2.53) AC_PREREQ(2.53)
AC_CONFIG_SRCDIR([decoder.h]) AC_CONFIG_SRCDIR([decoder.h])
...@@ -212,6 +212,7 @@ dnl Checks for typedefs, structures, and compiler characteristics. ...@@ -212,6 +212,7 @@ dnl Checks for typedefs, structures, and compiler characteristics.
AC_C_CONST AC_C_CONST
AC_C_INLINE AC_C_INLINE
AC_C_BIGENDIAN
AC_TYPE_PID_T AC_TYPE_PID_T
AC_CHECK_SIZEOF(int, 2) AC_CHECK_SIZEOF(int, 2)
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: decoder.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: decoder.c,v 1.22 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: decoder.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: decoder.h,v 1.17 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBMAD_DECODER_H # ifndef LIBMAD_DECODER_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: fixed.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: fixed.c,v 1.13 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: fixed.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: fixed.h,v 1.38 2004/02/17 02:02:03 rob Exp $
*/ */
# ifndef LIBMAD_FIXED_H # ifndef LIBMAD_FIXED_H
...@@ -208,7 +208,22 @@ mad_fixed_t mad_f_mul_inline(mad_fixed_t x, mad_fixed_t y) ...@@ -208,7 +208,22 @@ mad_fixed_t mad_f_mul_inline(mad_fixed_t x, mad_fixed_t y)
: "cc"); \ : "cc"); \
__result; \ __result; \
}) })
# else # elif defined(OPT_INTEL)
/*
* Alternate Intel scaling that may or may not perform better.
*/
# define mad_f_scale64(hi, lo) \
({ mad_fixed_t __result; \
asm ("shrl %3,%1\n\t" \
"shll %4,%2\n\t" \
"orl %2,%1" \
: "=rm" (__result) \
: "0" (lo), "r" (hi), \
"I" (MAD_F_SCALEBITS), "I" (32 - MAD_F_SCALEBITS) \
: "cc"); \
__result; \
})
# else
# define mad_f_scale64(hi, lo) \ # define mad_f_scale64(hi, lo) \
({ mad_fixed_t __result; \ ({ mad_fixed_t __result; \
asm ("shrdl %3,%2,%1" \ asm ("shrdl %3,%2,%1" \
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: frame.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: frame.c,v 1.29 2004/02/04 22:59:19 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -376,7 +376,8 @@ int mad_header_decode(struct mad_header *header, struct mad_stream *stream) ...@@ -376,7 +376,8 @@ int mad_header_decode(struct mad_header *header, struct mad_stream *stream)
/* calculate free bit rate */ /* calculate free bit rate */
if (header->bitrate == 0) { if (header->bitrate == 0) {
if ((stream->freerate == 0 || !stream->sync) && if ((stream->freerate == 0 || !stream->sync ||
(header->layer == MAD_LAYER_III && stream->freerate > 640000)) &&
free_bitrate(stream, header) == -1) free_bitrate(stream, header) == -1)
goto fail; goto fail;
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: frame.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: frame.h,v 1.20 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBMAD_FRAME_H # ifndef LIBMAD_FRAME_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: global.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: global.h,v 1.11 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBMAD_GLOBAL_H # ifndef LIBMAD_GLOBAL_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: huffman.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: huffman.c,v 1.10 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -34,13 +34,19 @@ ...@@ -34,13 +34,19 @@
* These tables support decoding up to 4 Huffman code bits at a time. * These tables support decoding up to 4 Huffman code bits at a time.
*/ */
# if defined(__GNUC__) # if defined(__GNUC__) || \
# define PTR(offs, bits) { ptr: { 0, bits, offs } } (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901)
# define V(v, w, x, y, hlen) { value: { 1, hlen, v, w, x, y } } # define PTR(offs, bits) { .ptr = { 0, bits, offs } }
# define V(v, w, x, y, hlen) { .value = { 1, hlen, v, w, x, y } }
# else # else
# define PTR(offs, bits) { { 0, bits, offs } } # define PTR(offs, bits) { { 0, bits, offs } }
# define V(v, w, x, y, hlen) { { 1, hlen, (v << 0) | (w << 1) | \ # if defined(WORDS_BIGENDIAN)
(x << 2) | (y << 3) } } # define V(v, w, x, y, hlen) { { 1, hlen, (v << 11) | (w << 10) | \
(x << 9) | (y << 8) } }
# else
# define V(v, w, x, y, hlen) { { 1, hlen, (v << 0) | (w << 1) | \
(x << 2) | (y << 3) } }
# endif
# endif # endif
static static
...@@ -106,12 +112,17 @@ union huffquad const hufftabB[] = { ...@@ -106,12 +112,17 @@ union huffquad const hufftabB[] = {
# undef V # undef V
# undef PTR # undef PTR
# if defined(__GNUC__) # if defined(__GNUC__) || \
# define PTR(offs, bits) { ptr: { 0, bits, offs } } (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901)
# define V(x, y, hlen) { value: { 1, hlen, x, y } } # define PTR(offs, bits) { .ptr = { 0, bits, offs } }
# define V(x, y, hlen) { .value = { 1, hlen, x, y } }
# else # else
# define PTR(offs, bits) { { 0, bits, offs } } # define PTR(offs, bits) { { 0, bits, offs } }
# define V(x, y, hlen) { { 1, hlen, (x << 0) | (y << 4) } } # if defined(WORDS_BIGENDIAN)
# define V(x, y, hlen) { { 1, hlen, (x << 8) | (y << 4) } }
# else
# define V(x, y, hlen) { { 1, hlen, (x << 0) | (y << 4) } }
# endif
# endif # endif
static static
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: huffman.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: huffman.h,v 1.11 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBMAD_HUFFMAN_H # ifndef LIBMAD_HUFFMAN_H
......
...@@ -22,7 +22,7 @@ ...@@ -22,7 +22,7 @@
* *
***************************************************************************** *****************************************************************************
* *
* $Id: imdct_l_arm.S,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: imdct_l_arm.S,v 1.7 2001/03/25 20:03:34 rob Rel $
* *
* 2001/03/24: Andre McCurdy <armccurdy@yahoo.co.uk> * 2001/03/24: Andre McCurdy <armccurdy@yahoo.co.uk>
* - Corrected PIC unsafe loading of address of 'imdct36_long_karray' * - Corrected PIC unsafe loading of address of 'imdct36_long_karray'
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: imdct_s.dat,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: imdct_s.dat,v 1.8 2004/01/23 09:41:32 rob Exp $
*/ */
/* 0 */ { MAD_F(0x09bd7ca0) /* 0.608761429 */, /* 0 */ { MAD_F(0x09bd7ca0) /* 0.608761429 */,
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: layer12.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: layer12.c,v 1.17 2004/02/05 09:02:39 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -341,20 +341,44 @@ int mad_layer_II(struct mad_stream *stream, struct mad_frame *frame) ...@@ -341,20 +341,44 @@ int mad_layer_II(struct mad_stream *stream, struct mad_frame *frame)
if (header->flags & MAD_FLAG_LSF_EXT) if (header->flags & MAD_FLAG_LSF_EXT)
index = 4; index = 4;
else if (header->flags & MAD_FLAG_FREEFORMAT)
goto freeformat;
else { else {
switch (nch == 2 ? header->bitrate / 2 : header->bitrate) { unsigned long bitrate_per_channel;
case 32000:
case 48000:
index = (header->samplerate == 32000) ? 3 : 2;
break;
case 56000: bitrate_per_channel = header->bitrate;
case 64000: if (nch == 2) {
case 80000: bitrate_per_channel /= 2;
index = 0;
break;
default: # if defined(OPT_STRICT)
/*
* ISO/IEC 11172-3 allows only single channel mode for 32, 48, 56, and
* 80 kbps bitrates in Layer II, but some encoders ignore this
* restriction. We enforce it if OPT_STRICT is defined.
*/
if (bitrate_per_channel <= 28000 || bitrate_per_channel == 40000) {
stream->error = MAD_ERROR_BADMODE;
return -1;
}
# endif
}
else { /* nch == 1 */
if (bitrate_per_channel > 192000) {
/*
* ISO/IEC 11172-3 does not allow single channel mode for 224, 256,
* 320, or 384 kbps bitrates in Layer II.
*/
stream->error = MAD_ERROR_BADMODE;
return -1;
}
}
if (bitrate_per_channel <= 48000)
index = (header->samplerate == 32000) ? 3 : 2;
else if (bitrate_per_channel <= 80000)
index = 0;
else {
freeformat:
index = (header->samplerate == 48000) ? 0 : 1; index = (header->samplerate == 48000) ? 0 : 1;
} }
} }
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: layer12.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: layer12.h,v 1.10 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBMAD_LAYER12_H # ifndef LIBMAD_LAYER12_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: layer3.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: layer3.c,v 1.43 2004/01/23 09:41:32 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -1575,6 +1575,193 @@ void III_aliasreduce(mad_fixed_t xr[576], int lines) ...@@ -1575,6 +1575,193 @@ void III_aliasreduce(mad_fixed_t xr[576], int lines)
# if defined(ASO_IMDCT) # if defined(ASO_IMDCT)
void III_imdct_l(mad_fixed_t const [18], mad_fixed_t [36], unsigned int); void III_imdct_l(mad_fixed_t const [18], mad_fixed_t [36], unsigned int);
# else # else
# if 1
static
void fastsdct(mad_fixed_t const x[9], mad_fixed_t y[18])
{
mad_fixed_t a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12;
mad_fixed_t a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24, a25;
mad_fixed_t m0, m1, m2, m3, m4, m5, m6, m7;
enum {
c0 = MAD_F(0x1f838b8d), /* 2 * cos( 1 * PI / 18) */
c1 = MAD_F(0x1bb67ae8), /* 2 * cos( 3 * PI / 18) */
c2 = MAD_F(0x18836fa3), /* 2 * cos( 4 * PI / 18) */
c3 = MAD_F(0x1491b752), /* 2 * cos( 5 * PI / 18) */
c4 = MAD_F(0x0af1d43a), /* 2 * cos( 7 * PI / 18) */
c5 = MAD_F(0x058e86a0), /* 2 * cos( 8 * PI / 18) */
c6 = -MAD_F(0x1e11f642) /* 2 * cos(16 * PI / 18) */
};
a0 = x[3] + x[5];
a1 = x[3] - x[5];
a2 = x[6] + x[2];
a3 = x[6] - x[2];
a4 = x[1] + x[7];
a5 = x[1] - x[7];
a6 = x[8] + x[0];
a7 = x[8] - x[0];
a8 = a0 + a2;
a9 = a0 - a2;
a10 = a0 - a6;
a11 = a2 - a6;
a12 = a8 + a6;
a13 = a1 - a3;
a14 = a13 + a7;
a15 = a3 + a7;
a16 = a1 - a7;
a17 = a1 + a3;
m0 = mad_f_mul(a17, -c3);
m1 = mad_f_mul(a16, -c0);
m2 = mad_f_mul(a15, -c4);
m3 = mad_f_mul(a14, -c1);
m4 = mad_f_mul(a5, -c1);
m5 = mad_f_mul(a11, -c6);
m6 = mad_f_mul(a10, -c5);
m7 = mad_f_mul(a9, -c2);
a18 = x[4] + a4;
a19 = 2 * x[4] - a4;
a20 = a19 + m5;
a21 = a19 - m5;
a22 = a19 + m6;
a23 = m4 + m2;
a24 = m4 - m2;
a25 = m4 + m1;
/* output to every other slot for convenience */
y[ 0] = a18 + a12;
y[ 2] = m0 - a25;
y[ 4] = m7 - a20;
y[ 6] = m3;
y[ 8] = a21 - m6;
y[10] = a24 - m1;
y[12] = a12 - 2 * a18;
y[14] = a23 + m0;
y[16] = a22 + m7;
}
static inline
void sdctII(mad_fixed_t const x[18], mad_fixed_t X[18])
{
mad_fixed_t tmp[9];
int i;
/* scale[i] = 2 * cos(PI * (2 * i + 1) / (2 * 18)) */
static mad_fixed_t const scale[9] = {
MAD_F(0x1fe0d3b4), MAD_F(0x1ee8dd47), MAD_F(0x1d007930),
MAD_F(0x1a367e59), MAD_F(0x16a09e66), MAD_F(0x125abcf8),
MAD_F(0x0d8616bc), MAD_F(0x08483ee1), MAD_F(0x02c9fad7)
};
/* divide the 18-point SDCT-II into two 9-point SDCT-IIs */
/* even input butterfly */
for (i = 0; i < 9; i += 3) {
tmp[i + 0] = x[i + 0] + x[18 - (i + 0) - 1];
tmp[i + 1] = x[i + 1] + x[18 - (i + 1) - 1];
tmp[i + 2] = x[i + 2] + x[18 - (i + 2) - 1];
}
fastsdct(tmp, &X[0]);
/* odd input butterfly and scaling */
for (i = 0; i < 9; i += 3) {
tmp[i + 0] = mad_f_mul(x[i + 0] - x[18 - (i + 0) - 1], scale[i + 0]);
tmp[i + 1] = mad_f_mul(x[i + 1] - x[18 - (i + 1) - 1], scale[i + 1]);
tmp[i + 2] = mad_f_mul(x[i + 2] - x[18 - (i + 2) - 1], scale[i + 2]);
}
fastsdct(tmp, &X[1]);
/* output accumulation */
for (i = 3; i < 18; i += 8) {
X[i + 0] -= X[(i + 0) - 2];
X[i + 2] -= X[(i + 2) - 2];
X[i + 4] -= X[(i + 4) - 2];
X[i + 6] -= X[(i + 6) - 2];
}
}
static inline
void dctIV(mad_fixed_t const y[18], mad_fixed_t X[18])
{
mad_fixed_t tmp[18];
int i;
/* scale[i] = 2 * cos(PI * (2 * i + 1) / (4 * 18)) */
static mad_fixed_t const scale[18] = {
MAD_F(0x1ff833fa), MAD_F(0x1fb9ea93), MAD_F(0x1f3dd120),
MAD_F(0x1e84d969), MAD_F(0x1d906bcf), MAD_F(0x1c62648b),
MAD_F(0x1afd100f), MAD_F(0x1963268b), MAD_F(0x1797c6a4),
MAD_F(0x159e6f5b), MAD_F(0x137af940), MAD_F(0x11318ef3),
MAD_F(0x0ec6a507), MAD_F(0x0c3ef153), MAD_F(0x099f61c5),
MAD_F(0x06ed12c5), MAD_F(0x042d4544), MAD_F(0x0165547c)
};
/* scaling */
for (i = 0; i < 18; i += 3) {
tmp[i + 0] = mad_f_mul(y[i + 0], scale[i + 0]);
tmp[i + 1] = mad_f_mul(y[i + 1], scale[i + 1]);
tmp[i + 2] = mad_f_mul(y[i + 2], scale[i + 2]);
}
/* SDCT-II */
sdctII(tmp, X);
/* scale reduction and output accumulation */
X[0] /= 2;
for (i = 1; i < 17; i += 4) {
X[i + 0] = X[i + 0] / 2 - X[(i + 0) - 1];
X[i + 1] = X[i + 1] / 2 - X[(i + 1) - 1];
X[i + 2] = X[i + 2] / 2 - X[(i + 2) - 1];
X[i + 3] = X[i + 3] / 2 - X[(i + 3) - 1];
}
X[17] = X[17] / 2 - X[16];
}
/*
* NAME: imdct36
* DESCRIPTION: perform X[18]->x[36] IMDCT using Szu-Wei Lee's fast algorithm
*/
static inline
void imdct36(mad_fixed_t const x[18], mad_fixed_t y[36])
{
mad_fixed_t tmp[18];
int i;
/* DCT-IV */
dctIV(x, tmp);
/* convert 18-point DCT-IV to 36-point IMDCT */
for (i = 0; i < 9; i += 3) {
y[i + 0] = tmp[9 + (i + 0)];
y[i + 1] = tmp[9 + (i + 1)];
y[i + 2] = tmp[9 + (i + 2)];
}
for (i = 9; i < 27; i += 3) {
y[i + 0] = -tmp[36 - (9 + (i + 0)) - 1];
y[i + 1] = -tmp[36 - (9 + (i + 1)) - 1];
y[i + 2] = -tmp[36 - (9 + (i + 2)) - 1];
}
for (i = 27; i < 36; i += 3) {
y[i + 0] = -tmp[(i + 0) - 27];
y[i + 1] = -tmp[(i + 1) - 27];
y[i + 2] = -tmp[(i + 2) - 27];
}
}
# else
/* /*
* NAME: imdct36 * NAME: imdct36
* DESCRIPTION: perform X[18]->x[36] IMDCT * DESCRIPTION: perform X[18]->x[36] IMDCT
...@@ -1865,6 +2052,7 @@ void imdct36(mad_fixed_t const X[18], mad_fixed_t x[36]) ...@@ -1865,6 +2052,7 @@ void imdct36(mad_fixed_t const X[18], mad_fixed_t x[36])
x[26] = x[27] = MAD_F_MLZ(hi, lo) + t5; x[26] = x[27] = MAD_F_MLZ(hi, lo) + t5;
} }
# endif
/* /*
* NAME: III_imdct_l() * NAME: III_imdct_l()
...@@ -1929,7 +2117,11 @@ void III_imdct_l(mad_fixed_t const X[18], mad_fixed_t z[36], ...@@ -1929,7 +2117,11 @@ void III_imdct_l(mad_fixed_t const X[18], mad_fixed_t z[36],
break; break;
case 1: /* start block */ case 1: /* start block */
for (i = 0; i < 18; ++i) z[i] = mad_f_mul(z[i], window_l[i]); for (i = 0; i < 18; i += 3) {
z[i + 0] = mad_f_mul(z[i + 0], window_l[i + 0]);
z[i + 1] = mad_f_mul(z[i + 1], window_l[i + 1]);
z[i + 2] = mad_f_mul(z[i + 2], window_l[i + 2]);
}
/* (i = 18; i < 24; ++i) z[i] unchanged */ /* (i = 18; i < 24; ++i) z[i] unchanged */
for (i = 24; i < 30; ++i) z[i] = mad_f_mul(z[i], window_s[i - 18]); for (i = 24; i < 30; ++i) z[i] = mad_f_mul(z[i], window_s[i - 18]);
for (i = 30; i < 36; ++i) z[i] = 0; for (i = 30; i < 36; ++i) z[i] = 0;
...@@ -1939,7 +2131,11 @@ void III_imdct_l(mad_fixed_t const X[18], mad_fixed_t z[36], ...@@ -1939,7 +2131,11 @@ void III_imdct_l(mad_fixed_t const X[18], mad_fixed_t z[36],
for (i = 0; i < 6; ++i) z[i] = 0; for (i = 0; i < 6; ++i) z[i] = 0;
for (i = 6; i < 12; ++i) z[i] = mad_f_mul(z[i], window_s[i - 6]); for (i = 6; i < 12; ++i) z[i] = mad_f_mul(z[i], window_s[i - 6]);
/* (i = 12; i < 18; ++i) z[i] unchanged */ /* (i = 12; i < 18; ++i) z[i] unchanged */
for (i = 18; i < 36; ++i) z[i] = mad_f_mul(z[i], window_l[i]); for (i = 18; i < 36; i += 3) {
z[i + 0] = mad_f_mul(z[i + 0], window_l[i + 0]);
z[i + 1] = mad_f_mul(z[i + 1], window_l[i + 1]);
z[i + 2] = mad_f_mul(z[i + 2], window_l[i + 2]);
}
break; break;
} }
} }
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: layer3.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: layer3.h,v 1.10 2004/01/23 09:41:32 rob Exp $
*/ */
# ifndef LIBMAD_LAYER3_H # ifndef LIBMAD_LAYER3_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -33,14 +33,14 @@ extern "C" { ...@@ -33,14 +33,14 @@ extern "C" {
# define SIZEOF_LONG_LONG 8 # define SIZEOF_LONG_LONG 8
/* Id: version.h,v 1.1 2003/08/14 03:57:13 shank Exp */ /* Id: version.h,v 1.26 2004/01/23 09:41:33 rob Exp */
# ifndef LIBMAD_VERSION_H # ifndef LIBMAD_VERSION_H
# define LIBMAD_VERSION_H # define LIBMAD_VERSION_H
# define MAD_VERSION_MAJOR 0 # define MAD_VERSION_MAJOR 0
# define MAD_VERSION_MINOR 15 # define MAD_VERSION_MINOR 15
# define MAD_VERSION_PATCH 0 # define MAD_VERSION_PATCH 1
# define MAD_VERSION_EXTRA " (beta)" # define MAD_VERSION_EXTRA " (beta)"
# define MAD_VERSION_STRINGIZE(str) #str # define MAD_VERSION_STRINGIZE(str) #str
...@@ -51,7 +51,7 @@ extern "C" { ...@@ -51,7 +51,7 @@ extern "C" {
MAD_VERSION_STRING(MAD_VERSION_PATCH) \ MAD_VERSION_STRING(MAD_VERSION_PATCH) \
MAD_VERSION_EXTRA MAD_VERSION_EXTRA
# define MAD_PUBLISHYEAR "2000-2003" # define MAD_PUBLISHYEAR "2000-2004"
# define MAD_AUTHOR "Underbit Technologies, Inc." # define MAD_AUTHOR "Underbit Technologies, Inc."
# define MAD_EMAIL "info@underbit.com" # define MAD_EMAIL "info@underbit.com"
...@@ -62,7 +62,7 @@ extern char const mad_build[]; ...@@ -62,7 +62,7 @@ extern char const mad_build[];
# endif # endif
/* Id: fixed.h,v 1.1 2003/08/14 03:57:13 shank Exp */ /* Id: fixed.h,v 1.38 2004/02/17 02:02:03 rob Exp */
# ifndef LIBMAD_FIXED_H # ifndef LIBMAD_FIXED_H
# define LIBMAD_FIXED_H # define LIBMAD_FIXED_H
...@@ -253,7 +253,22 @@ mad_fixed_t mad_f_mul_inline(mad_fixed_t x, mad_fixed_t y) ...@@ -253,7 +253,22 @@ mad_fixed_t mad_f_mul_inline(mad_fixed_t x, mad_fixed_t y)
: "cc"); \ : "cc"); \
__result; \ __result; \
}) })
# else # elif defined(OPT_INTEL)
/*
* Alternate Intel scaling that may or may not perform better.
*/
# define mad_f_scale64(hi, lo) \
({ mad_fixed_t __result; \
asm ("shrl %3,%1\n\t" \
"shll %4,%2\n\t" \
"orl %2,%1" \
: "=rm" (__result) \
: "0" (lo), "r" (hi), \
"I" (MAD_F_SCALEBITS), "I" (32 - MAD_F_SCALEBITS) \
: "cc"); \
__result; \
})
# else
# define mad_f_scale64(hi, lo) \ # define mad_f_scale64(hi, lo) \
({ mad_fixed_t __result; \ ({ mad_fixed_t __result; \
asm ("shrdl %3,%2,%1" \ asm ("shrdl %3,%2,%1" \
...@@ -528,7 +543,7 @@ mad_fixed_t mad_f_div(mad_fixed_t, mad_fixed_t); ...@@ -528,7 +543,7 @@ mad_fixed_t mad_f_div(mad_fixed_t, mad_fixed_t);
# endif # endif
/* Id: bit.h,v 1.1 2003/08/14 03:57:13 shank Exp */ /* Id: bit.h,v 1.12 2004/01/23 09:41:32 rob Exp */
# ifndef LIBMAD_BIT_H # ifndef LIBMAD_BIT_H
# define LIBMAD_BIT_H # define LIBMAD_BIT_H
...@@ -557,7 +572,7 @@ unsigned short mad_bit_crc(struct mad_bitptr, unsigned int, unsigned short); ...@@ -557,7 +572,7 @@ unsigned short mad_bit_crc(struct mad_bitptr, unsigned int, unsigned short);
# endif # endif
/* Id: timer.h,v 1.1 2003/08/14 03:57:13 shank Exp */ /* Id: timer.h,v 1.16 2004/01/23 09:41:33 rob Exp */
# ifndef LIBMAD_TIMER_H # ifndef LIBMAD_TIMER_H
# define LIBMAD_TIMER_H # define LIBMAD_TIMER_H
...@@ -639,7 +654,7 @@ void mad_timer_string(mad_timer_t, char *, char const *, ...@@ -639,7 +654,7 @@ void mad_timer_string(mad_timer_t, char *, char const *,
# endif # endif
/* Id: stream.h,v 1.1 2003/08/14 03:57:13 shank Exp */ /* Id: stream.h,v 1.20 2004/02/05 09:02:39 rob Exp */
# ifndef LIBMAD_STREAM_H # ifndef LIBMAD_STREAM_H
# define LIBMAD_STREAM_H # define LIBMAD_STREAM_H
...@@ -665,6 +680,7 @@ enum mad_error { ...@@ -665,6 +680,7 @@ enum mad_error {
MAD_ERROR_BADCRC = 0x0201, /* CRC check failed */ MAD_ERROR_BADCRC = 0x0201, /* CRC check failed */
MAD_ERROR_BADBITALLOC = 0x0211, /* forbidden bit allocation value */ MAD_ERROR_BADBITALLOC = 0x0211, /* forbidden bit allocation value */
MAD_ERROR_BADSCALEFACTOR = 0x0221, /* bad scalefactor index */ MAD_ERROR_BADSCALEFACTOR = 0x0221, /* bad scalefactor index */
MAD_ERROR_BADMODE = 0x0222, /* bad bitrate/mode combination */
MAD_ERROR_BADFRAMELEN = 0x0231, /* bad frame length */ MAD_ERROR_BADFRAMELEN = 0x0231, /* bad frame length */
MAD_ERROR_BADBIGVALUES = 0x0232, /* bad big_values count */ MAD_ERROR_BADBIGVALUES = 0x0232, /* bad big_values count */
MAD_ERROR_BADBLOCKTYPE = 0x0233, /* reserved block_type */ MAD_ERROR_BADBLOCKTYPE = 0x0233, /* reserved block_type */
...@@ -727,7 +743,7 @@ char const *mad_stream_errorstr(struct mad_stream const *); ...@@ -727,7 +743,7 @@ char const *mad_stream_errorstr(struct mad_stream const *);
# endif # endif
/* Id: frame.h,v 1.1 2003/08/14 03:57:13 shank Exp */ /* Id: frame.h,v 1.20 2004/01/23 09:41:32 rob Exp */
# ifndef LIBMAD_FRAME_H # ifndef LIBMAD_FRAME_H
# define LIBMAD_FRAME_H # define LIBMAD_FRAME_H
...@@ -824,7 +840,7 @@ void mad_frame_mute(struct mad_frame *); ...@@ -824,7 +840,7 @@ void mad_frame_mute(struct mad_frame *);
# endif # endif
/* Id: synth.h,v 1.1 2003/08/14 03:57:13 shank Exp */ /* Id: synth.h,v 1.15 2004/01/23 09:41:33 rob Exp */
# ifndef LIBMAD_SYNTH_H # ifndef LIBMAD_SYNTH_H
# define LIBMAD_SYNTH_H # define LIBMAD_SYNTH_H
...@@ -873,7 +889,7 @@ void mad_synth_frame(struct mad_synth *, struct mad_frame const *); ...@@ -873,7 +889,7 @@ void mad_synth_frame(struct mad_synth *, struct mad_frame const *);
# endif # endif
/* Id: decoder.h,v 1.1 2003/08/14 03:57:13 shank Exp */ /* Id: decoder.h,v 1.17 2004/01/23 09:41:32 rob Exp */
# ifndef LIBMAD_DECODER_H # ifndef LIBMAD_DECODER_H
# define LIBMAD_DECODER_H # define LIBMAD_DECODER_H
......
# #
# libmad - MPEG audio decoder library # libmad - MPEG audio decoder library
# Copyright (C) 2000-2003 Underbit Technologies, Inc. # Copyright (C) 2000-2004 Underbit Technologies, Inc.
# #
# This program is free software; you can redistribute it and/or modify # This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by # it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
# along with this program; if not, write to the Free Software # along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# #
# $Id: mad.h.sed,v 1.1 2003/08/14 03:57:13 shank Exp $ # $Id: mad.h.sed,v 1.9 2004/01/23 09:41:32 rob Exp $
# #
/^\/\*$/{ /^\/\*$/{
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: minimad.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: minimad.c,v 1.4 2004/01/23 09:41:32 rob Exp $
*/ */
# include <stdio.h> # include <stdio.h>
...@@ -163,8 +163,8 @@ enum mad_flow output(void *data, ...@@ -163,8 +163,8 @@ enum mad_flow output(void *data,
/* /*
* This is the error callback function. It is called whenever a decoding * This is the error callback function. It is called whenever a decoding
* error occurs. The error is indicated by stream->error; the list of * error occurs. The error is indicated by stream->error; the list of
* possible MAD_ERROR_* errors can be found in the mad.h (or * possible MAD_ERROR_* errors can be found in the mad.h (or stream.h)
* libmad/stream.h) header file. * header file.
*/ */
static static
...@@ -184,9 +184,9 @@ enum mad_flow error(void *data, ...@@ -184,9 +184,9 @@ enum mad_flow error(void *data,
} }
/* /*
* This is the function called by main() above to perform all the * This is the function called by main() above to perform all the decoding.
* decoding. It instantiates a decoder object and configures it with the * It instantiates a decoder object and configures it with the input,
* input, output, and error callback functions above. A single call to * output, and error callback functions above. A single call to
* mad_decoder_run() continues until a callback function returns * mad_decoder_run() continues until a callback function returns
* MAD_FLOW_STOP (to stop decoding) or MAD_FLOW_BREAK (to stop decoding and * MAD_FLOW_STOP (to stop decoding) or MAD_FLOW_BREAK (to stop decoding and
* signal an error). * signal an error).
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: qc_table.dat,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: qc_table.dat,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
/* /*
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: rq_table.dat,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: rq_table.dat,v 1.7 2004/01/23 09:41:32 rob Exp $
*/ */
/* /*
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: sf_table.dat,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: sf_table.dat,v 1.7 2004/01/23 09:41:33 rob Exp $
*/ */
/* /*
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: stream.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: stream.c,v 1.12 2004/02/05 09:02:39 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
...@@ -145,6 +145,7 @@ char const *mad_stream_errorstr(struct mad_stream const *stream) ...@@ -145,6 +145,7 @@ char const *mad_stream_errorstr(struct mad_stream const *stream)
case MAD_ERROR_BADCRC: return "CRC check failed"; case MAD_ERROR_BADCRC: return "CRC check failed";
case MAD_ERROR_BADBITALLOC: return "forbidden bit allocation value"; case MAD_ERROR_BADBITALLOC: return "forbidden bit allocation value";
case MAD_ERROR_BADSCALEFACTOR: return "bad scalefactor index"; case MAD_ERROR_BADSCALEFACTOR: return "bad scalefactor index";
case MAD_ERROR_BADMODE: return "bad bitrate/mode combination";
case MAD_ERROR_BADFRAMELEN: return "bad frame length"; case MAD_ERROR_BADFRAMELEN: return "bad frame length";
case MAD_ERROR_BADBIGVALUES: return "bad big_values count"; case MAD_ERROR_BADBIGVALUES: return "bad big_values count";
case MAD_ERROR_BADBLOCKTYPE: return "reserved block_type"; case MAD_ERROR_BADBLOCKTYPE: return "reserved block_type";
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: stream.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: stream.h,v 1.20 2004/02/05 09:02:39 rob Exp $
*/ */
# ifndef LIBMAD_STREAM_H # ifndef LIBMAD_STREAM_H
...@@ -44,6 +44,7 @@ enum mad_error { ...@@ -44,6 +44,7 @@ enum mad_error {
MAD_ERROR_BADCRC = 0x0201, /* CRC check failed */ MAD_ERROR_BADCRC = 0x0201, /* CRC check failed */
MAD_ERROR_BADBITALLOC = 0x0211, /* forbidden bit allocation value */ MAD_ERROR_BADBITALLOC = 0x0211, /* forbidden bit allocation value */
MAD_ERROR_BADSCALEFACTOR = 0x0221, /* bad scalefactor index */ MAD_ERROR_BADSCALEFACTOR = 0x0221, /* bad scalefactor index */
MAD_ERROR_BADMODE = 0x0222, /* bad bitrate/mode combination */
MAD_ERROR_BADFRAMELEN = 0x0231, /* bad frame length */ MAD_ERROR_BADFRAMELEN = 0x0231, /* bad frame length */
MAD_ERROR_BADBIGVALUES = 0x0232, /* bad big_values count */ MAD_ERROR_BADBIGVALUES = 0x0232, /* bad big_values count */
MAD_ERROR_BADBLOCKTYPE = 0x0233, /* reserved block_type */ MAD_ERROR_BADBLOCKTYPE = 0x0233, /* reserved block_type */
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: synth.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: synth.c,v 1.25 2004/01/23 09:41:33 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: synth.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: synth.h,v 1.15 2004/01/23 09:41:33 rob Exp $
*/ */
# ifndef LIBMAD_SYNTH_H # ifndef LIBMAD_SYNTH_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: timer.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: timer.c,v 1.18 2004/01/23 09:41:33 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: timer.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: timer.h,v 1.16 2004/01/23 09:41:33 rob Exp $
*/ */
# ifndef LIBMAD_TIMER_H # ifndef LIBMAD_TIMER_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: version.c,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: version.c,v 1.15 2004/01/23 09:41:33 rob Exp $
*/ */
# ifdef HAVE_CONFIG_H # ifdef HAVE_CONFIG_H
......
/* /*
* libmad - MPEG audio decoder library * libmad - MPEG audio decoder library
* Copyright (C) 2000-2003 Underbit Technologies, Inc. * Copyright (C) 2000-2004 Underbit Technologies, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* *
* $Id: version.h,v 1.1 2003/08/14 03:57:13 shank Exp $ * $Id: version.h,v 1.26 2004/01/23 09:41:33 rob Exp $
*/ */
# ifndef LIBMAD_VERSION_H # ifndef LIBMAD_VERSION_H
...@@ -24,7 +24,7 @@ ...@@ -24,7 +24,7 @@
# define MAD_VERSION_MAJOR 0 # define MAD_VERSION_MAJOR 0
# define MAD_VERSION_MINOR 15 # define MAD_VERSION_MINOR 15
# define MAD_VERSION_PATCH 0 # define MAD_VERSION_PATCH 1
# define MAD_VERSION_EXTRA " (beta)" # define MAD_VERSION_EXTRA " (beta)"
# define MAD_VERSION_STRINGIZE(str) #str # define MAD_VERSION_STRINGIZE(str) #str
...@@ -35,7 +35,7 @@ ...@@ -35,7 +35,7 @@
MAD_VERSION_STRING(MAD_VERSION_PATCH) \ MAD_VERSION_STRING(MAD_VERSION_PATCH) \
MAD_VERSION_EXTRA MAD_VERSION_EXTRA
# define MAD_PUBLISHYEAR "2000-2003" # define MAD_PUBLISHYEAR "2000-2004"
# define MAD_AUTHOR "Underbit Technologies, Inc." # define MAD_AUTHOR "Underbit Technologies, Inc."
# define MAD_EMAIL "info@underbit.com" # define MAD_EMAIL "info@underbit.com"
......
...@@ -25,6 +25,13 @@ ...@@ -25,6 +25,13 @@
#else #else
#include <mad.h> #include <mad.h>
#endif #endif
#ifdef HAVE_ID3TAG
#ifdef USE_MPD_ID3TAG
#include "libid3tag/id3tag.h"
#else
#include <id3tag.h>
#endif
#endif
#include "playerData.h" #include "playerData.h"
#include "log.h" #include "log.h"
...@@ -38,6 +45,7 @@ ...@@ -38,6 +45,7 @@
#define READ_BUFFER_SIZE 40960 #define READ_BUFFER_SIZE 40960
#define DECODE_SKIP -3
#define DECODE_BREAK -2 #define DECODE_BREAK -2
#define DECODE_CONT -1 #define DECODE_CONT -1
#define DECODE_OK 0 #define DECODE_OK 0
...@@ -180,7 +188,19 @@ int decodeNextFrameHeader(mp3DecodeData * data) { ...@@ -180,7 +188,19 @@ int decodeNextFrameHeader(mp3DecodeData * data) {
} }
} }
if(mad_header_decode(&data->frame.header,&data->stream)) { if(mad_header_decode(&data->frame.header,&data->stream)) {
if(MAD_RECOVERABLE((data->stream).error)) return DECODE_CONT; #ifdef HAVE_ID3TAG
if((data->stream).error==MAD_ERROR_LOSTSYNC) {
signed long tagsize = id3_tag_query(
(data->stream).this_frame,
(data->stream).bufend-
(data->stream).this_frame);
if(tagsize>0) {
mad_stream_skip(&(data->stream),tagsize);
return DECODE_CONT;
}
}
#endif
if(MAD_RECOVERABLE((data->stream).error)) return DECODE_SKIP;
else { else {
if((data->stream).error==MAD_ERROR_BUFLEN) return DECODE_CONT; if((data->stream).error==MAD_ERROR_BUFLEN) return DECODE_CONT;
else else
...@@ -203,8 +223,20 @@ int decodeNextFrame(mp3DecodeData * data) { ...@@ -203,8 +223,20 @@ int decodeNextFrame(mp3DecodeData * data) {
return DECODE_BREAK; return DECODE_BREAK;
} }
} }
#ifdef HAVE_ID3TAG
if(mad_frame_decode(&data->frame,&data->stream)) { if(mad_frame_decode(&data->frame,&data->stream)) {
if(MAD_RECOVERABLE((data->stream).error)) return DECODE_CONT; if((data->stream).error==MAD_ERROR_LOSTSYNC) {
signed long tagsize = id3_tag_query(
(data->stream).this_frame,
(data->stream).bufend-
(data->stream).this_frame);
if(tagsize>0) {
mad_stream_skip(&(data->stream),tagsize);
return DECODE_CONT;
}
}
#endif
if(MAD_RECOVERABLE((data->stream).error)) return DECODE_SKIP;
else { else {
if((data->stream).error==MAD_ERROR_BUFLEN) return DECODE_CONT; if((data->stream).error==MAD_ERROR_BUFLEN) return DECODE_CONT;
else else
...@@ -282,14 +314,20 @@ int decodeFirstFrame(mp3DecodeData * data) { ...@@ -282,14 +314,20 @@ int decodeFirstFrame(mp3DecodeData * data) {
struct stat filestat; struct stat filestat;
struct xing xing; struct xing xing;
int ret; int ret;
int skip;
memset(&xing,0,sizeof(struct xing)); memset(&xing,0,sizeof(struct xing));
xing.flags = 0; xing.flags = 0;
while((ret = decodeNextFrameHeader(data))==DECODE_CONT); while(1) {
if(ret!=DECODE_OK) return -1; skip = 0;
while((ret = decodeNextFrame(data))==DECODE_CONT); while((ret = decodeNextFrameHeader(data))==DECODE_CONT);
if(ret!=DECODE_OK) return -1; if(ret==DECODE_SKIP) skip = 1;
else if(ret==DECODE_BREAK) return -1;
while((ret = decodeNextFrame(data))==DECODE_CONT);
if(ret==DECODE_BREAK) return -1;
if(!skip && ret==DECODE_OK) break;
}
if(parse_xing(&xing,data->stream.anc_ptr,data->stream.anc_bitlen)) { if(parse_xing(&xing,data->stream.anc_ptr,data->stream.anc_bitlen)) {
if(xing.flags & XING_FRAMES) { if(xing.flags & XING_FRAMES) {
...@@ -386,6 +424,7 @@ int mp3Read(mp3DecodeData * data, Buffer * cb, DecoderControl * dc) { ...@@ -386,6 +424,7 @@ int mp3Read(mp3DecodeData * data, Buffer * cb, DecoderControl * dc) {
static int i; static int i;
static int ret; static int ret;
static struct audio_dither dither; static struct audio_dither dither;
static int skip;
if(data->currentFrame>=data->highestFrame && if(data->currentFrame>=data->highestFrame &&
data->highestFrame<data->maxFrames) data->highestFrame<data->maxFrames)
...@@ -463,11 +502,18 @@ int mp3Read(mp3DecodeData * data, Buffer * cb, DecoderControl * dc) { ...@@ -463,11 +502,18 @@ int mp3Read(mp3DecodeData * data, Buffer * cb, DecoderControl * dc) {
} }
} }
if(data->muteFrame) { while(1) {
while((ret=decodeNextFrameHeader(data))==DECODE_CONT); skip = 0;
while((ret = decodeNextFrameHeader(data))==DECODE_CONT);
if(ret==DECODE_SKIP) skip = 1;
else if(ret==DECODE_BREAK) break;
if(!data->muteFrame) {
while((ret = decodeNextFrame(data))==DECODE_CONT);
if(ret==DECODE_BREAK) break;
}
if(!skip && ret==DECODE_OK) break;
} }
else while((ret=decodeNextFrame(data))==DECODE_CONT);
return ret; return ret;
} }
......
...@@ -63,6 +63,7 @@ int ogg_decode(Buffer * cb, AudioFormat * af, DecoderControl * dc) ...@@ -63,6 +63,7 @@ int ogg_decode(Buffer * cb, AudioFormat * af, DecoderControl * dc)
int eof = 0; int eof = 0;
long ret; long ret;
char chunk[CHUNK_SIZE]; char chunk[CHUNK_SIZE];
int chunkpos = 0;
long bitRate = 0; long bitRate = 0;
long test; long test;
...@@ -70,13 +71,17 @@ int ogg_decode(Buffer * cb, AudioFormat * af, DecoderControl * dc) ...@@ -70,13 +71,17 @@ int ogg_decode(Buffer * cb, AudioFormat * af, DecoderControl * dc)
if(dc->seek) { if(dc->seek) {
cb->end = 0; cb->end = 0;
cb->wrap = 0; cb->wrap = 0;
chunkpos = 0;
ov_time_seek_page(&vf,dc->seekWhere); ov_time_seek_page(&vf,dc->seekWhere);
dc->seek = 0; dc->seek = 0;
} }
ret = ov_read(&vf,chunk,CHUNK_SIZE,0,2,1, ret = ov_read(&vf,chunk+chunkpos,
CHUNK_SIZE-chunkpos,
0,2,1,
&current_section); &current_section);
if(ret<=0) eof = 1; if(ret<=0) eof = 1;
else { else chunkpos+=ret;
if(chunkpos>=CHUNK_SIZE || eof) {
while(cb->begin==cb->end && cb->wrap && while(cb->begin==cb->end && cb->wrap &&
!dc->stop && !dc->seek) !dc->stop && !dc->seek)
{ {
...@@ -89,8 +94,9 @@ int ogg_decode(Buffer * cb, AudioFormat * af, DecoderControl * dc) ...@@ -89,8 +94,9 @@ int ogg_decode(Buffer * cb, AudioFormat * af, DecoderControl * dc)
af->bits); af->bits);
#endif #endif
memcpy(cb->chunks+cb->end*CHUNK_SIZE, memcpy(cb->chunks+cb->end*CHUNK_SIZE,
chunk,CHUNK_SIZE); chunk,chunkpos);
cb->chunkSize[cb->end] = ret; cb->chunkSize[cb->end] = chunkpos;
chunkpos = 0;
cb->times[cb->end] = ov_time_tell(&vf); cb->times[cb->end] = ov_time_tell(&vf);
if((test = ov_bitrate_instant(&vf))>0) { if((test = ov_bitrate_instant(&vf))>0) {
bitRate = test/1000; bitRate = test/1000;
......
...@@ -85,7 +85,7 @@ void pcm_volumeChange(char * buffer, int bufferSize, AudioFormat * format, ...@@ -85,7 +85,7 @@ void pcm_volumeChange(char * buffer, int bufferSize, AudioFormat * format,
} }
void pcm_add(char * buffer1, char * buffer2, size_t bufferSize1, void pcm_add(char * buffer1, char * buffer2, size_t bufferSize1,
size_t bufferSize2, AudioFormat * format) size_t bufferSize2, int vol1, int vol2, AudioFormat * format)
{ {
mpd_sint32 temp32; mpd_sint32 temp32;
mpd_sint8 * buffer8_1 = (mpd_sint8 *)buffer1; mpd_sint8 * buffer8_1 = (mpd_sint8 *)buffer1;
...@@ -96,8 +96,7 @@ void pcm_add(char * buffer1, char * buffer2, size_t bufferSize1, ...@@ -96,8 +96,7 @@ void pcm_add(char * buffer1, char * buffer2, size_t bufferSize1,
switch(format->bits) { switch(format->bits) {
case 16: case 16:
while(bufferSize1>0 && bufferSize2>0) { while(bufferSize1>0 && bufferSize2>0) {
temp32 = *buffer16_1; temp32 = (vol1*(*buffer16_1)+vol2*(*buffer16_2))/100;
temp32+= *buffer16_2;
*buffer16_1 = temp32>32767 ? 32767 : *buffer16_1 = temp32>32767 ? 32767 :
(temp32<-32768 ? -32768 : temp32); (temp32<-32768 ? -32768 : temp32);
buffer16_1++; buffer16_1++;
...@@ -105,12 +104,11 @@ void pcm_add(char * buffer1, char * buffer2, size_t bufferSize1, ...@@ -105,12 +104,11 @@ void pcm_add(char * buffer1, char * buffer2, size_t bufferSize1,
bufferSize1-=2; bufferSize1-=2;
bufferSize2-=2; bufferSize2-=2;
} }
if(bufferSize2>0) memcpy(buffer8_1,buffer8_2,bufferSize2); if(bufferSize2>0) memcpy(buffer16_1,buffer16_2,bufferSize2);
break; break;
case 8: case 8:
while(bufferSize1>0 && bufferSize2>0) { while(bufferSize1>0 && bufferSize2>0) {
temp32 = *buffer8_1; temp32 = (vol1*(*buffer8_1)+vol2*(*buffer8_2))/100;
temp32+= *buffer8_2;
*buffer8_1 = temp32>127 ? 127 : *buffer8_1 = temp32>127 ? 127 :
(temp32<-128 ? -128 : temp32); (temp32<-128 ? -128 : temp32);
buffer8_1++; buffer8_1++;
...@@ -129,10 +127,12 @@ void pcm_add(char * buffer1, char * buffer2, size_t bufferSize1, ...@@ -129,10 +127,12 @@ void pcm_add(char * buffer1, char * buffer2, size_t bufferSize1,
void pcm_mix(char * buffer1, char * buffer2, size_t bufferSize1, void pcm_mix(char * buffer1, char * buffer2, size_t bufferSize1,
size_t bufferSize2, AudioFormat * format, float portion1) size_t bufferSize2, AudioFormat * format, float portion1)
{ {
int vol1;
float s = sin(M_PI_2*portion1); float s = sin(M_PI_2*portion1);
s*=s; s*=s;
vol1 = s*100+0.5;
vol1 = vol1>100 ? 100 : ( vol1<0 ? 0 : vol1 );
pcm_volumeChange(buffer1,bufferSize1,format,(int)(s*100)); pcm_add(buffer1,buffer2,bufferSize1,bufferSize2,vol1,100-vol1,format);
pcm_volumeChange(buffer2,bufferSize2,format,(int)((1-s)*100));
pcm_add(buffer1,buffer2,bufferSize1,bufferSize2,format);
} }
...@@ -24,7 +24,8 @@ ...@@ -24,7 +24,8 @@
#include "decode.h" #include "decode.h"
#include "mpd_types.h" #include "mpd_types.h"
#define CHUNK_SIZE 1024 /* pick 1020 since its devisible for 8,16,24, and 32-bit audio */
#define CHUNK_SIZE 1020
extern int buffered_before_play; extern int buffered_before_play;
extern int buffered_chunks; extern int buffered_chunks;
......
...@@ -1231,6 +1231,9 @@ int seekSongInPlaylist(FILE * fp, int song, float time) { ...@@ -1231,6 +1231,9 @@ int seekSongInPlaylist(FILE * fp, int song, float time) {
} }
else if(playPlaylistOrderNumber(fp,i)<0) return -1; else if(playPlaylistOrderNumber(fp,i)<0) return -1;
if(playlist.current!=i) if(playPlaylistOrderNumber(fp,i)<0) return -1; if(playlist.current!=i) {
if(playPlaylistOrderNumber(fp,i)<0) return -1;
}
return playerSeek(fp,playlist.songs[playlist.order[i]]->utf8file,time); return playerSeek(fp,playlist.songs[playlist.order[i]]->utf8file,time);
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment