X-Git-Url: https://diplodocus.org/git/flac-archive/blobdiff_plain/cbfd1b29112cd8ab5540c1019f2a400f4bf20410..7eae8b437dc78929d4dd6ed521f62e7330e8d9d3:/flac2mp3 diff --git a/flac2mp3 b/flac2mp3 index 3f0ef90..000d8ef 100755 --- a/flac2mp3 +++ b/flac2mp3 @@ -1,4 +1,4 @@ -#! /usr/bin/env python2.4 +#!/usr/bin/python """ =head1 NAME @@ -16,6 +16,10 @@ may be the kind of FLAC file B generates. That is, it contains a cue sheet, one TITLE tag per track listed therein, and ARTIST, ALBUM, and DATE tags. +Note that lame is retarded, and parses B directly itself! So, in order +for it to transcode textual tags, you must specify the encoding in LANG, e.g. +LANG=en_US.utf-8 + =head1 OPTIONS =over 4 @@ -50,20 +54,21 @@ Written by Eric Gillespie . """ -import re, sys, traceback +import os, re, sys, tempfile, traceback from optparse import OptionParser from subprocess import Popen, PIPE import org.diplodocus.jobs -from org.diplodocus import flac, taglib from org.diplodocus.util import run_or_die +from flac_archive import flac from flac_archive.tags import Tags ################################################################################ # The child processes -def flac2mp3(fn, title, artist, album, date, track, skip_until, pics=None): +def flac2mp3(fn, title, artist, album_artist, album, date, + track, skip_until, pics=None): (title, artist, album) = [(x == None and 'unknown') or x for x in (title, artist, album)] if date == None: @@ -88,20 +93,35 @@ def flac2mp3(fn, title, artist, album, date, track, skip_until, pics=None): track, title)).replace('/', '_') # Escape any single quotes ' so we can quote this. - (fn, title, artist, - album, date) = [x.replace("'", r"'\''") - for x in (fn, title, artist, album, date)] + (fn, title, artist, album_artist, + album, date) = [(x or '').replace("'", r"'\''") + for x in [fn, title, artist, album_artist, album, date]] + + album_artist_options = '' + if album_artist: + album_artist_options = "--tv 'TPE2=%s'" % album_artist quoted_outfile = ('%s (%s) %02d %s.mp3' % (artist, album, track, title)).replace('/', '_') - run_or_die(3, "flac %s -cd %s '%s' | lame --add-id3v2 %s --tt '%s' --ta '%s' --tl '%s' --ty '%s' --tn %d - '%s'" - % (flac_options, ' '.join(skip_until), fn, - lame_options, title, artist, album, date, track, - quoted_outfile)) - - if pics != None: - taglib.add_apic_frame_to_mp3(outfile, pics) + pic_options = None + if pics: + (fd, picfn) = tempfile.mkstemp() + f = os.fdopen(fd, 'wb') + f.write(pics[0][7]) + f.close() + pic_options = "--ti '%s'" % picfn + try: + run_or_die(3, "flac %s -cd %s '%s' | lame --id3v2-only --id3v2-latin1 --pad-id3v2-size 0 %s --tt '%s' --ta '%s' --tl '%s' --ty '%s' --tn %d %s %s - '%s'" + % (flac_options, ' '.join(skip_until), fn, + lame_options, title, artist, album, date, track, + pic_options, album_artist_options, quoted_outfile)) + finally: + if pic_options: + try: + os.unlink(picfn) + except: + pass return 0 @@ -185,6 +205,7 @@ def main(argv): traceback.print_exc() return 2 + separator = ' ' try: global debug, flac_options, lame_options, quiet, verbose debug = options.debug @@ -198,7 +219,7 @@ def main(argv): args = get_decode_args(fn) tags = get_tags(fn) - album = tags.gets('ALBUM') + album = tags.gets('ALBUM', separator=separator) discnum = tags.gets('DISCNUMBER') track = tags.gets('TRACKNUMBER') @@ -218,13 +239,19 @@ def main(argv): pics = flac.get_pictures(fn) for i in range(len(tags)): - title = tags.gets('TITLE', track) + title = tags.gets('TITLE', track, separator) part = tags.gets('PART', track) if part != None: title = '%s - %s' % (title, part) + version = tags.gets('VERSION', track) + if version != None: + title = '%s (%s)' % (title, version) + artist = tags.get('ARTIST', track) + artist.extend(tags.get('FEATURING', track)) + album_artist = tags.gets('ALBUMARTIST', track) jobs.append([fn, title, - tags.gets('ARTIST', track), - album, + ', '.join(artist), + album_artist, album, tags.gets('DATE', track), track, args[i], pics]) track = i + 2