Added default translator for mdata elements that don't specify it
This commit is contained in:
parent
a88b7255ff
commit
10c4a71866
|
@ -1,5 +1,5 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
import media.monitor.process as md
|
import media.metadata.process as md
|
||||||
from os.path import normpath
|
from os.path import normpath
|
||||||
from media.monitor.pure import format_length, file_md5
|
from media.monitor.pure import format_length, file_md5
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
from contextlib import contextmanager
|
from contextlib import contextmanager
|
||||||
from media.monitor.pure import truncate_to_length, toposort
|
from media.monitor.pure import truncate_to_length, toposort
|
||||||
|
from media.monitor.log import Loggable
|
||||||
import mutagen
|
import mutagen
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,7 +9,12 @@ class MetadataAbsent(Exception):
|
||||||
def __init__(self, name): self.name = name
|
def __init__(self, name): self.name = name
|
||||||
def __str__(self): return "Could not obtain element '%s'" % self.name
|
def __str__(self): return "Could not obtain element '%s'" % self.name
|
||||||
|
|
||||||
class MetadataElement(object):
|
class MetadataElement(Loggable):
|
||||||
|
|
||||||
|
def __default_translator(k):
|
||||||
|
e = [ x for x in self.dependencies() ][0]
|
||||||
|
return k[e]
|
||||||
|
|
||||||
def __init__(self,name):
|
def __init__(self,name):
|
||||||
self.name = name
|
self.name = name
|
||||||
# "Sane" defaults
|
# "Sane" defaults
|
||||||
|
@ -19,6 +25,8 @@ class MetadataElement(object):
|
||||||
self.__is_normalized = lambda _ : True
|
self.__is_normalized = lambda _ : True
|
||||||
self.__max_length = -1
|
self.__max_length = -1
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def max_length(self,l):
|
def max_length(self,l):
|
||||||
self.__max_length = l
|
self.__max_length = l
|
||||||
|
|
||||||
|
@ -82,6 +90,15 @@ class MetadataElement(object):
|
||||||
if self.has_default(): return self.get_default()
|
if self.has_default(): return self.get_default()
|
||||||
else: raise MetadataAbsent(self.name)
|
else: raise MetadataAbsent(self.name)
|
||||||
# We have all dependencies. Now for actual for parsing
|
# We have all dependencies. Now for actual for parsing
|
||||||
|
|
||||||
|
# Only case where we can select a default translator
|
||||||
|
if not self.__translator:
|
||||||
|
if len(self.dependencies()) == 1:
|
||||||
|
self.translate(MetadataElement.__default_translator)
|
||||||
|
else:
|
||||||
|
self.logger.info("Could not set more than 1 translator with \
|
||||||
|
more than 1 dependancies")
|
||||||
|
|
||||||
r = self.__normalizer( self.__translator(full_deps) )
|
r = self.__normalizer( self.__translator(full_deps) )
|
||||||
if self.__max_length != -1:
|
if self.__max_length != -1:
|
||||||
r = truncate_to_length(r, self.__max_length)
|
r = truncate_to_length(r, self.__max_length)
|
||||||
|
|
|
@ -196,7 +196,7 @@ class Metadata(Loggable):
|
||||||
normalized = global_reader.read('fpath', full_mutagen)
|
normalized = global_reader.read('fpath', full_mutagen)
|
||||||
self.logger.info(pformat(normalized))
|
self.logger.info(pformat(normalized))
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
self.logger.unexpected_exception(e)
|
self.unexpected_exception(e)
|
||||||
|
|
||||||
if full_mutagen is None: full_mutagen = FakeMutagen(fpath)
|
if full_mutagen is None: full_mutagen = FakeMutagen(fpath)
|
||||||
self.__metadata = Metadata.airtime_dict(full_mutagen)
|
self.__metadata = Metadata.airtime_dict(full_mutagen)
|
||||||
|
|
Loading…
Reference in New Issue