-#! /usr/bin/env python2.4
+#!/usr/bin/python
"""
=head1 NAME
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<LANG> 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
"""
-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.util import run_or_die
-from flac_archive import flac, taglib
+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:
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
title = '%s - %s' % (title, part)
artist = tags.get('ARTIST', track)
artist.extend(tags.get('FEATURING', track))
+ album_artist = tags.gets('ALBUMARTIST', track)
jobs.append([fn, title,
', '.join(artist),
- album,
+ album_artist, album,
tags.gets('DATE', track),
track, args[i], pics])
track = i + 2