Files
whipper-gui/morituri/rip/debug.py
Thomas Vander Stichele 306e6f2ad7 * morituri/common/cache.py:
* morituri/rip/debug.py:
	* morituri/test/test_common_cache.py:
	  Add rip debug resultcache list to list cached results.
2012-12-02 17:27:15 +00:00

150 lines
4.3 KiB
Python

# -*- Mode: Python -*-
# vi:si:et:sw=4:sts=4:ts=4
# Morituri - for those about to RIP
# Copyright (C) 2009 Thomas Vander Stichele
# This file is part of morituri.
#
# morituri is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# morituri is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with morituri. If not, see <http://www.gnu.org/licenses/>.
from morituri.common import logcommand
from morituri.common import task, cache
class RCList(logcommand.LogCommand):
name = "list"
summary = "list cached results"
def do(self, args):
self._cache = cache.ResultCache()
results = []
for i in self._cache.getIds():
r = self._cache.getRipResult(i)
results.append((r.object.artist, r.object.title, i))
results.sort()
for artist, title, cddbid in results:
self.stdout.write('%s: %s - %s\n' % (
cddbid, artist, title))
class ResultCache(logcommand.LogCommand):
summary = "debug result cache"
aliases = ['rc', ]
subCommandClasses = [RCList, ]
class Checksum(logcommand.LogCommand):
summary = "run a checksum task"
def do(self, args):
try:
fromPath = unicode(args[0])
except IndexError:
self.stdout.write('Please specify an input file.\n')
return 3
runner = task.SyncRunner()
# here to avoid import gst eating our options
from morituri.common import checksum
checksumtask = checksum.CRC32Task(fromPath)
runner.run(checksumtask)
self.stdout.write('Checksum: %08x\n' % checksumtask.checksum)
class Encode(logcommand.LogCommand):
summary = "run an encode task"
def addOptions(self):
# here to avoid import gst eating our options
from morituri.common import encode
default = 'flac'
self.parser.add_option('', '--profile',
action="store", dest="profile",
help="profile for encoding (default '%s', choices '%s')" % (
default, "', '".join(encode.PROFILES.keys())),
default=default)
def do(self, args):
try:
fromPath = unicode(args[0])
except IndexError:
self.stdout.write('Please specify an input file.\n')
return 3
try:
toPath = unicode(args[1])
except IndexError:
toPath = fromPath + '.' + self.options.profile
runner = task.SyncRunner()
from morituri.common import encode
profile = encode.PROFILES[self.options.profile]()
self.debug('Encoding %s to %s',
fromPath.encode('utf-8'),
toPath.encode('utf-8'))
encodetask = encode.EncodeTask(fromPath, toPath, profile)
runner.run(encodetask)
class MusicBrainzNGS(logcommand.LogCommand):
summary = "examine MusicBrainz NGS info"
def do(self, args):
try:
discId = unicode(args[0])
except IndexError:
self.stdout.write('Please specify a MusicBrainz disc id.\n')
return 3
from morituri.common import musicbrainzngs
metadatas = musicbrainzngs.musicbrainz(discId)
self.stdout.write('%d releases\n' % len(metadatas))
for i, md in enumerate(metadatas):
self.stdout.write('- Release %d:\n' % (i + 1, ))
self.stdout.write(' Artist: %s\n' % md.artist.encode('utf-8'))
self.stdout.write(' Title: %s\n' % md.title.encode('utf-8'))
self.stdout.write(' URL: %s\n' % md.url)
self.stdout.write(' Tracks: %d\n' % len(md.tracks))
for j, track in enumerate(md.tracks):
self.stdout.write(' Track %2d: %s - %s\n' % (
j + 1, track.artist.encode('utf-8'),
track.title.encode('utf-8')))
class Debug(logcommand.LogCommand):
summary = "debug internals"
subCommandClasses = [Checksum, Encode, MusicBrainzNGS, ResultCache]