emf improvements
This commit is contained in:
parent
10c4a71866
commit
b7b11feae0
2 changed files with 23 additions and 18 deletions
|
@ -96,17 +96,18 @@ def load_definitions():
|
||||||
t.depends('path')
|
t.depends('path')
|
||||||
t.translate(lambda k: normpath(k['path']))
|
t.translate(lambda k: normpath(k['path']))
|
||||||
|
|
||||||
with md.metadata("MDATA_KEY_MD5") as t:
|
#with md.metadata("MDATA_KEY_MD5") as t:
|
||||||
t.depends('path')
|
#t.depends('path')
|
||||||
t.optional(False)
|
#t.optional(False)
|
||||||
t.translate(lambda k: file_md5(k['path'], max_length=100))
|
#t.translate(lambda k: file_md5(k['path'], max_length=100))
|
||||||
|
|
||||||
# owner is handled differently by (by events.py)
|
# owner is handled differently by (by events.py)
|
||||||
|
|
||||||
with md.metadata('MDATA_KEY_ORIGINAL_PATH') as t:
|
with md.metadata('MDATA_KEY_ORIGINAL_PATH') as t:
|
||||||
t.depends('original_path')
|
t.depends('original_path')
|
||||||
|
|
||||||
# MDATA_KEY_TITLE is the annoying special case
|
# MDATA_KEY_TITLE is the annoying special case b/c we sometimes read it
|
||||||
|
# from file name
|
||||||
with md.metadata('MDATA_KEY_TITLE') as t:
|
with md.metadata('MDATA_KEY_TITLE') as t:
|
||||||
# Need to know MDATA_KEY_CREATOR to know if show was recorded. Value is
|
# Need to know MDATA_KEY_CREATOR to know if show was recorded. Value is
|
||||||
# defaulted to "" from definitions above
|
# defaulted to "" from definitions above
|
||||||
|
|
|
@ -11,10 +11,6 @@ class MetadataAbsent(Exception):
|
||||||
|
|
||||||
class MetadataElement(Loggable):
|
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
|
||||||
|
@ -24,8 +20,7 @@ class MetadataElement(Loggable):
|
||||||
self.__default = None
|
self.__default = None
|
||||||
self.__is_normalized = lambda _ : True
|
self.__is_normalized = lambda _ : True
|
||||||
self.__max_length = -1
|
self.__max_length = -1
|
||||||
|
self.__translator = None
|
||||||
|
|
||||||
|
|
||||||
def max_length(self,l):
|
def max_length(self,l):
|
||||||
self.__max_length = l
|
self.__max_length = l
|
||||||
|
@ -71,6 +66,7 @@ class MetadataElement(Loggable):
|
||||||
return "%s(%s)" % (self.name, ' '.join(list(self.__deps)))
|
return "%s(%s)" % (self.name, ' '.join(list(self.__deps)))
|
||||||
|
|
||||||
def read_value(self, path, original, running={}):
|
def read_value(self, path, original, running={}):
|
||||||
|
self.logger.info("Trying to read: %s" % str(original))
|
||||||
# If value is present and normalized then we don't touch it
|
# If value is present and normalized then we don't touch it
|
||||||
if self.name in original:
|
if self.name in original:
|
||||||
v = original[self.name]
|
v = original[self.name]
|
||||||
|
@ -83,21 +79,29 @@ class MetadataElement(Loggable):
|
||||||
full_deps = dict( dep_slice_orig.items()
|
full_deps = dict( dep_slice_orig.items()
|
||||||
+ dep_slice_running.items() )
|
+ dep_slice_running.items() )
|
||||||
|
|
||||||
|
full_deps['path'] = path
|
||||||
|
|
||||||
# check if any dependencies are absent
|
# check if any dependencies are absent
|
||||||
if len(full_deps) != len(self.__deps) or len(self.__deps) == 0:
|
if len(full_deps) < len(self.__deps) or len(self.__deps) == 0:
|
||||||
# If we have a default value then use that. Otherwise throw an
|
# If we have a default value then use that. Otherwise throw an
|
||||||
# exception
|
# exception
|
||||||
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
|
||||||
|
|
||||||
|
def def_translate(dep):
|
||||||
|
def wrap(k):
|
||||||
|
e = [ x for x in dep ][0]
|
||||||
|
return k[e]
|
||||||
|
return wrap
|
||||||
|
|
||||||
# Only case where we can select a default translator
|
# Only case where we can select a default translator
|
||||||
if not self.__translator:
|
if self.__translator is None:
|
||||||
if len(self.dependencies()) == 1:
|
self.translate(def_translate(self.dependencies()))
|
||||||
self.translate(MetadataElement.__default_translator)
|
if len(self.dependencies()) > 2: # dependencies include themselves
|
||||||
else:
|
self.logger.info("Ignoring some dependencies in translate %s"
|
||||||
self.logger.info("Could not set more than 1 translator with \
|
% self.name)
|
||||||
more than 1 dependancies")
|
self.logger.info(self.dependencies())
|
||||||
|
|
||||||
r = self.__normalizer( self.__translator(full_deps) )
|
r = self.__normalizer( self.__translator(full_deps) )
|
||||||
if self.__max_length != -1:
|
if self.__max_length != -1:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue