summaryrefslogtreecommitdiff
path: root/audio/abcde
diff options
context:
space:
mode:
authorkim <kim@pkgsrc.org>2003-01-01 19:06:01 +0000
committerkim <kim@pkgsrc.org>2003-01-01 19:06:01 +0000
commit6be9267f2f4ff5307d1b96984b513f05061dc180 (patch)
tree92f68e90f91e035f8c60eb3d96250122963e6f06 /audio/abcde
parent52a85d79e472fefdeb043aa8044cc250def308c0 (diff)
downloadpkgsrc-6be9267f2f4ff5307d1b96984b513f05061dc180.tar.gz
Add support for per-track and per-album (batch) normalizing.
Diffstat (limited to 'audio/abcde')
-rw-r--r--audio/abcde/Makefile4
-rw-r--r--audio/abcde/distinfo6
-rw-r--r--audio/abcde/patches/patch-aa74
-rw-r--r--audio/abcde/patches/patch-ac325
4 files changed, 357 insertions, 52 deletions
diff --git a/audio/abcde/Makefile b/audio/abcde/Makefile
index e9daa2f8f10..a84c2d18cbf 100644
--- a/audio/abcde/Makefile
+++ b/audio/abcde/Makefile
@@ -1,7 +1,7 @@
-# $NetBSD: Makefile,v 1.9 2002/12/16 05:14:28 lukem Exp $
+# $NetBSD: Makefile,v 1.10 2003/01/01 19:06:01 kim Exp $
DISTNAME= abcde-2.0.3
-PKGREVISION= 2
+PKGREVISION= 3
CATEGORIES= audio
MASTER_SITES= http://frantica.lly.org/~rcw/abcde/
DISTFILES= ${DISTNAME:S/-/_/}.orig.tar.gz
diff --git a/audio/abcde/distinfo b/audio/abcde/distinfo
index 2ed51f16048..6a2f0216ad1 100644
--- a/audio/abcde/distinfo
+++ b/audio/abcde/distinfo
@@ -1,8 +1,8 @@
-$NetBSD: distinfo,v 1.12 2002/12/16 05:14:29 lukem Exp $
+$NetBSD: distinfo,v 1.13 2003/01/01 19:06:01 kim Exp $
SHA1 (abcde_2.0.3.orig.tar.gz) = 66a7620a835baee29296f4d5e9322bb1679baa49
Size (abcde_2.0.3.orig.tar.gz) = 35655 bytes
-SHA1 (patch-aa) = d3c8a6c9c7bbd0c7fd22cf935d903fd05d1ccb31
+SHA1 (patch-aa) = 262ab12dfe094f1fc50c5fa4ca19ab73a8b6541a
SHA1 (patch-ab) = 524452b3930c25351deee7a508f98bcd0f51a872
-SHA1 (patch-ac) = 77fb524cef6bfcf3fa934e9229681535321fb9ee
+SHA1 (patch-ac) = 59eccd903d65fe3834d9d728d69dca3c238a7f9e
SHA1 (patch-ad) = b37aebe39a003da917d7b192e9169af4c2d17115
diff --git a/audio/abcde/patches/patch-aa b/audio/abcde/patches/patch-aa
index 0f7d14dfdc0..1265e61a5e3 100644
--- a/audio/abcde/patches/patch-aa
+++ b/audio/abcde/patches/patch-aa
@@ -1,7 +1,7 @@
-$NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
+$NetBSD: patch-aa,v 1.7 2003/01/01 19:06:02 kim Exp $
---- abcde.1.orig Tue Aug 21 11:22:33 2001
-+++ abcde.1
+--- abcde.1.orig Mon Aug 20 21:22:33 2001
++++ abcde.1 Wed Jan 1 14:00:54 2003
@@ -1,6 +1,6 @@
.TH ABCDE 1
.SH NAME
@@ -10,7 +10,7 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
.SH SYNOPSIS
.B abcde
.I [options] [tracks]
-@@ -19,7 +19,7 @@ Do a CDDB query over the Internet to loo
+@@ -19,7 +19,7 @@
Grab a track from your CD
.TP
.B *
@@ -19,7 +19,20 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
.TP
.B *
Comment or ID3 tag it
-@@ -42,7 +42,7 @@ cddb. The default is to do all actions e
+@@ -36,13 +36,17 @@
+ .TP
+ .B \-a [actions]
+ Comma-delimited list of actions to perform. Can be one or more of:
+-cddb, read, encode, tag, move, playlist, clean. Encode implies read. Tag implies
+-cddb, read, encode. Move implies cddb, read, encode, tag. Playlist implies
+-cddb. The default is to do all actions except playlist.
++cddb, read, normalize, encode, tag, move, playlist, clean. Normalize
++and encode imply read. Tag implies cddb, read, encode. Move implies
++cddb, read, encode, tag. Playlist implies cddb. The default is to
++do all actions except normalize and playlist.
++.TP
++.B \-b
++Enable batch mode normalization. See the BATCH configuration variable.
.TP
.B \-c [filename]
Specifies an additional configuration file to parse. Configuration options
@@ -28,7 +41,7 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
.TP
.B \-C [discid]
Allows you to resume a session for
-@@ -66,7 +66,7 @@ the MAXPROCS configuration variable.
+@@ -66,7 +70,7 @@
Use the low-diskspace algorithm. See the LOWDISK configuration variable.
.TP
.B \-o [filetype]
@@ -37,7 +50,7 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
configuration variable.
.TP
.B \-r [hosts...]
-@@ -87,11 +87,12 @@ will process the entire CD. Accepts rang
+@@ -87,11 +91,12 @@
.SH OUTPUT
Each track is, by default, placed in a separate file named after the track
in a subdirectory named after the artist under the current directory. Each
@@ -53,7 +66,7 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
$HOME/.abcde.conf, in that order. Here is a list of options abcde recognizes:
.TP
.B CDDBURL
-@@ -100,7 +101,8 @@ Specifies a server to use for CDDB looku
+@@ -100,10 +105,15 @@
.B ENCODERSYNTAX
Specifies the style of encoder to use. Valid options are \'oggenc\' (default
for Ogg Vorbis), \'vorbize\', \'lame\' (default for MP3), \'gogo\', \'bladeenc\',
@@ -63,7 +76,14 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
the variable to pick encoder command-line options from, and where the options
are given.
.TP
-@@ -118,7 +120,8 @@ to 700MB of temporary space for each ses
++.B NORMALIZERSYNTAX
++Specifies the style of normalizer to use. Valid options are \'default\'
++and \'normalize'\ (and both run \'normalize\').
++.TP
+ .B HELLOINFO
+ Specifies the Hello information to send to the CDDB server. The CDDB
+ protocol requires you to send a valid username and hostname each time you
+@@ -118,7 +128,8 @@
over 100MB for a machine that can encode music as fast as it can read it).
.TP
.B OUTPUTFORMAT
@@ -73,7 +93,7 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
using standard shell syntax. Allowed variables are ALBUMFILE, ARTISTFILE,
TRACKFILE, and TRACKNUM. Default is
\'${ARTISTFILE}/${TRACKFILE}.${OUTPUTTYPE}\'.
-@@ -127,8 +130,8 @@ automatically zero-padded.
+@@ -127,8 +138,8 @@
.TP
.B OUTPUTTYPE
Specifies the encoding format to output as well as the default extension and
@@ -84,24 +104,39 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
.TP
.B VAOUTPUTFORMAT
Just like OUTPUTFORMAT but for Various Artists discs. Default is whatever
-@@ -137,14 +140,14 @@ OUTPUTFORMAT is set to.
+@@ -137,15 +148,15 @@
.B PATHNAMES
The following configuration file options specify the pathnames of their
respective utilities: LAME, GOGO, BLADEENC, L3ENC, XINGMP3ENC, MP3ENC,
-VORBIZE, OGGENC, ID3, ID3V2, CDPARANOIA, CDDA2WAV, WGET, CDDISCID,
+-CDDBTOOL, EJECT, DISTMP3, and VORBISCOMMENT.
+VORBIZE, OGGENC, FLAC, ID3, ID3V2, CDPARANOIA, CDDA2WAV, WGET, CDDISCID,
- CDDBTOOL, EJECT, DISTMP3, and VORBISCOMMENT.
++CDDBTOOL, EJECT, NORMALIZE, DISTMP3, and VORBISCOMMENT.
.TP
.B COMMAND-LINE OPTIONS
If you wish to specify command-line options to any of the programs abcde
uses, set the following configuration file options: LAMEOPTS, GOGOOPTS,
BLADEENCOPTS, L3ENCOPTS, XINGMP3ENCOPTS, MP3ENCOPTS, VORBIZEOPTS,
-OGGENCOPTS, ID3OPTS, ID3V2OPTS, CDPARANOIAOPTS, CDDA2WAVOPTS, WGETOPTS,
+-CDDBTOOLOPTS, EJECTOPTS, and DISTMP3OPTS.
+OGGENCOPTS, FLACOPTS, ID3OPTS, ID3V2OPTS, CDPARANOIAOPTS, CDDA2WAVOPTS, WGETOPTS,
- CDDBTOOLOPTS, EJECTOPTS, and DISTMP3OPTS.
++CDDBTOOLOPTS, EJECTOPTS, NORMALIZEOPTS, and DISTMP3OPTS.
.TP
.B MAXPROCS
-@@ -197,7 +200,7 @@ after all tracks have been read.
+ Defines how many encoders to run at once. This makes for huge speedups
+@@ -159,6 +170,11 @@
+ entire CD. Use only if your system is low on space and cannot encode as
+ quickly as it can read.
+ .TP
++.B BATCH
++If set to y, enables batch mode normalization, which preserves relative
++volume differences between tracks of an album. Also enables nogap encoding
++when using the \'lame\' encoder.
++.TP
+ .B PLAYLISTFORMAT
+ Specifies the format for completed playlist filenames. Works like the
+ OUTPUTFORMAT configuration variable. Default is
+@@ -197,7 +213,7 @@
abcde requires the following backend tools to work:
.TP
.B *
@@ -110,8 +145,17 @@ $NetBSD: patch-aa,v 1.6 2002/12/16 05:14:30 lukem Exp $
.TP
.B *
An audio CD reading utility (cdparanoia, cdda2wav)
-@@ -218,6 +221,7 @@ wget, an HTTP retrieval program.
+@@ -213,11 +229,16 @@
+ .TP
+ .B *
+ (optional) distmp3, a client/server for distributed mp3 encoding.
++.TP
++.B *
++(optional) normalize, a WAV file volume normalizer
+ .SH "SEE ALSO"
+ .BR cdparanoia (1),
.BR cdda2wav (1),
++.BR normalize (1),
.BR oggenc (1),
.BR vorbize (1),
+.BR flac (1),
diff --git a/audio/abcde/patches/patch-ac b/audio/abcde/patches/patch-ac
index aa24b2cda66..ad30b31dd4f 100644
--- a/audio/abcde/patches/patch-ac
+++ b/audio/abcde/patches/patch-ac
@@ -1,8 +1,18 @@
-$NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
+$NetBSD: patch-ac,v 1.10 2003/01/01 19:06:02 kim Exp $
---- abcde.orig Mon Jan 28 16:44:02 2002
-+++ abcde
-@@ -27,7 +27,7 @@ echo "-j Number of encoder processes
+--- abcde.orig Mon Jan 28 00:44:02 2002
++++ abcde Wed Jan 1 13:50:59 2003
+@@ -17,7 +17,8 @@
+ echo "This is abcde v$VERSION."
+ echo "Usage: abcde [options] [tracks]"
+ echo "Options:"
+-echo "-a Specify actions to perform (cddb,read,encode,tag,move,playlist,clean)"
++echo "-a Actions to perform (cddb,read,normalize,encode,tag,move,playlist,clean)"
++echo "-b Batch mode: enable album normalization and nogap encoding"
+ echo "-c Specify a configuration file (overrides system and user config files)"
+ echo "-C Specify discid to resume from (only needed if you no longer have the cd)"
+ echo "-d Specify CDROM device to grab"
+@@ -27,7 +28,7 @@
echo "-l Use low disk space algorithm"
echo "-n No lookup. Don't query CDDB, just create and use template"
echo "-N Noninteractive. Never prompt for anything"
@@ -11,7 +21,22 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
echo "-r [host1,host2...] Also encode on these remote hosts"
echo "-x Eject CD after all tracks are read"
echo "Tracks is a space-delimited list of tracks to grab."
-@@ -206,6 +206,11 @@ splitvarious ()
+@@ -101,6 +102,14 @@
+ RETURN=$?
+ fi
+ fi
++ case "$1" in
++ normalize)
++ if [ "$RETURN" = "2" ]; then
++ # File was already normalized.
++ RETURN=0
++ fi
++ ;;
++ esac
+ if [ "$RETURN" != "0" ]; then
+ # Put an error in the errors file. For various reasons we
+ # can't capture a copy of the program's output but we can
+@@ -206,6 +215,11 @@
TRACKARTIST="$(echo $DTITLEARTIST | cut -f1 -d~)"
TRACKNAME="$(echo $DTITLEARTIST | cut -f2 -d~)"
;;
@@ -23,7 +48,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
esac
else
TRACKARTIST=$DARTIST
-@@ -221,7 +226,8 @@ do_tag ()
+@@ -221,7 +235,8 @@
{
COMMENTOUTPUT="$(eval echo ${COMMENT})"
run_command '' echo "Tagging track $1 of $TRACKS: $TRACKNAME..."
@@ -33,7 +58,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
# Amazingly, id3 and id3v2 have identical -a, -A, -c, -t, and -T switches
# ...except id3v2's -c is completely broken (there's a bug in id3lib
# v3.7.x keeping -c from being properly implemented)
-@@ -232,7 +238,8 @@ do_tag ()
+@@ -232,7 +247,8 @@
run_command tagtrack-$1 $TAGGER $TAGGEROPTS -c "$COMMENTOUTPUT" \
-A "$DALBUM" -a "$TRACKARTIST" -t "$TRACKNAME" -T "$1" "$ABCDETEMPDIR/track$1.$OUTPUTTYPE"
fi
@@ -43,7 +68,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
# vorbiscomment can't do in-place modification, mv the file first
if [ -f "$ABCDETEMPDIR/track$1.$OUTPUTTYPE" -a ! -f "$ABCDETEMPDIR/track$1.uncommented.$OUTPUTTYPE" ]; then
mv "$ABCDETEMPDIR/track$1.$OUTPUTTYPE" "$ABCDETEMPDIR/track$1.uncommented.$OUTPUTTYPE"
-@@ -254,7 +261,11 @@ do_tag ()
+@@ -254,7 +270,48 @@
else
mv "$ABCDETEMPDIR/track$1.uncommented.$OUTPUTTYPE" "$ABCDETEMPDIR/track$1.$OUTPUTTYPE"
fi
@@ -53,10 +78,47 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
+ run_command tagtrack-$1 true
+ ;;
+ esac
++}
++
++# do_batch_encode
++# variables used:
++# OUTPUTTYPE, ENCODERSYNTAX, ENCNICE, ENCODER, ENCODEROPTS
++do_batch_encode ()
++{
++ # The commands here don't go through run_command because they're never supposed to be silenced
++ echo "Batch encoding tracks: $TRACKQUEUE"
++ case "$OUTPUTTYPE" in
++ mp3)
++ case "$ENCODERSYNTAX" in
++ lame)
++ (
++ cd "$ABCDETEMPDIR"
++ TRACKFILES=
++ for UTRACKNUM in $TRACKQUEUE
++ do
++ TRACKFILES="$TRACKFILES track$UTRACKNUM.wav"
++ done
++ nice $ENCNICE $ENCODER $ENCODEROPTS --nogap $TRACKFILES
++ RETURN=$?
++ if [ "$RETURN" != "0" ]; then
++ echo "batch-encode: $ENCODER returned code $RETURN" >> errors
++ else
++ for UTRACKNUM in $TRACKQUEUE
++ do
++ echo encodetrack-$UTRACKNUM >> status
++ done
++ fi
++ )
++ ;;
++ esac
++ ;;
++ esac
++ # Other encoders fall through to normal encoding as the tracks
++ # have not been entered in the status file.
}
# do_encode [tracknumber] [hostname]
-@@ -295,6 +306,11 @@ do_encode ()
+@@ -295,6 +352,11 @@
;;
esac
;;
@@ -68,7 +130,69 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
esac
# Only remove .wav if the encoding succeeded
if checkerrors encodetrack-$1; then :; else
-@@ -574,7 +590,7 @@ do_cddbread ()
+@@ -302,6 +364,45 @@
+ fi
+ }
+
++# do_batch_normalize
++# variables used:
++# NORMALIZER, NORMALIZEROPTS
++do_batch_normalize ()
++{
++ # The commands here don't go through run_command because they're never supposed to be silenced
++ echo "Batch normalizing tracks: $TRACKQUEUE"
++ (
++ cd "$ABCDETEMPDIR"
++ BLURB=
++ TRACKFILES=
++ for UTRACKNUM in $TRACKQUEUE
++ do
++ TRACKFILES="$TRACKFILES track$UTRACKNUM.wav"
++ done
++ # XXX: Hard-coded batch option!
++ $NORMALIZER -b $NORMALIZEROPTS $TRACKFILES
++ RETURN=$?
++ if [ "$RETURN" != "0" ]; then
++ echo "batch-normalize: $NORMALIZER returned code $RETURN" >> errors
++ else
++ for UTRACKNUM in $TRACKQUEUE
++ do
++ echo normalizetrack-$UTRACKNUM >> status
++ done
++ fi
++ )
++}
++
++# do_normalize [tracknumber]
++# variables used:
++# TRACKS, TRACKNAME, NORMALIZER, NORMALIZEROPTS
++do_normalize ()
++{
++ IN="$ABCDETEMPDIR/track$1.wav"
++ run_command '' echo "Normalizing track $1 of $TRACKS: $TRACKNAME..."
++ run_command normalizetrack-$1 $NORMALIZER $NORMALIZEROPTS "$IN"
++}
++
+ # do_move [tracknumber]
+ # Deduces the outfile from environment variables
+ # Creates directory if necessary
+@@ -496,6 +597,7 @@
+ # following environment variables for them:
+ DOCDDB=n
+ DOREAD=n
++ DONORMALIZE=n
+ DOENCODE=n
+ DOTAG=n
+ DOMOVE=n
+@@ -507,6 +609,7 @@
+ case $ACTION in
+ cddb) DOCDDB=y;;
+ read) DOREAD=y;;
++ normalize) DONORMALIZE=y; DOREAD=y;;
+ encode) DOENCODE=y; DOREAD=y;;
+ tag) DOTAG=y; DOREAD=y; DOENCODE=y; DOCDDB=y;;
+ move) DOMOVE=y; DOTAG=y; DOREAD=y; DOENCODE=y; DOCDDB=y;;
+@@ -574,7 +677,7 @@
fi
# List out disc title/author and contents
echo ---- "$(cut '-d ' -f4- "$ABCDETEMPDIR/cddbquery")" ---- >> "$ABCDETEMPDIR/cddbchoices"
@@ -77,7 +201,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
do
echo $TRACK: "$(grep ^TTITLE$(expr $TRACK - 1)= "$ABCDETEMPDIR/cddbread.1" | cut -f2- -d= | tr -d \\r\\n)" >> "$ABCDETEMPDIR/cddbchoices"
done
-@@ -590,7 +606,7 @@ do_cddbread ()
+@@ -590,7 +693,7 @@
$CDDBTOOL template $(cat "$ABCDETEMPDIR/discid") > "$ABCDETEMPDIR/cddbread.1"
# List out disc title/author and contents of template
echo ---- Unknown Artist / Unknown Album ---- >> "$ABCDETEMPDIR/cddbchoices"
@@ -86,7 +210,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
do
echo $TRACK: "$(grep ^TTITLE$(expr $TRACK - 1)= "$ABCDETEMPDIR/cddbread.1" | cut -f2- -d= | tr -d \\r\\n)" >> "$ABCDETEMPDIR/cddbchoices"
done
-@@ -620,7 +636,7 @@ do_cddbread ()
+@@ -620,7 +723,7 @@
fi
# List out disc title/author and contents
echo \#$X: ---- "$DISCINFO" ---- >> "$ABCDETEMPDIR/cddbchoices"
@@ -95,7 +219,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
do
echo $TRACK: "$(grep ^TTITLE$(expr $TRACK - 1)= "$ABCDETEMPDIR/cddbread.$X" | cut -f2- -d= | tr -d \\r\\n)" >> "$ABCDETEMPDIR/cddbchoices"
done
-@@ -766,6 +782,9 @@ do_cddbedit ()
+@@ -766,6 +869,9 @@
elif [ "$(grep -c "^TTITLE.*\-" "$CDDBDATA")" -gt "$(expr $NUMTRACKS / 2 )" ]; then
# More than 1/2 contain a "-", so guess forward-dash
DEFAULTSTYLE=2
@@ -105,7 +229,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
fi
echo "1) Artist / Title" >&2
-@@ -773,21 +792,22 @@ do_cddbedit ()
+@@ -773,21 +879,22 @@
echo "3) Title / Artist" >&2
echo "4) Title - Artist" >&2
echo "5) Artist: Title" >&2
@@ -135,7 +259,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
done
if [ "$VARIOUSARTISTSTYLE" = "0" ]; then
VARIOUSARTISTSTYLE=$DEFAULTSTYLE
-@@ -809,7 +829,10 @@ do_cddbedit ()
+@@ -809,7 +916,10 @@
5) # Artist: Title
VARIOUSARTISTSTYLE=colon
;;
@@ -147,7 +271,15 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
VARIOUSARTISTS=n
;;
esac
-@@ -909,6 +932,7 @@ XINGMP3ENC=xingmp3enc
+@@ -899,6 +1009,7 @@
+ READNICE=10
+ VARIOUSARTISTS=n
+ VARIOUSARTISTSTYLE=forward
++NORMALIZERSYNTAX=default
+
+ # program paths - defaults to checking your $PATH
+ LAME=lame
+@@ -909,6 +1020,7 @@
MP3ENC=mp3enc
VORBIZE=vorbize
OGGENC=oggenc
@@ -155,7 +287,15 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
ID3=id3
ID3V2=id3v2
CDPARANOIA=cdparanoia
-@@ -929,9 +953,9 @@ XINGMP3ENCOPTS=
+@@ -919,6 +1031,7 @@
+ EJECT=eject
+ DISTMP3=distmp3
+ VORBISCOMMENT=vorbiscomment
++NORMALIZE=normalize
+
+ # Options for programs called from abcde
+ LAMEOPTS=
+@@ -929,14 +1042,15 @@
MP3ENCOPTS=
VORBIZEOPTS=
OGGENCOPTS=
@@ -166,7 +306,13 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
CDDA2WAVOPTS=
WGETOPTS=
CDDBTOOLOPTS=
-@@ -948,7 +972,7 @@ ACTIONS=cddb,read,encode,tag,move,clean
+ EJECTOPTS=
+ DISTMP3OPTS=
++NORMALIZEOPTS=
+
+ # Default to one process if -j isn't specified
+ MAXPROCS=1
+@@ -948,7 +1062,7 @@
# Custom filename munging:
mungefilename ()
{
@@ -175,7 +321,7 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
}
# If CDDBAVAIL is set to n, no CDDB read is done
-@@ -964,17 +988,13 @@ if [ -z "$WAVOUTPUTDIR" ]; then
+@@ -964,17 +1078,13 @@
WAVOUTPUTDIR="$OUTPUTDIR"
fi
@@ -198,7 +344,19 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
fi
# Load user preference defaults
if [ -r $HOME/.abcde.conf ]; then
-@@ -1010,7 +1030,7 @@ while [ $# -gt 0 ]; do
+@@ -982,9 +1092,10 @@
+ fi
+
+ # Parse command line options
+-while getopts a:c:C:d:Dhj:lnNo:r:x opt ; do
++while getopts a:bc:C:d:Dhj:lnNo:r:x opt ; do
+ case "$opt" in
+ a) ACTIONS="$OPTARG" ;;
++ b) BATCH=y ;;
+ c) . "$OPTARG" ;;
+ C) DISCID="$OPTARG" ;;
+ d) CDROM="$OPTARG" ;;
+@@ -1010,7 +1121,7 @@
if [ "$RSTART" = "$REND" ]; then
NEWTRACKS="$RSTART"
else
@@ -207,11 +365,19 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
fi
TRACKQUEUE=$(echo "$TRACKQUEUE" "$NEWTRACKS")
-@@ -1029,13 +1049,18 @@ case "$CDROMREADERSYNTAX" in
+@@ -1029,12 +1140,25 @@
;;
esac
-# If nothing has been specified, use oggenc for oggs and lame for mp3s
++# There's only one normalize...
++case "$NORMALIZERSYNTAX" in
++ default|normalize)
++ NORMALIZER="$NORMALIZE"
++ NORMALIZEROPTS="$NORMALIZEOPTS"
++ ;;
++esac
++
+# If nothing has been specified, use oggenc for oggs and lame for mp3s and flac
+# for flacs
if [ "$ENCODERSYNTAX" = "default" ]; then
@@ -220,16 +386,14 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
- else
+ elif [ "$OUTPUTTYPE" = "mp3" ]; then
ENCODERSYNTAX=lame
-- fi
+ elif [ "$OUTPUTTYPE" = "flac" ]; then
-+ ENCODERSYNTAX=flac
-+ else
-+ echo "abcde error: Invalid OUTPUTTYPE defined" >&2
-+ fi
++ ENCODERSYNTAX=flac
++ else
++ echo "abcde error: Invalid OUTPUTTYPE defined" >&2
+ fi
fi
- # decide which encoder
-@@ -1072,6 +1097,11 @@ case "$ENCODERSYNTAX" in
+@@ -1072,6 +1196,11 @@
ENCODEROPTS="$OGGENCOPTS"
ENCODER="$OGGENC"
;;
@@ -241,19 +405,94 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
esac
# and which tagger
-@@ -1099,9 +1129,10 @@ if [ "$REMOTEHOSTS" ]; then NEEDDISTMP3=
+@@ -1098,10 +1227,13 @@
+ if [ "$REMOTEHOSTS" ]; then NEEDDISTMP3=y; fi
if [ "$OUTPUTTYPE" = "mp3" ]; then NEEDTAGGER=y; fi
if [ "$OUTPUTTYPE" = "ogg" ]; then NEEDCOMMENTER=y; fi
-
++if [ "$DONORMALIZE" = "y" ]; then NEEDNORMALIZER=y; fi
+
+
# Make sure a buncha things exist
for X in $CDROMREADER $CDDISCID ${NEEDTAGGER+$TAGGER} $ENCODER $WGET \
- ${NEEDDISTMP3+$DISTMP3} ${NEEDCOMMENTER+$VORBISCOMMENT} seq
-+ ${NEEDDISTMP3+$DISTMP3} ${NEEDCOMMENTER+$VORBISCOMMENT} jot
++ ${NEEDDISTMP3+$DISTMP3} ${NEEDCOMMENTER+$VORBISCOMMENT} \
++ ${NEEDNORMALIZER+$NORMALIZER} jot
do
# Cut off the command-line options we just added in
X=$(echo $X | cut -d' ' -f2)
-@@ -1191,7 +1222,7 @@ fi
+@@ -1119,7 +1251,7 @@
+
+ # One thousand lines in, we can start doing stuff with things
+
+-# List of valid actions: cddb,playlist,read,encode,tag,move
++# List of valid actions: cddb,playlist,read,normalize,encode,tag,move
+
+ do_discid # Get ABCDETEMPDIR created and status file initialized
+
+@@ -1161,16 +1293,20 @@
+ fi
+ fi
+ fi
+- echo NEXTTRACK # Get the encoder machine churning again
+- if [ "$DOREAD" = "y" ]; then
+- if [ "$LOWDISK" = "y" ] && [ "$DOENCODE" = "y" ]; then
+- until checkstatus encodetrack-$UTRACKNUM
+- do
+- if checkerrors encodetrack-$UTRACKNUM; then
+- break
+- fi
+- sleep 2
+- done
++ if [ "$BATCH" = "y" ]; then
++ :
++ else
++ echo NEXTTRACK # Get the encoder machine churning again
++ if [ "$DOREAD" = "y" ]; then
++ if [ "$LOWDISK" = "y" ] && [ "$DOENCODE" = "y" ]; then
++ until checkstatus encodetrack-$UTRACKNUM
++ do
++ if checkerrors encodetrack-$UTRACKNUM; then
++ break
++ fi
++ sleep 2
++ done
++ fi
+ fi
+ fi
+ done
+@@ -1181,17 +1317,39 @@
+ echo "encode-output=loud" >> "$ABCDETEMPDIR/status"
+ fi
+
++# All tracks read, start encoding.
++if [ "$BATCH" = "y" ]; then
++ echo NEXTTRACK
++fi
++
+ # We are now finished with the cdrom - it can be safely ejected. Note that
+ # abcde will not have completed yet.
+ if [ "$EJECTCD" = "y" ]; then
+ $EJECT $EJECTOPTS $CDROM
+ fi
+ ) | (
++# In batch mode, we want all tracks to be read first.
++if [ "$BATCH" = "y" ]; then
++ read GOAHEAD # For blocking - will contain either "NO" or "NEXTTRACK"
++ if [ "$GOAHEAD" = "NO" ]; then break; fi
++ for LASTTRACK in $TRACKQUEUE; do :; done
++ if checkstatus readtrack-$LASTTRACK; then
++ if [ "$DONORMALIZE" = "y" ]; then
++ if checkstatus normalizetrack-$LASTTRACK; then :; else do_batch_normalize; fi
++ if checkerrors batch-normalize; then exit; fi
++ fi
++ if [ "$DOENCODE" = "y" ]; then
++ if checkstatus encodetrack-$LASTTRACK; then :; else do_batch_encode; fi
++ if checkerrors batch-encode; then exit; fi
++ fi
++ fi
++fi
++
+ # Do the encoding, including parallelization of remote encoding
# Figure out where each track is going to be encoded
ENCODELOCATIONS="$(echo $REMOTEHOSTS | tr , ' ')"
if [ "$MAXPROCS" != "0" ]; then
@@ -262,3 +501,25 @@ $NetBSD: patch-ac,v 1.9 2002/12/16 05:14:30 lukem Exp $
do
ENCODELOCATIONS="$ENCODELOCATIONS %local$NUM%"
done
+@@ -1253,9 +1411,20 @@
+ # You can't tag a file before it's finished encoding -
+ # thus all of this is backgrounded together
+ (
++ if [ "$DONORMALIZE" = "y" ]; then
++ if checkstatus readtrack-$UTRACKNUM; then
++ if checkstatus normalizetrack-$UTRACKNUM; then :; else do_normalize $UTRACKNUM; fi
++ fi
++ fi
+ if [ "$DOENCODE" = "y" ]; then
+ if checkstatus readtrack-$UTRACKNUM; then
+- if checkstatus encodetrack-$UTRACKNUM; then :; else do_encode $UTRACKNUM $LOCATION; fi
++ if [ "$DONORMALIZE" = "y" ]; then
++ if checkstatus normalizetrack-$UTRACKNUM; then
++ if checkstatus encodetrack-$UTRACKNUM; then :; else do_encode $UTRACKNUM $LOCATION; fi
++ fi
++ else
++ if checkstatus encodetrack-$UTRACKNUM; then :; else do_encode $UTRACKNUM $LOCATION; fi
++ fi
+ fi
+ fi
+ if [ "$DOTAG" = "y" ]; then