Comments about on cardinality/multiplicity.

This commit is contained in:
David Read 2012-12-05 12:05:45 +00:00 committed by amercader
parent d2c97fe3cc
commit 46fb0030a5
1 changed files with 14 additions and 0 deletions

View File

@ -104,26 +104,40 @@ class MappedXmlElement(MappedXmlObject):
return etree.tostring(element, pretty_print=False) return etree.tostring(element, pretty_print=False)
def fix_multiplicity(self, values): def fix_multiplicity(self, values):
'''
When a field contains multiple values, yet the spec says
it should contain only one, then return just the first value,
rather than a list.
In the ISO19115 specification, multiplicity relates to:
* 'Association Cardinality'
* 'Obligation/Condition' & 'Maximum Occurence'
'''
if self.multiplicity == "0": if self.multiplicity == "0":
# 0 = None
if values: if values:
raise Exception( raise Exception(
"Values found for element '%s': %s" % (self.name, values)) "Values found for element '%s': %s" % (self.name, values))
else: else:
return "" return ""
elif self.multiplicity == "1": elif self.multiplicity == "1":
# 1 = Mandatory, maximum 1 = Exactly one
if values: if values:
return values[0] return values[0]
else: else:
raise Exception( raise Exception(
"Value not found for element '%s'" % self.name) "Value not found for element '%s'" % self.name)
elif self.multiplicity == "*": elif self.multiplicity == "*":
# * = 0..* = zero or more
return values return values
elif self.multiplicity == "0..1": elif self.multiplicity == "0..1":
# 0..1 = Mandatory, maximum 1 = optional (zero or one)
if values: if values:
return values[0] return values[0]
else: else:
return "" return ""
elif self.multiplicity == "1..*": elif self.multiplicity == "1..*":
# 1..* = one or more
return values return values
else: else:
raise Exception( raise Exception(