from org.diplodocus import flac, taglib
from org.diplodocus.util import run_or_die
+from flac_archive.tags import Tags
+
################################################################################
# The child processes
return args
-# XXX other things should usue this; flac files, for example, should
-# get PART as part of the filelname, same as mp3s.
-class Tags(object):
- def __init__(self):
- self._global = {}
- self._tags = {}
- def __len__(self):
- # All files have at least one track.
- return max(1, len(self._tags))
- def get(self, key, track=None):
- key = key.upper()
- try:
- try:
- return self._tags[track][key]
- except KeyError:
- return self._global[key]
- except KeyError:
- return None
- def gets(self, key, track=None):
- value = self.get(key, track)
- if value == None:
- return None
- return '\n'.join(value)
- def set(self, key, value, track=None):
- key = key.upper()
- if track == None:
- tags = self._global
- else:
- try:
- tags = self._tags[track]
- except KeyError:
- tags = self._tags[track] = {}
- if key not in tags:
- tags[key] = []
- tags[key].append(value)
-
def get_tags(fn):
"""Return the ARTIST, ALBUM, and DATE tags followed by the TITLE tags
in the file FN."""
tags = Tags()
p = Popen(['metaflac', '--export-tags-to=-', fn], stdout=PIPE)
- for line in (x.rstrip() for x in p.stdout):
- (tag, value) = line.split('=', 1)
-
- m = re.search(r'\[([0-9]+)]$', tag)
- if m != None:
- tag = tag[:m.start()]
- track = int(m.group(1))
- else:
- track = None
+ tags.load(p.stdout)
- tags.set(tag, value, track)
# XXX dataloss! check status
status = p.wait()
traceback.print_exc()
return 2
+ separator = ' '
try:
global debug, flac_options, lame_options, quiet, verbose
debug = options.debug
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')
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)
jobs.append([fn, title,
- tags.gets('ARTIST', track),
+ tags.gets('ARTIST', track, separator=', '),
album,
tags.gets('DATE', track),
track, args[i], pics])