diff --git a/CHANGELOG.md b/CHANGELOG.md
index b63fb7216..939a3554b 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -5,6 +5,25 @@ Versioned according to [Semantic Versioning](http://semver.org/).
## Unreleased
+## [2.4.4] - 2020-03-17
+
+Fixed:
+
+ * #437 broke simple types in PAGE model, (really) revert 3a0a3a8, #451
+
+## [2.4.3] - 2020-03-12
+
+Fixed:
+
+ * bashlib: ocrd-tool.json-related errors no longer lead to silent exit, #456
+ * #437 broke simple types in PAGE model, revert 3a0a3a8, #451
+
+## [2.4.2] - 2020-02-20
+
+Fixed:
+
+ * JSON strings longer than OS-allowed filename size crash fixed, #444
+
## [2.4.1] - 2020-02-19
Changed:
@@ -757,6 +776,9 @@ Fixed
Initial Release
+[2.4.4]: ../../compare/v2.4.4...v2.4.3
+[2.4.3]: ../../compare/v2.4.3...v2.4.2
+[2.4.2]: ../../compare/v2.4.2...v2.4.1
[2.4.1]: ../../compare/v2.4.1...v2.4.0
[2.4.0]: ../../compare/v2.4.0...v2.3.1
[2.3.1]: ../../compare/v2.3.1...v2.3.0
diff --git a/ocrd/bashlib/src/parse_argv.bash b/ocrd/bashlib/src/parse_argv.bash
index 35e8f1acd..36cdbeb83 100644
--- a/ocrd/bashlib/src/parse_argv.bash
+++ b/ocrd/bashlib/src/parse_argv.bash
@@ -57,13 +57,11 @@ ocrd__parse_argv () {
local params_parsed retval
- params_parsed="$(ocrd ocrd-tool "$OCRD_TOOL_JSON" tool $OCRD_TOOL_NAME parse-params -p "${ocrd__argv[parameter]:-{\}}")"
- retval=$?
- if [[ $retval != 0 ]];then
- echo "Error: Failed to parse parameters (retval $retval):"
- echo "$params_parsed"
- exit 42 # $retval
- fi
+ params_parsed="$(ocrd ocrd-tool "$OCRD_TOOL_JSON" tool $OCRD_TOOL_NAME parse-params -p "${ocrd__argv[parameter]:-{\}}")" || {
+ retval=$?
+ ocrd__raise "Failed to parse parameters (retval $retval):
+$params_parsed"
+ }
eval "$params_parsed"
}
diff --git a/ocrd/ocrd/lib.bash b/ocrd/ocrd/lib.bash
index 8d53a04fe..0564f7688 100644
--- a/ocrd/ocrd/lib.bash
+++ b/ocrd/ocrd/lib.bash
@@ -96,13 +96,11 @@ ocrd__parse_argv () {
local params_parsed retval
- params_parsed="$(ocrd ocrd-tool "$OCRD_TOOL_JSON" tool $OCRD_TOOL_NAME parse-params -p "${ocrd__argv[parameter]:-{\}}")"
- retval=$?
- if [[ $retval != 0 ]];then
- echo "Error: Failed to parse parameters (retval $retval):"
- echo "$params_parsed"
- exit 42 # $retval
- fi
+ params_parsed="$(ocrd ocrd-tool "$OCRD_TOOL_JSON" tool $OCRD_TOOL_NAME parse-params -p "${ocrd__argv[parameter]:-{\}}")" || {
+ retval=$?
+ ocrd__raise "Failed to parse parameters (retval $retval):
+$params_parsed"
+ }
eval "$params_parsed"
}
diff --git a/ocrd_models/ocrd_models/ocrd_page.py b/ocrd_models/ocrd_models/ocrd_page.py
index 8f8cc3613..381101e29 100644
--- a/ocrd_models/ocrd_models/ocrd_page.py
+++ b/ocrd_models/ocrd_models/ocrd_page.py
@@ -67,7 +67,7 @@ def to_xml(el):
"""
sio = StringIO()
el.export(sio, 0, name_='PcGts',
- namespacedef_='xmlns="%s" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="%s %s/pagecontent.xsd"' % (
+ namespacedef_='xmlns:pc="%s" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="%s %s/pagecontent.xsd"' % (
NAMESPACES['page'],
NAMESPACES['page'],
NAMESPACES['page']
diff --git a/ocrd_models/ocrd_models/ocrd_page_generateds.py b/ocrd_models/ocrd_models/ocrd_page_generateds.py
index c6339957d..5db34adaf 100644
--- a/ocrd_models/ocrd_models/ocrd_page_generateds.py
+++ b/ocrd_models/ocrd_models/ocrd_page_generateds.py
@@ -2,32 +2,29 @@
# -*- coding: utf-8 -*-
#
-# Generated Wed Feb 19 17:32:09 2020 by generateDS.py version 2.35.13.
+# Generated Mon Aug 5 20:18:48 2019 by generateDS.py version 2.30.11.
# Python 3.6.6 (default, Jul 24 2018, 16:39:20) [GCC 4.9.2]
#
# Command line options:
# ('-f', '')
# ('--root-element', 'PcGts')
-# ('--user-methods', 'ocrd_models/ocrd_page_user_methods.py')
# ('-o', 'ocrd_models/ocrd_models/ocrd_page_generateds.py')
#
# Command line arguments:
# repo/assets/data/schema/data/2019.xsd
#
# Command line:
-# /data/monorepo/venv3.6/bin/generateDS -f --root-element="PcGts" --user-methods="ocrd_models/ocrd_page_user_methods.py" -o "ocrd_models/ocrd_models/ocrd_page_generateds.py" repo/assets/data/schema/data/2019.xsd
+# /data/monorepo/venv3.6/bin/generateDS -f --root-element="PcGts" -o "ocrd_models/ocrd_models/ocrd_page_generateds.py" repo/assets/data/schema/data/2019.xsd
#
# Current working directory (os.getcwd()):
# core
#
-from six.moves import zip_longest
-import os
import sys
import re as re_
import base64
import datetime as datetime_
-import decimal as decimal_
+import warnings as warnings_
try:
from lxml import etree as etree_
except ImportError:
@@ -35,7 +32,6 @@
Validate_simpletypes_ = True
-SaveElementTreeNode = True
if sys.version_info.major == 2:
BaseStrType_ = basestring
else:
@@ -51,11 +47,6 @@ def parsexml_(infile, parser=None, **kwargs):
except AttributeError:
# fallback to xml.etree
parser = etree_.XMLParser()
- try:
- if isinstance(infile, os.PathLike):
- infile = os.path.join(infile)
- except AttributeError:
- pass
doc = etree_.parse(infile, parser=parser, **kwargs)
return doc
@@ -80,7 +71,7 @@ def parsexmlstring_(instring, parser=None, **kwargs):
# definitions. The export method for any class for which there is
# a namespace prefix definition, will export that definition in the
# XML representation of that element. See the export method of
-# any generated element type class for an example of the use of this
+# any generated element type class for a example of the use of this
# table.
# A sample table is:
#
@@ -91,75 +82,11 @@ def parsexmlstring_(instring, parser=None, **kwargs):
# "ElementtypeB": "http://www.xxx.com/namespaceB",
# }
#
-# Additionally, the generatedsnamespaces module can contain a python
-# dictionary named GenerateDSNamespaceTypePrefixes that associates element
-# types with the namespace prefixes that are to be added to the
-# "xsi:type" attribute value. See the exportAttributes method of
-# any generated element type and the generation of "xsi:type" for an
-# example of the use of this table.
-# An example table:
-#
-# # File: generatedsnamespaces.py
-#
-# GenerateDSNamespaceTypePrefixes = {
-# "ElementtypeC": "aaa:",
-# "ElementtypeD": "bbb:",
-# }
-#
try:
from generatedsnamespaces import GenerateDSNamespaceDefs as GenerateDSNamespaceDefs_
except ImportError:
GenerateDSNamespaceDefs_ = {}
-try:
- from generatedsnamespaces import GenerateDSNamespaceTypePrefixes as GenerateDSNamespaceTypePrefixes_
-except ImportError:
- GenerateDSNamespaceTypePrefixes_ = {}
-
-#
-# You can replace the following class definition by defining an
-# importable module named "generatedscollector" containing a class
-# named "GdsCollector". See the default class definition below for
-# clues about the possible content of that class.
-#
-try:
- from generatedscollector import GdsCollector as GdsCollector_
-except ImportError:
-
- class GdsCollector_(object):
-
- def __init__(self, messages=None):
- if messages is None:
- self.messages = []
- else:
- self.messages = messages
-
- def add_message(self, msg):
- self.messages.append(msg)
-
- def get_messages(self):
- return self.messages
-
- def clear_messages(self):
- self.messages = []
-
- def print_messages(self):
- for msg in self.messages:
- print("Warning: {}".format(msg))
-
- def write_messages(self, outstream):
- for msg in self.messages:
- outstream.write("Warning: {}\n".format(msg))
-
-
-#
-# The super-class for enum types
-#
-
-try:
- from enum import Enum
-except ImportError:
- Enum = object
#
# The root super-class for element type classes
@@ -173,7 +100,6 @@ def write_messages(self, outstream):
except ImportError as exp:
class GeneratedsSuper(object):
- __hash__ = object.__hash__
tzoff_pattern = re_.compile(r'(\+|-)((0\d|1[0-3]):[0-5]\d|14:00)$')
class _FixedOffsetTZ(datetime_.tzinfo):
def __init__(self, offset, name):
@@ -187,8 +113,6 @@ def dst(self, dt):
return None
def gds_format_string(self, input_data, input_name=''):
return input_data
- def gds_parse_string(self, input_data, node=None, input_name=''):
- return input_data
def gds_validate_string(self, input_data, node=None, input_name=''):
if not input_data:
return ''
@@ -200,18 +124,8 @@ def gds_validate_base64(self, input_data, node=None, input_name=''):
return input_data
def gds_format_integer(self, input_data, input_name=''):
return '%d' % input_data
- def gds_parse_integer(self, input_data, node=None, input_name=''):
- try:
- ival = int(input_data)
- except (TypeError, ValueError) as exp:
- raise_parse_error(node, 'Requires integer value: %s' % exp)
- return ival
def gds_validate_integer(self, input_data, node=None, input_name=''):
- try:
- value = int(input_data)
- except (TypeError, ValueError):
- raise_parse_error(node, 'Requires integer value')
- return value
+ return input_data
def gds_format_integer_list(self, input_data, input_name=''):
return '%s' % ' '.join(input_data)
def gds_validate_integer_list(
@@ -221,22 +135,12 @@ def gds_validate_integer_list(
try:
int(value)
except (TypeError, ValueError):
- raise_parse_error(node, 'Requires sequence of integer valuess')
+ raise_parse_error(node, 'Requires sequence of integers')
return values
def gds_format_float(self, input_data, input_name=''):
return ('%.15f' % input_data).rstrip('0')
- def gds_parse_float(self, input_data, node=None, input_name=''):
- try:
- fval_ = float(input_data)
- except (TypeError, ValueError) as exp:
- raise_parse_error(node, 'Requires float or double value: %s' % exp)
- return fval_
def gds_validate_float(self, input_data, node=None, input_name=''):
- try:
- value = float(input_data)
- except (TypeError, ValueError):
- raise_parse_error(node, 'Requires float value')
- return value
+ return input_data
def gds_format_float_list(self, input_data, input_name=''):
return '%s' % ' '.join(input_data)
def gds_validate_float_list(
@@ -246,47 +150,12 @@ def gds_validate_float_list(
try:
float(value)
except (TypeError, ValueError):
- raise_parse_error(node, 'Requires sequence of float values')
- return values
- def gds_format_decimal(self, input_data, input_name=''):
- return ('%0.10f' % input_data).rstrip('0')
- def gds_parse_decimal(self, input_data, node=None, input_name=''):
- try:
- decimal_value = decimal_.Decimal(input_data)
- except (TypeError, ValueError):
- raise_parse_error(node, 'Requires decimal value')
- return decimal_value
- def gds_validate_decimal(self, input_data, node=None, input_name=''):
- try:
- value = decimal_.Decimal(input_data)
- except (TypeError, ValueError):
- raise_parse_error(node, 'Requires decimal value')
- return value
- def gds_format_decimal_list(self, input_data, input_name=''):
- return '%s' % ' '.join(input_data)
- def gds_validate_decimal_list(
- self, input_data, node=None, input_name=''):
- values = input_data.split()
- for value in values:
- try:
- decimal_.Decimal(value)
- except (TypeError, ValueError):
- raise_parse_error(node, 'Requires sequence of decimal values')
+ raise_parse_error(node, 'Requires sequence of floats')
return values
def gds_format_double(self, input_data, input_name=''):
return '%e' % input_data
- def gds_parse_double(self, input_data, node=None, input_name=''):
- try:
- fval_ = float(input_data)
- except (TypeError, ValueError) as exp:
- raise_parse_error(node, 'Requires double or float value: %s' % exp)
- return fval_
def gds_validate_double(self, input_data, node=None, input_name=''):
- try:
- value = float(input_data)
- except (TypeError, ValueError):
- raise_parse_error(node, 'Requires double or float value')
- return value
+ return input_data
def gds_format_double_list(self, input_data, input_name=''):
return '%s' % ' '.join(input_data)
def gds_validate_double_list(
@@ -296,25 +165,11 @@ def gds_validate_double_list(
try:
float(value)
except (TypeError, ValueError):
- raise_parse_error(
- node, 'Requires sequence of double or float values')
+ raise_parse_error(node, 'Requires sequence of doubles')
return values
def gds_format_boolean(self, input_data, input_name=''):
return ('%s' % input_data).lower()
- def gds_parse_boolean(self, input_data, node=None, input_name=''):
- if input_data in ('true', '1'):
- bval = True
- elif input_data in ('false', '0'):
- bval = False
- else:
- raise_parse_error(node, 'Requires boolean value')
- return bval
def gds_validate_boolean(self, input_data, node=None, input_name=''):
- if input_data not in (True, 1, False, 0, ):
- raise_parse_error(
- node,
- 'Requires boolean value '
- '(one of True, 1, False, 0)')
return input_data
def gds_format_boolean_list(self, input_data, input_name=''):
return '%s' % ' '.join(input_data)
@@ -322,11 +177,11 @@ def gds_validate_boolean_list(
self, input_data, node=None, input_name=''):
values = input_data.split()
for value in values:
- if value not in (True, 1, False, 0, ):
+ if value not in ('true', '1', 'false', '0', ):
raise_parse_error(
node,
- 'Requires sequence of boolean values '
- '(one of True, 1, False, 0)')
+ 'Requires sequence of booleans '
+ '("true", "1", "false", "0")')
return values
def gds_validate_datetime(self, input_data, node=None, input_name=''):
return input_data
@@ -511,50 +366,6 @@ def gds_parse_time(cls, input_data):
dt = datetime_.datetime.strptime(input_data, '%H:%M:%S')
dt = dt.replace(tzinfo=tz)
return dt.time()
- def gds_check_cardinality_(
- self, value, input_name,
- min_occurs=0, max_occurs=1, required=None):
- if value is None:
- length = 0
- elif isinstance(value, list):
- length = len(value)
- else:
- length = 1
- if required is not None :
- if required and length < 1:
- self.gds_collector_.add_message(
- "Required value {}{} is missing".format(
- input_name, self.gds_get_node_lineno_()))
- if length < min_occurs:
- self.gds_collector_.add_message(
- "Number of values for {}{} is below "
- "the minimum allowed, "
- "expected at least {}, found {}".format(
- input_name, self.gds_get_node_lineno_(),
- min_occurs, length))
- elif length > max_occurs:
- self.gds_collector_.add_message(
- "Number of values for {}{} is above "
- "the maximum allowed, "
- "expected at most {}, found {}".format(
- input_name, self.gds_get_node_lineno_(),
- max_occurs, length))
- def gds_validate_builtin_ST_(
- self, validator, value, input_name,
- min_occurs=None, max_occurs=None, required=None):
- if value is not None:
- try:
- validator(value, input_name=input_name)
- except GDSParseError as parse_error:
- self.gds_collector_.add_message(str(parse_error))
- def gds_validate_defined_ST_(
- self, validator, value, input_name,
- min_occurs=None, max_occurs=None, required=None):
- if value is not None:
- try:
- validator(value)
- except GDSParseError as parse_error:
- self.gds_collector_.add_message(str(parse_error))
def gds_str_lower(self, instring):
return instring.lower()
def get_path_(self, node):
@@ -584,10 +395,7 @@ def get_class_obj_(self, node, default_class=None):
class_obj1 = class_obj2
return class_obj1
def gds_build_any(self, node, type_name=None):
- # provide default value in case option --disable-xml is used.
- content = ""
- content = etree_.tostring(node, encoding="unicode")
- return content
+ return None
@classmethod
def gds_reverse_node_mapping(cls, mapping):
return dict(((v, k) for k, v in mapping.items()))
@@ -611,34 +419,11 @@ def convert_unicode(instring):
result = GeneratedsSuper.gds_encode(str(instring))
return result
def __eq__(self, other):
- def excl_select_objs_(obj):
- return (obj[0] != 'parent_object_' and
- obj[0] != 'gds_collector_')
if type(self) != type(other):
return False
- return all(x == y for x, y in zip_longest(
- filter(excl_select_objs_, self.__dict__.items()),
- filter(excl_select_objs_, other.__dict__.items())))
+ return self.__dict__ == other.__dict__
def __ne__(self, other):
return not self.__eq__(other)
- # Django ETL transform hooks.
- def gds_djo_etl_transform(self):
- pass
- def gds_djo_etl_transform_db_obj(self, dbobj):
- pass
- # SQLAlchemy ETL transform hooks.
- def gds_sqa_etl_transform(self):
- return 0, None
- def gds_sqa_etl_transform_db_obj(self, dbobj):
- pass
- def gds_get_node_lineno_(self):
- if (hasattr(self, "gds_elementtree_node_") and
- self.gds_elementtree_node_ is not None):
- return ' near line {}'.format(
- self.gds_elementtree_node_.sourceline)
- else:
- return ""
-
def getSubclassFromModule_(module, class_):
'''Get the subclass of a class from a specific module.'''
@@ -669,10 +454,6 @@ def getSubclassFromModule_(module, class_):
#
ExternalEncoding = ''
-# Set this to false in order to deactivate during export, the use of
-# name space prefixes captured from the input document.
-UseCapturedNS_ = True
-CapturedNsmap_ = {}
Tag_pattern_ = re_.compile(r'({.*})?(.*)')
String_cleanup_pat_ = re_.compile(r"[\n\r\s]+")
Namespace_extract_pat_ = re_.compile(r'{(.*)}(.*)')
@@ -774,17 +555,12 @@ def find_attr_value_(attr_name, node):
return value
-def encode_str_2_3(instr):
- return instr
-
-
class GDSParseError(Exception):
pass
def raise_parse_error(node, msg):
- if node is not None:
- msg = '%s (element %s/line %d)' % (msg, node.tag, node.sourceline, )
+ msg = '%s (element %s/line %d)' % (msg, node.tag, node.sourceline, )
raise GDSParseError(msg)
@@ -947,14 +723,14 @@ def _cast(typ, value):
#
-class AlignSimpleType(Enum):
+class AlignSimpleType(object):
LEFT='left'
CENTRE='centre'
RIGHT='right'
JUSTIFY='justify'
-class ChartTypeSimpleType(Enum):
+class ChartTypeSimpleType(object):
BAR='bar'
LINE='line'
PIE='pie'
@@ -963,14 +739,14 @@ class ChartTypeSimpleType(Enum):
OTHER='other'
-class ColourDepthSimpleType(Enum):
+class ColourDepthSimpleType(object):
BILEVEL='bilevel'
GREYSCALE='greyscale'
COLOUR='colour'
OTHER='other'
-class ColourSimpleType(Enum):
+class ColourSimpleType(object):
BLACK='black'
BLUE='blue'
BROWN='brown'
@@ -989,7 +765,7 @@ class ColourSimpleType(Enum):
OTHER='other'
-class GraphicsTypeSimpleType(Enum):
+class GraphicsTypeSimpleType(object):
LOGO='logo'
LETTERHEAD='letterhead'
DECORATION='decoration'
@@ -1003,7 +779,7 @@ class GraphicsTypeSimpleType(Enum):
OTHER='other'
-class GroupTypeSimpleType(Enum):
+class GroupTypeSimpleType(object):
PARAGRAPH='paragraph'
LIST='list'
LISTITEM='list-item'
@@ -1013,7 +789,7 @@ class GroupTypeSimpleType(Enum):
OTHER='other'
-class PageTypeSimpleType(Enum):
+class PageTypeSimpleType(object):
FRONTCOVER='front-cover'
BACKCOVER='back-cover'
TITLE='title'
@@ -1024,8 +800,7 @@ class PageTypeSimpleType(Enum):
OTHER='other'
-class ProductionSimpleType(Enum):
- """Text production type"""
+class ProductionSimpleType(object):
PRINTED='printed'
TYPEWRITTEN='typewritten'
HANDWRITTENCURSIVE='handwritten-cursive'
@@ -1034,33 +809,33 @@ class ProductionSimpleType(Enum):
OTHER='other'
-class ReadingDirectionSimpleType(Enum):
+class ReadingDirectionSimpleType(object):
LEFTTORIGHT='left-to-right'
RIGHTTOLEFT='right-to-left'
TOPTOBOTTOM='top-to-bottom'
BOTTOMTOTOP='bottom-to-top'
-class TextDataTypeSimpleType(Enum):
- XSDDECIMAL='xsd:decimal' # Examples: "123.456", "+1234.456", "-1234.456", "-.456", "-456"
- XSDFLOAT='xsd:float' # Examples: "123.456", "+1234.456", "-1.2344e56", "-.45E-6", "INF", "-INF", "NaN"
- XSDINTEGER='xsd:integer' # Examples: "123456", "+00000012", "-1", "-456"
- XSDBOOLEAN='xsd:boolean' # Examples: "true", "false", "1", "0"
- XSDDATE='xsd:date' # Examples: "2001-10-26", "2001-10-26+02:00", "2001-10-26Z", "2001-10-26+00:00", "-2001-10-26", "-20000-04-01"
- XSDTIME='xsd:time' # Examples: "21:32:52", "21:32:52+02:00", "19:32:52Z", "19:32:52+00:00", "21:32:52.12679"
- XSDDATE_TIME='xsd:dateTime' # Examples: "2001-10-26T21:32:52", "2001-10-26T21:32:52+02:00", "2001-10-26T19:32:52Z", "2001-10-26T19:32:52+00:00", "-2001-10-26T21:32:52", "2001-10-26T21:32:52.12679"
- XSDSTRING='xsd:string' # Generic text string
- OTHER='other' # An XSD type that is not listed or a custom type (use dataTypeDetails attribute).
+class TextDataTypeSimpleType(object):
+ XSDDECIMAL='xsd:decimal'
+ XSDFLOAT='xsd:float'
+ XSDINTEGER='xsd:integer'
+ XSDBOOLEAN='xsd:boolean'
+ XSDDATE='xsd:date'
+ XSDTIME='xsd:time'
+ XSDDATE_TIME='xsd:dateTime'
+ XSDSTRING='xsd:string'
+ OTHER='other'
-class TextLineOrderSimpleType(Enum):
+class TextLineOrderSimpleType(object):
TOPTOBOTTOM='top-to-bottom'
BOTTOMTOTOP='bottom-to-top'
LEFTTORIGHT='left-to-right'
RIGHTTOLEFT='right-to-left'
-class TextTypeSimpleType(Enum):
+class TextTypeSimpleType(object):
PARAGRAPH='paragraph'
HEADING='heading'
CAPTION='caption'
@@ -1081,33 +856,21 @@ class TextTypeSimpleType(Enum):
OTHER='other'
-class underlineStyleType(Enum):
+class underlineStyleType(object):
SINGLE_LINE='singleLine'
DOUBLE_LINE='doubleLine'
OTHER='other'
class PcGtsType(GeneratedsSuper):
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('pcGtsId', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('Metadata', 'MetadataType', 0, 0, {'name': 'Metadata', 'type': 'MetadataType'}, None),
- MemberSpec_('Page', 'PageType', 0, 0, {'name': 'Page', 'type': 'PageType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, pcGtsId=None, Metadata=None, Page=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, pcGtsId=None, Metadata=None, Page=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.pcGtsId = _cast(None, pcGtsId)
- self.pcGtsId_nsprefix_ = None
self.Metadata = Metadata
- self.Metadata_nsprefix_ = None
self.Page = Page
- self.Page_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -1119,10 +882,6 @@ def factory(*args_, **kwargs_):
else:
return PcGtsType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Metadata(self):
return self.Metadata
def set_Metadata(self, Metadata):
@@ -1143,7 +902,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PcGtsType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PcGtsType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('PcGtsType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -1153,8 +912,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -1166,98 +923,70 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='PcGtsType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='PcGtsType'):
if self.pcGtsId is not None and 'pcGtsId' not in already_processed:
already_processed.add('pcGtsId')
outfile.write(' pcGtsId=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.pcGtsId), input_name='pcGtsId')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PcGtsType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PcGtsType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.Metadata is not None:
- namespaceprefix_ = self.Metadata_nsprefix_ + ':' if (UseCapturedNS_ and self.Metadata_nsprefix_) else ''
self.Metadata.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Metadata', pretty_print=pretty_print)
if self.Page is not None:
- namespaceprefix_ = self.Page_nsprefix_ + ':' if (UseCapturedNS_ and self.Page_nsprefix_) else ''
self.Page.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Page', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('pcGtsId', node)
if value is not None and 'pcGtsId' not in already_processed:
already_processed.add('pcGtsId')
self.pcGtsId = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Metadata':
obj_ = MetadataType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Metadata = obj_
obj_.original_tagname_ = 'Metadata'
elif nodeName_ == 'Page':
obj_ = PageType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Page = obj_
obj_.original_tagname_ = 'Page'
- def __hash__(self):
- return hash(self.id)
# end class PcGtsType
class MetadataType(GeneratedsSuper):
"""External reference of any kind"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('externalRef', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('Creator', 'string', 0, 0, {'name': 'Creator', 'type': 'string'}, None),
- MemberSpec_('Created', 'dateTime', 0, 0, {'name': 'Created', 'type': 'dateTime'}, None),
- MemberSpec_('LastChange', 'dateTime', 0, 0, {'name': 'LastChange', 'type': 'dateTime'}, None),
- MemberSpec_('Comments', 'string', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'Comments', 'type': 'string'}, None),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('MetadataItem', 'MetadataItemType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'MetadataItem', 'type': 'MetadataItemType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, externalRef=None, Creator=None, Created=None, LastChange=None, Comments=None, UserDefined=None, MetadataItem=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, externalRef=None, Creator=None, Created=None, LastChange=None, Comments=None, UserDefined=None, MetadataItem=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.externalRef = _cast(None, externalRef)
- self.externalRef_nsprefix_ = None
self.Creator = Creator
- self.Creator_nsprefix_ = None
if isinstance(Created, BaseStrType_):
initvalue_ = datetime_.datetime.strptime(Created, '%Y-%m-%dT%H:%M:%S')
else:
initvalue_ = Created
self.Created = initvalue_
- self.Created_nsprefix_ = None
if isinstance(LastChange, BaseStrType_):
initvalue_ = datetime_.datetime.strptime(LastChange, '%Y-%m-%dT%H:%M:%S')
else:
initvalue_ = LastChange
self.LastChange = initvalue_
- self.LastChange_nsprefix_ = None
self.Comments = Comments
- self.Comments_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if MetadataItem is None:
self.MetadataItem = []
else:
self.MetadataItem = MetadataItem
- self.MetadataItem_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -1269,10 +998,6 @@ def factory(*args_, **kwargs_):
else:
return MetadataType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Creator(self):
return self.Creator
def set_Creator(self, Creator):
@@ -1299,6 +1024,8 @@ def set_MetadataItem(self, MetadataItem):
self.MetadataItem = MetadataItem
def add_MetadataItem(self, value):
self.MetadataItem.append(value)
+ def add_MetadataItem(self, value):
+ self.MetadataItem.append(value)
def insert_MetadataItem_at(self, index, value):
self.MetadataItem.insert(index, value)
def replace_MetadataItem_at(self, index, value):
@@ -1319,7 +1046,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15" xmlns:None="http://www.w3.org/2001/XMLSchema" ', name_='MetadataType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='MetadataType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('MetadataType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -1329,8 +1056,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -1342,117 +1067,84 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='MetadataType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='MetadataType'):
if self.externalRef is not None and 'externalRef' not in already_processed:
already_processed.add('externalRef')
outfile.write(' externalRef=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.externalRef), input_name='externalRef')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15" xmlns:None="http://www.w3.org/2001/XMLSchema" ', name_='MetadataType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='MetadataType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.Creator is not None:
- namespaceprefix_ = self.Creator_nsprefix_ + ':' if (UseCapturedNS_ and self.Creator_nsprefix_) else ''
showIndent(outfile, level, pretty_print)
outfile.write('<%sCreator>%s%sCreator>%s' % (namespaceprefix_ , self.gds_encode(self.gds_format_string(quote_xml(self.Creator), input_name='Creator')), namespaceprefix_ , eol_))
if self.Created is not None:
- namespaceprefix_ = self.Created_nsprefix_ + ':' if (UseCapturedNS_ and self.Created_nsprefix_) else ''
showIndent(outfile, level, pretty_print)
outfile.write('<%sCreated>%s%sCreated>%s' % (namespaceprefix_ , self.gds_format_datetime(self.Created, input_name='Created'), namespaceprefix_ , eol_))
if self.LastChange is not None:
- namespaceprefix_ = self.LastChange_nsprefix_ + ':' if (UseCapturedNS_ and self.LastChange_nsprefix_) else ''
showIndent(outfile, level, pretty_print)
outfile.write('<%sLastChange>%s%sLastChange>%s' % (namespaceprefix_ , self.gds_format_datetime(self.LastChange, input_name='LastChange'), namespaceprefix_ , eol_))
if self.Comments is not None:
- namespaceprefix_ = self.Comments_nsprefix_ + ':' if (UseCapturedNS_ and self.Comments_nsprefix_) else ''
showIndent(outfile, level, pretty_print)
outfile.write('<%sComments>%s%sComments>%s' % (namespaceprefix_ , self.gds_encode(self.gds_format_string(quote_xml(self.Comments), input_name='Comments')), namespaceprefix_ , eol_))
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for MetadataItem_ in self.MetadataItem:
- namespaceprefix_ = self.MetadataItem_nsprefix_ + ':' if (UseCapturedNS_ and self.MetadataItem_nsprefix_) else ''
MetadataItem_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='MetadataItem', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('externalRef', node)
if value is not None and 'externalRef' not in already_processed:
already_processed.add('externalRef')
self.externalRef = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Creator':
- value_ = child_.text
- value_ = self.gds_parse_string(value_, node, 'Creator')
- value_ = self.gds_validate_string(value_, node, 'Creator')
- self.Creator = value_
- self.Creator_nsprefix_ = child_.prefix
+ Creator_ = child_.text
+ Creator_ = self.gds_validate_string(Creator_, node, 'Creator')
+ self.Creator = Creator_
elif nodeName_ == 'Created':
sval_ = child_.text
dval_ = self.gds_parse_datetime(sval_)
self.Created = dval_
- self.Created_nsprefix_ = child_.prefix
elif nodeName_ == 'LastChange':
sval_ = child_.text
dval_ = self.gds_parse_datetime(sval_)
self.LastChange = dval_
- self.LastChange_nsprefix_ = child_.prefix
elif nodeName_ == 'Comments':
- value_ = child_.text
- value_ = self.gds_parse_string(value_, node, 'Comments')
- value_ = self.gds_validate_string(value_, node, 'Comments')
- self.Comments = value_
- self.Comments_nsprefix_ = child_.prefix
+ Comments_ = child_.text
+ Comments_ = self.gds_validate_string(Comments_, node, 'Comments')
+ self.Comments = Comments_
elif nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'MetadataItem':
obj_ = MetadataItemType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.MetadataItem.append(obj_)
obj_.original_tagname_ = 'MetadataItem'
- def __hash__(self):
- return hash(self.id)
# end class MetadataType
class MetadataItemType(GeneratedsSuper):
- """Type of metadata (e.g. author)
- E.g. imagePhotometricInterpretation
+ """Type of metadata (e.g. author) E.g. imagePhotometricInterpretation
E.g. RGB"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('type_', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('name', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('value', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('date', 'dateTime', 0, 1, {'use': 'optional'}),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, type_=None, name=None, value=None, date=None, Labels=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, type_=None, name=None, value=None, date=None, Labels=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.name = _cast(None, name)
- self.name_nsprefix_ = None
self.value = _cast(None, value)
- self.value_nsprefix_ = None
if isinstance(date, BaseStrType_):
initvalue_ = datetime_.datetime.strptime(date, '%Y-%m-%dT%H:%M:%S')
else:
@@ -1462,7 +1154,6 @@ def __init__(self, type_=None, name=None, value=None, date=None, Labels=None, gd
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -1474,16 +1165,14 @@ def factory(*args_, **kwargs_):
else:
return MetadataItemType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Labels(self):
return self.Labels
def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -1511,7 +1200,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='MetadataItemType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='MetadataItemType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('MetadataItemType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -1521,8 +1210,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -1534,7 +1221,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='MetadataItemType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='MetadataItemType'):
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
@@ -1547,24 +1234,19 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.date is not None and 'date' not in already_processed:
already_processed.add('date')
outfile.write(' date="%s"' % self.gds_format_datetime(self.date, input_name='date'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='MetadataItemType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='MetadataItemType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('type', node)
@@ -1586,51 +1268,32 @@ def buildAttributes(self, node, attrs, already_processed):
self.date = self.gds_parse_datetime(value)
except ValueError as exp:
raise ValueError('Bad date-time attribute (date): %s' % exp)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
- def __hash__(self):
- return hash(self.id)
# end class MetadataItemType
class LabelsType(GeneratedsSuper):
- """Reference to external model / ontology / schema
- E.g. an RDF resource identifier
- (to be used as subject or object of an RDF triple)
+ """Reference to external model / ontology / schema E.g. an RDF resource
+ identifier (to be used as subject or object of an RDF triple)
Prefix for all labels (e.g. first part of an URI)"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('externalModel', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('externalId', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('prefix', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('Label', 'LabelType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Label', 'type': 'LabelType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, externalModel=None, externalId=None, prefix=None, comments=None, Label=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, externalModel=None, externalId=None, prefix=None, comments=None, Label=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.externalModel = _cast(None, externalModel)
- self.externalModel_nsprefix_ = None
self.externalId = _cast(None, externalId)
- self.externalId_nsprefix_ = None
self.prefix = _cast(None, prefix)
- self.prefix_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
if Label is None:
self.Label = []
else:
self.Label = Label
- self.Label_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -1642,16 +1305,14 @@ def factory(*args_, **kwargs_):
else:
return LabelsType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Label(self):
return self.Label
def set_Label(self, Label):
self.Label = Label
def add_Label(self, value):
self.Label.append(value)
+ def add_Label(self, value):
+ self.Label.append(value)
def insert_Label_at(self, index, value):
self.Label.insert(index, value)
def replace_Label_at(self, index, value):
@@ -1679,7 +1340,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LabelsType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LabelsType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('LabelsType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -1689,8 +1350,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -1702,7 +1361,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='LabelsType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='LabelsType'):
if self.externalModel is not None and 'externalModel' not in already_processed:
already_processed.add('externalModel')
outfile.write(' externalModel=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.externalModel), input_name='externalModel')), ))
@@ -1715,24 +1374,19 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LabelsType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LabelsType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for Label_ in self.Label:
- namespaceprefix_ = self.Label_nsprefix_ + ':' if (UseCapturedNS_ and self.Label_nsprefix_) else ''
Label_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Label', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('externalModel', node)
@@ -1751,45 +1405,28 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Label':
obj_ = LabelType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Label.append(obj_)
obj_.original_tagname_ = 'Label'
- def __hash__(self):
- return hash(self.id)
# end class LabelsType
class LabelType(GeneratedsSuper):
- """Semantic label
- The label / tag (e.g. 'person').
- Can be an RDF resource identifier
- (e.g. object of an RDF triple).
- Additional information on the label
- (e.g. 'YYYY-mm-dd' for a date label).
+ """Semantic label The label / tag (e.g. 'person'). Can be an RDF
+ resource identifier (e.g. object of an RDF triple). Additional
+ information on the label (e.g. 'YYYY-mm-dd' for a date label).
Can be used as predicate of an RDF triple."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('value', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('type_', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- ]
subclass = None
superclass = None
- def __init__(self, value=None, type_=None, comments=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, value=None, type_=None, comments=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.value = _cast(None, value)
- self.value_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -1801,10 +1438,6 @@ def factory(*args_, **kwargs_):
else:
return LabelType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_value(self):
return self.value
def set_value(self, value):
@@ -1824,7 +1457,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LabelType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LabelType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('LabelType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -1834,8 +1467,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -1846,7 +1477,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='LabelType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='LabelType'):
if self.value is not None and 'value' not in already_processed:
already_processed.add('value')
outfile.write(' value=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.value), input_name='value')), ))
@@ -1856,18 +1487,14 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LabelType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LabelType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('value', node)
@@ -1882,229 +1509,133 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class LabelType
class PageType(GeneratedsSuper):
- """Contains the image file name including the file extension.
- Specifies the width of the image.Specifies the height of the
- image.Specifies the image resolution in width.Specifies the image
- resolution in height.
- Specifies the unit of the resolution information
- referring to a standardised unit of measurement
- (pixels per inch, pixels per centimeter or other).
- For generic use
- The angle the rectangle encapsulating the page
- (or its Border) has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- (The rotated image can be further referenced
- via “AlternativeImage”.)
- Range: -179.999,180
- The type of the page within the document
- (e.g. cover page).
- The primary language used in the page
- (lower-level definitions override the page-level definition).
- The secondary language used in the page
- (lower-level definitions override the page-level definition).
- The primary script used in the page
- (lower-level definitions override the page-level definition).
- The secondary script used in the page
- (lower-level definitions override the page-level definition).
- The direction in which text within lines
- should be read (order of words and characters),
- in addition to “textLineOrder”
- (lower-level definitions override the page-level definition).
- The order of text lines within a block,
- in addition to “readingDirection”
+ """Contains the image file name including the file extension. Specifies
+ the width of the image.Specifies the height of the
+ image.Specifies the image resolution in width.Specifies the
+ image resolution in height. Specifies the unit of the resolution
+ information referring to a standardised unit of measurement
+ (pixels per inch, pixels per centimeter or other). For generic
+ use The angle the rectangle encapsulating the page (or its
+ Border) has to be rotated in clockwise direction in order to
+ correct the present skew (negative values indicate anti-
+ clockwise rotation). (The rotated image can be further
+ referenced via “AlternativeImage”.) Range: -179.999,180 The type
+ of the page within the document (e.g. cover page). The primary
+ language used in the page (lower-level definitions override the
+ page-level definition). The secondary language used in the page
(lower-level definitions override the page-level definition).
- Confidence value for whole page (between 0 and 1)"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('imageFilename', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('imageWidth', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('imageHeight', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('imageXResolution', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('imageYResolution', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('imageResolutionUnit', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'pc:PageTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('primaryLanguage', 'pc:LanguageSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('secondaryLanguage', 'pc:LanguageSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('primaryScript', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('secondaryScript', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('readingDirection', 'pc:ReadingDirectionSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('textLineOrder', 'pc:TextLineOrderSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('conf', 'pc:ConfSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('AlternativeImage', 'AlternativeImageType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'AlternativeImage', 'type': 'AlternativeImageType'}, None),
- MemberSpec_('Border', 'BorderType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'Border', 'type': 'BorderType'}, None),
- MemberSpec_('PrintSpace', 'PrintSpaceType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'PrintSpace', 'type': 'PrintSpaceType'}, None),
- MemberSpec_('ReadingOrder', 'ReadingOrderType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'ReadingOrder', 'type': 'ReadingOrderType'}, None),
- MemberSpec_('Layers', 'LayersType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'Layers', 'type': 'LayersType'}, None),
- MemberSpec_('Relations', 'RelationsType', 0, 1, {'minOccurs': '0', 'name': 'Relations', 'type': 'RelationsType'}, None),
- MemberSpec_('TextStyle', 'TextStyleType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'TextStyle', 'type': 'TextStyleType'}, None),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- MemberSpec_('TextRegion', 'TextRegionType', 1, 1, {'name': 'TextRegion', 'type': 'TextRegionType'}, 1),
- MemberSpec_('ImageRegion', 'ImageRegionType', 1, 1, {'name': 'ImageRegion', 'type': 'ImageRegionType'}, 1),
- MemberSpec_('LineDrawingRegion', 'LineDrawingRegionType', 1, 1, {'name': 'LineDrawingRegion', 'type': 'LineDrawingRegionType'}, 1),
- MemberSpec_('GraphicRegion', 'GraphicRegionType', 1, 1, {'name': 'GraphicRegion', 'type': 'GraphicRegionType'}, 1),
- MemberSpec_('TableRegion', 'TableRegionType', 1, 1, {'name': 'TableRegion', 'type': 'TableRegionType'}, 1),
- MemberSpec_('ChartRegion', 'ChartRegionType', 1, 1, {'name': 'ChartRegion', 'type': 'ChartRegionType'}, 1),
- MemberSpec_('MapRegion', 'MapRegionType', 1, 1, {'name': 'MapRegion', 'type': 'MapRegionType'}, 1),
- MemberSpec_('SeparatorRegion', 'SeparatorRegionType', 1, 1, {'name': 'SeparatorRegion', 'type': 'SeparatorRegionType'}, 1),
- MemberSpec_('MathsRegion', 'MathsRegionType', 1, 1, {'name': 'MathsRegion', 'type': 'MathsRegionType'}, 1),
- MemberSpec_('ChemRegion', 'ChemRegionType', 1, 1, {'name': 'ChemRegion', 'type': 'ChemRegionType'}, 1),
- MemberSpec_('MusicRegion', 'MusicRegionType', 1, 1, {'name': 'MusicRegion', 'type': 'MusicRegionType'}, 1),
- MemberSpec_('AdvertRegion', 'AdvertRegionType', 1, 1, {'name': 'AdvertRegion', 'type': 'AdvertRegionType'}, 1),
- MemberSpec_('NoiseRegion', 'NoiseRegionType', 1, 1, {'name': 'NoiseRegion', 'type': 'NoiseRegionType'}, 1),
- MemberSpec_('UnknownRegion', 'UnknownRegionType', 1, 1, {'name': 'UnknownRegion', 'type': 'UnknownRegionType'}, 1),
- MemberSpec_('CustomRegion', 'CustomRegionType', 1, 1, {'name': 'CustomRegion', 'type': 'CustomRegionType'}, 1),
- ]
+ The primary script used in the page (lower-level definitions
+ override the page-level definition). The secondary script used
+ in the page (lower-level definitions override the page-level
+ definition). The direction in which text within lines should be
+ read (order of words and characters), in addition to
+ “textLineOrder” (lower-level definitions override the page-level
+ definition). The order of text lines within a block, in addition
+ to “readingDirection” (lower-level definitions override the
+ page-level definition). Confidence value for whole page (between
+ 0 and 1)"""
subclass = None
superclass = None
- def __init__(self, imageFilename=None, imageWidth=None, imageHeight=None, imageXResolution=None, imageYResolution=None, imageResolutionUnit=None, custom=None, orientation=None, type_=None, primaryLanguage=None, secondaryLanguage=None, primaryScript=None, secondaryScript=None, readingDirection=None, textLineOrder=None, conf=None, AlternativeImage=None, Border=None, PrintSpace=None, ReadingOrder=None, Layers=None, Relations=None, TextStyle=None, UserDefined=None, Labels=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, MapRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, imageFilename=None, imageWidth=None, imageHeight=None, imageXResolution=None, imageYResolution=None, imageResolutionUnit=None, custom=None, orientation=None, type_=None, primaryLanguage=None, secondaryLanguage=None, primaryScript=None, secondaryScript=None, readingDirection=None, textLineOrder=None, conf=None, AlternativeImage=None, Border=None, PrintSpace=None, ReadingOrder=None, Layers=None, Relations=None, TextStyle=None, UserDefined=None, Labels=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, MapRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.imageFilename = _cast(None, imageFilename)
- self.imageFilename_nsprefix_ = None
self.imageWidth = _cast(int, imageWidth)
- self.imageWidth_nsprefix_ = None
self.imageHeight = _cast(int, imageHeight)
- self.imageHeight_nsprefix_ = None
self.imageXResolution = _cast(float, imageXResolution)
- self.imageXResolution_nsprefix_ = None
self.imageYResolution = _cast(float, imageYResolution)
- self.imageYResolution_nsprefix_ = None
self.imageResolutionUnit = _cast(None, imageResolutionUnit)
- self.imageResolutionUnit_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.primaryLanguage = _cast(None, primaryLanguage)
- self.primaryLanguage_nsprefix_ = None
self.secondaryLanguage = _cast(None, secondaryLanguage)
- self.secondaryLanguage_nsprefix_ = None
self.primaryScript = _cast(None, primaryScript)
- self.primaryScript_nsprefix_ = None
self.secondaryScript = _cast(None, secondaryScript)
- self.secondaryScript_nsprefix_ = None
self.readingDirection = _cast(None, readingDirection)
- self.readingDirection_nsprefix_ = None
self.textLineOrder = _cast(None, textLineOrder)
- self.textLineOrder_nsprefix_ = None
self.conf = _cast(float, conf)
- self.conf_nsprefix_ = None
if AlternativeImage is None:
self.AlternativeImage = []
else:
self.AlternativeImage = AlternativeImage
- self.AlternativeImage_nsprefix_ = None
self.Border = Border
- self.Border_nsprefix_ = None
self.PrintSpace = PrintSpace
- self.PrintSpace_nsprefix_ = None
self.ReadingOrder = ReadingOrder
- self.ReadingOrder_nsprefix_ = None
self.Layers = Layers
- self.Layers_nsprefix_ = None
self.Relations = Relations
- self.Relations_nsprefix_ = None
self.TextStyle = TextStyle
- self.TextStyle_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
if TextRegion is None:
self.TextRegion = []
else:
self.TextRegion = TextRegion
- self.TextRegion_nsprefix_ = None
if ImageRegion is None:
self.ImageRegion = []
else:
self.ImageRegion = ImageRegion
- self.ImageRegion_nsprefix_ = None
if LineDrawingRegion is None:
self.LineDrawingRegion = []
else:
self.LineDrawingRegion = LineDrawingRegion
- self.LineDrawingRegion_nsprefix_ = None
if GraphicRegion is None:
self.GraphicRegion = []
else:
self.GraphicRegion = GraphicRegion
- self.GraphicRegion_nsprefix_ = None
if TableRegion is None:
self.TableRegion = []
else:
self.TableRegion = TableRegion
- self.TableRegion_nsprefix_ = None
if ChartRegion is None:
self.ChartRegion = []
else:
self.ChartRegion = ChartRegion
- self.ChartRegion_nsprefix_ = None
if MapRegion is None:
self.MapRegion = []
else:
self.MapRegion = MapRegion
- self.MapRegion_nsprefix_ = None
if SeparatorRegion is None:
self.SeparatorRegion = []
else:
self.SeparatorRegion = SeparatorRegion
- self.SeparatorRegion_nsprefix_ = None
if MathsRegion is None:
self.MathsRegion = []
else:
self.MathsRegion = MathsRegion
- self.MathsRegion_nsprefix_ = None
if ChemRegion is None:
self.ChemRegion = []
else:
self.ChemRegion = ChemRegion
- self.ChemRegion_nsprefix_ = None
if MusicRegion is None:
self.MusicRegion = []
else:
self.MusicRegion = MusicRegion
- self.MusicRegion_nsprefix_ = None
if AdvertRegion is None:
self.AdvertRegion = []
else:
self.AdvertRegion = AdvertRegion
- self.AdvertRegion_nsprefix_ = None
if NoiseRegion is None:
self.NoiseRegion = []
else:
self.NoiseRegion = NoiseRegion
- self.NoiseRegion_nsprefix_ = None
if UnknownRegion is None:
self.UnknownRegion = []
else:
self.UnknownRegion = UnknownRegion
- self.UnknownRegion_nsprefix_ = None
if CustomRegion is None:
self.CustomRegion = []
else:
self.CustomRegion = CustomRegion
- self.CustomRegion_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -2116,16 +1647,14 @@ def factory(*args_, **kwargs_):
else:
return PageType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_AlternativeImage(self):
return self.AlternativeImage
def set_AlternativeImage(self, AlternativeImage):
self.AlternativeImage = AlternativeImage
def add_AlternativeImage(self, value):
self.AlternativeImage.append(value)
+ def add_AlternativeImage(self, value):
+ self.AlternativeImage.append(value)
def insert_AlternativeImage_at(self, index, value):
self.AlternativeImage.insert(index, value)
def replace_AlternativeImage_at(self, index, value):
@@ -2164,6 +1693,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -2174,6 +1705,8 @@ def set_TextRegion(self, TextRegion):
self.TextRegion = TextRegion
def add_TextRegion(self, value):
self.TextRegion.append(value)
+ def add_TextRegion(self, value):
+ self.TextRegion.append(value)
def insert_TextRegion_at(self, index, value):
self.TextRegion.insert(index, value)
def replace_TextRegion_at(self, index, value):
@@ -2184,6 +1717,8 @@ def set_ImageRegion(self, ImageRegion):
self.ImageRegion = ImageRegion
def add_ImageRegion(self, value):
self.ImageRegion.append(value)
+ def add_ImageRegion(self, value):
+ self.ImageRegion.append(value)
def insert_ImageRegion_at(self, index, value):
self.ImageRegion.insert(index, value)
def replace_ImageRegion_at(self, index, value):
@@ -2194,6 +1729,8 @@ def set_LineDrawingRegion(self, LineDrawingRegion):
self.LineDrawingRegion = LineDrawingRegion
def add_LineDrawingRegion(self, value):
self.LineDrawingRegion.append(value)
+ def add_LineDrawingRegion(self, value):
+ self.LineDrawingRegion.append(value)
def insert_LineDrawingRegion_at(self, index, value):
self.LineDrawingRegion.insert(index, value)
def replace_LineDrawingRegion_at(self, index, value):
@@ -2204,6 +1741,8 @@ def set_GraphicRegion(self, GraphicRegion):
self.GraphicRegion = GraphicRegion
def add_GraphicRegion(self, value):
self.GraphicRegion.append(value)
+ def add_GraphicRegion(self, value):
+ self.GraphicRegion.append(value)
def insert_GraphicRegion_at(self, index, value):
self.GraphicRegion.insert(index, value)
def replace_GraphicRegion_at(self, index, value):
@@ -2214,6 +1753,8 @@ def set_TableRegion(self, TableRegion):
self.TableRegion = TableRegion
def add_TableRegion(self, value):
self.TableRegion.append(value)
+ def add_TableRegion(self, value):
+ self.TableRegion.append(value)
def insert_TableRegion_at(self, index, value):
self.TableRegion.insert(index, value)
def replace_TableRegion_at(self, index, value):
@@ -2224,6 +1765,8 @@ def set_ChartRegion(self, ChartRegion):
self.ChartRegion = ChartRegion
def add_ChartRegion(self, value):
self.ChartRegion.append(value)
+ def add_ChartRegion(self, value):
+ self.ChartRegion.append(value)
def insert_ChartRegion_at(self, index, value):
self.ChartRegion.insert(index, value)
def replace_ChartRegion_at(self, index, value):
@@ -2234,6 +1777,8 @@ def set_MapRegion(self, MapRegion):
self.MapRegion = MapRegion
def add_MapRegion(self, value):
self.MapRegion.append(value)
+ def add_MapRegion(self, value):
+ self.MapRegion.append(value)
def insert_MapRegion_at(self, index, value):
self.MapRegion.insert(index, value)
def replace_MapRegion_at(self, index, value):
@@ -2244,6 +1789,8 @@ def set_SeparatorRegion(self, SeparatorRegion):
self.SeparatorRegion = SeparatorRegion
def add_SeparatorRegion(self, value):
self.SeparatorRegion.append(value)
+ def add_SeparatorRegion(self, value):
+ self.SeparatorRegion.append(value)
def insert_SeparatorRegion_at(self, index, value):
self.SeparatorRegion.insert(index, value)
def replace_SeparatorRegion_at(self, index, value):
@@ -2254,6 +1801,8 @@ def set_MathsRegion(self, MathsRegion):
self.MathsRegion = MathsRegion
def add_MathsRegion(self, value):
self.MathsRegion.append(value)
+ def add_MathsRegion(self, value):
+ self.MathsRegion.append(value)
def insert_MathsRegion_at(self, index, value):
self.MathsRegion.insert(index, value)
def replace_MathsRegion_at(self, index, value):
@@ -2264,6 +1813,8 @@ def set_ChemRegion(self, ChemRegion):
self.ChemRegion = ChemRegion
def add_ChemRegion(self, value):
self.ChemRegion.append(value)
+ def add_ChemRegion(self, value):
+ self.ChemRegion.append(value)
def insert_ChemRegion_at(self, index, value):
self.ChemRegion.insert(index, value)
def replace_ChemRegion_at(self, index, value):
@@ -2274,6 +1825,8 @@ def set_MusicRegion(self, MusicRegion):
self.MusicRegion = MusicRegion
def add_MusicRegion(self, value):
self.MusicRegion.append(value)
+ def add_MusicRegion(self, value):
+ self.MusicRegion.append(value)
def insert_MusicRegion_at(self, index, value):
self.MusicRegion.insert(index, value)
def replace_MusicRegion_at(self, index, value):
@@ -2284,6 +1837,8 @@ def set_AdvertRegion(self, AdvertRegion):
self.AdvertRegion = AdvertRegion
def add_AdvertRegion(self, value):
self.AdvertRegion.append(value)
+ def add_AdvertRegion(self, value):
+ self.AdvertRegion.append(value)
def insert_AdvertRegion_at(self, index, value):
self.AdvertRegion.insert(index, value)
def replace_AdvertRegion_at(self, index, value):
@@ -2294,6 +1849,8 @@ def set_NoiseRegion(self, NoiseRegion):
self.NoiseRegion = NoiseRegion
def add_NoiseRegion(self, value):
self.NoiseRegion.append(value)
+ def add_NoiseRegion(self, value):
+ self.NoiseRegion.append(value)
def insert_NoiseRegion_at(self, index, value):
self.NoiseRegion.insert(index, value)
def replace_NoiseRegion_at(self, index, value):
@@ -2304,6 +1861,8 @@ def set_UnknownRegion(self, UnknownRegion):
self.UnknownRegion = UnknownRegion
def add_UnknownRegion(self, value):
self.UnknownRegion.append(value)
+ def add_UnknownRegion(self, value):
+ self.UnknownRegion.append(value)
def insert_UnknownRegion_at(self, index, value):
self.UnknownRegion.insert(index, value)
def replace_UnknownRegion_at(self, index, value):
@@ -2314,6 +1873,8 @@ def set_CustomRegion(self, CustomRegion):
self.CustomRegion = CustomRegion
def add_CustomRegion(self, value):
self.CustomRegion.append(value)
+ def add_CustomRegion(self, value):
+ self.CustomRegion.append(value)
def insert_CustomRegion_at(self, index, value):
self.CustomRegion.insert(index, value)
def replace_CustomRegion_at(self, index, value):
@@ -2382,86 +1943,6 @@ def get_conf(self):
return self.conf
def set_conf(self, conf):
self.conf = conf
- def validate_PageTypeSimpleType(self, value):
- # Validate type pc:PageTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['front-cover', 'back-cover', 'title', 'table-of-contents', 'index', 'content', 'blank', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on PageTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_LanguageSimpleType(self, value):
- # Validate type pc:LanguageSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Abkhaz', 'Afar', 'Afrikaans', 'Akan', 'Albanian', 'Amharic', 'Arabic', 'Aragonese', 'Armenian', 'Assamese', 'Avaric', 'Avestan', 'Aymara', 'Azerbaijani', 'Bambara', 'Bashkir', 'Basque', 'Belarusian', 'Bengali', 'Bihari', 'Bislama', 'Bosnian', 'Breton', 'Bulgarian', 'Burmese', 'Cambodian', 'Cantonese', 'Catalan', 'Chamorro', 'Chechen', 'Chichewa', 'Chinese', 'Chuvash', 'Cornish', 'Corsican', 'Cree', 'Croatian', 'Czech', 'Danish', 'Divehi', 'Dutch', 'Dzongkha', 'English', 'Esperanto', 'Estonian', 'Ewe', 'Faroese', 'Fijian', 'Finnish', 'French', 'Fula', 'Gaelic', 'Galician', 'Ganda', 'Georgian', 'German', 'Greek', 'Guaraní', 'Gujarati', 'Haitian', 'Hausa', 'Hebrew', 'Herero', 'Hindi', 'Hiri Motu', 'Hungarian', 'Icelandic', 'Ido', 'Igbo', 'Indonesian', 'Interlingua', 'Interlingue', 'Inuktitut', 'Inupiaq', 'Irish', 'Italian', 'Japanese', 'Javanese', 'Kalaallisut', 'Kannada', 'Kanuri', 'Kashmiri', 'Kazakh', 'Khmer', 'Kikuyu', 'Kinyarwanda', 'Kirundi', 'Komi', 'Kongo', 'Korean', 'Kurdish', 'Kwanyama', 'Kyrgyz', 'Lao', 'Latin', 'Latvian', 'Limburgish', 'Lingala', 'Lithuanian', 'Luba-Katanga', 'Luxembourgish', 'Macedonian', 'Malagasy', 'Malay', 'Malayalam', 'Maltese', 'Manx', 'Māori', 'Marathi', 'Marshallese', 'Mongolian', 'Nauru', 'Navajo', 'Ndonga', 'Nepali', 'North Ndebele', 'Northern Sami', 'Norwegian', 'Norwegian Bokmål', 'Norwegian Nynorsk', 'Nuosu', 'Occitan', 'Ojibwe', 'Old Church Slavonic', 'Oriya', 'Oromo', 'Ossetian', 'Pāli', 'Panjabi', 'Pashto', 'Persian', 'Polish', 'Portuguese', 'Punjabi', 'Quechua', 'Romanian', 'Romansh', 'Russian', 'Samoan', 'Sango', 'Sanskrit', 'Sardinian', 'Serbian', 'Shona', 'Sindhi', 'Sinhala', 'Slovak', 'Slovene', 'Somali', 'South Ndebele', 'Southern Sotho', 'Spanish', 'Sundanese', 'Swahili', 'Swati', 'Swedish', 'Tagalog', 'Tahitian', 'Tajik', 'Tamil', 'Tatar', 'Telugu', 'Thai', 'Tibetan', 'Tigrinya', 'Tonga', 'Tsonga', 'Tswana', 'Turkish', 'Turkmen', 'Twi', 'Uighur', 'Ukrainian', 'Urdu', 'Uzbek', 'Venda', 'Vietnamese', 'Volapük', 'Walloon', 'Welsh', 'Western Frisian', 'Wolof', 'Xhosa', 'Yiddish', 'Yoruba', 'Zhuang', 'Zulu', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on LanguageSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ScriptSimpleType(self, value):
- # Validate type pc:ScriptSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Adlm - Adlam', 'Afak - Afaka', 'Aghb - Caucasian Albanian', 'Ahom - Ahom, Tai Ahom', 'Arab - Arabic', 'Aran - Arabic (Nastaliq variant)', 'Armi - Imperial Aramaic', 'Armn - Armenian', 'Avst - Avestan', 'Bali - Balinese', 'Bamu - Bamum', 'Bass - Bassa Vah', 'Batk - Batak', 'Beng - Bengali', 'Bhks - Bhaiksuki', 'Blis - Blissymbols', 'Bopo - Bopomofo', 'Brah - Brahmi', 'Brai - Braille', 'Bugi - Buginese', 'Buhd - Buhid', 'Cakm - Chakma', 'Cans - Unified Canadian Aboriginal Syllabics', 'Cari - Carian', 'Cham - Cham', 'Cher - Cherokee', 'Cirt - Cirth', 'Copt - Coptic', 'Cprt - Cypriot', 'Cyrl - Cyrillic', 'Cyrs - Cyrillic (Old Church Slavonic variant)', 'Deva - Devanagari (Nagari)', 'Dsrt - Deseret (Mormon)', 'Dupl - Duployan shorthand, Duployan stenography', 'Egyd - Egyptian demotic', 'Egyh - Egyptian hieratic', 'Egyp - Egyptian hieroglyphs', 'Elba - Elbasan', 'Ethi - Ethiopic', 'Geok - Khutsuri (Asomtavruli and Nuskhuri)', 'Geor - Georgian (Mkhedruli)', 'Glag - Glagolitic', 'Goth - Gothic', 'Gran - Grantha', 'Grek - Greek', 'Gujr - Gujarati', 'Guru - Gurmukhi', 'Hanb - Han with Bopomofo', 'Hang - Hangul', 'Hani - Han (Hanzi, Kanji, Hanja)', 'Hano - Hanunoo (Hanunóo)', 'Hans - Han (Simplified variant)', 'Hant - Han (Traditional variant)', 'Hatr - Hatran', 'Hebr - Hebrew', 'Hira - Hiragana', 'Hluw - Anatolian Hieroglyphs', 'Hmng - Pahawh Hmong', 'Hrkt - Japanese syllabaries', 'Hung - Old Hungarian (Hungarian Runic)', 'Inds - Indus (Harappan)', 'Ital - Old Italic (Etruscan, Oscan etc.)', 'Jamo - Jamo', 'Java - Javanese', 'Jpan - Japanese', 'Jurc - Jurchen', 'Kali - Kayah Li', 'Kana - Katakana', 'Khar - Kharoshthi', 'Khmr - Khmer', 'Khoj - Khojki', 'Kitl - Khitan large script', 'Kits - Khitan small script', 'Knda - Kannada', 'Kore - Korean (alias for Hangul + Han)', 'Kpel - Kpelle', 'Kthi - Kaithi', 'Lana - Tai Tham (Lanna)', 'Laoo - Lao', 'Latf - Latin (Fraktur variant)', 'Latg - Latin (Gaelic variant)', 'Latn - Latin', 'Leke - Leke', 'Lepc - Lepcha (Róng)', 'Limb - Limbu', 'Lina - Linear A', 'Linb - Linear B', 'Lisu - Lisu (Fraser)', 'Loma - Loma', 'Lyci - Lycian', 'Lydi - Lydian', 'Mahj - Mahajani', 'Mand - Mandaic, Mandaean', 'Mani - Manichaean', 'Marc - Marchen', 'Maya - Mayan hieroglyphs', 'Mend - Mende Kikakui', 'Merc - Meroitic Cursive', 'Mero - Meroitic Hieroglyphs', 'Mlym - Malayalam', 'Modi - Modi, Moḍī', 'Mong - Mongolian', 'Moon - Moon (Moon code, Moon script, Moon type)', 'Mroo - Mro, Mru', 'Mtei - Meitei Mayek (Meithei, Meetei)', 'Mult - Multani', 'Mymr - Myanmar (Burmese)', 'Narb - Old North Arabian (Ancient North Arabian)', 'Nbat - Nabataean', 'Newa - Newa, Newar, Newari', 'Nkgb - Nakhi Geba', 'Nkoo - N’Ko', 'Nshu - Nüshu', 'Ogam - Ogham', 'Olck - Ol Chiki (Ol Cemet’, Ol, Santali)', 'Orkh - Old Turkic, Orkhon Runic', 'Orya - Oriya', 'Osge - Osage', 'Osma - Osmanya', 'Palm - Palmyrene', 'Pauc - Pau Cin Hau', 'Perm - Old Permic', 'Phag - Phags-pa', 'Phli - Inscriptional Pahlavi', 'Phlp - Psalter Pahlavi', 'Phlv - Book Pahlavi', 'Phnx - Phoenician', 'Piqd - Klingon (KLI pIqaD)', 'Plrd - Miao (Pollard)', 'Prti - Inscriptional Parthian', 'Rjng - Rejang (Redjang, Kaganga)', 'Roro - Rongorongo', 'Runr - Runic', 'Samr - Samaritan', 'Sara - Sarati', 'Sarb - Old South Arabian', 'Saur - Saurashtra', 'Sgnw - SignWriting', 'Shaw - Shavian (Shaw)', 'Shrd - Sharada, Śāradā', 'Sidd - Siddham', 'Sind - Khudawadi, Sindhi', 'Sinh - Sinhala', 'Sora - Sora Sompeng', 'Sund - Sundanese', 'Sylo - Syloti Nagri', 'Syrc - Syriac', 'Syre - Syriac (Estrangelo variant)', 'Syrj - Syriac (Western variant)', 'Syrn - Syriac (Eastern variant)', 'Tagb - Tagbanwa', 'Takr - Takri', 'Tale - Tai Le', 'Talu - New Tai Lue', 'Taml - Tamil', 'Tang - Tangut', 'Tavt - Tai Viet', 'Telu - Telugu', 'Teng - Tengwar', 'Tfng - Tifinagh (Berber)', 'Tglg - Tagalog (Baybayin, Alibata)', 'Thaa - Thaana', 'Thai - Thai', 'Tibt - Tibetan', 'Tirh - Tirhuta', 'Ugar - Ugaritic', 'Vaii - Vai', 'Visp - Visible Speech', 'Wara - Warang Citi (Varang Kshiti)', 'Wole - Woleai', 'Xpeo - Old Persian', 'Xsux - Cuneiform, Sumero-Akkadian', 'Yiii - Yi', 'Zinh - Code for inherited script', 'Zmth - Mathematical notation', 'Zsye - Symbols (Emoji variant)', 'Zsym - Symbols', 'Zxxx - Code for unwritten documents', 'Zyyy - Code for undetermined script', 'Zzzz - Code for uncoded script', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ScriptSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ReadingDirectionSimpleType(self, value):
- # Validate type pc:ReadingDirectionSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['left-to-right', 'right-to-left', 'top-to-bottom', 'bottom-to-top']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ReadingDirectionSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_TextLineOrderSimpleType(self, value):
- # Validate type pc:TextLineOrderSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['top-to-bottom', 'bottom-to-top', 'left-to-right', 'right-to-left']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on TextLineOrderSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ConfSimpleType(self, value):
- # Validate type pc:ConfSimpleType, a restriction on float.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, float):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (float)' % {"value": value, "lineno": lineno, })
- return False
- if value < 0:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd minInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
- if value > 1:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd maxInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.AlternativeImage or
@@ -2492,7 +1973,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PageType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PageType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('PageType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -2502,8 +1983,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -2515,7 +1994,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='PageType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='PageType'):
if self.imageFilename is not None and 'imageFilename' not in already_processed:
already_processed.add('imageFilename')
outfile.write(' imageFilename=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.imageFilename), input_name='imageFilename')), ))
@@ -2542,115 +2021,87 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
- outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
+ outfile.write(' type=%s' % (quote_attrib(self.type_), ))
if self.primaryLanguage is not None and 'primaryLanguage' not in already_processed:
already_processed.add('primaryLanguage')
- outfile.write(' primaryLanguage=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.primaryLanguage), input_name='primaryLanguage')), ))
+ outfile.write(' primaryLanguage=%s' % (quote_attrib(self.primaryLanguage), ))
if self.secondaryLanguage is not None and 'secondaryLanguage' not in already_processed:
already_processed.add('secondaryLanguage')
- outfile.write(' secondaryLanguage=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.secondaryLanguage), input_name='secondaryLanguage')), ))
+ outfile.write(' secondaryLanguage=%s' % (quote_attrib(self.secondaryLanguage), ))
if self.primaryScript is not None and 'primaryScript' not in already_processed:
already_processed.add('primaryScript')
- outfile.write(' primaryScript=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.primaryScript), input_name='primaryScript')), ))
+ outfile.write(' primaryScript=%s' % (quote_attrib(self.primaryScript), ))
if self.secondaryScript is not None and 'secondaryScript' not in already_processed:
already_processed.add('secondaryScript')
- outfile.write(' secondaryScript=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.secondaryScript), input_name='secondaryScript')), ))
+ outfile.write(' secondaryScript=%s' % (quote_attrib(self.secondaryScript), ))
if self.readingDirection is not None and 'readingDirection' not in already_processed:
already_processed.add('readingDirection')
- outfile.write(' readingDirection=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.readingDirection), input_name='readingDirection')), ))
+ outfile.write(' readingDirection=%s' % (quote_attrib(self.readingDirection), ))
if self.textLineOrder is not None and 'textLineOrder' not in already_processed:
already_processed.add('textLineOrder')
- outfile.write(' textLineOrder=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.textLineOrder), input_name='textLineOrder')), ))
+ outfile.write(' textLineOrder=%s' % (quote_attrib(self.textLineOrder), ))
if self.conf is not None and 'conf' not in already_processed:
already_processed.add('conf')
- outfile.write(' conf="%s"' % self.gds_format_float(self.conf, input_name='conf'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PageType', fromsubclass_=False, pretty_print=True):
+ outfile.write(' conf=%s' % (quote_attrib(self.conf), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PageType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for AlternativeImage_ in self.AlternativeImage:
- namespaceprefix_ = self.AlternativeImage_nsprefix_ + ':' if (UseCapturedNS_ and self.AlternativeImage_nsprefix_) else ''
AlternativeImage_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='AlternativeImage', pretty_print=pretty_print)
if self.Border is not None:
- namespaceprefix_ = self.Border_nsprefix_ + ':' if (UseCapturedNS_ and self.Border_nsprefix_) else ''
self.Border.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Border', pretty_print=pretty_print)
if self.PrintSpace is not None:
- namespaceprefix_ = self.PrintSpace_nsprefix_ + ':' if (UseCapturedNS_ and self.PrintSpace_nsprefix_) else ''
self.PrintSpace.export(outfile, level, namespaceprefix_, namespacedef_='', name_='PrintSpace', pretty_print=pretty_print)
if self.ReadingOrder is not None:
- namespaceprefix_ = self.ReadingOrder_nsprefix_ + ':' if (UseCapturedNS_ and self.ReadingOrder_nsprefix_) else ''
self.ReadingOrder.export(outfile, level, namespaceprefix_, namespacedef_='', name_='ReadingOrder', pretty_print=pretty_print)
if self.Layers is not None:
- namespaceprefix_ = self.Layers_nsprefix_ + ':' if (UseCapturedNS_ and self.Layers_nsprefix_) else ''
self.Layers.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Layers', pretty_print=pretty_print)
if self.Relations is not None:
- namespaceprefix_ = self.Relations_nsprefix_ + ':' if (UseCapturedNS_ and self.Relations_nsprefix_) else ''
self.Relations.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Relations', pretty_print=pretty_print)
if self.TextStyle is not None:
- namespaceprefix_ = self.TextStyle_nsprefix_ + ':' if (UseCapturedNS_ and self.TextStyle_nsprefix_) else ''
self.TextStyle.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextStyle', pretty_print=pretty_print)
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
for TextRegion_ in self.TextRegion:
- namespaceprefix_ = self.TextRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.TextRegion_nsprefix_) else ''
TextRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextRegion', pretty_print=pretty_print)
for ImageRegion_ in self.ImageRegion:
- namespaceprefix_ = self.ImageRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.ImageRegion_nsprefix_) else ''
ImageRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='ImageRegion', pretty_print=pretty_print)
for LineDrawingRegion_ in self.LineDrawingRegion:
- namespaceprefix_ = self.LineDrawingRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.LineDrawingRegion_nsprefix_) else ''
LineDrawingRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='LineDrawingRegion', pretty_print=pretty_print)
for GraphicRegion_ in self.GraphicRegion:
- namespaceprefix_ = self.GraphicRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.GraphicRegion_nsprefix_) else ''
GraphicRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='GraphicRegion', pretty_print=pretty_print)
for TableRegion_ in self.TableRegion:
- namespaceprefix_ = self.TableRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.TableRegion_nsprefix_) else ''
TableRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TableRegion', pretty_print=pretty_print)
for ChartRegion_ in self.ChartRegion:
- namespaceprefix_ = self.ChartRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.ChartRegion_nsprefix_) else ''
ChartRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='ChartRegion', pretty_print=pretty_print)
for MapRegion_ in self.MapRegion:
- namespaceprefix_ = self.MapRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.MapRegion_nsprefix_) else ''
MapRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='MapRegion', pretty_print=pretty_print)
for SeparatorRegion_ in self.SeparatorRegion:
- namespaceprefix_ = self.SeparatorRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.SeparatorRegion_nsprefix_) else ''
SeparatorRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='SeparatorRegion', pretty_print=pretty_print)
for MathsRegion_ in self.MathsRegion:
- namespaceprefix_ = self.MathsRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.MathsRegion_nsprefix_) else ''
MathsRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='MathsRegion', pretty_print=pretty_print)
for ChemRegion_ in self.ChemRegion:
- namespaceprefix_ = self.ChemRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.ChemRegion_nsprefix_) else ''
ChemRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='ChemRegion', pretty_print=pretty_print)
for MusicRegion_ in self.MusicRegion:
- namespaceprefix_ = self.MusicRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.MusicRegion_nsprefix_) else ''
MusicRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='MusicRegion', pretty_print=pretty_print)
for AdvertRegion_ in self.AdvertRegion:
- namespaceprefix_ = self.AdvertRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.AdvertRegion_nsprefix_) else ''
AdvertRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='AdvertRegion', pretty_print=pretty_print)
for NoiseRegion_ in self.NoiseRegion:
- namespaceprefix_ = self.NoiseRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.NoiseRegion_nsprefix_) else ''
NoiseRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='NoiseRegion', pretty_print=pretty_print)
for UnknownRegion_ in self.UnknownRegion:
- namespaceprefix_ = self.UnknownRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.UnknownRegion_nsprefix_) else ''
UnknownRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UnknownRegion', pretty_print=pretty_print)
for CustomRegion_ in self.CustomRegion:
- namespaceprefix_ = self.CustomRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.CustomRegion_nsprefix_) else ''
CustomRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='CustomRegion', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('imageFilename', node)
@@ -2660,21 +2111,31 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('imageWidth', node)
if value is not None and 'imageWidth' not in already_processed:
already_processed.add('imageWidth')
- self.imageWidth = self.gds_parse_integer(value, node, 'imageWidth')
+ try:
+ self.imageWidth = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('imageHeight', node)
if value is not None and 'imageHeight' not in already_processed:
already_processed.add('imageHeight')
- self.imageHeight = self.gds_parse_integer(value, node, 'imageHeight')
+ try:
+ self.imageHeight = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('imageXResolution', node)
if value is not None and 'imageXResolution' not in already_processed:
already_processed.add('imageXResolution')
- value = self.gds_parse_float(value, node, 'imageXResolution')
- self.imageXResolution = value
+ try:
+ self.imageXResolution = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (imageXResolution): %s' % exp)
value = find_attr_value_('imageYResolution', node)
if value is not None and 'imageYResolution' not in already_processed:
already_processed.add('imageYResolution')
- value = self.gds_parse_float(value, node, 'imageYResolution')
- self.imageYResolution = value
+ try:
+ self.imageYResolution = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (imageYResolution): %s' % exp)
value = find_attr_value_('imageResolutionUnit', node)
if value is not None and 'imageResolutionUnit' not in already_processed:
already_processed.add('imageResolutionUnit')
@@ -2686,201 +2147,181 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('type', node)
if value is not None and 'type' not in already_processed:
already_processed.add('type')
self.type_ = value
- self.validate_PageTypeSimpleType(self.type_) # validate type PageTypeSimpleType
value = find_attr_value_('primaryLanguage', node)
if value is not None and 'primaryLanguage' not in already_processed:
already_processed.add('primaryLanguage')
self.primaryLanguage = value
- self.validate_LanguageSimpleType(self.primaryLanguage) # validate type LanguageSimpleType
value = find_attr_value_('secondaryLanguage', node)
if value is not None and 'secondaryLanguage' not in already_processed:
already_processed.add('secondaryLanguage')
self.secondaryLanguage = value
- self.validate_LanguageSimpleType(self.secondaryLanguage) # validate type LanguageSimpleType
value = find_attr_value_('primaryScript', node)
if value is not None and 'primaryScript' not in already_processed:
already_processed.add('primaryScript')
self.primaryScript = value
- self.validate_ScriptSimpleType(self.primaryScript) # validate type ScriptSimpleType
value = find_attr_value_('secondaryScript', node)
if value is not None and 'secondaryScript' not in already_processed:
already_processed.add('secondaryScript')
self.secondaryScript = value
- self.validate_ScriptSimpleType(self.secondaryScript) # validate type ScriptSimpleType
value = find_attr_value_('readingDirection', node)
if value is not None and 'readingDirection' not in already_processed:
already_processed.add('readingDirection')
self.readingDirection = value
- self.validate_ReadingDirectionSimpleType(self.readingDirection) # validate type ReadingDirectionSimpleType
value = find_attr_value_('textLineOrder', node)
if value is not None and 'textLineOrder' not in already_processed:
already_processed.add('textLineOrder')
self.textLineOrder = value
- self.validate_TextLineOrderSimpleType(self.textLineOrder) # validate type TextLineOrderSimpleType
value = find_attr_value_('conf', node)
if value is not None and 'conf' not in already_processed:
already_processed.add('conf')
- value = self.gds_parse_float(value, node, 'conf')
self.conf = value
- self.validate_ConfSimpleType(self.conf) # validate type ConfSimpleType
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'AlternativeImage':
obj_ = AlternativeImageType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.AlternativeImage.append(obj_)
obj_.original_tagname_ = 'AlternativeImage'
elif nodeName_ == 'Border':
obj_ = BorderType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Border = obj_
obj_.original_tagname_ = 'Border'
elif nodeName_ == 'PrintSpace':
obj_ = PrintSpaceType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.PrintSpace = obj_
obj_.original_tagname_ = 'PrintSpace'
elif nodeName_ == 'ReadingOrder':
obj_ = ReadingOrderType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.ReadingOrder = obj_
obj_.original_tagname_ = 'ReadingOrder'
elif nodeName_ == 'Layers':
obj_ = LayersType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Layers = obj_
obj_.original_tagname_ = 'Layers'
elif nodeName_ == 'Relations':
obj_ = RelationsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Relations = obj_
obj_.original_tagname_ = 'Relations'
elif nodeName_ == 'TextStyle':
obj_ = TextStyleType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextStyle = obj_
obj_.original_tagname_ = 'TextStyle'
elif nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
elif nodeName_ == 'TextRegion':
obj_ = TextRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextRegion.append(obj_)
obj_.original_tagname_ = 'TextRegion'
elif nodeName_ == 'ImageRegion':
obj_ = ImageRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.ImageRegion.append(obj_)
obj_.original_tagname_ = 'ImageRegion'
elif nodeName_ == 'LineDrawingRegion':
obj_ = LineDrawingRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.LineDrawingRegion.append(obj_)
obj_.original_tagname_ = 'LineDrawingRegion'
elif nodeName_ == 'GraphicRegion':
obj_ = GraphicRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.GraphicRegion.append(obj_)
obj_.original_tagname_ = 'GraphicRegion'
elif nodeName_ == 'TableRegion':
obj_ = TableRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TableRegion.append(obj_)
obj_.original_tagname_ = 'TableRegion'
elif nodeName_ == 'ChartRegion':
obj_ = ChartRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.ChartRegion.append(obj_)
obj_.original_tagname_ = 'ChartRegion'
elif nodeName_ == 'MapRegion':
obj_ = MapRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.MapRegion.append(obj_)
obj_.original_tagname_ = 'MapRegion'
elif nodeName_ == 'SeparatorRegion':
obj_ = SeparatorRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.SeparatorRegion.append(obj_)
obj_.original_tagname_ = 'SeparatorRegion'
elif nodeName_ == 'MathsRegion':
obj_ = MathsRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.MathsRegion.append(obj_)
obj_.original_tagname_ = 'MathsRegion'
elif nodeName_ == 'ChemRegion':
obj_ = ChemRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.ChemRegion.append(obj_)
obj_.original_tagname_ = 'ChemRegion'
elif nodeName_ == 'MusicRegion':
obj_ = MusicRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.MusicRegion.append(obj_)
obj_.original_tagname_ = 'MusicRegion'
elif nodeName_ == 'AdvertRegion':
obj_ = AdvertRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.AdvertRegion.append(obj_)
obj_.original_tagname_ = 'AdvertRegion'
elif nodeName_ == 'NoiseRegion':
obj_ = NoiseRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.NoiseRegion.append(obj_)
obj_.original_tagname_ = 'NoiseRegion'
elif nodeName_ == 'UnknownRegion':
obj_ = UnknownRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UnknownRegion.append(obj_)
obj_.original_tagname_ = 'UnknownRegion'
elif nodeName_ == 'CustomRegion':
obj_ = CustomRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.CustomRegion.append(obj_)
obj_.original_tagname_ = 'CustomRegion'
- def __hash__(self):
- return hash(self.id)
# end class PageType
class CoordsType(GeneratedsSuper):
- """Polygon outline of the element as a path of points.
- No points may lie outside the outline of its parent,
- which in the case of Border is the bounding rectangle
- of the root image. Paths are closed by convention,
- i.e. the last point logically connects with the first
- (and at least 3 points are required to span an area).
- Paths must be planar (i.e. must not self-intersect).
+ """Polygon outline of the element as a path of points. No points may
+ lie outside the outline of its parent, which in the case of
+ Border is the bounding rectangle of the root image. Paths are
+ closed by convention, i.e. the last point logically connects
+ with the first (and at least 3 points are required to span an
+ area). Paths must be planar (i.e. must not self-intersect).
Confidence value (between 0 and 1)"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('points', 'pc:PointsType', 0, 0, {'use': 'required'}),
- MemberSpec_('conf', 'pc:ConfSimpleType', 0, 1, {'use': 'optional'}),
- ]
subclass = None
superclass = None
- def __init__(self, points=None, conf=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, points=None, conf=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.points = _cast(None, points)
- self.points_nsprefix_ = None
self.conf = _cast(float, conf)
- self.conf_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -2892,10 +2333,6 @@ def factory(*args_, **kwargs_):
else:
return CoordsType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_points(self):
return self.points
def set_points(self, points):
@@ -2904,32 +2341,6 @@ def get_conf(self):
return self.conf
def set_conf(self, conf):
self.conf = conf
- def validate_PointsType(self, value):
- # Validate type pc:PointsType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- if not self.gds_validate_simple_patterns(
- self.validate_PointsType_patterns_, value):
- self.gds_collector_.add_message('Value "%s" does not match xsd pattern restrictions: %s' % (encode_str_2_3(value), self.validate_PointsType_patterns_, ))
- validate_PointsType_patterns_ = [['^(([0-9]+,[0-9]+ )+([0-9]+,[0-9]+))$']]
- def validate_ConfSimpleType(self, value):
- # Validate type pc:ConfSimpleType, a restriction on float.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, float):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (float)' % {"value": value, "lineno": lineno, })
- return False
- if value < 0:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd minInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
- if value > 1:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd maxInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
def hasContent_(self):
if (
@@ -2937,7 +2348,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='CoordsType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='CoordsType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('CoordsType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -2947,8 +2358,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -2959,131 +2368,78 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='CoordsType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='CoordsType'):
if self.points is not None and 'points' not in already_processed:
already_processed.add('points')
- outfile.write(' points=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.points), input_name='points')), ))
+ outfile.write(' points=%s' % (quote_attrib(self.points), ))
if self.conf is not None and 'conf' not in already_processed:
already_processed.add('conf')
- outfile.write(' conf="%s"' % self.gds_format_float(self.conf, input_name='conf'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='CoordsType', fromsubclass_=False, pretty_print=True):
+ outfile.write(' conf=%s' % (quote_attrib(self.conf), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='CoordsType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('points', node)
if value is not None and 'points' not in already_processed:
already_processed.add('points')
self.points = value
- self.validate_PointsType(self.points) # validate type PointsType
value = find_attr_value_('conf', node)
if value is not None and 'conf' not in already_processed:
already_processed.add('conf')
- value = self.gds_parse_float(value, node, 'conf')
self.conf = value
- self.validate_ConfSimpleType(self.conf) # validate type ConfSimpleType
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class CoordsType
class TextLineType(GeneratedsSuper):
- """Overrides primaryLanguage attribute of parent text
- region
- The primary script used in the text line
- The secondary script used in the text line
- The direction in which text within the line
- should be read (order of words and characters).
- Overrides the production attribute of the parent
- text region
- For generic use
- Position (order number) of this text line within the
- parent text region."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('primaryLanguage', 'pc:LanguageSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('primaryScript', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('secondaryScript', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('readingDirection', 'pc:ReadingDirectionSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('production', 'pc:ProductionSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('index', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('AlternativeImage', 'AlternativeImageType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'AlternativeImage', 'type': 'AlternativeImageType'}, None),
- MemberSpec_('Coords', 'CoordsType', 0, 0, {'name': 'Coords', 'type': 'CoordsType'}, None),
- MemberSpec_('Baseline', 'BaselineType', 0, 1, {'minOccurs': '0', 'name': 'Baseline', 'type': 'BaselineType'}, None),
- MemberSpec_('Word', 'WordType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Word', 'type': 'WordType'}, None),
- MemberSpec_('TextEquiv', 'TextEquivType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'TextEquiv', 'type': 'TextEquivType'}, None),
- MemberSpec_('TextStyle', 'TextStyleType', 0, 1, {'minOccurs': '0', 'name': 'TextStyle', 'type': 'TextStyleType'}, None),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- ]
+ """Overrides primaryLanguage attribute of parent text region The
+ primary script used in the text line The secondary script used
+ in the text line The direction in which text within the line
+ should be read (order of words and characters). Overrides the
+ production attribute of the parent text region For generic use
+ Position (order number) of this text line within the parent text
+ region."""
subclass = None
superclass = None
- def __init__(self, id=None, primaryLanguage=None, primaryScript=None, secondaryScript=None, readingDirection=None, production=None, custom=None, comments=None, index=None, AlternativeImage=None, Coords=None, Baseline=None, Word=None, TextEquiv=None, TextStyle=None, UserDefined=None, Labels=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, primaryLanguage=None, primaryScript=None, secondaryScript=None, readingDirection=None, production=None, custom=None, comments=None, index=None, AlternativeImage=None, Coords=None, Baseline=None, Word=None, TextEquiv=None, TextStyle=None, UserDefined=None, Labels=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.primaryLanguage = _cast(None, primaryLanguage)
- self.primaryLanguage_nsprefix_ = None
self.primaryScript = _cast(None, primaryScript)
- self.primaryScript_nsprefix_ = None
self.secondaryScript = _cast(None, secondaryScript)
- self.secondaryScript_nsprefix_ = None
self.readingDirection = _cast(None, readingDirection)
- self.readingDirection_nsprefix_ = None
self.production = _cast(None, production)
- self.production_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
self.index = _cast(int, index)
- self.index_nsprefix_ = None
if AlternativeImage is None:
self.AlternativeImage = []
else:
self.AlternativeImage = AlternativeImage
- self.AlternativeImage_nsprefix_ = None
self.Coords = Coords
- self.Coords_nsprefix_ = None
self.Baseline = Baseline
- self.Baseline_nsprefix_ = None
if Word is None:
self.Word = []
else:
self.Word = Word
- self.Word_nsprefix_ = None
if TextEquiv is None:
self.TextEquiv = []
else:
self.TextEquiv = TextEquiv
- self.TextEquiv_nsprefix_ = None
self.TextStyle = TextStyle
- self.TextStyle_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -3095,16 +2451,14 @@ def factory(*args_, **kwargs_):
else:
return TextLineType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_AlternativeImage(self):
return self.AlternativeImage
def set_AlternativeImage(self, AlternativeImage):
self.AlternativeImage = AlternativeImage
def add_AlternativeImage(self, value):
self.AlternativeImage.append(value)
+ def add_AlternativeImage(self, value):
+ self.AlternativeImage.append(value)
def insert_AlternativeImage_at(self, index, value):
self.AlternativeImage.insert(index, value)
def replace_AlternativeImage_at(self, index, value):
@@ -3123,6 +2477,8 @@ def set_Word(self, Word):
self.Word = Word
def add_Word(self, value):
self.Word.append(value)
+ def add_Word(self, value):
+ self.Word.append(value)
def insert_Word_at(self, index, value):
self.Word.insert(index, value)
def replace_Word_at(self, index, value):
@@ -3133,6 +2489,8 @@ def set_TextEquiv(self, TextEquiv):
self.TextEquiv = TextEquiv
def add_TextEquiv(self, value):
self.TextEquiv.append(value)
+ def add_TextEquiv(self, value):
+ self.TextEquiv.append(value)
def insert_TextEquiv_at(self, index, value):
self.TextEquiv.insert(index, value)
def replace_TextEquiv_at(self, index, value):
@@ -3151,6 +2509,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -3191,58 +2551,6 @@ def get_index(self):
return self.index
def set_index(self, index):
self.index = index
- def validate_LanguageSimpleType(self, value):
- # Validate type pc:LanguageSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Abkhaz', 'Afar', 'Afrikaans', 'Akan', 'Albanian', 'Amharic', 'Arabic', 'Aragonese', 'Armenian', 'Assamese', 'Avaric', 'Avestan', 'Aymara', 'Azerbaijani', 'Bambara', 'Bashkir', 'Basque', 'Belarusian', 'Bengali', 'Bihari', 'Bislama', 'Bosnian', 'Breton', 'Bulgarian', 'Burmese', 'Cambodian', 'Cantonese', 'Catalan', 'Chamorro', 'Chechen', 'Chichewa', 'Chinese', 'Chuvash', 'Cornish', 'Corsican', 'Cree', 'Croatian', 'Czech', 'Danish', 'Divehi', 'Dutch', 'Dzongkha', 'English', 'Esperanto', 'Estonian', 'Ewe', 'Faroese', 'Fijian', 'Finnish', 'French', 'Fula', 'Gaelic', 'Galician', 'Ganda', 'Georgian', 'German', 'Greek', 'Guaraní', 'Gujarati', 'Haitian', 'Hausa', 'Hebrew', 'Herero', 'Hindi', 'Hiri Motu', 'Hungarian', 'Icelandic', 'Ido', 'Igbo', 'Indonesian', 'Interlingua', 'Interlingue', 'Inuktitut', 'Inupiaq', 'Irish', 'Italian', 'Japanese', 'Javanese', 'Kalaallisut', 'Kannada', 'Kanuri', 'Kashmiri', 'Kazakh', 'Khmer', 'Kikuyu', 'Kinyarwanda', 'Kirundi', 'Komi', 'Kongo', 'Korean', 'Kurdish', 'Kwanyama', 'Kyrgyz', 'Lao', 'Latin', 'Latvian', 'Limburgish', 'Lingala', 'Lithuanian', 'Luba-Katanga', 'Luxembourgish', 'Macedonian', 'Malagasy', 'Malay', 'Malayalam', 'Maltese', 'Manx', 'Māori', 'Marathi', 'Marshallese', 'Mongolian', 'Nauru', 'Navajo', 'Ndonga', 'Nepali', 'North Ndebele', 'Northern Sami', 'Norwegian', 'Norwegian Bokmål', 'Norwegian Nynorsk', 'Nuosu', 'Occitan', 'Ojibwe', 'Old Church Slavonic', 'Oriya', 'Oromo', 'Ossetian', 'Pāli', 'Panjabi', 'Pashto', 'Persian', 'Polish', 'Portuguese', 'Punjabi', 'Quechua', 'Romanian', 'Romansh', 'Russian', 'Samoan', 'Sango', 'Sanskrit', 'Sardinian', 'Serbian', 'Shona', 'Sindhi', 'Sinhala', 'Slovak', 'Slovene', 'Somali', 'South Ndebele', 'Southern Sotho', 'Spanish', 'Sundanese', 'Swahili', 'Swati', 'Swedish', 'Tagalog', 'Tahitian', 'Tajik', 'Tamil', 'Tatar', 'Telugu', 'Thai', 'Tibetan', 'Tigrinya', 'Tonga', 'Tsonga', 'Tswana', 'Turkish', 'Turkmen', 'Twi', 'Uighur', 'Ukrainian', 'Urdu', 'Uzbek', 'Venda', 'Vietnamese', 'Volapük', 'Walloon', 'Welsh', 'Western Frisian', 'Wolof', 'Xhosa', 'Yiddish', 'Yoruba', 'Zhuang', 'Zulu', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on LanguageSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ScriptSimpleType(self, value):
- # Validate type pc:ScriptSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Adlm - Adlam', 'Afak - Afaka', 'Aghb - Caucasian Albanian', 'Ahom - Ahom, Tai Ahom', 'Arab - Arabic', 'Aran - Arabic (Nastaliq variant)', 'Armi - Imperial Aramaic', 'Armn - Armenian', 'Avst - Avestan', 'Bali - Balinese', 'Bamu - Bamum', 'Bass - Bassa Vah', 'Batk - Batak', 'Beng - Bengali', 'Bhks - Bhaiksuki', 'Blis - Blissymbols', 'Bopo - Bopomofo', 'Brah - Brahmi', 'Brai - Braille', 'Bugi - Buginese', 'Buhd - Buhid', 'Cakm - Chakma', 'Cans - Unified Canadian Aboriginal Syllabics', 'Cari - Carian', 'Cham - Cham', 'Cher - Cherokee', 'Cirt - Cirth', 'Copt - Coptic', 'Cprt - Cypriot', 'Cyrl - Cyrillic', 'Cyrs - Cyrillic (Old Church Slavonic variant)', 'Deva - Devanagari (Nagari)', 'Dsrt - Deseret (Mormon)', 'Dupl - Duployan shorthand, Duployan stenography', 'Egyd - Egyptian demotic', 'Egyh - Egyptian hieratic', 'Egyp - Egyptian hieroglyphs', 'Elba - Elbasan', 'Ethi - Ethiopic', 'Geok - Khutsuri (Asomtavruli and Nuskhuri)', 'Geor - Georgian (Mkhedruli)', 'Glag - Glagolitic', 'Goth - Gothic', 'Gran - Grantha', 'Grek - Greek', 'Gujr - Gujarati', 'Guru - Gurmukhi', 'Hanb - Han with Bopomofo', 'Hang - Hangul', 'Hani - Han (Hanzi, Kanji, Hanja)', 'Hano - Hanunoo (Hanunóo)', 'Hans - Han (Simplified variant)', 'Hant - Han (Traditional variant)', 'Hatr - Hatran', 'Hebr - Hebrew', 'Hira - Hiragana', 'Hluw - Anatolian Hieroglyphs', 'Hmng - Pahawh Hmong', 'Hrkt - Japanese syllabaries', 'Hung - Old Hungarian (Hungarian Runic)', 'Inds - Indus (Harappan)', 'Ital - Old Italic (Etruscan, Oscan etc.)', 'Jamo - Jamo', 'Java - Javanese', 'Jpan - Japanese', 'Jurc - Jurchen', 'Kali - Kayah Li', 'Kana - Katakana', 'Khar - Kharoshthi', 'Khmr - Khmer', 'Khoj - Khojki', 'Kitl - Khitan large script', 'Kits - Khitan small script', 'Knda - Kannada', 'Kore - Korean (alias for Hangul + Han)', 'Kpel - Kpelle', 'Kthi - Kaithi', 'Lana - Tai Tham (Lanna)', 'Laoo - Lao', 'Latf - Latin (Fraktur variant)', 'Latg - Latin (Gaelic variant)', 'Latn - Latin', 'Leke - Leke', 'Lepc - Lepcha (Róng)', 'Limb - Limbu', 'Lina - Linear A', 'Linb - Linear B', 'Lisu - Lisu (Fraser)', 'Loma - Loma', 'Lyci - Lycian', 'Lydi - Lydian', 'Mahj - Mahajani', 'Mand - Mandaic, Mandaean', 'Mani - Manichaean', 'Marc - Marchen', 'Maya - Mayan hieroglyphs', 'Mend - Mende Kikakui', 'Merc - Meroitic Cursive', 'Mero - Meroitic Hieroglyphs', 'Mlym - Malayalam', 'Modi - Modi, Moḍī', 'Mong - Mongolian', 'Moon - Moon (Moon code, Moon script, Moon type)', 'Mroo - Mro, Mru', 'Mtei - Meitei Mayek (Meithei, Meetei)', 'Mult - Multani', 'Mymr - Myanmar (Burmese)', 'Narb - Old North Arabian (Ancient North Arabian)', 'Nbat - Nabataean', 'Newa - Newa, Newar, Newari', 'Nkgb - Nakhi Geba', 'Nkoo - N’Ko', 'Nshu - Nüshu', 'Ogam - Ogham', 'Olck - Ol Chiki (Ol Cemet’, Ol, Santali)', 'Orkh - Old Turkic, Orkhon Runic', 'Orya - Oriya', 'Osge - Osage', 'Osma - Osmanya', 'Palm - Palmyrene', 'Pauc - Pau Cin Hau', 'Perm - Old Permic', 'Phag - Phags-pa', 'Phli - Inscriptional Pahlavi', 'Phlp - Psalter Pahlavi', 'Phlv - Book Pahlavi', 'Phnx - Phoenician', 'Piqd - Klingon (KLI pIqaD)', 'Plrd - Miao (Pollard)', 'Prti - Inscriptional Parthian', 'Rjng - Rejang (Redjang, Kaganga)', 'Roro - Rongorongo', 'Runr - Runic', 'Samr - Samaritan', 'Sara - Sarati', 'Sarb - Old South Arabian', 'Saur - Saurashtra', 'Sgnw - SignWriting', 'Shaw - Shavian (Shaw)', 'Shrd - Sharada, Śāradā', 'Sidd - Siddham', 'Sind - Khudawadi, Sindhi', 'Sinh - Sinhala', 'Sora - Sora Sompeng', 'Sund - Sundanese', 'Sylo - Syloti Nagri', 'Syrc - Syriac', 'Syre - Syriac (Estrangelo variant)', 'Syrj - Syriac (Western variant)', 'Syrn - Syriac (Eastern variant)', 'Tagb - Tagbanwa', 'Takr - Takri', 'Tale - Tai Le', 'Talu - New Tai Lue', 'Taml - Tamil', 'Tang - Tangut', 'Tavt - Tai Viet', 'Telu - Telugu', 'Teng - Tengwar', 'Tfng - Tifinagh (Berber)', 'Tglg - Tagalog (Baybayin, Alibata)', 'Thaa - Thaana', 'Thai - Thai', 'Tibt - Tibetan', 'Tirh - Tirhuta', 'Ugar - Ugaritic', 'Vaii - Vai', 'Visp - Visible Speech', 'Wara - Warang Citi (Varang Kshiti)', 'Wole - Woleai', 'Xpeo - Old Persian', 'Xsux - Cuneiform, Sumero-Akkadian', 'Yiii - Yi', 'Zinh - Code for inherited script', 'Zmth - Mathematical notation', 'Zsye - Symbols (Emoji variant)', 'Zsym - Symbols', 'Zxxx - Code for unwritten documents', 'Zyyy - Code for undetermined script', 'Zzzz - Code for uncoded script', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ScriptSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ReadingDirectionSimpleType(self, value):
- # Validate type pc:ReadingDirectionSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['left-to-right', 'right-to-left', 'top-to-bottom', 'bottom-to-top']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ReadingDirectionSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ProductionSimpleType(self, value):
- # Validate type pc:ProductionSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['printed', 'typewritten', 'handwritten-cursive', 'handwritten-printscript', 'medieval-manuscript', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ProductionSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.AlternativeImage or
@@ -3257,7 +2565,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextLineType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextLineType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('TextLineType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -3267,8 +2575,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -3280,25 +2586,25 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='TextLineType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='TextLineType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
if self.primaryLanguage is not None and 'primaryLanguage' not in already_processed:
already_processed.add('primaryLanguage')
- outfile.write(' primaryLanguage=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.primaryLanguage), input_name='primaryLanguage')), ))
+ outfile.write(' primaryLanguage=%s' % (quote_attrib(self.primaryLanguage), ))
if self.primaryScript is not None and 'primaryScript' not in already_processed:
already_processed.add('primaryScript')
- outfile.write(' primaryScript=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.primaryScript), input_name='primaryScript')), ))
+ outfile.write(' primaryScript=%s' % (quote_attrib(self.primaryScript), ))
if self.secondaryScript is not None and 'secondaryScript' not in already_processed:
already_processed.add('secondaryScript')
- outfile.write(' secondaryScript=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.secondaryScript), input_name='secondaryScript')), ))
+ outfile.write(' secondaryScript=%s' % (quote_attrib(self.secondaryScript), ))
if self.readingDirection is not None and 'readingDirection' not in already_processed:
already_processed.add('readingDirection')
- outfile.write(' readingDirection=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.readingDirection), input_name='readingDirection')), ))
+ outfile.write(' readingDirection=%s' % (quote_attrib(self.readingDirection), ))
if self.production is not None and 'production' not in already_processed:
already_processed.add('production')
- outfile.write(' production=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.production), input_name='production')), ))
+ outfile.write(' production=%s' % (quote_attrib(self.production), ))
if self.custom is not None and 'custom' not in already_processed:
already_processed.add('custom')
outfile.write(' custom=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.custom), input_name='custom')), ))
@@ -3308,45 +2614,33 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.index is not None and 'index' not in already_processed:
already_processed.add('index')
outfile.write(' index="%s"' % self.gds_format_integer(self.index, input_name='index'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextLineType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextLineType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for AlternativeImage_ in self.AlternativeImage:
- namespaceprefix_ = self.AlternativeImage_nsprefix_ + ':' if (UseCapturedNS_ and self.AlternativeImage_nsprefix_) else ''
AlternativeImage_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='AlternativeImage', pretty_print=pretty_print)
if self.Coords is not None:
- namespaceprefix_ = self.Coords_nsprefix_ + ':' if (UseCapturedNS_ and self.Coords_nsprefix_) else ''
self.Coords.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Coords', pretty_print=pretty_print)
if self.Baseline is not None:
- namespaceprefix_ = self.Baseline_nsprefix_ + ':' if (UseCapturedNS_ and self.Baseline_nsprefix_) else ''
self.Baseline.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Baseline', pretty_print=pretty_print)
for Word_ in self.Word:
- namespaceprefix_ = self.Word_nsprefix_ + ':' if (UseCapturedNS_ and self.Word_nsprefix_) else ''
Word_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Word', pretty_print=pretty_print)
for TextEquiv_ in self.TextEquiv:
- namespaceprefix_ = self.TextEquiv_nsprefix_ + ':' if (UseCapturedNS_ and self.TextEquiv_nsprefix_) else ''
TextEquiv_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextEquiv', pretty_print=pretty_print)
if self.TextStyle is not None:
- namespaceprefix_ = self.TextStyle_nsprefix_ + ':' if (UseCapturedNS_ and self.TextStyle_nsprefix_) else ''
self.TextStyle.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextStyle', pretty_print=pretty_print)
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -3357,27 +2651,22 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'primaryLanguage' not in already_processed:
already_processed.add('primaryLanguage')
self.primaryLanguage = value
- self.validate_LanguageSimpleType(self.primaryLanguage) # validate type LanguageSimpleType
value = find_attr_value_('primaryScript', node)
if value is not None and 'primaryScript' not in already_processed:
already_processed.add('primaryScript')
self.primaryScript = value
- self.validate_ScriptSimpleType(self.primaryScript) # validate type ScriptSimpleType
value = find_attr_value_('secondaryScript', node)
if value is not None and 'secondaryScript' not in already_processed:
already_processed.add('secondaryScript')
self.secondaryScript = value
- self.validate_ScriptSimpleType(self.secondaryScript) # validate type ScriptSimpleType
value = find_attr_value_('readingDirection', node)
if value is not None and 'readingDirection' not in already_processed:
already_processed.add('readingDirection')
self.readingDirection = value
- self.validate_ReadingDirectionSimpleType(self.readingDirection) # validate type ReadingDirectionSimpleType
value = find_attr_value_('production', node)
if value is not None and 'production' not in already_processed:
already_processed.add('production')
self.production = value
- self.validate_ProductionSimpleType(self.production) # validate type ProductionSimpleType
value = find_attr_value_('custom', node)
if value is not None and 'custom' not in already_processed:
already_processed.add('custom')
@@ -3389,131 +2678,93 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('index', node)
if value is not None and 'index' not in already_processed:
already_processed.add('index')
- self.index = self.gds_parse_integer(value, node, 'index')
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ try:
+ self.index = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'AlternativeImage':
obj_ = AlternativeImageType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.AlternativeImage.append(obj_)
obj_.original_tagname_ = 'AlternativeImage'
elif nodeName_ == 'Coords':
obj_ = CoordsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Coords = obj_
obj_.original_tagname_ = 'Coords'
elif nodeName_ == 'Baseline':
obj_ = BaselineType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Baseline = obj_
obj_.original_tagname_ = 'Baseline'
elif nodeName_ == 'Word':
obj_ = WordType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Word.append(obj_)
obj_.original_tagname_ = 'Word'
elif nodeName_ == 'TextEquiv':
obj_ = TextEquivType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextEquiv.append(obj_)
obj_.original_tagname_ = 'TextEquiv'
elif nodeName_ == 'TextStyle':
obj_ = TextStyleType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextStyle = obj_
obj_.original_tagname_ = 'TextStyle'
elif nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
- def __hash__(self):
- return hash(self.id)
# end class TextLineType
class WordType(GeneratedsSuper):
- """Overrides primaryLanguage attribute of parent line
- and/or text region
- The primary script used in the word
- The secondary script used in the word
- The direction in which text within the word
- should be read (order of characters).
- Overrides the production attribute of the parent
- text line and/or text region.
- For generic use"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('language', 'pc:LanguageSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('primaryScript', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('secondaryScript', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('readingDirection', 'pc:ReadingDirectionSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('production', 'pc:ProductionSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('AlternativeImage', 'AlternativeImageType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'AlternativeImage', 'type': 'AlternativeImageType'}, None),
- MemberSpec_('Coords', 'CoordsType', 0, 0, {'name': 'Coords', 'type': 'CoordsType'}, None),
- MemberSpec_('Glyph', 'GlyphType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Glyph', 'type': 'GlyphType'}, None),
- MemberSpec_('TextEquiv', 'TextEquivType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'TextEquiv', 'type': 'TextEquivType'}, None),
- MemberSpec_('TextStyle', 'TextStyleType', 0, 1, {'minOccurs': '0', 'name': 'TextStyle', 'type': 'TextStyleType'}, None),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- ]
+ """Overrides primaryLanguage attribute of parent line and/or text
+ region The primary script used in the word The secondary script
+ used in the word The direction in which text within the word
+ should be read (order of characters). Overrides the production
+ attribute of the parent text line and/or text region. For
+ generic use"""
subclass = None
superclass = None
- def __init__(self, id=None, language=None, primaryScript=None, secondaryScript=None, readingDirection=None, production=None, custom=None, comments=None, AlternativeImage=None, Coords=None, Glyph=None, TextEquiv=None, TextStyle=None, UserDefined=None, Labels=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, language=None, primaryScript=None, secondaryScript=None, readingDirection=None, production=None, custom=None, comments=None, AlternativeImage=None, Coords=None, Glyph=None, TextEquiv=None, TextStyle=None, UserDefined=None, Labels=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.language = _cast(None, language)
- self.language_nsprefix_ = None
self.primaryScript = _cast(None, primaryScript)
- self.primaryScript_nsprefix_ = None
self.secondaryScript = _cast(None, secondaryScript)
- self.secondaryScript_nsprefix_ = None
self.readingDirection = _cast(None, readingDirection)
- self.readingDirection_nsprefix_ = None
self.production = _cast(None, production)
- self.production_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
if AlternativeImage is None:
self.AlternativeImage = []
else:
self.AlternativeImage = AlternativeImage
- self.AlternativeImage_nsprefix_ = None
self.Coords = Coords
- self.Coords_nsprefix_ = None
if Glyph is None:
self.Glyph = []
else:
self.Glyph = Glyph
- self.Glyph_nsprefix_ = None
if TextEquiv is None:
self.TextEquiv = []
else:
self.TextEquiv = TextEquiv
- self.TextEquiv_nsprefix_ = None
self.TextStyle = TextStyle
- self.TextStyle_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -3525,16 +2776,14 @@ def factory(*args_, **kwargs_):
else:
return WordType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_AlternativeImage(self):
return self.AlternativeImage
def set_AlternativeImage(self, AlternativeImage):
self.AlternativeImage = AlternativeImage
def add_AlternativeImage(self, value):
self.AlternativeImage.append(value)
+ def add_AlternativeImage(self, value):
+ self.AlternativeImage.append(value)
def insert_AlternativeImage_at(self, index, value):
self.AlternativeImage.insert(index, value)
def replace_AlternativeImage_at(self, index, value):
@@ -3549,6 +2798,8 @@ def set_Glyph(self, Glyph):
self.Glyph = Glyph
def add_Glyph(self, value):
self.Glyph.append(value)
+ def add_Glyph(self, value):
+ self.Glyph.append(value)
def insert_Glyph_at(self, index, value):
self.Glyph.insert(index, value)
def replace_Glyph_at(self, index, value):
@@ -3559,6 +2810,8 @@ def set_TextEquiv(self, TextEquiv):
self.TextEquiv = TextEquiv
def add_TextEquiv(self, value):
self.TextEquiv.append(value)
+ def add_TextEquiv(self, value):
+ self.TextEquiv.append(value)
def insert_TextEquiv_at(self, index, value):
self.TextEquiv.insert(index, value)
def replace_TextEquiv_at(self, index, value):
@@ -3577,6 +2830,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -3613,58 +2868,6 @@ def get_comments(self):
return self.comments
def set_comments(self, comments):
self.comments = comments
- def validate_LanguageSimpleType(self, value):
- # Validate type pc:LanguageSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Abkhaz', 'Afar', 'Afrikaans', 'Akan', 'Albanian', 'Amharic', 'Arabic', 'Aragonese', 'Armenian', 'Assamese', 'Avaric', 'Avestan', 'Aymara', 'Azerbaijani', 'Bambara', 'Bashkir', 'Basque', 'Belarusian', 'Bengali', 'Bihari', 'Bislama', 'Bosnian', 'Breton', 'Bulgarian', 'Burmese', 'Cambodian', 'Cantonese', 'Catalan', 'Chamorro', 'Chechen', 'Chichewa', 'Chinese', 'Chuvash', 'Cornish', 'Corsican', 'Cree', 'Croatian', 'Czech', 'Danish', 'Divehi', 'Dutch', 'Dzongkha', 'English', 'Esperanto', 'Estonian', 'Ewe', 'Faroese', 'Fijian', 'Finnish', 'French', 'Fula', 'Gaelic', 'Galician', 'Ganda', 'Georgian', 'German', 'Greek', 'Guaraní', 'Gujarati', 'Haitian', 'Hausa', 'Hebrew', 'Herero', 'Hindi', 'Hiri Motu', 'Hungarian', 'Icelandic', 'Ido', 'Igbo', 'Indonesian', 'Interlingua', 'Interlingue', 'Inuktitut', 'Inupiaq', 'Irish', 'Italian', 'Japanese', 'Javanese', 'Kalaallisut', 'Kannada', 'Kanuri', 'Kashmiri', 'Kazakh', 'Khmer', 'Kikuyu', 'Kinyarwanda', 'Kirundi', 'Komi', 'Kongo', 'Korean', 'Kurdish', 'Kwanyama', 'Kyrgyz', 'Lao', 'Latin', 'Latvian', 'Limburgish', 'Lingala', 'Lithuanian', 'Luba-Katanga', 'Luxembourgish', 'Macedonian', 'Malagasy', 'Malay', 'Malayalam', 'Maltese', 'Manx', 'Māori', 'Marathi', 'Marshallese', 'Mongolian', 'Nauru', 'Navajo', 'Ndonga', 'Nepali', 'North Ndebele', 'Northern Sami', 'Norwegian', 'Norwegian Bokmål', 'Norwegian Nynorsk', 'Nuosu', 'Occitan', 'Ojibwe', 'Old Church Slavonic', 'Oriya', 'Oromo', 'Ossetian', 'Pāli', 'Panjabi', 'Pashto', 'Persian', 'Polish', 'Portuguese', 'Punjabi', 'Quechua', 'Romanian', 'Romansh', 'Russian', 'Samoan', 'Sango', 'Sanskrit', 'Sardinian', 'Serbian', 'Shona', 'Sindhi', 'Sinhala', 'Slovak', 'Slovene', 'Somali', 'South Ndebele', 'Southern Sotho', 'Spanish', 'Sundanese', 'Swahili', 'Swati', 'Swedish', 'Tagalog', 'Tahitian', 'Tajik', 'Tamil', 'Tatar', 'Telugu', 'Thai', 'Tibetan', 'Tigrinya', 'Tonga', 'Tsonga', 'Tswana', 'Turkish', 'Turkmen', 'Twi', 'Uighur', 'Ukrainian', 'Urdu', 'Uzbek', 'Venda', 'Vietnamese', 'Volapük', 'Walloon', 'Welsh', 'Western Frisian', 'Wolof', 'Xhosa', 'Yiddish', 'Yoruba', 'Zhuang', 'Zulu', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on LanguageSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ScriptSimpleType(self, value):
- # Validate type pc:ScriptSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Adlm - Adlam', 'Afak - Afaka', 'Aghb - Caucasian Albanian', 'Ahom - Ahom, Tai Ahom', 'Arab - Arabic', 'Aran - Arabic (Nastaliq variant)', 'Armi - Imperial Aramaic', 'Armn - Armenian', 'Avst - Avestan', 'Bali - Balinese', 'Bamu - Bamum', 'Bass - Bassa Vah', 'Batk - Batak', 'Beng - Bengali', 'Bhks - Bhaiksuki', 'Blis - Blissymbols', 'Bopo - Bopomofo', 'Brah - Brahmi', 'Brai - Braille', 'Bugi - Buginese', 'Buhd - Buhid', 'Cakm - Chakma', 'Cans - Unified Canadian Aboriginal Syllabics', 'Cari - Carian', 'Cham - Cham', 'Cher - Cherokee', 'Cirt - Cirth', 'Copt - Coptic', 'Cprt - Cypriot', 'Cyrl - Cyrillic', 'Cyrs - Cyrillic (Old Church Slavonic variant)', 'Deva - Devanagari (Nagari)', 'Dsrt - Deseret (Mormon)', 'Dupl - Duployan shorthand, Duployan stenography', 'Egyd - Egyptian demotic', 'Egyh - Egyptian hieratic', 'Egyp - Egyptian hieroglyphs', 'Elba - Elbasan', 'Ethi - Ethiopic', 'Geok - Khutsuri (Asomtavruli and Nuskhuri)', 'Geor - Georgian (Mkhedruli)', 'Glag - Glagolitic', 'Goth - Gothic', 'Gran - Grantha', 'Grek - Greek', 'Gujr - Gujarati', 'Guru - Gurmukhi', 'Hanb - Han with Bopomofo', 'Hang - Hangul', 'Hani - Han (Hanzi, Kanji, Hanja)', 'Hano - Hanunoo (Hanunóo)', 'Hans - Han (Simplified variant)', 'Hant - Han (Traditional variant)', 'Hatr - Hatran', 'Hebr - Hebrew', 'Hira - Hiragana', 'Hluw - Anatolian Hieroglyphs', 'Hmng - Pahawh Hmong', 'Hrkt - Japanese syllabaries', 'Hung - Old Hungarian (Hungarian Runic)', 'Inds - Indus (Harappan)', 'Ital - Old Italic (Etruscan, Oscan etc.)', 'Jamo - Jamo', 'Java - Javanese', 'Jpan - Japanese', 'Jurc - Jurchen', 'Kali - Kayah Li', 'Kana - Katakana', 'Khar - Kharoshthi', 'Khmr - Khmer', 'Khoj - Khojki', 'Kitl - Khitan large script', 'Kits - Khitan small script', 'Knda - Kannada', 'Kore - Korean (alias for Hangul + Han)', 'Kpel - Kpelle', 'Kthi - Kaithi', 'Lana - Tai Tham (Lanna)', 'Laoo - Lao', 'Latf - Latin (Fraktur variant)', 'Latg - Latin (Gaelic variant)', 'Latn - Latin', 'Leke - Leke', 'Lepc - Lepcha (Róng)', 'Limb - Limbu', 'Lina - Linear A', 'Linb - Linear B', 'Lisu - Lisu (Fraser)', 'Loma - Loma', 'Lyci - Lycian', 'Lydi - Lydian', 'Mahj - Mahajani', 'Mand - Mandaic, Mandaean', 'Mani - Manichaean', 'Marc - Marchen', 'Maya - Mayan hieroglyphs', 'Mend - Mende Kikakui', 'Merc - Meroitic Cursive', 'Mero - Meroitic Hieroglyphs', 'Mlym - Malayalam', 'Modi - Modi, Moḍī', 'Mong - Mongolian', 'Moon - Moon (Moon code, Moon script, Moon type)', 'Mroo - Mro, Mru', 'Mtei - Meitei Mayek (Meithei, Meetei)', 'Mult - Multani', 'Mymr - Myanmar (Burmese)', 'Narb - Old North Arabian (Ancient North Arabian)', 'Nbat - Nabataean', 'Newa - Newa, Newar, Newari', 'Nkgb - Nakhi Geba', 'Nkoo - N’Ko', 'Nshu - Nüshu', 'Ogam - Ogham', 'Olck - Ol Chiki (Ol Cemet’, Ol, Santali)', 'Orkh - Old Turkic, Orkhon Runic', 'Orya - Oriya', 'Osge - Osage', 'Osma - Osmanya', 'Palm - Palmyrene', 'Pauc - Pau Cin Hau', 'Perm - Old Permic', 'Phag - Phags-pa', 'Phli - Inscriptional Pahlavi', 'Phlp - Psalter Pahlavi', 'Phlv - Book Pahlavi', 'Phnx - Phoenician', 'Piqd - Klingon (KLI pIqaD)', 'Plrd - Miao (Pollard)', 'Prti - Inscriptional Parthian', 'Rjng - Rejang (Redjang, Kaganga)', 'Roro - Rongorongo', 'Runr - Runic', 'Samr - Samaritan', 'Sara - Sarati', 'Sarb - Old South Arabian', 'Saur - Saurashtra', 'Sgnw - SignWriting', 'Shaw - Shavian (Shaw)', 'Shrd - Sharada, Śāradā', 'Sidd - Siddham', 'Sind - Khudawadi, Sindhi', 'Sinh - Sinhala', 'Sora - Sora Sompeng', 'Sund - Sundanese', 'Sylo - Syloti Nagri', 'Syrc - Syriac', 'Syre - Syriac (Estrangelo variant)', 'Syrj - Syriac (Western variant)', 'Syrn - Syriac (Eastern variant)', 'Tagb - Tagbanwa', 'Takr - Takri', 'Tale - Tai Le', 'Talu - New Tai Lue', 'Taml - Tamil', 'Tang - Tangut', 'Tavt - Tai Viet', 'Telu - Telugu', 'Teng - Tengwar', 'Tfng - Tifinagh (Berber)', 'Tglg - Tagalog (Baybayin, Alibata)', 'Thaa - Thaana', 'Thai - Thai', 'Tibt - Tibetan', 'Tirh - Tirhuta', 'Ugar - Ugaritic', 'Vaii - Vai', 'Visp - Visible Speech', 'Wara - Warang Citi (Varang Kshiti)', 'Wole - Woleai', 'Xpeo - Old Persian', 'Xsux - Cuneiform, Sumero-Akkadian', 'Yiii - Yi', 'Zinh - Code for inherited script', 'Zmth - Mathematical notation', 'Zsye - Symbols (Emoji variant)', 'Zsym - Symbols', 'Zxxx - Code for unwritten documents', 'Zyyy - Code for undetermined script', 'Zzzz - Code for uncoded script', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ScriptSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ReadingDirectionSimpleType(self, value):
- # Validate type pc:ReadingDirectionSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['left-to-right', 'right-to-left', 'top-to-bottom', 'bottom-to-top']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ReadingDirectionSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ProductionSimpleType(self, value):
- # Validate type pc:ProductionSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['printed', 'typewritten', 'handwritten-cursive', 'handwritten-printscript', 'medieval-manuscript', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ProductionSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.AlternativeImage or
@@ -3678,7 +2881,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='WordType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='WordType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('WordType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -3688,8 +2891,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -3701,67 +2902,56 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='WordType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='WordType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
if self.language is not None and 'language' not in already_processed:
already_processed.add('language')
- outfile.write(' language=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.language), input_name='language')), ))
+ outfile.write(' language=%s' % (quote_attrib(self.language), ))
if self.primaryScript is not None and 'primaryScript' not in already_processed:
already_processed.add('primaryScript')
- outfile.write(' primaryScript=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.primaryScript), input_name='primaryScript')), ))
+ outfile.write(' primaryScript=%s' % (quote_attrib(self.primaryScript), ))
if self.secondaryScript is not None and 'secondaryScript' not in already_processed:
already_processed.add('secondaryScript')
- outfile.write(' secondaryScript=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.secondaryScript), input_name='secondaryScript')), ))
+ outfile.write(' secondaryScript=%s' % (quote_attrib(self.secondaryScript), ))
if self.readingDirection is not None and 'readingDirection' not in already_processed:
already_processed.add('readingDirection')
- outfile.write(' readingDirection=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.readingDirection), input_name='readingDirection')), ))
+ outfile.write(' readingDirection=%s' % (quote_attrib(self.readingDirection), ))
if self.production is not None and 'production' not in already_processed:
already_processed.add('production')
- outfile.write(' production=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.production), input_name='production')), ))
+ outfile.write(' production=%s' % (quote_attrib(self.production), ))
if self.custom is not None and 'custom' not in already_processed:
already_processed.add('custom')
outfile.write(' custom=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.custom), input_name='custom')), ))
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='WordType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='WordType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for AlternativeImage_ in self.AlternativeImage:
- namespaceprefix_ = self.AlternativeImage_nsprefix_ + ':' if (UseCapturedNS_ and self.AlternativeImage_nsprefix_) else ''
AlternativeImage_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='AlternativeImage', pretty_print=pretty_print)
if self.Coords is not None:
- namespaceprefix_ = self.Coords_nsprefix_ + ':' if (UseCapturedNS_ and self.Coords_nsprefix_) else ''
self.Coords.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Coords', pretty_print=pretty_print)
for Glyph_ in self.Glyph:
- namespaceprefix_ = self.Glyph_nsprefix_ + ':' if (UseCapturedNS_ and self.Glyph_nsprefix_) else ''
Glyph_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Glyph', pretty_print=pretty_print)
for TextEquiv_ in self.TextEquiv:
- namespaceprefix_ = self.TextEquiv_nsprefix_ + ':' if (UseCapturedNS_ and self.TextEquiv_nsprefix_) else ''
TextEquiv_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextEquiv', pretty_print=pretty_print)
if self.TextStyle is not None:
- namespaceprefix_ = self.TextStyle_nsprefix_ + ':' if (UseCapturedNS_ and self.TextStyle_nsprefix_) else ''
self.TextStyle.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextStyle', pretty_print=pretty_print)
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -3772,27 +2962,22 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'language' not in already_processed:
already_processed.add('language')
self.language = value
- self.validate_LanguageSimpleType(self.language) # validate type LanguageSimpleType
value = find_attr_value_('primaryScript', node)
if value is not None and 'primaryScript' not in already_processed:
already_processed.add('primaryScript')
self.primaryScript = value
- self.validate_ScriptSimpleType(self.primaryScript) # validate type ScriptSimpleType
value = find_attr_value_('secondaryScript', node)
if value is not None and 'secondaryScript' not in already_processed:
already_processed.add('secondaryScript')
self.secondaryScript = value
- self.validate_ScriptSimpleType(self.secondaryScript) # validate type ScriptSimpleType
value = find_attr_value_('readingDirection', node)
if value is not None and 'readingDirection' not in already_processed:
already_processed.add('readingDirection')
self.readingDirection = value
- self.validate_ReadingDirectionSimpleType(self.readingDirection) # validate type ReadingDirectionSimpleType
value = find_attr_value_('production', node)
if value is not None and 'production' not in already_processed:
already_processed.add('production')
self.production = value
- self.validate_ProductionSimpleType(self.production) # validate type ProductionSimpleType
value = find_attr_value_('custom', node)
if value is not None and 'custom' not in already_processed:
already_processed.add('custom')
@@ -3801,114 +2986,76 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'AlternativeImage':
obj_ = AlternativeImageType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.AlternativeImage.append(obj_)
obj_.original_tagname_ = 'AlternativeImage'
elif nodeName_ == 'Coords':
obj_ = CoordsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Coords = obj_
obj_.original_tagname_ = 'Coords'
elif nodeName_ == 'Glyph':
obj_ = GlyphType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Glyph.append(obj_)
obj_.original_tagname_ = 'Glyph'
elif nodeName_ == 'TextEquiv':
obj_ = TextEquivType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextEquiv.append(obj_)
obj_.original_tagname_ = 'TextEquiv'
elif nodeName_ == 'TextStyle':
obj_ = TextStyleType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextStyle = obj_
obj_.original_tagname_ = 'TextStyle'
elif nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
- def __hash__(self):
- return hash(self.id)
# end class WordType
class GlyphType(GeneratedsSuper):
- """The script used for the glyph
- Overrides the production attribute of the parent
- word / text line / text region.
- For generic use"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('ligature', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('symbol', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('script', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('production', 'pc:ProductionSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('AlternativeImage', 'AlternativeImageType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'AlternativeImage', 'type': 'AlternativeImageType'}, None),
- MemberSpec_('Coords', 'CoordsType', 0, 0, {'name': 'Coords', 'type': 'CoordsType'}, None),
- MemberSpec_('Graphemes', 'GraphemesType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'Graphemes', 'type': 'GraphemesType'}, None),
- MemberSpec_('TextEquiv', 'TextEquivType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'TextEquiv', 'type': 'TextEquivType'}, None),
- MemberSpec_('TextStyle', 'TextStyleType', 0, 1, {'minOccurs': '0', 'name': 'TextStyle', 'type': 'TextStyleType'}, None),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- ]
+ """The script used for the glyph Overrides the production attribute of
+ the parent word / text line / text region. For generic use"""
subclass = None
superclass = None
- def __init__(self, id=None, ligature=None, symbol=None, script=None, production=None, custom=None, comments=None, AlternativeImage=None, Coords=None, Graphemes=None, TextEquiv=None, TextStyle=None, UserDefined=None, Labels=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, ligature=None, symbol=None, script=None, production=None, custom=None, comments=None, AlternativeImage=None, Coords=None, Graphemes=None, TextEquiv=None, TextStyle=None, UserDefined=None, Labels=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.ligature = _cast(bool, ligature)
- self.ligature_nsprefix_ = None
self.symbol = _cast(bool, symbol)
- self.symbol_nsprefix_ = None
self.script = _cast(None, script)
- self.script_nsprefix_ = None
self.production = _cast(None, production)
- self.production_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
if AlternativeImage is None:
self.AlternativeImage = []
else:
self.AlternativeImage = AlternativeImage
- self.AlternativeImage_nsprefix_ = None
self.Coords = Coords
- self.Coords_nsprefix_ = None
self.Graphemes = Graphemes
- self.Graphemes_nsprefix_ = None
if TextEquiv is None:
self.TextEquiv = []
else:
self.TextEquiv = TextEquiv
- self.TextEquiv_nsprefix_ = None
self.TextStyle = TextStyle
- self.TextStyle_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -3920,16 +3067,14 @@ def factory(*args_, **kwargs_):
else:
return GlyphType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_AlternativeImage(self):
return self.AlternativeImage
def set_AlternativeImage(self, AlternativeImage):
self.AlternativeImage = AlternativeImage
def add_AlternativeImage(self, value):
self.AlternativeImage.append(value)
+ def add_AlternativeImage(self, value):
+ self.AlternativeImage.append(value)
def insert_AlternativeImage_at(self, index, value):
self.AlternativeImage.insert(index, value)
def replace_AlternativeImage_at(self, index, value):
@@ -3948,6 +3093,8 @@ def set_TextEquiv(self, TextEquiv):
self.TextEquiv = TextEquiv
def add_TextEquiv(self, value):
self.TextEquiv.append(value)
+ def add_TextEquiv(self, value):
+ self.TextEquiv.append(value)
def insert_TextEquiv_at(self, index, value):
self.TextEquiv.insert(index, value)
def replace_TextEquiv_at(self, index, value):
@@ -3966,6 +3113,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -3998,32 +3147,6 @@ def get_comments(self):
return self.comments
def set_comments(self, comments):
self.comments = comments
- def validate_ScriptSimpleType(self, value):
- # Validate type pc:ScriptSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Adlm - Adlam', 'Afak - Afaka', 'Aghb - Caucasian Albanian', 'Ahom - Ahom, Tai Ahom', 'Arab - Arabic', 'Aran - Arabic (Nastaliq variant)', 'Armi - Imperial Aramaic', 'Armn - Armenian', 'Avst - Avestan', 'Bali - Balinese', 'Bamu - Bamum', 'Bass - Bassa Vah', 'Batk - Batak', 'Beng - Bengali', 'Bhks - Bhaiksuki', 'Blis - Blissymbols', 'Bopo - Bopomofo', 'Brah - Brahmi', 'Brai - Braille', 'Bugi - Buginese', 'Buhd - Buhid', 'Cakm - Chakma', 'Cans - Unified Canadian Aboriginal Syllabics', 'Cari - Carian', 'Cham - Cham', 'Cher - Cherokee', 'Cirt - Cirth', 'Copt - Coptic', 'Cprt - Cypriot', 'Cyrl - Cyrillic', 'Cyrs - Cyrillic (Old Church Slavonic variant)', 'Deva - Devanagari (Nagari)', 'Dsrt - Deseret (Mormon)', 'Dupl - Duployan shorthand, Duployan stenography', 'Egyd - Egyptian demotic', 'Egyh - Egyptian hieratic', 'Egyp - Egyptian hieroglyphs', 'Elba - Elbasan', 'Ethi - Ethiopic', 'Geok - Khutsuri (Asomtavruli and Nuskhuri)', 'Geor - Georgian (Mkhedruli)', 'Glag - Glagolitic', 'Goth - Gothic', 'Gran - Grantha', 'Grek - Greek', 'Gujr - Gujarati', 'Guru - Gurmukhi', 'Hanb - Han with Bopomofo', 'Hang - Hangul', 'Hani - Han (Hanzi, Kanji, Hanja)', 'Hano - Hanunoo (Hanunóo)', 'Hans - Han (Simplified variant)', 'Hant - Han (Traditional variant)', 'Hatr - Hatran', 'Hebr - Hebrew', 'Hira - Hiragana', 'Hluw - Anatolian Hieroglyphs', 'Hmng - Pahawh Hmong', 'Hrkt - Japanese syllabaries', 'Hung - Old Hungarian (Hungarian Runic)', 'Inds - Indus (Harappan)', 'Ital - Old Italic (Etruscan, Oscan etc.)', 'Jamo - Jamo', 'Java - Javanese', 'Jpan - Japanese', 'Jurc - Jurchen', 'Kali - Kayah Li', 'Kana - Katakana', 'Khar - Kharoshthi', 'Khmr - Khmer', 'Khoj - Khojki', 'Kitl - Khitan large script', 'Kits - Khitan small script', 'Knda - Kannada', 'Kore - Korean (alias for Hangul + Han)', 'Kpel - Kpelle', 'Kthi - Kaithi', 'Lana - Tai Tham (Lanna)', 'Laoo - Lao', 'Latf - Latin (Fraktur variant)', 'Latg - Latin (Gaelic variant)', 'Latn - Latin', 'Leke - Leke', 'Lepc - Lepcha (Róng)', 'Limb - Limbu', 'Lina - Linear A', 'Linb - Linear B', 'Lisu - Lisu (Fraser)', 'Loma - Loma', 'Lyci - Lycian', 'Lydi - Lydian', 'Mahj - Mahajani', 'Mand - Mandaic, Mandaean', 'Mani - Manichaean', 'Marc - Marchen', 'Maya - Mayan hieroglyphs', 'Mend - Mende Kikakui', 'Merc - Meroitic Cursive', 'Mero - Meroitic Hieroglyphs', 'Mlym - Malayalam', 'Modi - Modi, Moḍī', 'Mong - Mongolian', 'Moon - Moon (Moon code, Moon script, Moon type)', 'Mroo - Mro, Mru', 'Mtei - Meitei Mayek (Meithei, Meetei)', 'Mult - Multani', 'Mymr - Myanmar (Burmese)', 'Narb - Old North Arabian (Ancient North Arabian)', 'Nbat - Nabataean', 'Newa - Newa, Newar, Newari', 'Nkgb - Nakhi Geba', 'Nkoo - N’Ko', 'Nshu - Nüshu', 'Ogam - Ogham', 'Olck - Ol Chiki (Ol Cemet’, Ol, Santali)', 'Orkh - Old Turkic, Orkhon Runic', 'Orya - Oriya', 'Osge - Osage', 'Osma - Osmanya', 'Palm - Palmyrene', 'Pauc - Pau Cin Hau', 'Perm - Old Permic', 'Phag - Phags-pa', 'Phli - Inscriptional Pahlavi', 'Phlp - Psalter Pahlavi', 'Phlv - Book Pahlavi', 'Phnx - Phoenician', 'Piqd - Klingon (KLI pIqaD)', 'Plrd - Miao (Pollard)', 'Prti - Inscriptional Parthian', 'Rjng - Rejang (Redjang, Kaganga)', 'Roro - Rongorongo', 'Runr - Runic', 'Samr - Samaritan', 'Sara - Sarati', 'Sarb - Old South Arabian', 'Saur - Saurashtra', 'Sgnw - SignWriting', 'Shaw - Shavian (Shaw)', 'Shrd - Sharada, Śāradā', 'Sidd - Siddham', 'Sind - Khudawadi, Sindhi', 'Sinh - Sinhala', 'Sora - Sora Sompeng', 'Sund - Sundanese', 'Sylo - Syloti Nagri', 'Syrc - Syriac', 'Syre - Syriac (Estrangelo variant)', 'Syrj - Syriac (Western variant)', 'Syrn - Syriac (Eastern variant)', 'Tagb - Tagbanwa', 'Takr - Takri', 'Tale - Tai Le', 'Talu - New Tai Lue', 'Taml - Tamil', 'Tang - Tangut', 'Tavt - Tai Viet', 'Telu - Telugu', 'Teng - Tengwar', 'Tfng - Tifinagh (Berber)', 'Tglg - Tagalog (Baybayin, Alibata)', 'Thaa - Thaana', 'Thai - Thai', 'Tibt - Tibetan', 'Tirh - Tirhuta', 'Ugar - Ugaritic', 'Vaii - Vai', 'Visp - Visible Speech', 'Wara - Warang Citi (Varang Kshiti)', 'Wole - Woleai', 'Xpeo - Old Persian', 'Xsux - Cuneiform, Sumero-Akkadian', 'Yiii - Yi', 'Zinh - Code for inherited script', 'Zmth - Mathematical notation', 'Zsye - Symbols (Emoji variant)', 'Zsym - Symbols', 'Zxxx - Code for unwritten documents', 'Zyyy - Code for undetermined script', 'Zzzz - Code for uncoded script', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ScriptSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ProductionSimpleType(self, value):
- # Validate type pc:ProductionSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['printed', 'typewritten', 'handwritten-cursive', 'handwritten-printscript', 'medieval-manuscript', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ProductionSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.AlternativeImage or
@@ -4037,7 +3160,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GlyphType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GlyphType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('GlyphType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -4047,8 +3170,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -4060,7 +3181,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='GlyphType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='GlyphType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -4072,52 +3193,41 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' symbol="%s"' % self.gds_format_boolean(self.symbol, input_name='symbol'))
if self.script is not None and 'script' not in already_processed:
already_processed.add('script')
- outfile.write(' script=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.script), input_name='script')), ))
+ outfile.write(' script=%s' % (quote_attrib(self.script), ))
if self.production is not None and 'production' not in already_processed:
already_processed.add('production')
- outfile.write(' production=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.production), input_name='production')), ))
+ outfile.write(' production=%s' % (quote_attrib(self.production), ))
if self.custom is not None and 'custom' not in already_processed:
already_processed.add('custom')
outfile.write(' custom=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.custom), input_name='custom')), ))
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GlyphType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GlyphType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for AlternativeImage_ in self.AlternativeImage:
- namespaceprefix_ = self.AlternativeImage_nsprefix_ + ':' if (UseCapturedNS_ and self.AlternativeImage_nsprefix_) else ''
AlternativeImage_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='AlternativeImage', pretty_print=pretty_print)
if self.Coords is not None:
- namespaceprefix_ = self.Coords_nsprefix_ + ':' if (UseCapturedNS_ and self.Coords_nsprefix_) else ''
self.Coords.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Coords', pretty_print=pretty_print)
if self.Graphemes is not None:
- namespaceprefix_ = self.Graphemes_nsprefix_ + ':' if (UseCapturedNS_ and self.Graphemes_nsprefix_) else ''
self.Graphemes.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Graphemes', pretty_print=pretty_print)
for TextEquiv_ in self.TextEquiv:
- namespaceprefix_ = self.TextEquiv_nsprefix_ + ':' if (UseCapturedNS_ and self.TextEquiv_nsprefix_) else ''
TextEquiv_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextEquiv', pretty_print=pretty_print)
if self.TextStyle is not None:
- namespaceprefix_ = self.TextStyle_nsprefix_ + ':' if (UseCapturedNS_ and self.TextStyle_nsprefix_) else ''
self.TextStyle.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextStyle', pretty_print=pretty_print)
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -4146,12 +3256,10 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'script' not in already_processed:
already_processed.add('script')
self.script = value
- self.validate_ScriptSimpleType(self.script) # validate type ScriptSimpleType
value = find_attr_value_('production', node)
if value is not None and 'production' not in already_processed:
already_processed.add('production')
self.production = value
- self.validate_ProductionSimpleType(self.production) # validate type ProductionSimpleType
value = find_attr_value_('custom', node)
if value is not None and 'custom' not in already_processed:
already_processed.add('custom')
@@ -4160,89 +3268,65 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'AlternativeImage':
obj_ = AlternativeImageType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.AlternativeImage.append(obj_)
obj_.original_tagname_ = 'AlternativeImage'
elif nodeName_ == 'Coords':
obj_ = CoordsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Coords = obj_
obj_.original_tagname_ = 'Coords'
elif nodeName_ == 'Graphemes':
obj_ = GraphemesType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Graphemes = obj_
obj_.original_tagname_ = 'Graphemes'
elif nodeName_ == 'TextEquiv':
obj_ = TextEquivType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextEquiv.append(obj_)
obj_.original_tagname_ = 'TextEquiv'
elif nodeName_ == 'TextStyle':
obj_ = TextStyleType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextStyle = obj_
obj_.original_tagname_ = 'TextStyle'
elif nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
- def __hash__(self):
- return hash(self.id)
# end class GlyphType
class TextEquivType(GeneratedsSuper):
- """Used for sort order in case multiple TextEquivs are defined.
- The text content with the lowest index should be interpreted
- as the main text content.
- OCR confidence value (between 0 and 1)
- Type of text content (is it free text or a number, for instance).
- This is only a descriptive attribute, the text type
- is not checked during XML validation.
- Refinement for dataType attribute. Can be a regular expression, for
- instance."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('index', 'integer', 0, 1, {'use': 'optional'}),
- MemberSpec_('conf', 'pc:ConfSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('dataType', 'pc:TextDataTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('dataTypeDetails', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('PlainText', 'string', 0, 1, {'minOccurs': '0', 'name': 'PlainText', 'type': 'string'}, None),
- MemberSpec_('Unicode', 'string', 0, 0, {'name': 'Unicode', 'type': 'string'}, None),
- ]
+ """Used for sort order in case multiple TextEquivs are defined. The
+ text content with the lowest index should be interpreted as the
+ main text content. OCR confidence value (between 0 and 1) Type
+ of text content (is it free text or a number, for instance).
+ This is only a descriptive attribute, the text type is not
+ checked during XML validation. Refinement for dataType
+ attribute. Can be a regular expression, for instance."""
subclass = None
superclass = None
- def __init__(self, index=None, conf=None, dataType=None, dataTypeDetails=None, comments=None, PlainText=None, Unicode=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, index=None, conf=None, dataType=None, dataTypeDetails=None, comments=None, PlainText=None, Unicode=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.index = _cast(int, index)
- self.index_nsprefix_ = None
self.conf = _cast(float, conf)
- self.conf_nsprefix_ = None
self.dataType = _cast(None, dataType)
- self.dataType_nsprefix_ = None
self.dataTypeDetails = _cast(None, dataTypeDetails)
- self.dataTypeDetails_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
self.PlainText = PlainText
- self.PlainText_nsprefix_ = None
self.Unicode = Unicode
- self.Unicode_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -4254,10 +3338,6 @@ def factory(*args_, **kwargs_):
else:
return TextEquivType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_PlainText(self):
return self.PlainText
def set_PlainText(self, PlainText):
@@ -4286,34 +3366,6 @@ def get_comments(self):
return self.comments
def set_comments(self, comments):
self.comments = comments
- def validate_ConfSimpleType(self, value):
- # Validate type pc:ConfSimpleType, a restriction on float.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, float):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (float)' % {"value": value, "lineno": lineno, })
- return False
- if value < 0:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd minInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
- if value > 1:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd maxInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
- def validate_TextDataTypeSimpleType(self, value):
- # Validate type pc:TextDataTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['xsd:decimal', 'xsd:float', 'xsd:integer', 'xsd:boolean', 'xsd:date', 'xsd:time', 'xsd:dateTime', 'xsd:string', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on TextDataTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.PlainText is not None or
@@ -4322,7 +3374,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15" xmlns:None="http://www.w3.org/2001/XMLSchema" ', name_='TextEquivType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextEquivType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('TextEquivType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -4332,8 +3384,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -4345,62 +3395,56 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='TextEquivType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='TextEquivType'):
if self.index is not None and 'index' not in already_processed:
already_processed.add('index')
outfile.write(' index="%s"' % self.gds_format_integer(self.index, input_name='index'))
if self.conf is not None and 'conf' not in already_processed:
already_processed.add('conf')
- outfile.write(' conf="%s"' % self.gds_format_float(self.conf, input_name='conf'))
+ outfile.write(' conf=%s' % (quote_attrib(self.conf), ))
if self.dataType is not None and 'dataType' not in already_processed:
already_processed.add('dataType')
- outfile.write(' dataType=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.dataType), input_name='dataType')), ))
+ outfile.write(' dataType=%s' % (quote_attrib(self.dataType), ))
if self.dataTypeDetails is not None and 'dataTypeDetails' not in already_processed:
already_processed.add('dataTypeDetails')
outfile.write(' dataTypeDetails=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.dataTypeDetails), input_name='dataTypeDetails')), ))
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15" xmlns:None="http://www.w3.org/2001/XMLSchema" ', name_='TextEquivType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextEquivType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.PlainText is not None:
- namespaceprefix_ = self.PlainText_nsprefix_ + ':' if (UseCapturedNS_ and self.PlainText_nsprefix_) else ''
showIndent(outfile, level, pretty_print)
outfile.write('<%sPlainText>%s%sPlainText>%s' % (namespaceprefix_ , self.gds_encode(self.gds_format_string(quote_xml(self.PlainText), input_name='PlainText')), namespaceprefix_ , eol_))
if self.Unicode is not None:
- namespaceprefix_ = self.Unicode_nsprefix_ + ':' if (UseCapturedNS_ and self.Unicode_nsprefix_) else ''
showIndent(outfile, level, pretty_print)
outfile.write('<%sUnicode>%s%sUnicode>%s' % (namespaceprefix_ , self.gds_encode(self.gds_format_string(quote_xml(self.Unicode), input_name='Unicode')), namespaceprefix_ , eol_))
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('index', node)
if value is not None and 'index' not in already_processed:
already_processed.add('index')
- self.index = self.gds_parse_integer(value, node, 'index')
+ try:
+ self.index = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('conf', node)
if value is not None and 'conf' not in already_processed:
already_processed.add('conf')
- value = self.gds_parse_float(value, node, 'conf')
self.conf = value
- self.validate_ConfSimpleType(self.conf) # validate type ConfSimpleType
value = find_attr_value_('dataType', node)
if value is not None and 'dataType' not in already_processed:
already_processed.add('dataType')
self.dataType = value
- self.validate_TextDataTypeSimpleType(self.dataType) # validate type TextDataTypeSimpleType
value = find_attr_value_('dataTypeDetails', node)
if value is not None and 'dataTypeDetails' not in already_processed:
already_processed.add('dataTypeDetails')
@@ -4409,43 +3453,29 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'PlainText':
- value_ = child_.text
- value_ = self.gds_parse_string(value_, node, 'PlainText')
- value_ = self.gds_validate_string(value_, node, 'PlainText')
- self.PlainText = value_
- self.PlainText_nsprefix_ = child_.prefix
+ PlainText_ = child_.text
+ PlainText_ = self.gds_validate_string(PlainText_, node, 'PlainText')
+ self.PlainText = PlainText_
elif nodeName_ == 'Unicode':
- value_ = child_.text
- value_ = self.gds_parse_string(value_, node, 'Unicode')
- value_ = self.gds_validate_string(value_, node, 'Unicode')
- self.Unicode = value_
- self.Unicode_nsprefix_ = child_.prefix
- def __hash__(self):
- return hash(self.id)
+ Unicode_ = child_.text
+ Unicode_ = self.gds_validate_string(Unicode_, node, 'Unicode')
+ self.Unicode = Unicode_
# end class TextEquivType
class GridType(GeneratedsSuper):
"""Matrix of grid points defining the table grid on the page."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('GridPoints', 'GridPointsType', 1, 0, {'maxOccurs': 'unbounded', 'minOccurs': '2', 'name': 'GridPoints', 'type': 'GridPointsType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, GridPoints=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, GridPoints=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
if GridPoints is None:
self.GridPoints = []
else:
self.GridPoints = GridPoints
- self.GridPoints_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -4457,16 +3487,14 @@ def factory(*args_, **kwargs_):
else:
return GridType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_GridPoints(self):
return self.GridPoints
def set_GridPoints(self, GridPoints):
self.GridPoints = GridPoints
def add_GridPoints(self, value):
self.GridPoints.append(value)
+ def add_GridPoints(self, value):
+ self.GridPoints.append(value)
def insert_GridPoints_at(self, index, value):
self.GridPoints.insert(index, value)
def replace_GridPoints_at(self, index, value):
@@ -4478,7 +3506,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GridType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GridType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('GridType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -4488,8 +3516,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -4501,60 +3527,42 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='GridType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='GridType'):
pass
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GridType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GridType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for GridPoints_ in self.GridPoints:
- namespaceprefix_ = self.GridPoints_nsprefix_ + ':' if (UseCapturedNS_ and self.GridPoints_nsprefix_) else ''
GridPoints_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='GridPoints', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
pass
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'GridPoints':
obj_ = GridPointsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.GridPoints.append(obj_)
obj_.original_tagname_ = 'GridPoints'
- def __hash__(self):
- return hash(self.id)
# end class GridType
class GridPointsType(GeneratedsSuper):
- """Points with x,y coordinates.
- The grid row index"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('index', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('points', 'pc:PointsType', 0, 0, {'use': 'required'}),
- ]
+ """Points with x,y coordinates. The grid row index"""
subclass = None
superclass = None
- def __init__(self, index=None, points=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, index=None, points=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.index = _cast(int, index)
- self.index_nsprefix_ = None
self.points = _cast(None, points)
- self.points_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -4566,10 +3574,6 @@ def factory(*args_, **kwargs_):
else:
return GridPointsType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_index(self):
return self.index
def set_index(self, index):
@@ -4578,17 +3582,6 @@ def get_points(self):
return self.points
def set_points(self, points):
self.points = points
- def validate_PointsType(self, value):
- # Validate type pc:PointsType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- if not self.gds_validate_simple_patterns(
- self.validate_PointsType_patterns_, value):
- self.gds_collector_.add_message('Value "%s" does not match xsd pattern restrictions: %s' % (encode_str_2_3(value), self.validate_PointsType_patterns_, ))
- validate_PointsType_patterns_ = [['^(([0-9]+,[0-9]+ )+([0-9]+,[0-9]+))$']]
def hasContent_(self):
if (
@@ -4596,7 +3589,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GridPointsType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GridPointsType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('GridPointsType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -4606,8 +3599,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -4618,65 +3609,52 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='GridPointsType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='GridPointsType'):
if self.index is not None and 'index' not in already_processed:
already_processed.add('index')
outfile.write(' index="%s"' % self.gds_format_integer(self.index, input_name='index'))
if self.points is not None and 'points' not in already_processed:
already_processed.add('points')
- outfile.write(' points=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.points), input_name='points')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GridPointsType', fromsubclass_=False, pretty_print=True):
+ outfile.write(' points=%s' % (quote_attrib(self.points), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GridPointsType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('index', node)
if value is not None and 'index' not in already_processed:
already_processed.add('index')
- self.index = self.gds_parse_integer(value, node, 'index')
+ try:
+ self.index = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('points', node)
if value is not None and 'points' not in already_processed:
already_processed.add('points')
self.points = value
- self.validate_PointsType(self.points) # validate type PointsType
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class GridPointsType
class PrintSpaceType(GeneratedsSuper):
- """Determines the effective area on the paper of a printed page.
- Its size is equal for all pages of a book
- (exceptions: titlepage, multipage pictures).
- It contains all living elements (except marginals)
- like body type, footnotes, headings, running titles.
+ """Determines the effective area on the paper of a printed page. Its
+ size is equal for all pages of a book (exceptions: titlepage,
+ multipage pictures). It contains all living elements (except
+ marginals) like body type, footnotes, headings, running titles.
It does not contain pagenumber (if not part of running title),
marginals, signature mark, preview words."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('Coords', 'CoordsType', 0, 0, {'name': 'Coords', 'type': 'CoordsType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, Coords=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, Coords=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.Coords = Coords
- self.Coords_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -4688,10 +3666,6 @@ def factory(*args_, **kwargs_):
else:
return PrintSpaceType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Coords(self):
return self.Coords
def set_Coords(self, Coords):
@@ -4703,7 +3677,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PrintSpaceType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PrintSpaceType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('PrintSpaceType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -4713,8 +3687,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -4726,66 +3698,46 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='PrintSpaceType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='PrintSpaceType'):
pass
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PrintSpaceType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='PrintSpaceType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.Coords is not None:
- namespaceprefix_ = self.Coords_nsprefix_ + ':' if (UseCapturedNS_ and self.Coords_nsprefix_) else ''
self.Coords.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Coords', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
pass
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Coords':
obj_ = CoordsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Coords = obj_
obj_.original_tagname_ = 'Coords'
- def __hash__(self):
- return hash(self.id)
# end class PrintSpaceType
class ReadingOrderType(GeneratedsSuper):
- """Definition of the reading order within the page.
- To express a reading order between elements
- they have to be included in an OrderedGroup.
- Groups may contain further groups.
- Confidence value (between 0 and 1)"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('conf', 'pc:ConfSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('OrderedGroup', 'OrderedGroupType', 0, 0, {'name': 'OrderedGroup', 'type': 'OrderedGroupType'}, 2),
- MemberSpec_('UnorderedGroup', 'UnorderedGroupType', 0, 0, {'name': 'UnorderedGroup', 'type': 'UnorderedGroupType'}, 2),
- ]
+ """Definition of the reading order within the page. To express a
+ reading order between elements they have to be included in an
+ OrderedGroup. Groups may contain further groups. Confidence
+ value (between 0 and 1)"""
subclass = None
superclass = None
- def __init__(self, conf=None, OrderedGroup=None, UnorderedGroup=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, conf=None, OrderedGroup=None, UnorderedGroup=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.conf = _cast(float, conf)
- self.conf_nsprefix_ = None
self.OrderedGroup = OrderedGroup
- self.OrderedGroup_nsprefix_ = None
self.UnorderedGroup = UnorderedGroup
- self.UnorderedGroup_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -4797,10 +3749,6 @@ def factory(*args_, **kwargs_):
else:
return ReadingOrderType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_OrderedGroup(self):
return self.OrderedGroup
def set_OrderedGroup(self, OrderedGroup):
@@ -4813,21 +3761,6 @@ def get_conf(self):
return self.conf
def set_conf(self, conf):
self.conf = conf
- def validate_ConfSimpleType(self, value):
- # Validate type pc:ConfSimpleType, a restriction on float.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, float):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (float)' % {"value": value, "lineno": lineno, })
- return False
- if value < 0:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd minInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
- if value > 1:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd maxInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.OrderedGroup is not None or
@@ -4836,7 +3769,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='ReadingOrderType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='ReadingOrderType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('ReadingOrderType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -4846,8 +3779,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -4859,75 +3790,55 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='ReadingOrderType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='ReadingOrderType'):
if self.conf is not None and 'conf' not in already_processed:
already_processed.add('conf')
- outfile.write(' conf="%s"' % self.gds_format_float(self.conf, input_name='conf'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='ReadingOrderType', fromsubclass_=False, pretty_print=True):
+ outfile.write(' conf=%s' % (quote_attrib(self.conf), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='ReadingOrderType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.OrderedGroup is not None:
- namespaceprefix_ = self.OrderedGroup_nsprefix_ + ':' if (UseCapturedNS_ and self.OrderedGroup_nsprefix_) else ''
self.OrderedGroup.export(outfile, level, namespaceprefix_, namespacedef_='', name_='OrderedGroup', pretty_print=pretty_print)
if self.UnorderedGroup is not None:
- namespaceprefix_ = self.UnorderedGroup_nsprefix_ + ':' if (UseCapturedNS_ and self.UnorderedGroup_nsprefix_) else ''
self.UnorderedGroup.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UnorderedGroup', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('conf', node)
if value is not None and 'conf' not in already_processed:
already_processed.add('conf')
- value = self.gds_parse_float(value, node, 'conf')
self.conf = value
- self.validate_ConfSimpleType(self.conf) # validate type ConfSimpleType
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'OrderedGroup':
obj_ = OrderedGroupType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.OrderedGroup = obj_
obj_.original_tagname_ = 'OrderedGroup'
elif nodeName_ == 'UnorderedGroup':
obj_ = UnorderedGroupType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UnorderedGroup = obj_
obj_.original_tagname_ = 'UnorderedGroup'
- def __hash__(self):
- return hash(self.id)
# end class ReadingOrderType
class RegionRefIndexedType(GeneratedsSuper):
- """Numbered regionPosition (order number) of this item within the current
- hierarchy level."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('index', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('regionRef', 'string', 0, 0, {'use': 'required'}),
- ]
+ """Numbered regionPosition (order number) of this item within the
+ current hierarchy level."""
subclass = None
superclass = None
- def __init__(self, index=None, regionRef=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, index=None, regionRef=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.index = _cast(int, index)
- self.index_nsprefix_ = None
self.regionRef = _cast(None, regionRef)
- self.regionRef_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -4939,10 +3850,6 @@ def factory(*args_, **kwargs_):
else:
return RegionRefIndexedType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_index(self):
return self.index
def set_index(self, index):
@@ -4958,7 +3865,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionRefIndexedType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionRefIndexedType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('RegionRefIndexedType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -4968,8 +3875,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -4980,114 +3885,76 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='RegionRefIndexedType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='RegionRefIndexedType'):
if self.index is not None and 'index' not in already_processed:
already_processed.add('index')
outfile.write(' index="%s"' % self.gds_format_integer(self.index, input_name='index'))
if self.regionRef is not None and 'regionRef' not in already_processed:
already_processed.add('regionRef')
outfile.write(' regionRef=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.regionRef), input_name='regionRef')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionRefIndexedType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionRefIndexedType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('index', node)
if value is not None and 'index' not in already_processed:
already_processed.add('index')
- self.index = self.gds_parse_integer(value, node, 'index')
+ try:
+ self.index = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('regionRef', node)
if value is not None and 'regionRef' not in already_processed:
already_processed.add('regionRef')
self.regionRef = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class RegionRefIndexedType
class OrderedGroupIndexedType(GeneratedsSuper):
- """Indexed group containing ordered elements
- Optional link to a parent region of nested regions.
- The parent region doubles as reading order group.
- Only the nested regions should be allowed as group members.
- Position (order number) of this item within the
- current hierarchy level.
- Is this group a continuation of another group (from
- previous column or page, for example)?
- For generic use"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('regionRef', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('index', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('caption', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'pc:GroupTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('continuation', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- MemberSpec_('RegionRefIndexed', 'RegionRefIndexedType', 1, 0, {'name': 'RegionRefIndexed', 'type': 'RegionRefIndexedType'}, 3),
- MemberSpec_('OrderedGroupIndexed', 'OrderedGroupIndexedType', 1, 0, {'name': 'OrderedGroupIndexed', 'type': 'OrderedGroupIndexedType'}, 3),
- MemberSpec_('UnorderedGroupIndexed', 'UnorderedGroupIndexedType', 1, 0, {'name': 'UnorderedGroupIndexed', 'type': 'UnorderedGroupIndexedType'}, 3),
- ]
+ """Indexed group containing ordered elements Optional link to a parent
+ region of nested regions. The parent region doubles as reading
+ order group. Only the nested regions should be allowed as group
+ members. Position (order number) of this item within the current
+ hierarchy level. Is this group a continuation of another group
+ (from previous column or page, for example)? For generic use"""
subclass = None
superclass = None
- def __init__(self, id=None, regionRef=None, index=None, caption=None, type_=None, continuation=None, custom=None, comments=None, UserDefined=None, Labels=None, RegionRefIndexed=None, OrderedGroupIndexed=None, UnorderedGroupIndexed=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, regionRef=None, index=None, caption=None, type_=None, continuation=None, custom=None, comments=None, UserDefined=None, Labels=None, RegionRefIndexed=None, OrderedGroupIndexed=None, UnorderedGroupIndexed=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.regionRef = _cast(None, regionRef)
- self.regionRef_nsprefix_ = None
self.index = _cast(int, index)
- self.index_nsprefix_ = None
self.caption = _cast(None, caption)
- self.caption_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.continuation = _cast(bool, continuation)
- self.continuation_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
if RegionRefIndexed is None:
self.RegionRefIndexed = []
else:
self.RegionRefIndexed = RegionRefIndexed
- self.RegionRefIndexed_nsprefix_ = None
if OrderedGroupIndexed is None:
self.OrderedGroupIndexed = []
else:
self.OrderedGroupIndexed = OrderedGroupIndexed
- self.OrderedGroupIndexed_nsprefix_ = None
if UnorderedGroupIndexed is None:
self.UnorderedGroupIndexed = []
else:
self.UnorderedGroupIndexed = UnorderedGroupIndexed
- self.UnorderedGroupIndexed_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -5099,10 +3966,6 @@ def factory(*args_, **kwargs_):
else:
return OrderedGroupIndexedType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_UserDefined(self):
return self.UserDefined
def set_UserDefined(self, UserDefined):
@@ -5113,6 +3976,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -5123,6 +3988,8 @@ def set_RegionRefIndexed(self, RegionRefIndexed):
self.RegionRefIndexed = RegionRefIndexed
def add_RegionRefIndexed(self, value):
self.RegionRefIndexed.append(value)
+ def add_RegionRefIndexed(self, value):
+ self.RegionRefIndexed.append(value)
def insert_RegionRefIndexed_at(self, index, value):
self.RegionRefIndexed.insert(index, value)
def replace_RegionRefIndexed_at(self, index, value):
@@ -5133,6 +4000,8 @@ def set_OrderedGroupIndexed(self, OrderedGroupIndexed):
self.OrderedGroupIndexed = OrderedGroupIndexed
def add_OrderedGroupIndexed(self, value):
self.OrderedGroupIndexed.append(value)
+ def add_OrderedGroupIndexed(self, value):
+ self.OrderedGroupIndexed.append(value)
def insert_OrderedGroupIndexed_at(self, index, value):
self.OrderedGroupIndexed.insert(index, value)
def replace_OrderedGroupIndexed_at(self, index, value):
@@ -5143,6 +4012,8 @@ def set_UnorderedGroupIndexed(self, UnorderedGroupIndexed):
self.UnorderedGroupIndexed = UnorderedGroupIndexed
def add_UnorderedGroupIndexed(self, value):
self.UnorderedGroupIndexed.append(value)
+ def add_UnorderedGroupIndexed(self, value):
+ self.UnorderedGroupIndexed.append(value)
def insert_UnorderedGroupIndexed_at(self, index, value):
self.UnorderedGroupIndexed.insert(index, value)
def replace_UnorderedGroupIndexed_at(self, index, value):
@@ -5179,19 +4050,6 @@ def get_comments(self):
return self.comments
def set_comments(self, comments):
self.comments = comments
- def validate_GroupTypeSimpleType(self, value):
- # Validate type pc:GroupTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['paragraph', 'list', 'list-item', 'figure', 'article', 'div', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on GroupTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.UserDefined is not None or
@@ -5203,7 +4061,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='OrderedGroupIndexedType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='OrderedGroupIndexedType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('OrderedGroupIndexedType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -5213,8 +4071,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -5226,7 +4082,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='OrderedGroupIndexedType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='OrderedGroupIndexedType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -5241,7 +4097,7 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' caption=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.caption), input_name='caption')), ))
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
- outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
+ outfile.write(' type=%s' % (quote_attrib(self.type_), ))
if self.continuation is not None and 'continuation' not in already_processed:
already_processed.add('continuation')
outfile.write(' continuation="%s"' % self.gds_format_boolean(self.continuation, input_name='continuation'))
@@ -5251,36 +4107,27 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='OrderedGroupIndexedType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='OrderedGroupIndexedType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
for RegionRefIndexed_ in self.RegionRefIndexed:
- namespaceprefix_ = self.RegionRefIndexed_nsprefix_ + ':' if (UseCapturedNS_ and self.RegionRefIndexed_nsprefix_) else ''
RegionRefIndexed_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='RegionRefIndexed', pretty_print=pretty_print)
for OrderedGroupIndexed_ in self.OrderedGroupIndexed:
- namespaceprefix_ = self.OrderedGroupIndexed_nsprefix_ + ':' if (UseCapturedNS_ and self.OrderedGroupIndexed_nsprefix_) else ''
OrderedGroupIndexed_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='OrderedGroupIndexed', pretty_print=pretty_print)
for UnorderedGroupIndexed_ in self.UnorderedGroupIndexed:
- namespaceprefix_ = self.UnorderedGroupIndexed_nsprefix_ + ':' if (UseCapturedNS_ and self.UnorderedGroupIndexed_nsprefix_) else ''
UnorderedGroupIndexed_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UnorderedGroupIndexed', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -5294,7 +4141,10 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('index', node)
if value is not None and 'index' not in already_processed:
already_processed.add('index')
- self.index = self.gds_parse_integer(value, node, 'index')
+ try:
+ self.index = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('caption', node)
if value is not None and 'caption' not in already_processed:
already_processed.add('caption')
@@ -5303,7 +4153,6 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'type' not in already_processed:
already_processed.add('type')
self.type_ = value
- self.validate_GroupTypeSimpleType(self.type_) # validate type GroupTypeSimpleType
value = find_attr_value_('continuation', node)
if value is not None and 'continuation' not in already_processed:
already_processed.add('continuation')
@@ -5321,109 +4170,73 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
elif nodeName_ == 'RegionRefIndexed':
obj_ = RegionRefIndexedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.RegionRefIndexed.append(obj_)
obj_.original_tagname_ = 'RegionRefIndexed'
elif nodeName_ == 'OrderedGroupIndexed':
obj_ = OrderedGroupIndexedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.OrderedGroupIndexed.append(obj_)
obj_.original_tagname_ = 'OrderedGroupIndexed'
elif nodeName_ == 'UnorderedGroupIndexed':
obj_ = UnorderedGroupIndexedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UnorderedGroupIndexed.append(obj_)
obj_.original_tagname_ = 'UnorderedGroupIndexed'
- def __hash__(self):
- return hash(self.id)
# end class OrderedGroupIndexedType
class UnorderedGroupIndexedType(GeneratedsSuper):
- """Indexed group containing unordered elements
- Optional link to a parent region of nested regions.
- The parent region doubles as reading order group.
- Only the nested regions should be allowed as group members.
- Position (order number) of this item within the
- current hierarchy level.
- Is this group a continuation of another group
- (from previous column or page, for example)?
- For generic use"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('regionRef', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('index', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('caption', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'pc:GroupTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('continuation', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- MemberSpec_('RegionRef', 'RegionRefType', 1, 0, {'name': 'RegionRef', 'type': 'RegionRefType'}, 4),
- MemberSpec_('OrderedGroup', 'OrderedGroupType', 1, 0, {'name': 'OrderedGroup', 'type': 'OrderedGroupType'}, 4),
- MemberSpec_('UnorderedGroup', 'UnorderedGroupType', 1, 0, {'name': 'UnorderedGroup', 'type': 'UnorderedGroupType'}, 4),
- ]
+ """Indexed group containing unordered elements Optional link to a
+ parent region of nested regions. The parent region doubles as
+ reading order group. Only the nested regions should be allowed
+ as group members. Position (order number) of this item within
+ the current hierarchy level. Is this group a continuation of
+ another group (from previous column or page, for example)? For
+ generic use"""
subclass = None
superclass = None
- def __init__(self, id=None, regionRef=None, index=None, caption=None, type_=None, continuation=None, custom=None, comments=None, UserDefined=None, Labels=None, RegionRef=None, OrderedGroup=None, UnorderedGroup=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, regionRef=None, index=None, caption=None, type_=None, continuation=None, custom=None, comments=None, UserDefined=None, Labels=None, RegionRef=None, OrderedGroup=None, UnorderedGroup=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.regionRef = _cast(None, regionRef)
- self.regionRef_nsprefix_ = None
self.index = _cast(int, index)
- self.index_nsprefix_ = None
self.caption = _cast(None, caption)
- self.caption_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.continuation = _cast(bool, continuation)
- self.continuation_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
if RegionRef is None:
self.RegionRef = []
else:
self.RegionRef = RegionRef
- self.RegionRef_nsprefix_ = None
if OrderedGroup is None:
self.OrderedGroup = []
else:
self.OrderedGroup = OrderedGroup
- self.OrderedGroup_nsprefix_ = None
if UnorderedGroup is None:
self.UnorderedGroup = []
else:
self.UnorderedGroup = UnorderedGroup
- self.UnorderedGroup_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -5435,10 +4248,6 @@ def factory(*args_, **kwargs_):
else:
return UnorderedGroupIndexedType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_UserDefined(self):
return self.UserDefined
def set_UserDefined(self, UserDefined):
@@ -5449,6 +4258,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -5459,6 +4270,8 @@ def set_RegionRef(self, RegionRef):
self.RegionRef = RegionRef
def add_RegionRef(self, value):
self.RegionRef.append(value)
+ def add_RegionRef(self, value):
+ self.RegionRef.append(value)
def insert_RegionRef_at(self, index, value):
self.RegionRef.insert(index, value)
def replace_RegionRef_at(self, index, value):
@@ -5469,6 +4282,8 @@ def set_OrderedGroup(self, OrderedGroup):
self.OrderedGroup = OrderedGroup
def add_OrderedGroup(self, value):
self.OrderedGroup.append(value)
+ def add_OrderedGroup(self, value):
+ self.OrderedGroup.append(value)
def insert_OrderedGroup_at(self, index, value):
self.OrderedGroup.insert(index, value)
def replace_OrderedGroup_at(self, index, value):
@@ -5479,6 +4294,8 @@ def set_UnorderedGroup(self, UnorderedGroup):
self.UnorderedGroup = UnorderedGroup
def add_UnorderedGroup(self, value):
self.UnorderedGroup.append(value)
+ def add_UnorderedGroup(self, value):
+ self.UnorderedGroup.append(value)
def insert_UnorderedGroup_at(self, index, value):
self.UnorderedGroup.insert(index, value)
def replace_UnorderedGroup_at(self, index, value):
@@ -5515,19 +4332,6 @@ def get_comments(self):
return self.comments
def set_comments(self, comments):
self.comments = comments
- def validate_GroupTypeSimpleType(self, value):
- # Validate type pc:GroupTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['paragraph', 'list', 'list-item', 'figure', 'article', 'div', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on GroupTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.UserDefined is not None or
@@ -5539,7 +4343,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UnorderedGroupIndexedType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UnorderedGroupIndexedType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('UnorderedGroupIndexedType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -5549,8 +4353,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -5562,7 +4364,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='UnorderedGroupIndexedType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='UnorderedGroupIndexedType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -5577,7 +4379,7 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' caption=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.caption), input_name='caption')), ))
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
- outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
+ outfile.write(' type=%s' % (quote_attrib(self.type_), ))
if self.continuation is not None and 'continuation' not in already_processed:
already_processed.add('continuation')
outfile.write(' continuation="%s"' % self.gds_format_boolean(self.continuation, input_name='continuation'))
@@ -5587,36 +4389,27 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UnorderedGroupIndexedType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UnorderedGroupIndexedType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
for RegionRef_ in self.RegionRef:
- namespaceprefix_ = self.RegionRef_nsprefix_ + ':' if (UseCapturedNS_ and self.RegionRef_nsprefix_) else ''
RegionRef_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='RegionRef', pretty_print=pretty_print)
for OrderedGroup_ in self.OrderedGroup:
- namespaceprefix_ = self.OrderedGroup_nsprefix_ + ':' if (UseCapturedNS_ and self.OrderedGroup_nsprefix_) else ''
OrderedGroup_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='OrderedGroup', pretty_print=pretty_print)
for UnorderedGroup_ in self.UnorderedGroup:
- namespaceprefix_ = self.UnorderedGroup_nsprefix_ + ':' if (UseCapturedNS_ and self.UnorderedGroup_nsprefix_) else ''
UnorderedGroup_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UnorderedGroup', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -5630,7 +4423,10 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('index', node)
if value is not None and 'index' not in already_processed:
already_processed.add('index')
- self.index = self.gds_parse_integer(value, node, 'index')
+ try:
+ self.index = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('caption', node)
if value is not None and 'caption' not in already_processed:
already_processed.add('caption')
@@ -5639,7 +4435,6 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'type' not in already_processed:
already_processed.add('type')
self.type_ = value
- self.validate_GroupTypeSimpleType(self.type_) # validate type GroupTypeSimpleType
value = find_attr_value_('continuation', node)
if value is not None and 'continuation' not in already_processed:
already_processed.add('continuation')
@@ -5657,52 +4452,42 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
elif nodeName_ == 'RegionRef':
obj_ = RegionRefType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.RegionRef.append(obj_)
obj_.original_tagname_ = 'RegionRef'
elif nodeName_ == 'OrderedGroup':
obj_ = OrderedGroupType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.OrderedGroup.append(obj_)
obj_.original_tagname_ = 'OrderedGroup'
elif nodeName_ == 'UnorderedGroup':
obj_ = UnorderedGroupType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UnorderedGroup.append(obj_)
obj_.original_tagname_ = 'UnorderedGroup'
- def __hash__(self):
- return hash(self.id)
# end class UnorderedGroupIndexedType
class RegionRefType(GeneratedsSuper):
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('regionRef', 'string', 0, 0, {'use': 'required'}),
- ]
subclass = None
superclass = None
- def __init__(self, regionRef=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, regionRef=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.regionRef = _cast(None, regionRef)
- self.regionRef_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -5714,10 +4499,6 @@ def factory(*args_, **kwargs_):
else:
return RegionRefType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_regionRef(self):
return self.regionRef
def set_regionRef(self, regionRef):
@@ -5729,7 +4510,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionRefType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionRefType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('RegionRefType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -5739,8 +4520,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -5751,102 +4530,64 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='RegionRefType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='RegionRefType'):
if self.regionRef is not None and 'regionRef' not in already_processed:
already_processed.add('regionRef')
outfile.write(' regionRef=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.regionRef), input_name='regionRef')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionRefType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionRefType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('regionRef', node)
if value is not None and 'regionRef' not in already_processed:
already_processed.add('regionRef')
self.regionRef = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class RegionRefType
class OrderedGroupType(GeneratedsSuper):
- """Numbered group (contains ordered elements)
- Optional link to a parent region of nested regions.
- The parent region doubles as reading order group.
- Only the nested regions should be allowed as group members.
- Is this group a continuation of another group
- (from previous column or page, for example)?
- For generic use"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('regionRef', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('caption', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'pc:GroupTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('continuation', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- MemberSpec_('RegionRefIndexed', 'RegionRefIndexedType', 1, 0, {'name': 'RegionRefIndexed', 'type': 'RegionRefIndexedType'}, 5),
- MemberSpec_('OrderedGroupIndexed', 'OrderedGroupIndexedType', 1, 0, {'name': 'OrderedGroupIndexed', 'type': 'OrderedGroupIndexedType'}, 5),
- MemberSpec_('UnorderedGroupIndexed', 'UnorderedGroupIndexedType', 1, 0, {'name': 'UnorderedGroupIndexed', 'type': 'UnorderedGroupIndexedType'}, 5),
- ]
+ """Numbered group (contains ordered elements) Optional link to a parent
+ region of nested regions. The parent region doubles as reading
+ order group. Only the nested regions should be allowed as group
+ members. Is this group a continuation of another group (from
+ previous column or page, for example)? For generic use"""
subclass = None
superclass = None
- def __init__(self, id=None, regionRef=None, caption=None, type_=None, continuation=None, custom=None, comments=None, UserDefined=None, Labels=None, RegionRefIndexed=None, OrderedGroupIndexed=None, UnorderedGroupIndexed=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, regionRef=None, caption=None, type_=None, continuation=None, custom=None, comments=None, UserDefined=None, Labels=None, RegionRefIndexed=None, OrderedGroupIndexed=None, UnorderedGroupIndexed=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.regionRef = _cast(None, regionRef)
- self.regionRef_nsprefix_ = None
self.caption = _cast(None, caption)
- self.caption_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.continuation = _cast(bool, continuation)
- self.continuation_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
if RegionRefIndexed is None:
self.RegionRefIndexed = []
else:
self.RegionRefIndexed = RegionRefIndexed
- self.RegionRefIndexed_nsprefix_ = None
if OrderedGroupIndexed is None:
self.OrderedGroupIndexed = []
else:
self.OrderedGroupIndexed = OrderedGroupIndexed
- self.OrderedGroupIndexed_nsprefix_ = None
if UnorderedGroupIndexed is None:
self.UnorderedGroupIndexed = []
else:
self.UnorderedGroupIndexed = UnorderedGroupIndexed
- self.UnorderedGroupIndexed_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -5858,10 +4599,6 @@ def factory(*args_, **kwargs_):
else:
return OrderedGroupType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_UserDefined(self):
return self.UserDefined
def set_UserDefined(self, UserDefined):
@@ -5872,6 +4609,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -5882,6 +4621,8 @@ def set_RegionRefIndexed(self, RegionRefIndexed):
self.RegionRefIndexed = RegionRefIndexed
def add_RegionRefIndexed(self, value):
self.RegionRefIndexed.append(value)
+ def add_RegionRefIndexed(self, value):
+ self.RegionRefIndexed.append(value)
def insert_RegionRefIndexed_at(self, index, value):
self.RegionRefIndexed.insert(index, value)
def replace_RegionRefIndexed_at(self, index, value):
@@ -5892,6 +4633,8 @@ def set_OrderedGroupIndexed(self, OrderedGroupIndexed):
self.OrderedGroupIndexed = OrderedGroupIndexed
def add_OrderedGroupIndexed(self, value):
self.OrderedGroupIndexed.append(value)
+ def add_OrderedGroupIndexed(self, value):
+ self.OrderedGroupIndexed.append(value)
def insert_OrderedGroupIndexed_at(self, index, value):
self.OrderedGroupIndexed.insert(index, value)
def replace_OrderedGroupIndexed_at(self, index, value):
@@ -5902,6 +4645,8 @@ def set_UnorderedGroupIndexed(self, UnorderedGroupIndexed):
self.UnorderedGroupIndexed = UnorderedGroupIndexed
def add_UnorderedGroupIndexed(self, value):
self.UnorderedGroupIndexed.append(value)
+ def add_UnorderedGroupIndexed(self, value):
+ self.UnorderedGroupIndexed.append(value)
def insert_UnorderedGroupIndexed_at(self, index, value):
self.UnorderedGroupIndexed.insert(index, value)
def replace_UnorderedGroupIndexed_at(self, index, value):
@@ -5934,19 +4679,6 @@ def get_comments(self):
return self.comments
def set_comments(self, comments):
self.comments = comments
- def validate_GroupTypeSimpleType(self, value):
- # Validate type pc:GroupTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['paragraph', 'list', 'list-item', 'figure', 'article', 'div', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on GroupTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.UserDefined is not None or
@@ -5958,7 +4690,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='OrderedGroupType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='OrderedGroupType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('OrderedGroupType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -5968,8 +4700,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -5981,7 +4711,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='OrderedGroupType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='OrderedGroupType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -5993,7 +4723,7 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' caption=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.caption), input_name='caption')), ))
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
- outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
+ outfile.write(' type=%s' % (quote_attrib(self.type_), ))
if self.continuation is not None and 'continuation' not in already_processed:
already_processed.add('continuation')
outfile.write(' continuation="%s"' % self.gds_format_boolean(self.continuation, input_name='continuation'))
@@ -6003,36 +4733,27 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='OrderedGroupType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='OrderedGroupType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
for RegionRefIndexed_ in self.RegionRefIndexed:
- namespaceprefix_ = self.RegionRefIndexed_nsprefix_ + ':' if (UseCapturedNS_ and self.RegionRefIndexed_nsprefix_) else ''
RegionRefIndexed_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='RegionRefIndexed', pretty_print=pretty_print)
for OrderedGroupIndexed_ in self.OrderedGroupIndexed:
- namespaceprefix_ = self.OrderedGroupIndexed_nsprefix_ + ':' if (UseCapturedNS_ and self.OrderedGroupIndexed_nsprefix_) else ''
OrderedGroupIndexed_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='OrderedGroupIndexed', pretty_print=pretty_print)
for UnorderedGroupIndexed_ in self.UnorderedGroupIndexed:
- namespaceprefix_ = self.UnorderedGroupIndexed_nsprefix_ + ':' if (UseCapturedNS_ and self.UnorderedGroupIndexed_nsprefix_) else ''
UnorderedGroupIndexed_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UnorderedGroupIndexed', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -6051,7 +4772,6 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'type' not in already_processed:
already_processed.add('type')
self.type_ = value
- self.validate_GroupTypeSimpleType(self.type_) # validate type GroupTypeSimpleType
value = find_attr_value_('continuation', node)
if value is not None and 'continuation' not in already_processed:
already_processed.add('continuation')
@@ -6069,104 +4789,70 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
elif nodeName_ == 'RegionRefIndexed':
obj_ = RegionRefIndexedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.RegionRefIndexed.append(obj_)
obj_.original_tagname_ = 'RegionRefIndexed'
elif nodeName_ == 'OrderedGroupIndexed':
obj_ = OrderedGroupIndexedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.OrderedGroupIndexed.append(obj_)
obj_.original_tagname_ = 'OrderedGroupIndexed'
elif nodeName_ == 'UnorderedGroupIndexed':
obj_ = UnorderedGroupIndexedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UnorderedGroupIndexed.append(obj_)
obj_.original_tagname_ = 'UnorderedGroupIndexed'
- def __hash__(self):
- return hash(self.id)
# end class OrderedGroupType
class UnorderedGroupType(GeneratedsSuper):
- """Numbered group (contains unordered elements)
- Optional link to a parent region of nested regions.
- The parent region doubles as reading order group.
- Only the nested regions should be allowed as group members.
- Is this group a continuation of another group
- (from previous column or page, for example)?
- For generic use"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('regionRef', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('caption', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'pc:GroupTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('continuation', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- MemberSpec_('RegionRef', 'RegionRefType', 1, 0, {'name': 'RegionRef', 'type': 'RegionRefType'}, 6),
- MemberSpec_('OrderedGroup', 'OrderedGroupType', 1, 0, {'name': 'OrderedGroup', 'type': 'OrderedGroupType'}, 6),
- MemberSpec_('UnorderedGroup', 'UnorderedGroupType', 1, 0, {'name': 'UnorderedGroup', 'type': 'UnorderedGroupType'}, 6),
- ]
+ """Numbered group (contains unordered elements) Optional link to a
+ parent region of nested regions. The parent region doubles as
+ reading order group. Only the nested regions should be allowed
+ as group members. Is this group a continuation of another group
+ (from previous column or page, for example)? For generic use"""
subclass = None
superclass = None
- def __init__(self, id=None, regionRef=None, caption=None, type_=None, continuation=None, custom=None, comments=None, UserDefined=None, Labels=None, RegionRef=None, OrderedGroup=None, UnorderedGroup=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, regionRef=None, caption=None, type_=None, continuation=None, custom=None, comments=None, UserDefined=None, Labels=None, RegionRef=None, OrderedGroup=None, UnorderedGroup=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.regionRef = _cast(None, regionRef)
- self.regionRef_nsprefix_ = None
self.caption = _cast(None, caption)
- self.caption_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.continuation = _cast(bool, continuation)
- self.continuation_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
if RegionRef is None:
self.RegionRef = []
else:
self.RegionRef = RegionRef
- self.RegionRef_nsprefix_ = None
if OrderedGroup is None:
self.OrderedGroup = []
else:
self.OrderedGroup = OrderedGroup
- self.OrderedGroup_nsprefix_ = None
if UnorderedGroup is None:
self.UnorderedGroup = []
else:
self.UnorderedGroup = UnorderedGroup
- self.UnorderedGroup_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -6178,10 +4864,6 @@ def factory(*args_, **kwargs_):
else:
return UnorderedGroupType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_UserDefined(self):
return self.UserDefined
def set_UserDefined(self, UserDefined):
@@ -6192,6 +4874,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -6202,6 +4886,8 @@ def set_RegionRef(self, RegionRef):
self.RegionRef = RegionRef
def add_RegionRef(self, value):
self.RegionRef.append(value)
+ def add_RegionRef(self, value):
+ self.RegionRef.append(value)
def insert_RegionRef_at(self, index, value):
self.RegionRef.insert(index, value)
def replace_RegionRef_at(self, index, value):
@@ -6212,6 +4898,8 @@ def set_OrderedGroup(self, OrderedGroup):
self.OrderedGroup = OrderedGroup
def add_OrderedGroup(self, value):
self.OrderedGroup.append(value)
+ def add_OrderedGroup(self, value):
+ self.OrderedGroup.append(value)
def insert_OrderedGroup_at(self, index, value):
self.OrderedGroup.insert(index, value)
def replace_OrderedGroup_at(self, index, value):
@@ -6222,6 +4910,8 @@ def set_UnorderedGroup(self, UnorderedGroup):
self.UnorderedGroup = UnorderedGroup
def add_UnorderedGroup(self, value):
self.UnorderedGroup.append(value)
+ def add_UnorderedGroup(self, value):
+ self.UnorderedGroup.append(value)
def insert_UnorderedGroup_at(self, index, value):
self.UnorderedGroup.insert(index, value)
def replace_UnorderedGroup_at(self, index, value):
@@ -6254,19 +4944,6 @@ def get_comments(self):
return self.comments
def set_comments(self, comments):
self.comments = comments
- def validate_GroupTypeSimpleType(self, value):
- # Validate type pc:GroupTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['paragraph', 'list', 'list-item', 'figure', 'article', 'div', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on GroupTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.UserDefined is not None or
@@ -6278,7 +4955,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UnorderedGroupType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UnorderedGroupType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('UnorderedGroupType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -6288,8 +4965,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -6301,7 +4976,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='UnorderedGroupType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='UnorderedGroupType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -6313,7 +4988,7 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' caption=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.caption), input_name='caption')), ))
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
- outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
+ outfile.write(' type=%s' % (quote_attrib(self.type_), ))
if self.continuation is not None and 'continuation' not in already_processed:
already_processed.add('continuation')
outfile.write(' continuation="%s"' % self.gds_format_boolean(self.continuation, input_name='continuation'))
@@ -6323,36 +4998,27 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UnorderedGroupType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UnorderedGroupType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
for RegionRef_ in self.RegionRef:
- namespaceprefix_ = self.RegionRef_nsprefix_ + ':' if (UseCapturedNS_ and self.RegionRef_nsprefix_) else ''
RegionRef_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='RegionRef', pretty_print=pretty_print)
for OrderedGroup_ in self.OrderedGroup:
- namespaceprefix_ = self.OrderedGroup_nsprefix_ + ':' if (UseCapturedNS_ and self.OrderedGroup_nsprefix_) else ''
OrderedGroup_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='OrderedGroup', pretty_print=pretty_print)
for UnorderedGroup_ in self.UnorderedGroup:
- namespaceprefix_ = self.UnorderedGroup_nsprefix_ + ':' if (UseCapturedNS_ and self.UnorderedGroup_nsprefix_) else ''
UnorderedGroup_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UnorderedGroup', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -6371,7 +5037,6 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'type' not in already_processed:
already_processed.add('type')
self.type_ = value
- self.validate_GroupTypeSimpleType(self.type_) # validate type GroupTypeSimpleType
value = find_attr_value_('continuation', node)
if value is not None and 'continuation' not in already_processed:
already_processed.add('continuation')
@@ -6389,54 +5054,44 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
elif nodeName_ == 'RegionRef':
obj_ = RegionRefType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.RegionRef.append(obj_)
obj_.original_tagname_ = 'RegionRef'
elif nodeName_ == 'OrderedGroup':
obj_ = OrderedGroupType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.OrderedGroup.append(obj_)
obj_.original_tagname_ = 'OrderedGroup'
elif nodeName_ == 'UnorderedGroup':
obj_ = UnorderedGroupType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UnorderedGroup.append(obj_)
obj_.original_tagname_ = 'UnorderedGroup'
- def __hash__(self):
- return hash(self.id)
# end class UnorderedGroupType
class BorderType(GeneratedsSuper):
- """Border of the actual page (if the scanned image
- contains parts not belonging to the page)."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('Coords', 'CoordsType', 0, 0, {'name': 'Coords', 'type': 'CoordsType'}, None),
- ]
+ """Border of the actual page (if the scanned image contains parts not
+ belonging to the page)."""
subclass = None
superclass = None
- def __init__(self, Coords=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, Coords=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.Coords = Coords
- self.Coords_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -6448,10 +5103,6 @@ def factory(*args_, **kwargs_):
else:
return BorderType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Coords(self):
return self.Coords
def set_Coords(self, Coords):
@@ -6463,7 +5114,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='BorderType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='BorderType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('BorderType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -6473,8 +5124,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -6486,61 +5135,46 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='BorderType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='BorderType'):
pass
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='BorderType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='BorderType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.Coords is not None:
- namespaceprefix_ = self.Coords_nsprefix_ + ':' if (UseCapturedNS_ and self.Coords_nsprefix_) else ''
self.Coords.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Coords', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
pass
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Coords':
obj_ = CoordsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Coords = obj_
obj_.original_tagname_ = 'Coords'
- def __hash__(self):
- return hash(self.id)
# end class BorderType
class LayersType(GeneratedsSuper):
- """Can be used to express the z-index of overlapping
- regions. An element with a greater z-index is always in
- front of another element with lower z-index."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('Layer', 'LayerType', 1, 0, {'maxOccurs': 'unbounded', 'minOccurs': '1', 'name': 'Layer', 'type': 'LayerType'}, None),
- ]
+ """Can be used to express the z-index of overlapping regions. An
+ element with a greater z-index is always in front of another
+ element with lower z-index."""
subclass = None
superclass = None
- def __init__(self, Layer=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, Layer=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
if Layer is None:
self.Layer = []
else:
self.Layer = Layer
- self.Layer_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -6552,16 +5186,14 @@ def factory(*args_, **kwargs_):
else:
return LayersType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Layer(self):
return self.Layer
def set_Layer(self, Layer):
self.Layer = Layer
def add_Layer(self, value):
self.Layer.append(value)
+ def add_Layer(self, value):
+ self.Layer.append(value)
def insert_Layer_at(self, index, value):
self.Layer.insert(index, value)
def replace_Layer_at(self, index, value):
@@ -6573,7 +5205,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LayersType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LayersType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('LayersType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -6583,8 +5215,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -6596,67 +5226,46 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='LayersType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='LayersType'):
pass
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LayersType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LayersType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for Layer_ in self.Layer:
- namespaceprefix_ = self.Layer_nsprefix_ + ':' if (UseCapturedNS_ and self.Layer_nsprefix_) else ''
Layer_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Layer', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
pass
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Layer':
obj_ = LayerType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Layer.append(obj_)
obj_.original_tagname_ = 'Layer'
- def __hash__(self):
- return hash(self.id)
# end class LayersType
class LayerType(GeneratedsSuper):
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('zIndex', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('caption', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('RegionRef', 'RegionRefType', 1, 0, {'maxOccurs': 'unbounded', 'minOccurs': '1', 'name': 'RegionRef', 'type': 'RegionRefType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, id=None, zIndex=None, caption=None, RegionRef=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, zIndex=None, caption=None, RegionRef=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.zIndex = _cast(int, zIndex)
- self.zIndex_nsprefix_ = None
self.caption = _cast(None, caption)
- self.caption_nsprefix_ = None
if RegionRef is None:
self.RegionRef = []
else:
self.RegionRef = RegionRef
- self.RegionRef_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -6668,16 +5277,14 @@ def factory(*args_, **kwargs_):
else:
return LayerType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_RegionRef(self):
return self.RegionRef
def set_RegionRef(self, RegionRef):
self.RegionRef = RegionRef
def add_RegionRef(self, value):
self.RegionRef.append(value)
+ def add_RegionRef(self, value):
+ self.RegionRef.append(value)
def insert_RegionRef_at(self, index, value):
self.RegionRef.insert(index, value)
def replace_RegionRef_at(self, index, value):
@@ -6701,7 +5308,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LayerType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LayerType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('LayerType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -6711,8 +5318,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -6724,7 +5329,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='LayerType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='LayerType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -6734,24 +5339,19 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.caption is not None and 'caption' not in already_processed:
already_processed.add('caption')
outfile.write(' caption=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.caption), input_name='caption')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LayerType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='LayerType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for RegionRef_ in self.RegionRef:
- namespaceprefix_ = self.RegionRef_nsprefix_ + ':' if (UseCapturedNS_ and self.RegionRef_nsprefix_) else ''
RegionRef_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='RegionRef', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -6761,41 +5361,32 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('zIndex', node)
if value is not None and 'zIndex' not in already_processed:
already_processed.add('zIndex')
- self.zIndex = self.gds_parse_integer(value, node, 'zIndex')
+ try:
+ self.zIndex = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('caption', node)
if value is not None and 'caption' not in already_processed:
already_processed.add('caption')
self.caption = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'RegionRef':
obj_ = RegionRefType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.RegionRef.append(obj_)
obj_.original_tagname_ = 'RegionRef'
- def __hash__(self):
- return hash(self.id)
# end class LayerType
class BaselineType(GeneratedsSuper):
"""Confidence value (between 0 and 1)"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('points', 'pc:PointsType', 0, 0, {'use': 'required'}),
- MemberSpec_('conf', 'pc:ConfSimpleType', 0, 1, {'use': 'optional'}),
- ]
subclass = None
superclass = None
- def __init__(self, points=None, conf=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, points=None, conf=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.points = _cast(None, points)
- self.points_nsprefix_ = None
self.conf = _cast(float, conf)
- self.conf_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -6807,10 +5398,6 @@ def factory(*args_, **kwargs_):
else:
return BaselineType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_points(self):
return self.points
def set_points(self, points):
@@ -6819,32 +5406,6 @@ def get_conf(self):
return self.conf
def set_conf(self, conf):
self.conf = conf
- def validate_PointsType(self, value):
- # Validate type pc:PointsType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- if not self.gds_validate_simple_patterns(
- self.validate_PointsType_patterns_, value):
- self.gds_collector_.add_message('Value "%s" does not match xsd pattern restrictions: %s' % (encode_str_2_3(value), self.validate_PointsType_patterns_, ))
- validate_PointsType_patterns_ = [['^(([0-9]+,[0-9]+ )+([0-9]+,[0-9]+))$']]
- def validate_ConfSimpleType(self, value):
- # Validate type pc:ConfSimpleType, a restriction on float.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, float):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (float)' % {"value": value, "lineno": lineno, })
- return False
- if value < 0:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd minInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
- if value > 1:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd maxInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
def hasContent_(self):
if (
@@ -6852,7 +5413,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='BaselineType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='BaselineType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('BaselineType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -6862,8 +5423,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -6874,66 +5433,48 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='BaselineType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='BaselineType'):
if self.points is not None and 'points' not in already_processed:
already_processed.add('points')
- outfile.write(' points=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.points), input_name='points')), ))
+ outfile.write(' points=%s' % (quote_attrib(self.points), ))
if self.conf is not None and 'conf' not in already_processed:
already_processed.add('conf')
- outfile.write(' conf="%s"' % self.gds_format_float(self.conf, input_name='conf'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='BaselineType', fromsubclass_=False, pretty_print=True):
+ outfile.write(' conf=%s' % (quote_attrib(self.conf), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='BaselineType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('points', node)
if value is not None and 'points' not in already_processed:
already_processed.add('points')
self.points = value
- self.validate_PointsType(self.points) # validate type PointsType
value = find_attr_value_('conf', node)
if value is not None and 'conf' not in already_processed:
already_processed.add('conf')
- value = self.gds_parse_float(value, node, 'conf')
self.conf = value
- self.validate_ConfSimpleType(self.conf) # validate type ConfSimpleType
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class BaselineType
class RelationsType(GeneratedsSuper):
- """Container for one-to-one relations between layout
- objects (for example: DropCap - paragraph, caption -
- image)."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('Relation', 'RelationType', 1, 0, {'maxOccurs': 'unbounded', 'minOccurs': '1', 'name': 'Relation', 'type': 'RelationType'}, None),
- ]
+ """Container for one-to-one relations between layout objects (for
+ example: DropCap - paragraph, caption - image)."""
subclass = None
superclass = None
- def __init__(self, Relation=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, Relation=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
if Relation is None:
self.Relation = []
else:
self.Relation = Relation
- self.Relation_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -6945,16 +5486,14 @@ def factory(*args_, **kwargs_):
else:
return RelationsType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Relation(self):
return self.Relation
def set_Relation(self, Relation):
self.Relation = Relation
def add_Relation(self, value):
self.Relation.append(value)
+ def add_Relation(self, value):
+ self.Relation.append(value)
def insert_Relation_at(self, index, value):
self.Relation.insert(index, value)
def replace_Relation_at(self, index, value):
@@ -6966,7 +5505,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RelationsType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RelationsType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('RelationsType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -6976,8 +5515,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -6989,91 +5526,61 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='RelationsType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='RelationsType'):
pass
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RelationsType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RelationsType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for Relation_ in self.Relation:
- namespaceprefix_ = self.Relation_nsprefix_ + ':' if (UseCapturedNS_ and self.Relation_nsprefix_) else ''
Relation_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Relation', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
pass
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Relation':
obj_ = RelationType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Relation.append(obj_)
obj_.original_tagname_ = 'Relation'
- def __hash__(self):
- return hash(self.id)
# end class RelationsType
class RelationType(GeneratedsSuper):
- """One-to-one relation between to layout object. Use 'link'
- for loose relations and 'join' for strong relations
- (where something is fragmented for instance).
- Examples for 'link': caption - image floating -
- paragraph paragraph - paragraph (when a paragraph is
- split across columns and the last word of the first
- paragraph DOES NOT continue in the second paragraph)
- drop-cap - paragraph (when the drop-cap is a whole word)
- Examples for 'join': word - word (separated word at the
- end of a line) drop-cap - paragraph (when the drop-cap
- is not a whole word) paragraph - paragraph (when a
- pragraph is split across columns and the last word of
- the first paragraph DOES continue in the second
- paragraph)
- For generic use"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('type_', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- MemberSpec_('SourceRegionRef', 'RegionRefType', 0, 0, {'maxOccurs': '1', 'minOccurs': '1', 'name': 'SourceRegionRef', 'type': 'RegionRefType'}, None),
- MemberSpec_('TargetRegionRef', 'RegionRefType', 0, 0, {'maxOccurs': '1', 'minOccurs': '1', 'name': 'TargetRegionRef', 'type': 'RegionRefType'}, None),
- ]
+ """One-to-one relation between to layout object. Use 'link' for loose
+ relations and 'join' for strong relations (where something is
+ fragmented for instance). Examples for 'link': caption - image
+ floating - paragraph paragraph - paragraph (when a paragraph is
+ split across columns and the last word of the first paragraph
+ DOES NOT continue in the second paragraph) drop-cap - paragraph
+ (when the drop-cap is a whole word) Examples for 'join': word -
+ word (separated word at the end of a line) drop-cap - paragraph
+ (when the drop-cap is not a whole word) paragraph - paragraph
+ (when a pragraph is split across columns and the last word of
+ the first paragraph DOES continue in the second paragraph) For
+ generic use"""
subclass = None
superclass = None
- def __init__(self, id=None, type_=None, custom=None, comments=None, Labels=None, SourceRegionRef=None, TargetRegionRef=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, type_=None, custom=None, comments=None, Labels=None, SourceRegionRef=None, TargetRegionRef=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
self.SourceRegionRef = SourceRegionRef
- self.SourceRegionRef_nsprefix_ = None
self.TargetRegionRef = TargetRegionRef
- self.TargetRegionRef_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -7085,16 +5592,14 @@ def factory(*args_, **kwargs_):
else:
return RelationType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Labels(self):
return self.Labels
def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -7132,7 +5637,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RelationType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RelationType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('RelationType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -7142,8 +5647,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -7155,7 +5658,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='RelationType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='RelationType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -7168,30 +5671,23 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.comments is not None and 'comments' not in already_processed:
already_processed.add('comments')
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RelationType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RelationType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
if self.SourceRegionRef is not None:
- namespaceprefix_ = self.SourceRegionRef_nsprefix_ + ':' if (UseCapturedNS_ and self.SourceRegionRef_nsprefix_) else ''
self.SourceRegionRef.export(outfile, level, namespaceprefix_, namespacedef_='', name_='SourceRegionRef', pretty_print=pretty_print)
if self.TargetRegionRef is not None:
- namespaceprefix_ = self.TargetRegionRef_nsprefix_ + ':' if (UseCapturedNS_ and self.TargetRegionRef_nsprefix_) else ''
self.TargetRegionRef.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TargetRegionRef', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -7210,123 +5706,65 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'comments' not in already_processed:
already_processed.add('comments')
self.comments = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
elif nodeName_ == 'SourceRegionRef':
obj_ = RegionRefType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.SourceRegionRef = obj_
obj_.original_tagname_ = 'SourceRegionRef'
elif nodeName_ == 'TargetRegionRef':
obj_ = RegionRefType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TargetRegionRef = obj_
obj_.original_tagname_ = 'TargetRegionRef'
- def __hash__(self):
- return hash(self.id)
# end class RelationType
class TextStyleType(GeneratedsSuper):
- """Monospace (fixed-pitch, non-proportional) or
- proportional font.
- For instance: Arial, Times New Roman.
- Add more information if necessary
- (e.g. blackletter, antiqua).
- Serif or sans-serif typeface.
- The size of the characters in points.
- The x-height or corpus size refers to the distance
- between the baseline and the mean line of
- lower-case letters in a typeface.
- The unit is assumed to be pixels.
- The degree of space (in points) between
- the characters in a string of text.
- Text colour in RGB encoded format
- (red value) + (256 x green value) + (65536 x blue value).
- Background colour
- Background colour in RGB encoded format
- (red value) + (256 x green value) + (65536 x blue value).
- Specifies whether the colour of the text appears
- reversed against a background colour.
- Line style details if "underlined" is TRUE"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('fontFamily', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('serif', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('monospace', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('fontSize', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('xHeight', 'integer', 0, 1, {'use': 'optional'}),
- MemberSpec_('kerning', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('textColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('textColourRgb', 'integer', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColourRgb', 'integer', 0, 1, {'use': 'optional'}),
- MemberSpec_('reverseVideo', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('bold', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('italic', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('underlined', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('underlineStyle', 'pc:underlineStyleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('doubleUnderlined', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('subscript', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('superscript', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('strikethrough', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('smallCaps', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('letterSpaced', 'boolean', 0, 1, {'use': 'optional'}),
- ]
+ """Monospace (fixed-pitch, non-proportional) or proportional font. For
+ instance: Arial, Times New Roman. Add more information if
+ necessary (e.g. blackletter, antiqua). Serif or sans-serif
+ typeface. The size of the characters in points. The x-height or
+ corpus size refers to the distance between the baseline and the
+ mean line of lower-case letters in a typeface. The unit is
+ assumed to be pixels. The degree of space (in points) between
+ the characters in a string of text. Text colour in RGB encoded
+ format (red value) + (256 x green value) + (65536 x blue value).
+ Background colour Background colour in RGB encoded format (red
+ value) + (256 x green value) + (65536 x blue value). Specifies
+ whether the colour of the text appears reversed against a
+ background colour. Line style details if "underlined" is TRUE"""
subclass = None
superclass = None
- def __init__(self, fontFamily=None, serif=None, monospace=None, fontSize=None, xHeight=None, kerning=None, textColour=None, textColourRgb=None, bgColour=None, bgColourRgb=None, reverseVideo=None, bold=None, italic=None, underlined=None, underlineStyle=None, doubleUnderlined=None, subscript=None, superscript=None, strikethrough=None, smallCaps=None, letterSpaced=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, fontFamily=None, serif=None, monospace=None, fontSize=None, xHeight=None, kerning=None, textColour=None, textColourRgb=None, bgColour=None, bgColourRgb=None, reverseVideo=None, bold=None, italic=None, underlined=None, underlineStyle=None, doubleUnderlined=None, subscript=None, superscript=None, strikethrough=None, smallCaps=None, letterSpaced=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.fontFamily = _cast(None, fontFamily)
- self.fontFamily_nsprefix_ = None
self.serif = _cast(bool, serif)
- self.serif_nsprefix_ = None
self.monospace = _cast(bool, monospace)
- self.monospace_nsprefix_ = None
self.fontSize = _cast(float, fontSize)
- self.fontSize_nsprefix_ = None
self.xHeight = _cast(int, xHeight)
- self.xHeight_nsprefix_ = None
self.kerning = _cast(int, kerning)
- self.kerning_nsprefix_ = None
self.textColour = _cast(None, textColour)
- self.textColour_nsprefix_ = None
self.textColourRgb = _cast(int, textColourRgb)
- self.textColourRgb_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
self.bgColourRgb = _cast(int, bgColourRgb)
- self.bgColourRgb_nsprefix_ = None
self.reverseVideo = _cast(bool, reverseVideo)
- self.reverseVideo_nsprefix_ = None
self.bold = _cast(bool, bold)
- self.bold_nsprefix_ = None
self.italic = _cast(bool, italic)
- self.italic_nsprefix_ = None
self.underlined = _cast(bool, underlined)
- self.underlined_nsprefix_ = None
self.underlineStyle = _cast(None, underlineStyle)
- self.underlineStyle_nsprefix_ = None
self.doubleUnderlined = _cast(bool, doubleUnderlined)
- self.doubleUnderlined_nsprefix_ = None
self.subscript = _cast(bool, subscript)
- self.subscript_nsprefix_ = None
self.superscript = _cast(bool, superscript)
- self.superscript_nsprefix_ = None
self.strikethrough = _cast(bool, strikethrough)
- self.strikethrough_nsprefix_ = None
self.smallCaps = _cast(bool, smallCaps)
- self.smallCaps_nsprefix_ = None
self.letterSpaced = _cast(bool, letterSpaced)
- self.letterSpaced_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -7338,10 +5776,6 @@ def factory(*args_, **kwargs_):
else:
return TextStyleType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_fontFamily(self):
return self.fontFamily
def set_fontFamily(self, fontFamily):
@@ -7426,32 +5860,6 @@ def get_letterSpaced(self):
return self.letterSpaced
def set_letterSpaced(self, letterSpaced):
self.letterSpaced = letterSpaced
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_underlineStyleType(self, value):
- # Validate type pc:underlineStyleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['singleLine', 'doubleLine', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on underlineStyleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
@@ -7459,7 +5867,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextStyleType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextStyleType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('TextStyleType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -7469,8 +5877,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -7481,7 +5887,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='TextStyleType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='TextStyleType'):
if self.fontFamily is not None and 'fontFamily' not in already_processed:
already_processed.add('fontFamily')
outfile.write(' fontFamily=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.fontFamily), input_name='fontFamily')), ))
@@ -7502,13 +5908,13 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' kerning="%s"' % self.gds_format_integer(self.kerning, input_name='kerning'))
if self.textColour is not None and 'textColour' not in already_processed:
already_processed.add('textColour')
- outfile.write(' textColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.textColour), input_name='textColour')), ))
+ outfile.write(' textColour=%s' % (quote_attrib(self.textColour), ))
if self.textColourRgb is not None and 'textColourRgb' not in already_processed:
already_processed.add('textColourRgb')
outfile.write(' textColourRgb="%s"' % self.gds_format_integer(self.textColourRgb, input_name='textColourRgb'))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
if self.bgColourRgb is not None and 'bgColourRgb' not in already_processed:
already_processed.add('bgColourRgb')
outfile.write(' bgColourRgb="%s"' % self.gds_format_integer(self.bgColourRgb, input_name='bgColourRgb'))
@@ -7526,7 +5932,7 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' underlined="%s"' % self.gds_format_boolean(self.underlined, input_name='underlined'))
if self.underlineStyle is not None and 'underlineStyle' not in already_processed:
already_processed.add('underlineStyle')
- outfile.write(' underlineStyle=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.underlineStyle), input_name='underlineStyle')), ))
+ outfile.write(' underlineStyle=%s' % (quote_attrib(self.underlineStyle), ))
if self.doubleUnderlined is not None and 'doubleUnderlined' not in already_processed:
already_processed.add('doubleUnderlined')
outfile.write(' doubleUnderlined="%s"' % self.gds_format_boolean(self.doubleUnderlined, input_name='doubleUnderlined'))
@@ -7545,18 +5951,14 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.letterSpaced is not None and 'letterSpaced' not in already_processed:
already_processed.add('letterSpaced')
outfile.write(' letterSpaced="%s"' % self.gds_format_boolean(self.letterSpaced, input_name='letterSpaced'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextStyleType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TextStyleType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('fontFamily', node)
@@ -7584,34 +5986,46 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('fontSize', node)
if value is not None and 'fontSize' not in already_processed:
already_processed.add('fontSize')
- value = self.gds_parse_float(value, node, 'fontSize')
- self.fontSize = value
+ try:
+ self.fontSize = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (fontSize): %s' % exp)
value = find_attr_value_('xHeight', node)
if value is not None and 'xHeight' not in already_processed:
already_processed.add('xHeight')
- self.xHeight = self.gds_parse_integer(value, node, 'xHeight')
+ try:
+ self.xHeight = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('kerning', node)
if value is not None and 'kerning' not in already_processed:
already_processed.add('kerning')
- self.kerning = self.gds_parse_integer(value, node, 'kerning')
+ try:
+ self.kerning = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('textColour', node)
if value is not None and 'textColour' not in already_processed:
already_processed.add('textColour')
self.textColour = value
- self.validate_ColourSimpleType(self.textColour) # validate type ColourSimpleType
value = find_attr_value_('textColourRgb', node)
if value is not None and 'textColourRgb' not in already_processed:
already_processed.add('textColourRgb')
- self.textColourRgb = self.gds_parse_integer(value, node, 'textColourRgb')
+ try:
+ self.textColourRgb = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
value = find_attr_value_('bgColourRgb', node)
if value is not None and 'bgColourRgb' not in already_processed:
already_processed.add('bgColourRgb')
- self.bgColourRgb = self.gds_parse_integer(value, node, 'bgColourRgb')
+ try:
+ self.bgColourRgb = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('reverseVideo', node)
if value is not None and 'reverseVideo' not in already_processed:
already_processed.add('reverseVideo')
@@ -7652,7 +6066,6 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'underlineStyle' not in already_processed:
already_processed.add('underlineStyle')
self.underlineStyle = value
- self.validate_underlineStyleType(self.underlineStyle) # validate type underlineStyleType
value = find_attr_value_('doubleUnderlined', node)
if value is not None and 'doubleUnderlined' not in already_processed:
already_processed.add('doubleUnderlined')
@@ -7707,145 +6120,90 @@ def buildAttributes(self, node, attrs, already_processed):
self.letterSpaced = False
else:
raise_parse_error(node, 'Bad boolean attribute')
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class TextStyleType
class RegionType(GeneratedsSuper):
- """For generic use
- Is this region a continuation of another region
- (in previous column or page, for example)?"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('continuation', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('AlternativeImage', 'AlternativeImageType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'AlternativeImage', 'type': 'AlternativeImageType'}, None),
- MemberSpec_('Coords', 'CoordsType', 0, 0, {'name': 'Coords', 'type': 'CoordsType'}, None),
- MemberSpec_('UserDefined', 'UserDefinedType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'UserDefined', 'type': 'UserDefinedType'}, None),
- MemberSpec_('Labels', 'LabelsType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'Labels', 'type': 'LabelsType'}, None),
- MemberSpec_('Roles', 'RolesType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'Roles', 'type': 'RolesType'}, None),
- MemberSpec_('TextRegion', 'TextRegionType', 1, 1, {'name': 'TextRegion', 'type': 'TextRegionType'}, 7),
- MemberSpec_('ImageRegion', 'ImageRegionType', 1, 1, {'name': 'ImageRegion', 'type': 'ImageRegionType'}, 7),
- MemberSpec_('LineDrawingRegion', 'LineDrawingRegionType', 1, 1, {'name': 'LineDrawingRegion', 'type': 'LineDrawingRegionType'}, 7),
- MemberSpec_('GraphicRegion', 'GraphicRegionType', 1, 1, {'name': 'GraphicRegion', 'type': 'GraphicRegionType'}, 7),
- MemberSpec_('TableRegion', 'TableRegionType', 1, 1, {'name': 'TableRegion', 'type': 'TableRegionType'}, 7),
- MemberSpec_('ChartRegion', 'ChartRegionType', 1, 1, {'name': 'ChartRegion', 'type': 'ChartRegionType'}, 7),
- MemberSpec_('SeparatorRegion', 'SeparatorRegionType', 1, 1, {'name': 'SeparatorRegion', 'type': 'SeparatorRegionType'}, 7),
- MemberSpec_('MathsRegion', 'MathsRegionType', 1, 1, {'name': 'MathsRegion', 'type': 'MathsRegionType'}, 7),
- MemberSpec_('ChemRegion', 'ChemRegionType', 1, 1, {'name': 'ChemRegion', 'type': 'ChemRegionType'}, 7),
- MemberSpec_('MusicRegion', 'MusicRegionType', 1, 1, {'name': 'MusicRegion', 'type': 'MusicRegionType'}, 7),
- MemberSpec_('AdvertRegion', 'AdvertRegionType', 1, 1, {'name': 'AdvertRegion', 'type': 'AdvertRegionType'}, 7),
- MemberSpec_('NoiseRegion', 'NoiseRegionType', 1, 1, {'name': 'NoiseRegion', 'type': 'NoiseRegionType'}, 7),
- MemberSpec_('UnknownRegion', 'UnknownRegionType', 1, 1, {'name': 'UnknownRegion', 'type': 'UnknownRegionType'}, 7),
- MemberSpec_('CustomRegion', 'CustomRegionType', 1, 1, {'name': 'CustomRegion', 'type': 'CustomRegionType'}, 7),
- ]
+ """For generic use Is this region a continuation of another region (in
+ previous column or page, for example)?"""
subclass = None
superclass = None
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, extensiontype_=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, extensiontype_=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
self.continuation = _cast(bool, continuation)
- self.continuation_nsprefix_ = None
if AlternativeImage is None:
self.AlternativeImage = []
else:
self.AlternativeImage = AlternativeImage
- self.AlternativeImage_nsprefix_ = None
self.Coords = Coords
- self.Coords_nsprefix_ = None
self.UserDefined = UserDefined
- self.UserDefined_nsprefix_ = None
if Labels is None:
self.Labels = []
else:
self.Labels = Labels
- self.Labels_nsprefix_ = None
self.Roles = Roles
- self.Roles_nsprefix_ = None
if TextRegion is None:
self.TextRegion = []
else:
self.TextRegion = TextRegion
- self.TextRegion_nsprefix_ = None
if ImageRegion is None:
self.ImageRegion = []
else:
self.ImageRegion = ImageRegion
- self.ImageRegion_nsprefix_ = None
if LineDrawingRegion is None:
self.LineDrawingRegion = []
else:
self.LineDrawingRegion = LineDrawingRegion
- self.LineDrawingRegion_nsprefix_ = None
if GraphicRegion is None:
self.GraphicRegion = []
else:
self.GraphicRegion = GraphicRegion
- self.GraphicRegion_nsprefix_ = None
if TableRegion is None:
self.TableRegion = []
else:
self.TableRegion = TableRegion
- self.TableRegion_nsprefix_ = None
if ChartRegion is None:
self.ChartRegion = []
else:
self.ChartRegion = ChartRegion
- self.ChartRegion_nsprefix_ = None
if SeparatorRegion is None:
self.SeparatorRegion = []
else:
self.SeparatorRegion = SeparatorRegion
- self.SeparatorRegion_nsprefix_ = None
if MathsRegion is None:
self.MathsRegion = []
else:
self.MathsRegion = MathsRegion
- self.MathsRegion_nsprefix_ = None
if ChemRegion is None:
self.ChemRegion = []
else:
self.ChemRegion = ChemRegion
- self.ChemRegion_nsprefix_ = None
if MusicRegion is None:
self.MusicRegion = []
else:
self.MusicRegion = MusicRegion
- self.MusicRegion_nsprefix_ = None
if AdvertRegion is None:
self.AdvertRegion = []
else:
self.AdvertRegion = AdvertRegion
- self.AdvertRegion_nsprefix_ = None
if NoiseRegion is None:
self.NoiseRegion = []
else:
self.NoiseRegion = NoiseRegion
- self.NoiseRegion_nsprefix_ = None
if UnknownRegion is None:
self.UnknownRegion = []
else:
self.UnknownRegion = UnknownRegion
- self.UnknownRegion_nsprefix_ = None
if CustomRegion is None:
self.CustomRegion = []
else:
self.CustomRegion = CustomRegion
- self.CustomRegion_nsprefix_ = None
self.extensiontype_ = extensiontype_
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
@@ -7858,16 +6216,14 @@ def factory(*args_, **kwargs_):
else:
return RegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_AlternativeImage(self):
return self.AlternativeImage
def set_AlternativeImage(self, AlternativeImage):
self.AlternativeImage = AlternativeImage
def add_AlternativeImage(self, value):
self.AlternativeImage.append(value)
+ def add_AlternativeImage(self, value):
+ self.AlternativeImage.append(value)
def insert_AlternativeImage_at(self, index, value):
self.AlternativeImage.insert(index, value)
def replace_AlternativeImage_at(self, index, value):
@@ -7886,6 +6242,8 @@ def set_Labels(self, Labels):
self.Labels = Labels
def add_Labels(self, value):
self.Labels.append(value)
+ def add_Labels(self, value):
+ self.Labels.append(value)
def insert_Labels_at(self, index, value):
self.Labels.insert(index, value)
def replace_Labels_at(self, index, value):
@@ -7900,6 +6258,8 @@ def set_TextRegion(self, TextRegion):
self.TextRegion = TextRegion
def add_TextRegion(self, value):
self.TextRegion.append(value)
+ def add_TextRegion(self, value):
+ self.TextRegion.append(value)
def insert_TextRegion_at(self, index, value):
self.TextRegion.insert(index, value)
def replace_TextRegion_at(self, index, value):
@@ -7910,6 +6270,8 @@ def set_ImageRegion(self, ImageRegion):
self.ImageRegion = ImageRegion
def add_ImageRegion(self, value):
self.ImageRegion.append(value)
+ def add_ImageRegion(self, value):
+ self.ImageRegion.append(value)
def insert_ImageRegion_at(self, index, value):
self.ImageRegion.insert(index, value)
def replace_ImageRegion_at(self, index, value):
@@ -7920,6 +6282,8 @@ def set_LineDrawingRegion(self, LineDrawingRegion):
self.LineDrawingRegion = LineDrawingRegion
def add_LineDrawingRegion(self, value):
self.LineDrawingRegion.append(value)
+ def add_LineDrawingRegion(self, value):
+ self.LineDrawingRegion.append(value)
def insert_LineDrawingRegion_at(self, index, value):
self.LineDrawingRegion.insert(index, value)
def replace_LineDrawingRegion_at(self, index, value):
@@ -7930,6 +6294,8 @@ def set_GraphicRegion(self, GraphicRegion):
self.GraphicRegion = GraphicRegion
def add_GraphicRegion(self, value):
self.GraphicRegion.append(value)
+ def add_GraphicRegion(self, value):
+ self.GraphicRegion.append(value)
def insert_GraphicRegion_at(self, index, value):
self.GraphicRegion.insert(index, value)
def replace_GraphicRegion_at(self, index, value):
@@ -7940,6 +6306,8 @@ def set_TableRegion(self, TableRegion):
self.TableRegion = TableRegion
def add_TableRegion(self, value):
self.TableRegion.append(value)
+ def add_TableRegion(self, value):
+ self.TableRegion.append(value)
def insert_TableRegion_at(self, index, value):
self.TableRegion.insert(index, value)
def replace_TableRegion_at(self, index, value):
@@ -7950,6 +6318,8 @@ def set_ChartRegion(self, ChartRegion):
self.ChartRegion = ChartRegion
def add_ChartRegion(self, value):
self.ChartRegion.append(value)
+ def add_ChartRegion(self, value):
+ self.ChartRegion.append(value)
def insert_ChartRegion_at(self, index, value):
self.ChartRegion.insert(index, value)
def replace_ChartRegion_at(self, index, value):
@@ -7960,6 +6330,8 @@ def set_SeparatorRegion(self, SeparatorRegion):
self.SeparatorRegion = SeparatorRegion
def add_SeparatorRegion(self, value):
self.SeparatorRegion.append(value)
+ def add_SeparatorRegion(self, value):
+ self.SeparatorRegion.append(value)
def insert_SeparatorRegion_at(self, index, value):
self.SeparatorRegion.insert(index, value)
def replace_SeparatorRegion_at(self, index, value):
@@ -7970,6 +6342,8 @@ def set_MathsRegion(self, MathsRegion):
self.MathsRegion = MathsRegion
def add_MathsRegion(self, value):
self.MathsRegion.append(value)
+ def add_MathsRegion(self, value):
+ self.MathsRegion.append(value)
def insert_MathsRegion_at(self, index, value):
self.MathsRegion.insert(index, value)
def replace_MathsRegion_at(self, index, value):
@@ -7980,6 +6354,8 @@ def set_ChemRegion(self, ChemRegion):
self.ChemRegion = ChemRegion
def add_ChemRegion(self, value):
self.ChemRegion.append(value)
+ def add_ChemRegion(self, value):
+ self.ChemRegion.append(value)
def insert_ChemRegion_at(self, index, value):
self.ChemRegion.insert(index, value)
def replace_ChemRegion_at(self, index, value):
@@ -7990,6 +6366,8 @@ def set_MusicRegion(self, MusicRegion):
self.MusicRegion = MusicRegion
def add_MusicRegion(self, value):
self.MusicRegion.append(value)
+ def add_MusicRegion(self, value):
+ self.MusicRegion.append(value)
def insert_MusicRegion_at(self, index, value):
self.MusicRegion.insert(index, value)
def replace_MusicRegion_at(self, index, value):
@@ -8000,6 +6378,8 @@ def set_AdvertRegion(self, AdvertRegion):
self.AdvertRegion = AdvertRegion
def add_AdvertRegion(self, value):
self.AdvertRegion.append(value)
+ def add_AdvertRegion(self, value):
+ self.AdvertRegion.append(value)
def insert_AdvertRegion_at(self, index, value):
self.AdvertRegion.insert(index, value)
def replace_AdvertRegion_at(self, index, value):
@@ -8010,6 +6390,8 @@ def set_NoiseRegion(self, NoiseRegion):
self.NoiseRegion = NoiseRegion
def add_NoiseRegion(self, value):
self.NoiseRegion.append(value)
+ def add_NoiseRegion(self, value):
+ self.NoiseRegion.append(value)
def insert_NoiseRegion_at(self, index, value):
self.NoiseRegion.insert(index, value)
def replace_NoiseRegion_at(self, index, value):
@@ -8020,6 +6402,8 @@ def set_UnknownRegion(self, UnknownRegion):
self.UnknownRegion = UnknownRegion
def add_UnknownRegion(self, value):
self.UnknownRegion.append(value)
+ def add_UnknownRegion(self, value):
+ self.UnknownRegion.append(value)
def insert_UnknownRegion_at(self, index, value):
self.UnknownRegion.insert(index, value)
def replace_UnknownRegion_at(self, index, value):
@@ -8030,6 +6414,8 @@ def set_CustomRegion(self, CustomRegion):
self.CustomRegion = CustomRegion
def add_CustomRegion(self, value):
self.CustomRegion.append(value)
+ def add_CustomRegion(self, value):
+ self.CustomRegion.append(value)
def insert_CustomRegion_at(self, index, value):
self.CustomRegion.insert(index, value)
def replace_CustomRegion_at(self, index, value):
@@ -8077,7 +6463,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('RegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -8087,8 +6473,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -8100,7 +6484,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='RegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='RegionType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -8116,83 +6500,56 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.extensiontype_ is not None and 'xsi:type' not in already_processed:
already_processed.add('xsi:type')
outfile.write(' xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"')
- if ":" not in self.extensiontype_:
- imported_ns_type_prefix_ = GenerateDSNamespaceTypePrefixes_.get(self.extensiontype_, '')
- outfile.write(' xsi:type="%s%s"' % (imported_ns_type_prefix_, self.extensiontype_))
- else:
- outfile.write(' xsi:type="%s"' % self.extensiontype_)
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionType', fromsubclass_=False, pretty_print=True):
+ outfile.write(' xsi:type="%s"' % self.extensiontype_)
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RegionType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for AlternativeImage_ in self.AlternativeImage:
- namespaceprefix_ = self.AlternativeImage_nsprefix_ + ':' if (UseCapturedNS_ and self.AlternativeImage_nsprefix_) else ''
AlternativeImage_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='AlternativeImage', pretty_print=pretty_print)
if self.Coords is not None:
- namespaceprefix_ = self.Coords_nsprefix_ + ':' if (UseCapturedNS_ and self.Coords_nsprefix_) else ''
self.Coords.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Coords', pretty_print=pretty_print)
if self.UserDefined is not None:
- namespaceprefix_ = self.UserDefined_nsprefix_ + ':' if (UseCapturedNS_ and self.UserDefined_nsprefix_) else ''
self.UserDefined.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserDefined', pretty_print=pretty_print)
for Labels_ in self.Labels:
- namespaceprefix_ = self.Labels_nsprefix_ + ':' if (UseCapturedNS_ and self.Labels_nsprefix_) else ''
Labels_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Labels', pretty_print=pretty_print)
if self.Roles is not None:
- namespaceprefix_ = self.Roles_nsprefix_ + ':' if (UseCapturedNS_ and self.Roles_nsprefix_) else ''
self.Roles.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Roles', pretty_print=pretty_print)
for TextRegion_ in self.TextRegion:
- namespaceprefix_ = self.TextRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.TextRegion_nsprefix_) else ''
TextRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextRegion', pretty_print=pretty_print)
for ImageRegion_ in self.ImageRegion:
- namespaceprefix_ = self.ImageRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.ImageRegion_nsprefix_) else ''
ImageRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='ImageRegion', pretty_print=pretty_print)
for LineDrawingRegion_ in self.LineDrawingRegion:
- namespaceprefix_ = self.LineDrawingRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.LineDrawingRegion_nsprefix_) else ''
LineDrawingRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='LineDrawingRegion', pretty_print=pretty_print)
for GraphicRegion_ in self.GraphicRegion:
- namespaceprefix_ = self.GraphicRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.GraphicRegion_nsprefix_) else ''
GraphicRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='GraphicRegion', pretty_print=pretty_print)
for TableRegion_ in self.TableRegion:
- namespaceprefix_ = self.TableRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.TableRegion_nsprefix_) else ''
TableRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TableRegion', pretty_print=pretty_print)
for ChartRegion_ in self.ChartRegion:
- namespaceprefix_ = self.ChartRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.ChartRegion_nsprefix_) else ''
ChartRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='ChartRegion', pretty_print=pretty_print)
for SeparatorRegion_ in self.SeparatorRegion:
- namespaceprefix_ = self.SeparatorRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.SeparatorRegion_nsprefix_) else ''
SeparatorRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='SeparatorRegion', pretty_print=pretty_print)
for MathsRegion_ in self.MathsRegion:
- namespaceprefix_ = self.MathsRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.MathsRegion_nsprefix_) else ''
MathsRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='MathsRegion', pretty_print=pretty_print)
for ChemRegion_ in self.ChemRegion:
- namespaceprefix_ = self.ChemRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.ChemRegion_nsprefix_) else ''
ChemRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='ChemRegion', pretty_print=pretty_print)
for MusicRegion_ in self.MusicRegion:
- namespaceprefix_ = self.MusicRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.MusicRegion_nsprefix_) else ''
MusicRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='MusicRegion', pretty_print=pretty_print)
for AdvertRegion_ in self.AdvertRegion:
- namespaceprefix_ = self.AdvertRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.AdvertRegion_nsprefix_) else ''
AdvertRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='AdvertRegion', pretty_print=pretty_print)
for NoiseRegion_ in self.NoiseRegion:
- namespaceprefix_ = self.NoiseRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.NoiseRegion_nsprefix_) else ''
NoiseRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='NoiseRegion', pretty_print=pretty_print)
for UnknownRegion_ in self.UnknownRegion:
- namespaceprefix_ = self.UnknownRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.UnknownRegion_nsprefix_) else ''
UnknownRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UnknownRegion', pretty_print=pretty_print)
for CustomRegion_ in self.CustomRegion:
- namespaceprefix_ = self.CustomRegion_nsprefix_ + ':' if (UseCapturedNS_ and self.CustomRegion_nsprefix_) else ''
CustomRegion_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='CustomRegion', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -8220,129 +6577,115 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'xsi:type' not in already_processed:
already_processed.add('xsi:type')
self.extensiontype_ = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'AlternativeImage':
obj_ = AlternativeImageType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.AlternativeImage.append(obj_)
obj_.original_tagname_ = 'AlternativeImage'
elif nodeName_ == 'Coords':
obj_ = CoordsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Coords = obj_
obj_.original_tagname_ = 'Coords'
elif nodeName_ == 'UserDefined':
obj_ = UserDefinedType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserDefined = obj_
obj_.original_tagname_ = 'UserDefined'
elif nodeName_ == 'Labels':
obj_ = LabelsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Labels.append(obj_)
obj_.original_tagname_ = 'Labels'
elif nodeName_ == 'Roles':
obj_ = RolesType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Roles = obj_
obj_.original_tagname_ = 'Roles'
elif nodeName_ == 'TextRegion':
obj_ = TextRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextRegion.append(obj_)
obj_.original_tagname_ = 'TextRegion'
elif nodeName_ == 'ImageRegion':
obj_ = ImageRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.ImageRegion.append(obj_)
obj_.original_tagname_ = 'ImageRegion'
elif nodeName_ == 'LineDrawingRegion':
obj_ = LineDrawingRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.LineDrawingRegion.append(obj_)
obj_.original_tagname_ = 'LineDrawingRegion'
elif nodeName_ == 'GraphicRegion':
obj_ = GraphicRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.GraphicRegion.append(obj_)
obj_.original_tagname_ = 'GraphicRegion'
elif nodeName_ == 'TableRegion':
obj_ = TableRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TableRegion.append(obj_)
obj_.original_tagname_ = 'TableRegion'
elif nodeName_ == 'ChartRegion':
obj_ = ChartRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.ChartRegion.append(obj_)
obj_.original_tagname_ = 'ChartRegion'
elif nodeName_ == 'SeparatorRegion':
obj_ = SeparatorRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.SeparatorRegion.append(obj_)
obj_.original_tagname_ = 'SeparatorRegion'
elif nodeName_ == 'MathsRegion':
obj_ = MathsRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.MathsRegion.append(obj_)
obj_.original_tagname_ = 'MathsRegion'
elif nodeName_ == 'ChemRegion':
obj_ = ChemRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.ChemRegion.append(obj_)
obj_.original_tagname_ = 'ChemRegion'
elif nodeName_ == 'MusicRegion':
obj_ = MusicRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.MusicRegion.append(obj_)
obj_.original_tagname_ = 'MusicRegion'
elif nodeName_ == 'AdvertRegion':
obj_ = AdvertRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.AdvertRegion.append(obj_)
obj_.original_tagname_ = 'AdvertRegion'
elif nodeName_ == 'NoiseRegion':
obj_ = NoiseRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.NoiseRegion.append(obj_)
obj_.original_tagname_ = 'NoiseRegion'
elif nodeName_ == 'UnknownRegion':
obj_ = UnknownRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UnknownRegion.append(obj_)
obj_.original_tagname_ = 'UnknownRegion'
elif nodeName_ == 'CustomRegion':
obj_ = CustomRegionType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.CustomRegion.append(obj_)
obj_.original_tagname_ = 'CustomRegion'
- def __hash__(self):
- return hash(self.id)
# end class RegionType
class AlternativeImageType(GeneratedsSuper):
"""Confidence value (between 0 and 1)"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('filename', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('conf', 'pc:ConfSimpleType', 0, 1, {'use': 'optional'}),
- ]
subclass = None
superclass = None
- def __init__(self, filename=None, comments=None, conf=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, filename=None, comments=None, conf=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.filename = _cast(None, filename)
- self.filename_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
self.conf = _cast(float, conf)
- self.conf_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -8354,10 +6697,6 @@ def factory(*args_, **kwargs_):
else:
return AlternativeImageType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_filename(self):
return self.filename
def set_filename(self, filename):
@@ -8370,21 +6709,6 @@ def get_conf(self):
return self.conf
def set_conf(self, conf):
self.conf = conf
- def validate_ConfSimpleType(self, value):
- # Validate type pc:ConfSimpleType, a restriction on float.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, float):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (float)' % {"value": value, "lineno": lineno, })
- return False
- if value < 0:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd minInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
- if value > 1:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd maxInclusive restriction on ConfSimpleType' % {"value": value, "lineno": lineno} )
- result = False
def hasContent_(self):
if (
@@ -8392,7 +6716,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='AlternativeImageType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='AlternativeImageType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('AlternativeImageType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -8402,8 +6726,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -8414,7 +6736,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='AlternativeImageType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='AlternativeImageType'):
if self.filename is not None and 'filename' not in already_processed:
already_processed.add('filename')
outfile.write(' filename=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.filename), input_name='filename')), ))
@@ -8423,19 +6745,15 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' comments=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.comments), input_name='comments')), ))
if self.conf is not None and 'conf' not in already_processed:
already_processed.add('conf')
- outfile.write(' conf="%s"' % self.gds_format_float(self.conf, input_name='conf'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='AlternativeImageType', fromsubclass_=False, pretty_print=True):
+ outfile.write(' conf=%s' % (quote_attrib(self.conf), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='AlternativeImageType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('filename', node)
@@ -8449,48 +6767,32 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('conf', node)
if value is not None and 'conf' not in already_processed:
already_processed.add('conf')
- value = self.gds_parse_float(value, node, 'conf')
self.conf = value
- self.validate_ConfSimpleType(self.conf) # validate type ConfSimpleType
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class AlternativeImageType
class GraphemesType(GeneratedsSuper):
- """Container for graphemes, grapheme groups and
- non-printing characters."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('Grapheme', 'GraphemeType', 1, 0, {'name': 'Grapheme', 'type': 'GraphemeType'}, 8),
- MemberSpec_('NonPrintingChar', 'NonPrintingCharType', 1, 0, {'name': 'NonPrintingChar', 'type': 'NonPrintingCharType'}, 8),
- MemberSpec_('GraphemeGroup', 'GraphemeGroupType', 1, 0, {'name': 'GraphemeGroup', 'type': 'GraphemeGroupType'}, 8),
- ]
+ """Container for graphemes, grapheme groups and non-printing
+ characters."""
subclass = None
superclass = None
- def __init__(self, Grapheme=None, NonPrintingChar=None, GraphemeGroup=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, Grapheme=None, NonPrintingChar=None, GraphemeGroup=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
if Grapheme is None:
self.Grapheme = []
else:
self.Grapheme = Grapheme
- self.Grapheme_nsprefix_ = None
if NonPrintingChar is None:
self.NonPrintingChar = []
else:
self.NonPrintingChar = NonPrintingChar
- self.NonPrintingChar_nsprefix_ = None
if GraphemeGroup is None:
self.GraphemeGroup = []
else:
self.GraphemeGroup = GraphemeGroup
- self.GraphemeGroup_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -8502,16 +6804,14 @@ def factory(*args_, **kwargs_):
else:
return GraphemesType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Grapheme(self):
return self.Grapheme
def set_Grapheme(self, Grapheme):
self.Grapheme = Grapheme
def add_Grapheme(self, value):
self.Grapheme.append(value)
+ def add_Grapheme(self, value):
+ self.Grapheme.append(value)
def insert_Grapheme_at(self, index, value):
self.Grapheme.insert(index, value)
def replace_Grapheme_at(self, index, value):
@@ -8522,6 +6822,8 @@ def set_NonPrintingChar(self, NonPrintingChar):
self.NonPrintingChar = NonPrintingChar
def add_NonPrintingChar(self, value):
self.NonPrintingChar.append(value)
+ def add_NonPrintingChar(self, value):
+ self.NonPrintingChar.append(value)
def insert_NonPrintingChar_at(self, index, value):
self.NonPrintingChar.insert(index, value)
def replace_NonPrintingChar_at(self, index, value):
@@ -8532,6 +6834,8 @@ def set_GraphemeGroup(self, GraphemeGroup):
self.GraphemeGroup = GraphemeGroup
def add_GraphemeGroup(self, value):
self.GraphemeGroup.append(value)
+ def add_GraphemeGroup(self, value):
+ self.GraphemeGroup.append(value)
def insert_GraphemeGroup_at(self, index, value):
self.GraphemeGroup.insert(index, value)
def replace_GraphemeGroup_at(self, index, value):
@@ -8545,7 +6849,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemesType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemesType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('GraphemesType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -8555,8 +6859,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -8568,98 +6870,69 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='GraphemesType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='GraphemesType'):
pass
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemesType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemesType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for Grapheme_ in self.Grapheme:
- namespaceprefix_ = self.Grapheme_nsprefix_ + ':' if (UseCapturedNS_ and self.Grapheme_nsprefix_) else ''
Grapheme_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Grapheme', pretty_print=pretty_print)
for NonPrintingChar_ in self.NonPrintingChar:
- namespaceprefix_ = self.NonPrintingChar_nsprefix_ + ':' if (UseCapturedNS_ and self.NonPrintingChar_nsprefix_) else ''
NonPrintingChar_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='NonPrintingChar', pretty_print=pretty_print)
for GraphemeGroup_ in self.GraphemeGroup:
- namespaceprefix_ = self.GraphemeGroup_nsprefix_ + ':' if (UseCapturedNS_ and self.GraphemeGroup_nsprefix_) else ''
GraphemeGroup_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='GraphemeGroup', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
pass
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Grapheme':
obj_ = GraphemeType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Grapheme.append(obj_)
obj_.original_tagname_ = 'Grapheme'
elif nodeName_ == 'NonPrintingChar':
obj_ = NonPrintingCharType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.NonPrintingChar.append(obj_)
obj_.original_tagname_ = 'NonPrintingChar'
elif nodeName_ == 'GraphemeGroup':
obj_ = GraphemeGroupType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.GraphemeGroup.append(obj_)
obj_.original_tagname_ = 'GraphemeGroup'
- def __hash__(self):
- return hash(self.id)
# end class GraphemesType
class GraphemeBaseType(GeneratedsSuper):
- """Base type for graphemes, grapheme groups and non-printing characters.
- Order index of grapheme, group, or non-printing character
- within the parent container (graphemes or glyph or grapheme group).
- Type of character represented by the
- grapheme, group, or non-printing character element.
- For generic useFor generic use"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('id', 'string', 0, 0, {'use': 'required'}),
- MemberSpec_('index', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('ligature', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('charType', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('custom', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('comments', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('TextEquiv', 'TextEquivType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'TextEquiv', 'type': 'TextEquivType'}, None),
- ]
+ """Base type for graphemes, grapheme groups and non-printing
+ characters. Order index of grapheme, group, or non-printing
+ character within the parent container (graphemes or glyph or
+ grapheme group). Type of character represented by the grapheme,
+ group, or non-printing character element. For generic useFor
+ generic use"""
subclass = None
superclass = None
- def __init__(self, id=None, index=None, ligature=None, charType=None, custom=None, comments=None, TextEquiv=None, extensiontype_=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, index=None, ligature=None, charType=None, custom=None, comments=None, TextEquiv=None, extensiontype_=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.id = _cast(None, id)
- self.id_nsprefix_ = None
self.index = _cast(int, index)
- self.index_nsprefix_ = None
self.ligature = _cast(bool, ligature)
- self.ligature_nsprefix_ = None
self.charType = _cast(None, charType)
- self.charType_nsprefix_ = None
self.custom = _cast(None, custom)
- self.custom_nsprefix_ = None
self.comments = _cast(None, comments)
- self.comments_nsprefix_ = None
if TextEquiv is None:
self.TextEquiv = []
else:
self.TextEquiv = TextEquiv
- self.TextEquiv_nsprefix_ = None
self.extensiontype_ = extensiontype_
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
@@ -8672,16 +6945,14 @@ def factory(*args_, **kwargs_):
else:
return GraphemeBaseType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_TextEquiv(self):
return self.TextEquiv
def set_TextEquiv(self, TextEquiv):
self.TextEquiv = TextEquiv
def add_TextEquiv(self, value):
self.TextEquiv.append(value)
+ def add_TextEquiv(self, value):
+ self.TextEquiv.append(value)
def insert_TextEquiv_at(self, index, value):
self.TextEquiv.insert(index, value)
def replace_TextEquiv_at(self, index, value):
@@ -8719,7 +6990,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeBaseType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeBaseType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('GraphemeBaseType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -8729,8 +7000,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -8742,7 +7011,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='GraphemeBaseType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='GraphemeBaseType'):
if self.id is not None and 'id' not in already_processed:
already_processed.add('id')
outfile.write(' id=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.id), input_name='id')), ))
@@ -8764,29 +7033,20 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.extensiontype_ is not None and 'xsi:type' not in already_processed:
already_processed.add('xsi:type')
outfile.write(' xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"')
- if ":" not in self.extensiontype_:
- imported_ns_type_prefix_ = GenerateDSNamespaceTypePrefixes_.get(self.extensiontype_, '')
- outfile.write(' xsi:type="%s%s"' % (imported_ns_type_prefix_, self.extensiontype_))
- else:
- outfile.write(' xsi:type="%s"' % self.extensiontype_)
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeBaseType', fromsubclass_=False, pretty_print=True):
+ outfile.write(' xsi:type="%s"' % self.extensiontype_)
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeBaseType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for TextEquiv_ in self.TextEquiv:
- namespaceprefix_ = self.TextEquiv_nsprefix_ + ':' if (UseCapturedNS_ and self.TextEquiv_nsprefix_) else ''
TextEquiv_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextEquiv', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('id', node)
@@ -8796,7 +7056,10 @@ def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('index', node)
if value is not None and 'index' not in already_processed:
already_processed.add('index')
- self.index = self.gds_parse_integer(value, node, 'index')
+ try:
+ self.index = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('ligature', node)
if value is not None and 'ligature' not in already_processed:
already_processed.add('ligature')
@@ -8822,36 +7085,25 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'xsi:type' not in already_processed:
already_processed.add('xsi:type')
self.extensiontype_ = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'TextEquiv':
obj_ = TextEquivType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextEquiv.append(obj_)
obj_.original_tagname_ = 'TextEquiv'
- def __hash__(self):
- return hash(self.id)
# end class GraphemeBaseType
class GraphemeType(GraphemeBaseType):
- """Represents a sub-element of a glyph.
- Smallest graphical unit that can be
- assigned a Unicode code point."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('Coords', 'CoordsType', 0, 0, {'name': 'Coords', 'type': 'CoordsType'}, None),
- ]
+ """Represents a sub-element of a glyph. Smallest graphical unit that
+ can be assigned a Unicode code point."""
subclass = None
superclass = GraphemeBaseType
- def __init__(self, id=None, index=None, ligature=None, charType=None, custom=None, comments=None, TextEquiv=None, Coords=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, index=None, ligature=None, charType=None, custom=None, comments=None, TextEquiv=None, Coords=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(GraphemeType, self).__init__(id, index, ligature, charType, custom, comments, TextEquiv, **kwargs_)
self.Coords = Coords
- self.Coords_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -8863,10 +7115,6 @@ def factory(*args_, **kwargs_):
else:
return GraphemeType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Coords(self):
return self.Coords
def set_Coords(self, Coords):
@@ -8879,7 +7127,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('GraphemeType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -8889,8 +7137,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -8902,58 +7148,44 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='GraphemeType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='GraphemeType'):
super(GraphemeType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='GraphemeType')
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeType', fromsubclass_=False, pretty_print=True):
- super(GraphemeType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeType', fromsubclass_=False, pretty_print=True):
+ super(GraphemeType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.Coords is not None:
- namespaceprefix_ = self.Coords_nsprefix_ + ':' if (UseCapturedNS_ and self.Coords_nsprefix_) else ''
self.Coords.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Coords', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
super(GraphemeType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Coords':
obj_ = CoordsType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Coords = obj_
obj_.original_tagname_ = 'Coords'
super(GraphemeType, self).buildChildren(child_, node, nodeName_, True)
- def __hash__(self):
- return hash(self.id)
# end class GraphemeType
class NonPrintingCharType(GraphemeBaseType):
- """A glyph component without visual representation
- but with Unicode code point.
- Non-visual / non-printing / control character.
- Part of grapheme container (of glyph) or grapheme sub group."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- ]
+ """A glyph component without visual representation but with Unicode
+ code point. Non-visual / non-printing / control character. Part
+ of grapheme container (of glyph) or grapheme sub group."""
subclass = None
superclass = GraphemeBaseType
- def __init__(self, id=None, index=None, ligature=None, charType=None, custom=None, comments=None, TextEquiv=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, index=None, ligature=None, charType=None, custom=None, comments=None, TextEquiv=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(NonPrintingCharType, self).__init__(id, index, ligature, charType, custom, comments, TextEquiv, **kwargs_)
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
@@ -8966,10 +7198,6 @@ def factory(*args_, **kwargs_):
else:
return NonPrintingCharType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def hasContent_(self):
if (
super(NonPrintingCharType, self).hasContent_()
@@ -8977,7 +7205,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='NonPrintingCharType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='NonPrintingCharType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('NonPrintingCharType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -8987,8 +7215,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9000,56 +7226,40 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='NonPrintingCharType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='NonPrintingCharType'):
super(NonPrintingCharType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='NonPrintingCharType')
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='NonPrintingCharType', fromsubclass_=False, pretty_print=True):
- super(NonPrintingCharType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='NonPrintingCharType', fromsubclass_=False, pretty_print=True):
+ super(NonPrintingCharType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
super(NonPrintingCharType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(NonPrintingCharType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class NonPrintingCharType
class GraphemeGroupType(GraphemeBaseType):
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('Grapheme', 'GraphemeType', 1, 1, {'name': 'Grapheme', 'type': 'GraphemeType'}, 9),
- MemberSpec_('NonPrintingChar', 'NonPrintingCharType', 1, 1, {'name': 'NonPrintingChar', 'type': 'NonPrintingCharType'}, 9),
- ]
subclass = None
superclass = GraphemeBaseType
- def __init__(self, id=None, index=None, ligature=None, charType=None, custom=None, comments=None, TextEquiv=None, Grapheme=None, NonPrintingChar=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, index=None, ligature=None, charType=None, custom=None, comments=None, TextEquiv=None, Grapheme=None, NonPrintingChar=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(GraphemeGroupType, self).__init__(id, index, ligature, charType, custom, comments, TextEquiv, **kwargs_)
if Grapheme is None:
self.Grapheme = []
else:
self.Grapheme = Grapheme
- self.Grapheme_nsprefix_ = None
if NonPrintingChar is None:
self.NonPrintingChar = []
else:
self.NonPrintingChar = NonPrintingChar
- self.NonPrintingChar_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -9061,16 +7271,14 @@ def factory(*args_, **kwargs_):
else:
return GraphemeGroupType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Grapheme(self):
return self.Grapheme
def set_Grapheme(self, Grapheme):
self.Grapheme = Grapheme
def add_Grapheme(self, value):
self.Grapheme.append(value)
+ def add_Grapheme(self, value):
+ self.Grapheme.append(value)
def insert_Grapheme_at(self, index, value):
self.Grapheme.insert(index, value)
def replace_Grapheme_at(self, index, value):
@@ -9081,6 +7289,8 @@ def set_NonPrintingChar(self, NonPrintingChar):
self.NonPrintingChar = NonPrintingChar
def add_NonPrintingChar(self, value):
self.NonPrintingChar.append(value)
+ def add_NonPrintingChar(self, value):
+ self.NonPrintingChar.append(value)
def insert_NonPrintingChar_at(self, index, value):
self.NonPrintingChar.insert(index, value)
def replace_NonPrintingChar_at(self, index, value):
@@ -9094,7 +7304,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeGroupType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeGroupType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('GraphemeGroupType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -9104,8 +7314,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9117,69 +7325,53 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='GraphemeGroupType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='GraphemeGroupType'):
super(GraphemeGroupType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='GraphemeGroupType')
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeGroupType', fromsubclass_=False, pretty_print=True):
- super(GraphemeGroupType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='GraphemeGroupType', fromsubclass_=False, pretty_print=True):
+ super(GraphemeGroupType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for Grapheme_ in self.Grapheme:
- namespaceprefix_ = self.Grapheme_nsprefix_ + ':' if (UseCapturedNS_ and self.Grapheme_nsprefix_) else ''
Grapheme_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Grapheme', pretty_print=pretty_print)
for NonPrintingChar_ in self.NonPrintingChar:
- namespaceprefix_ = self.NonPrintingChar_nsprefix_ + ':' if (UseCapturedNS_ and self.NonPrintingChar_nsprefix_) else ''
NonPrintingChar_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='NonPrintingChar', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
super(GraphemeGroupType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Grapheme':
obj_ = GraphemeType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Grapheme.append(obj_)
obj_.original_tagname_ = 'Grapheme'
elif nodeName_ == 'NonPrintingChar':
obj_ = NonPrintingCharType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.NonPrintingChar.append(obj_)
obj_.original_tagname_ = 'NonPrintingChar'
super(GraphemeGroupType, self).buildChildren(child_, node, nodeName_, True)
- def __hash__(self):
- return hash(self.id)
# end class GraphemeGroupType
class UserDefinedType(GeneratedsSuper):
"""Container for user-defined attributes"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('UserAttribute', 'UserAttributeType', 1, 0, {'maxOccurs': 'unbounded', 'minOccurs': '1', 'name': 'UserAttribute', 'type': 'UserAttributeType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, UserAttribute=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, UserAttribute=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
if UserAttribute is None:
self.UserAttribute = []
else:
self.UserAttribute = UserAttribute
- self.UserAttribute_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -9191,16 +7383,14 @@ def factory(*args_, **kwargs_):
else:
return UserDefinedType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_UserAttribute(self):
return self.UserAttribute
def set_UserAttribute(self, UserAttribute):
self.UserAttribute = UserAttribute
def add_UserAttribute(self, value):
self.UserAttribute.append(value)
+ def add_UserAttribute(self, value):
+ self.UserAttribute.append(value)
def insert_UserAttribute_at(self, index, value):
self.UserAttribute.insert(index, value)
def replace_UserAttribute_at(self, index, value):
@@ -9212,7 +7402,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UserDefinedType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UserDefinedType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('UserDefinedType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -9222,8 +7412,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9235,65 +7423,44 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='UserDefinedType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='UserDefinedType'):
pass
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UserDefinedType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UserDefinedType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for UserAttribute_ in self.UserAttribute:
- namespaceprefix_ = self.UserAttribute_nsprefix_ + ':' if (UseCapturedNS_ and self.UserAttribute_nsprefix_) else ''
UserAttribute_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='UserAttribute', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
pass
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'UserAttribute':
obj_ = UserAttributeType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.UserAttribute.append(obj_)
obj_.original_tagname_ = 'UserAttribute'
- def __hash__(self):
- return hash(self.id)
# end class UserDefinedType
class UserAttributeType(GeneratedsSuper):
"""Structured custom data defined by name, type and value."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('name', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('description', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'string', 0, 1, {'use': 'optional'}),
- MemberSpec_('value', 'string', 0, 1, {'use': 'optional'}),
- ]
subclass = None
superclass = None
- def __init__(self, name=None, description=None, type_=None, value=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, name=None, description=None, type_=None, value=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.name = _cast(None, name)
- self.name_nsprefix_ = None
self.description = _cast(None, description)
- self.description_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.value = _cast(None, value)
- self.value_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -9305,10 +7472,6 @@ def factory(*args_, **kwargs_):
else:
return UserAttributeType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_name(self):
return self.name
def set_name(self, name):
@@ -9332,7 +7495,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UserAttributeType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UserAttributeType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('UserAttributeType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -9342,8 +7505,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9354,7 +7515,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='UserAttributeType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='UserAttributeType'):
if self.name is not None and 'name' not in already_processed:
already_processed.add('name')
outfile.write(' name=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.name), input_name='name')), ))
@@ -9367,18 +7528,14 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.value is not None and 'value' not in already_processed:
already_processed.add('value')
outfile.write(' value=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.value), input_name='value')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UserAttributeType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='UserAttributeType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('name', node)
@@ -9397,44 +7554,26 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'value' not in already_processed:
already_processed.add('value')
self.value = value
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class UserAttributeType
class TableCellRoleType(GeneratedsSuper):
"""Cell position in table starting with row 0Cell position in table
- starting with column 0Number of rows the cell spans (optional; default
- is 1)Number of columns the cell spans (optional; default is 1)
- Is the cell a column or row header?"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('rowIndex', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('columnIndex', 'int', 0, 0, {'use': 'required'}),
- MemberSpec_('rowSpan', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('colSpan', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('header', 'boolean', 0, 1, {'use': 'optional'}),
- ]
+ starting with column 0Number of rows the cell spans (optional;
+ default is 1)Number of columns the cell spans (optional; default
+ is 1) Is the cell a column or row header?"""
subclass = None
superclass = None
- def __init__(self, rowIndex=None, columnIndex=None, rowSpan=None, colSpan=None, header=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, rowIndex=None, columnIndex=None, rowSpan=None, colSpan=None, header=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.rowIndex = _cast(int, rowIndex)
- self.rowIndex_nsprefix_ = None
self.columnIndex = _cast(int, columnIndex)
- self.columnIndex_nsprefix_ = None
self.rowSpan = _cast(int, rowSpan)
- self.rowSpan_nsprefix_ = None
self.colSpan = _cast(int, colSpan)
- self.colSpan_nsprefix_ = None
self.header = _cast(bool, header)
- self.header_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -9446,10 +7585,6 @@ def factory(*args_, **kwargs_):
else:
return TableCellRoleType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_rowIndex(self):
return self.rowIndex
def set_rowIndex(self, rowIndex):
@@ -9477,7 +7612,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TableCellRoleType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TableCellRoleType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('TableCellRoleType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -9487,8 +7622,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9499,7 +7632,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='TableCellRoleType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='TableCellRoleType'):
if self.rowIndex is not None and 'rowIndex' not in already_processed:
already_processed.add('rowIndex')
outfile.write(' rowIndex="%s"' % self.gds_format_integer(self.rowIndex, input_name='rowIndex'))
@@ -9515,36 +7648,44 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
if self.header is not None and 'header' not in already_processed:
already_processed.add('header')
outfile.write(' header="%s"' % self.gds_format_boolean(self.header, input_name='header'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TableCellRoleType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='TableCellRoleType', fromsubclass_=False, pretty_print=True):
pass
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('rowIndex', node)
if value is not None and 'rowIndex' not in already_processed:
already_processed.add('rowIndex')
- self.rowIndex = self.gds_parse_integer(value, node, 'rowIndex')
+ try:
+ self.rowIndex = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('columnIndex', node)
if value is not None and 'columnIndex' not in already_processed:
already_processed.add('columnIndex')
- self.columnIndex = self.gds_parse_integer(value, node, 'columnIndex')
+ try:
+ self.columnIndex = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('rowSpan', node)
if value is not None and 'rowSpan' not in already_processed:
already_processed.add('rowSpan')
- self.rowSpan = self.gds_parse_integer(value, node, 'rowSpan')
+ try:
+ self.rowSpan = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('colSpan', node)
if value is not None and 'colSpan' not in already_processed:
already_processed.add('colSpan')
- self.colSpan = self.gds_parse_integer(value, node, 'colSpan')
+ try:
+ self.colSpan = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('header', node)
if value is not None and 'header' not in already_processed:
already_processed.add('header')
@@ -9554,28 +7695,18 @@ def buildAttributes(self, node, attrs, already_processed):
self.header = False
else:
raise_parse_error(node, 'Bad boolean attribute')
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
pass
- def __hash__(self):
- return hash(self.id)
# end class TableCellRoleType
class RolesType(GeneratedsSuper):
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('TableCellRole', 'TableCellRoleType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'TableCellRole', 'type': 'TableCellRoleType'}, None),
- ]
subclass = None
superclass = None
- def __init__(self, TableCellRole=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, TableCellRole=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
self.TableCellRole = TableCellRole
- self.TableCellRole_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -9587,10 +7718,6 @@ def factory(*args_, **kwargs_):
else:
return RolesType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_TableCellRole(self):
return self.TableCellRole
def set_TableCellRole(self, TableCellRole):
@@ -9602,7 +7729,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RolesType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RolesType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('RolesType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -9612,8 +7739,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9625,61 +7750,45 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="h
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='RolesType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='RolesType'):
pass
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RolesType', fromsubclass_=False, pretty_print=True):
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"', name_='RolesType', fromsubclass_=False, pretty_print=True):
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.TableCellRole is not None:
- namespaceprefix_ = self.TableCellRole_nsprefix_ + ':' if (UseCapturedNS_ and self.TableCellRole_nsprefix_) else ''
self.TableCellRole.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TableCellRole', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
pass
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'TableCellRole':
obj_ = TableCellRoleType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TableCellRole = obj_
obj_.original_tagname_ = 'TableCellRole'
- def __hash__(self):
- return hash(self.id)
# end class RolesType
class CustomRegionType(RegionType):
- """Regions containing content that is not covered
- by the default types (text, graphic, image,
- line drawing, chart, table, separator, maths,
- map, music, chem, advert, noise, unknown).
- Information on the type of content represented by this region"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('type_', 'string', 0, 1, {'use': 'optional'}),
- ]
+ """Regions containing content that is not covered by the default types
+ (text, graphic, image, line drawing, chart, table, separator,
+ maths, map, music, chem, advert, noise, unknown). Information on
+ the type of content represented by this region"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, type_=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, type_=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(CustomRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -9691,10 +7800,6 @@ def factory(*args_, **kwargs_):
else:
return CustomRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_type(self):
return self.type_
def set_type(self, type_):
@@ -9706,7 +7811,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='CustomRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='CustomRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('CustomRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -9716,8 +7821,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='C
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9729,23 +7832,19 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='C
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='CustomRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='CustomRegionType'):
super(CustomRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='CustomRegionType')
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='CustomRegionType', fromsubclass_=False, pretty_print=True):
- super(CustomRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='CustomRegionType', fromsubclass_=False, pretty_print=True):
+ super(CustomRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('type', node)
@@ -9753,27 +7852,19 @@ def buildAttributes(self, node, attrs, already_processed):
already_processed.add('type')
self.type_ = value
super(CustomRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(CustomRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class CustomRegionType
class UnknownRegionType(RegionType):
"""To be used if the region type cannot be ascertained."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- ]
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(UnknownRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
@@ -9786,10 +7877,6 @@ def factory(*args_, **kwargs_):
else:
return UnknownRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def hasContent_(self):
if (
super(UnknownRegionType, self).hasContent_()
@@ -9797,7 +7884,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='UnknownRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='UnknownRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('UnknownRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -9807,8 +7894,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='U
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9820,46 +7905,33 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='U
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='UnknownRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='UnknownRegionType'):
super(UnknownRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='UnknownRegionType')
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='UnknownRegionType', fromsubclass_=False, pretty_print=True):
- super(UnknownRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='UnknownRegionType', fromsubclass_=False, pretty_print=True):
+ super(UnknownRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
super(UnknownRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(UnknownRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class UnknownRegionType
class NoiseRegionType(RegionType):
- """Noise regions are regions where no real data lies, only
- false data created by artifacts on the document or
- scanner noise."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- ]
+ """Noise regions are regions where no real data lies, only false data
+ created by artifacts on the document or scanner noise."""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(NoiseRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
@@ -9872,10 +7944,6 @@ def factory(*args_, **kwargs_):
else:
return NoiseRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def hasContent_(self):
if (
super(NoiseRegionType, self).hasContent_()
@@ -9883,7 +7951,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='NoiseRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='NoiseRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('NoiseRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -9893,8 +7961,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='N
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -9906,57 +7972,39 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='N
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='NoiseRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='NoiseRegionType'):
super(NoiseRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='NoiseRegionType')
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='NoiseRegionType', fromsubclass_=False, pretty_print=True):
- super(NoiseRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='NoiseRegionType', fromsubclass_=False, pretty_print=True):
+ super(NoiseRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
super(NoiseRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(NoiseRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class NoiseRegionType
class AdvertRegionType(RegionType):
- """Regions containing advertisements.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The background colour of the region"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- ]
+ """Regions containing advertisements. The angle the rectangle
+ encapsulating a region has to be rotated in clockwise direction
+ in order to correct the present skew (negative values indicate
+ anti-clockwise rotation). Range: -179.999,180 The background
+ colour of the region"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, bgColour=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, bgColour=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(AdvertRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -9968,10 +8016,6 @@ def factory(*args_, **kwargs_):
else:
return AdvertRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -9980,19 +8024,6 @@ def get_bgColour(self):
return self.bgColour
def set_bgColour(self, bgColour):
self.bgColour = bgColour
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(AdvertRegionType, self).hasContent_()
@@ -10000,7 +8031,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='AdvertRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='AdvertRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('AdvertRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -10010,8 +8041,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='A
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -10023,73 +8052,56 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='A
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='AdvertRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='AdvertRegionType'):
super(AdvertRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='AdvertRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='AdvertRegionType', fromsubclass_=False, pretty_print=True):
- super(AdvertRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='AdvertRegionType', fromsubclass_=False, pretty_print=True):
+ super(AdvertRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
super(AdvertRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(AdvertRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class AdvertRegionType
class MusicRegionType(RegionType):
- """Regions containing musical notations.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The background colour of the region"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- ]
+ """Regions containing musical notations. The angle the rectangle
+ encapsulating a region has to be rotated in clockwise direction
+ in order to correct the present skew (negative values indicate
+ anti-clockwise rotation). Range: -179.999,180 The background
+ colour of the region"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, bgColour=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, bgColour=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(MusicRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -10101,10 +8113,6 @@ def factory(*args_, **kwargs_):
else:
return MusicRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -10113,19 +8121,6 @@ def get_bgColour(self):
return self.bgColour
def set_bgColour(self, bgColour):
self.bgColour = bgColour
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(MusicRegionType, self).hasContent_()
@@ -10133,7 +8128,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='MusicRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='MusicRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('MusicRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -10143,8 +8138,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='M
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -10156,70 +8149,54 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='M
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='MusicRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='MusicRegionType'):
super(MusicRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='MusicRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='MusicRegionType', fromsubclass_=False, pretty_print=True):
- super(MusicRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='MusicRegionType', fromsubclass_=False, pretty_print=True):
+ super(MusicRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
super(MusicRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(MusicRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class MusicRegionType
class MapRegionType(RegionType):
- """Regions containing maps.
- The angle the rectangle encapsulating a
- region has to be rotated in clockwise
- direction in order to correct the present
- skew (negative values indicate
- anti-clockwise rotation). Range:
- -179.999,180"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- ]
+ """Regions containing maps. The angle the rectangle encapsulating a
+ region has to be rotated in clockwise direction in order to
+ correct the present skew (negative values indicate anti-
+ clockwise rotation). Range: -179.999,180"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(MapRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -10231,10 +8208,6 @@ def factory(*args_, **kwargs_):
else:
return MapRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -10246,7 +8219,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='MapRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='MapRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('MapRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -10256,8 +8229,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='M
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -10269,66 +8240,49 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='M
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='MapRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='MapRegionType'):
super(MapRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='MapRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='MapRegionType', fromsubclass_=False, pretty_print=True):
- super(MapRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='MapRegionType', fromsubclass_=False, pretty_print=True):
+ super(MapRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
super(MapRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(MapRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class MapRegionType
class ChemRegionType(RegionType):
- """Regions containing chemical formulas.
- The angle the rectangle encapsulating a
- region has to be rotated in clockwise
- direction in order to correct the present
- skew (negative values indicate
- anti-clockwise rotation). Range:
- -179.999,180
- The background colour of the region"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- ]
+ """Regions containing chemical formulas. The angle the rectangle
+ encapsulating a region has to be rotated in clockwise direction
+ in order to correct the present skew (negative values indicate
+ anti-clockwise rotation). Range: -179.999,180 The background
+ colour of the region"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, bgColour=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, bgColour=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(ChemRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -10340,10 +8294,6 @@ def factory(*args_, **kwargs_):
else:
return ChemRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -10352,19 +8302,6 @@ def get_bgColour(self):
return self.bgColour
def set_bgColour(self, bgColour):
self.bgColour = bgColour
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(ChemRegionType, self).hasContent_()
@@ -10372,7 +8309,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='ChemRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='ChemRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('ChemRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -10382,8 +8319,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='C
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -10395,74 +8330,57 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='C
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='ChemRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='ChemRegionType'):
super(ChemRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='ChemRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='ChemRegionType', fromsubclass_=False, pretty_print=True):
- super(ChemRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='ChemRegionType', fromsubclass_=False, pretty_print=True):
+ super(ChemRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
super(ChemRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(ChemRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class ChemRegionType
class MathsRegionType(RegionType):
- """Regions containing equations and mathematical symbols
- should be marked as maths regions.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The background colour of the region"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- ]
+ """Regions containing equations and mathematical symbols should be
+ marked as maths regions. The angle the rectangle encapsulating a
+ region has to be rotated in clockwise direction in order to
+ correct the present skew (negative values indicate anti-
+ clockwise rotation). Range: -179.999,180 The background colour
+ of the region"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, bgColour=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, bgColour=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(MathsRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -10474,10 +8392,6 @@ def factory(*args_, **kwargs_):
else:
return MathsRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -10486,19 +8400,6 @@ def get_bgColour(self):
return self.bgColour
def set_bgColour(self, bgColour):
self.bgColour = bgColour
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(MathsRegionType, self).hasContent_()
@@ -10506,7 +8407,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='MathsRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='MathsRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('MathsRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -10516,8 +8417,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='M
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -10529,75 +8428,57 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='M
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='MathsRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='MathsRegionType'):
super(MathsRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='MathsRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='MathsRegionType', fromsubclass_=False, pretty_print=True):
- super(MathsRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='MathsRegionType', fromsubclass_=False, pretty_print=True):
+ super(MathsRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
super(MathsRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(MathsRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class MathsRegionType
class SeparatorRegionType(RegionType):
- """Separators are lines that lie between columns and
- paragraphs and can be used to logically separate
- different articles from each other.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The colour of the separator"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('colour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- ]
+ """Separators are lines that lie between columns and paragraphs and can
+ be used to logically separate different articles from each
+ other. The angle the rectangle encapsulating a region has to be
+ rotated in clockwise direction in order to correct the present
+ skew (negative values indicate anti-clockwise rotation). Range:
+ -179.999,180 The colour of the separator"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, colour=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, colour=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(SeparatorRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.colour = _cast(None, colour)
- self.colour_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -10609,10 +8490,6 @@ def factory(*args_, **kwargs_):
else:
return SeparatorRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -10621,19 +8498,6 @@ def get_colour(self):
return self.colour
def set_colour(self, colour):
self.colour = colour
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(SeparatorRegionType, self).hasContent_()
@@ -10641,7 +8505,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='SeparatorRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='SeparatorRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('SeparatorRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -10651,8 +8515,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='S
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -10664,88 +8526,62 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='S
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='SeparatorRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='SeparatorRegionType'):
super(SeparatorRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='SeparatorRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.colour is not None and 'colour' not in already_processed:
already_processed.add('colour')
- outfile.write(' colour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.colour), input_name='colour')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='SeparatorRegionType', fromsubclass_=False, pretty_print=True):
- super(SeparatorRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ outfile.write(' colour=%s' % (quote_attrib(self.colour), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='SeparatorRegionType', fromsubclass_=False, pretty_print=True):
+ super(SeparatorRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('colour', node)
if value is not None and 'colour' not in already_processed:
already_processed.add('colour')
self.colour = value
- self.validate_ColourSimpleType(self.colour) # validate type ColourSimpleType
super(SeparatorRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(SeparatorRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class SeparatorRegionType
class ChartRegionType(RegionType):
- """Regions containing charts or graphs of any type, should
- be marked as chart regions.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The type of chart in the region
- An approximation of the number of colours
- used in the region
- The background colour of the region
- Specifies whether the region also contains
- text"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'pc:ChartTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('numColours', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('embText', 'boolean', 0, 1, {'use': 'optional'}),
- ]
+ """Regions containing charts or graphs of any type, should be marked as
+ chart regions. The angle the rectangle encapsulating a region
+ has to be rotated in clockwise direction in order to correct the
+ present skew (negative values indicate anti-clockwise rotation).
+ Range: -179.999,180 The type of chart in the region An
+ approximation of the number of colours used in the region The
+ background colour of the region Specifies whether the region
+ also contains text"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, type_=None, numColours=None, bgColour=None, embText=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, type_=None, numColours=None, bgColour=None, embText=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(ChartRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.numColours = _cast(int, numColours)
- self.numColours_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
self.embText = _cast(bool, embText)
- self.embText_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -10757,10 +8593,6 @@ def factory(*args_, **kwargs_):
else:
return ChartRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -10781,32 +8613,6 @@ def get_embText(self):
return self.embText
def set_embText(self, embText):
self.embText = embText
- def validate_ChartTypeSimpleType(self, value):
- # Validate type pc:ChartTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['bar', 'line', 'pie', 'scatter', 'surface', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ChartTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(ChartRegionType, self).hasContent_()
@@ -10814,7 +8620,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='ChartRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='ChartRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('ChartRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -10824,8 +8630,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='C
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -10837,56 +8641,55 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='C
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='ChartRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='ChartRegionType'):
super(ChartRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='ChartRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
- outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
+ outfile.write(' type=%s' % (quote_attrib(self.type_), ))
if self.numColours is not None and 'numColours' not in already_processed:
already_processed.add('numColours')
outfile.write(' numColours="%s"' % self.gds_format_integer(self.numColours, input_name='numColours'))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
if self.embText is not None and 'embText' not in already_processed:
already_processed.add('embText')
outfile.write(' embText="%s"' % self.gds_format_boolean(self.embText, input_name='embText'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='ChartRegionType', fromsubclass_=False, pretty_print=True):
- super(ChartRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='ChartRegionType', fromsubclass_=False, pretty_print=True):
+ super(ChartRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('type', node)
if value is not None and 'type' not in already_processed:
already_processed.add('type')
self.type_ = value
- self.validate_ChartTypeSimpleType(self.type_) # validate type ChartTypeSimpleType
value = find_attr_value_('numColours', node)
if value is not None and 'numColours' not in already_processed:
already_processed.add('numColours')
- self.numColours = self.gds_parse_integer(value, node, 'numColours')
+ try:
+ self.numColours = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
value = find_attr_value_('embText', node)
if value is not None and 'embText' not in already_processed:
already_processed.add('embText')
@@ -10897,66 +8700,37 @@ def buildAttributes(self, node, attrs, already_processed):
else:
raise_parse_error(node, 'Bad boolean attribute')
super(ChartRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(ChartRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class ChartRegionType
class TableRegionType(RegionType):
- """Tabular data in any form is represented with a table
- region. Rows and columns may or may not have separator
- lines; these lines are not separator regions.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The number of rows present in the table
- The number of columns present in the table
- The colour of the lines used in the region
- The background colour of the region
- Specifies the presence of line separators
- Specifies whether the region also contains
- text"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('rows', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('columns', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('lineColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('lineSeparators', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('embText', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('Grid', 'GridType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'Grid', 'type': 'GridType'}, None),
- ]
+ """Tabular data in any form is represented with a table region. Rows
+ and columns may or may not have separator lines; these lines are
+ not separator regions. The angle the rectangle encapsulating a
+ region has to be rotated in clockwise direction in order to
+ correct the present skew (negative values indicate anti-
+ clockwise rotation). Range: -179.999,180 The number of rows
+ present in the table The number of columns present in the table
+ The colour of the lines used in the region The background colour
+ of the region Specifies the presence of line separators
+ Specifies whether the region also contains text"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, rows=None, columns=None, lineColour=None, bgColour=None, lineSeparators=None, embText=None, Grid=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, rows=None, columns=None, lineColour=None, bgColour=None, lineSeparators=None, embText=None, Grid=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(TableRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.rows = _cast(int, rows)
- self.rows_nsprefix_ = None
self.columns = _cast(int, columns)
- self.columns_nsprefix_ = None
self.lineColour = _cast(None, lineColour)
- self.lineColour_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
self.lineSeparators = _cast(bool, lineSeparators)
- self.lineSeparators_nsprefix_ = None
self.embText = _cast(bool, embText)
- self.embText_nsprefix_ = None
self.Grid = Grid
- self.Grid_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -10968,10 +8742,6 @@ def factory(*args_, **kwargs_):
else:
return TableRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_Grid(self):
return self.Grid
def set_Grid(self, Grid):
@@ -11004,19 +8774,6 @@ def get_embText(self):
return self.embText
def set_embText(self, embText):
self.embText = embText
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.Grid is not None or
@@ -11025,7 +8782,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='TableRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='TableRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('TableRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -11035,8 +8792,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='T
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -11048,7 +8803,7 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='T
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='TableRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='TableRegionType'):
super(TableRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='TableRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
@@ -11061,60 +8816,61 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' columns="%s"' % self.gds_format_integer(self.columns, input_name='columns'))
if self.lineColour is not None and 'lineColour' not in already_processed:
already_processed.add('lineColour')
- outfile.write(' lineColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.lineColour), input_name='lineColour')), ))
+ outfile.write(' lineColour=%s' % (quote_attrib(self.lineColour), ))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
if self.lineSeparators is not None and 'lineSeparators' not in already_processed:
already_processed.add('lineSeparators')
outfile.write(' lineSeparators="%s"' % self.gds_format_boolean(self.lineSeparators, input_name='lineSeparators'))
if self.embText is not None and 'embText' not in already_processed:
already_processed.add('embText')
outfile.write(' embText="%s"' % self.gds_format_boolean(self.embText, input_name='embText'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='TableRegionType', fromsubclass_=False, pretty_print=True):
- super(TableRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='TableRegionType', fromsubclass_=False, pretty_print=True):
+ super(TableRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
if self.Grid is not None:
- namespaceprefix_ = self.Grid_nsprefix_ + ':' if (UseCapturedNS_ and self.Grid_nsprefix_) else ''
self.Grid.export(outfile, level, namespaceprefix_, namespacedef_='', name_='Grid', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('rows', node)
if value is not None and 'rows' not in already_processed:
already_processed.add('rows')
- self.rows = self.gds_parse_integer(value, node, 'rows')
+ try:
+ self.rows = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('columns', node)
if value is not None and 'columns' not in already_processed:
already_processed.add('columns')
- self.columns = self.gds_parse_integer(value, node, 'columns')
+ try:
+ self.columns = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('lineColour', node)
if value is not None and 'lineColour' not in already_processed:
already_processed.add('lineColour')
self.lineColour = value
- self.validate_ColourSimpleType(self.lineColour) # validate type ColourSimpleType
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
value = find_attr_value_('lineSeparators', node)
if value is not None and 'lineSeparators' not in already_processed:
already_processed.add('lineSeparators')
@@ -11134,55 +8890,35 @@ def buildAttributes(self, node, attrs, already_processed):
else:
raise_parse_error(node, 'Bad boolean attribute')
super(TableRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'Grid':
obj_ = GridType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.Grid = obj_
obj_.original_tagname_ = 'Grid'
super(TableRegionType, self).buildChildren(child_, node, nodeName_, True)
- def __hash__(self):
- return hash(self.id)
# end class TableRegionType
class GraphicRegionType(RegionType):
- """Regions containing simple graphics, such as a company
- logo, should be marked as graphic regions.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The type of graphic in the region
- An approximation of the number of colours
- used in the region
- Specifies whether the region also contains
+ """Regions containing simple graphics, such as a company logo, should
+ be marked as graphic regions. The angle the rectangle
+ encapsulating a region has to be rotated in clockwise direction
+ in order to correct the present skew (negative values indicate
+ anti-clockwise rotation). Range: -179.999,180 The type of
+ graphic in the region An approximation of the number of colours
+ used in the region Specifies whether the region also contains
text."""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'pc:GraphicsTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('numColours', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('embText', 'boolean', 0, 1, {'use': 'optional'}),
- ]
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, type_=None, numColours=None, embText=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, type_=None, numColours=None, embText=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(GraphicRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.numColours = _cast(int, numColours)
- self.numColours_nsprefix_ = None
self.embText = _cast(bool, embText)
- self.embText_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -11194,10 +8930,6 @@ def factory(*args_, **kwargs_):
else:
return GraphicRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -11214,19 +8946,6 @@ def get_embText(self):
return self.embText
def set_embText(self, embText):
self.embText = embText
- def validate_GraphicsTypeSimpleType(self, value):
- # Validate type pc:GraphicsTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['logo', 'letterhead', 'decoration', 'frame', 'handwritten-annotation', 'stamp', 'signature', 'barcode', 'paper-grow', 'punch-hole', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on GraphicsTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(GraphicRegionType, self).hasContent_()
@@ -11234,7 +8953,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='GraphicRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='GraphicRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('GraphicRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -11244,8 +8963,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='G
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -11257,48 +8974,48 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='G
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='GraphicRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='GraphicRegionType'):
super(GraphicRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='GraphicRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
- outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
+ outfile.write(' type=%s' % (quote_attrib(self.type_), ))
if self.numColours is not None and 'numColours' not in already_processed:
already_processed.add('numColours')
outfile.write(' numColours="%s"' % self.gds_format_integer(self.numColours, input_name='numColours'))
if self.embText is not None and 'embText' not in already_processed:
already_processed.add('embText')
outfile.write(' embText="%s"' % self.gds_format_boolean(self.embText, input_name='embText'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='GraphicRegionType', fromsubclass_=False, pretty_print=True):
- super(GraphicRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='GraphicRegionType', fromsubclass_=False, pretty_print=True):
+ super(GraphicRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('type', node)
if value is not None and 'type' not in already_processed:
already_processed.add('type')
self.type_ = value
- self.validate_GraphicsTypeSimpleType(self.type_) # validate type GraphicsTypeSimpleType
value = find_attr_value_('numColours', node)
if value is not None and 'numColours' not in already_processed:
already_processed.add('numColours')
- self.numColours = self.gds_parse_integer(value, node, 'numColours')
+ try:
+ self.numColours = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('embText', node)
if value is not None and 'embText' not in already_processed:
already_processed.add('embText')
@@ -11309,50 +9026,30 @@ def buildAttributes(self, node, attrs, already_processed):
else:
raise_parse_error(node, 'Bad boolean attribute')
super(GraphicRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(GraphicRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class GraphicRegionType
class LineDrawingRegionType(RegionType):
- """A line drawing is a single colour illustration without
- solid areas.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The pen (foreground) colour of the region
- The background colour of the region
- Specifies whether the region also contains
- text"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('penColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('embText', 'boolean', 0, 1, {'use': 'optional'}),
- ]
+ """A line drawing is a single colour illustration without solid areas.
+ The angle the rectangle encapsulating a region has to be rotated
+ in clockwise direction in order to correct the present skew
+ (negative values indicate anti-clockwise rotation). Range:
+ -179.999,180 The pen (foreground) colour of the region The
+ background colour of the region Specifies whether the region
+ also contains text"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, penColour=None, bgColour=None, embText=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, penColour=None, bgColour=None, embText=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(LineDrawingRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.penColour = _cast(None, penColour)
- self.penColour_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
self.embText = _cast(bool, embText)
- self.embText_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -11364,10 +9061,6 @@ def factory(*args_, **kwargs_):
else:
return LineDrawingRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -11384,19 +9077,6 @@ def get_embText(self):
return self.embText
def set_embText(self, embText):
self.embText = embText
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(LineDrawingRegionType, self).hasContent_()
@@ -11404,7 +9084,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='LineDrawingRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='LineDrawingRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('LineDrawingRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -11414,8 +9094,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='L
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -11427,49 +9105,45 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='L
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='LineDrawingRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='LineDrawingRegionType'):
super(LineDrawingRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='LineDrawingRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.penColour is not None and 'penColour' not in already_processed:
already_processed.add('penColour')
- outfile.write(' penColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.penColour), input_name='penColour')), ))
+ outfile.write(' penColour=%s' % (quote_attrib(self.penColour), ))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
if self.embText is not None and 'embText' not in already_processed:
already_processed.add('embText')
outfile.write(' embText="%s"' % self.gds_format_boolean(self.embText, input_name='embText'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='LineDrawingRegionType', fromsubclass_=False, pretty_print=True):
- super(LineDrawingRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='LineDrawingRegionType', fromsubclass_=False, pretty_print=True):
+ super(LineDrawingRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('penColour', node)
if value is not None and 'penColour' not in already_processed:
already_processed.add('penColour')
self.penColour = value
- self.validate_ColourSimpleType(self.penColour) # validate type ColourSimpleType
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
value = find_attr_value_('embText', node)
if value is not None and 'embText' not in already_processed:
already_processed.add('embText')
@@ -11480,50 +9154,30 @@ def buildAttributes(self, node, attrs, already_processed):
else:
raise_parse_error(node, 'Bad boolean attribute')
super(LineDrawingRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(LineDrawingRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class LineDrawingRegionType
class ImageRegionType(RegionType):
- """An image is considered to be more intricate and complex
- than a graphic. These can be photos or drawings.
- The angle the rectangle encapsulating a region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- The colour bit depth required for the region
- The background colour of the region
- Specifies whether the region also contains
- text"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('colourDepth', 'pc:ColourDepthSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('bgColour', 'pc:ColourSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('embText', 'boolean', 0, 1, {'use': 'optional'}),
- ]
+ """An image is considered to be more intricate and complex than a
+ graphic. These can be photos or drawings. The angle the
+ rectangle encapsulating a region has to be rotated in clockwise
+ direction in order to correct the present skew (negative values
+ indicate anti-clockwise rotation). Range: -179.999,180 The
+ colour bit depth required for the region The background colour
+ of the region Specifies whether the region also contains text"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, colourDepth=None, bgColour=None, embText=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, colourDepth=None, bgColour=None, embText=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(ImageRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.colourDepth = _cast(None, colourDepth)
- self.colourDepth_nsprefix_ = None
self.bgColour = _cast(None, bgColour)
- self.bgColour_nsprefix_ = None
self.embText = _cast(bool, embText)
- self.embText_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -11535,10 +9189,6 @@ def factory(*args_, **kwargs_):
else:
return ImageRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_orientation(self):
return self.orientation
def set_orientation(self, orientation):
@@ -11555,32 +9205,6 @@ def get_embText(self):
return self.embText
def set_embText(self, embText):
self.embText = embText
- def validate_ColourDepthSimpleType(self, value):
- # Validate type pc:ColourDepthSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['bilevel', 'greyscale', 'colour', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourDepthSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ColourSimpleType(self, value):
- # Validate type pc:ColourSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['black', 'blue', 'brown', 'cyan', 'green', 'grey', 'indigo', 'magenta', 'orange', 'pink', 'red', 'turquoise', 'violet', 'white', 'yellow', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ColourSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
super(ImageRegionType, self).hasContent_()
@@ -11588,7 +9212,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='ImageRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='ImageRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('ImageRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -11598,8 +9222,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='I
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -11611,49 +9233,45 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='I
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='ImageRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='ImageRegionType'):
super(ImageRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='ImageRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.colourDepth is not None and 'colourDepth' not in already_processed:
already_processed.add('colourDepth')
- outfile.write(' colourDepth=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.colourDepth), input_name='colourDepth')), ))
+ outfile.write(' colourDepth=%s' % (quote_attrib(self.colourDepth), ))
if self.bgColour is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
- outfile.write(' bgColour=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.bgColour), input_name='bgColour')), ))
+ outfile.write(' bgColour=%s' % (quote_attrib(self.bgColour), ))
if self.embText is not None and 'embText' not in already_processed:
already_processed.add('embText')
outfile.write(' embText="%s"' % self.gds_format_boolean(self.embText, input_name='embText'))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='ImageRegionType', fromsubclass_=False, pretty_print=True):
- super(ImageRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='ImageRegionType', fromsubclass_=False, pretty_print=True):
+ super(ImageRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('colourDepth', node)
if value is not None and 'colourDepth' not in already_processed:
already_processed.add('colourDepth')
self.colourDepth = value
- self.validate_ColourDepthSimpleType(self.colourDepth) # validate type ColourDepthSimpleType
value = find_attr_value_('bgColour', node)
if value is not None and 'bgColour' not in already_processed:
already_processed.add('bgColour')
self.bgColour = value
- self.validate_ColourSimpleType(self.bgColour) # validate type ColourSimpleType
value = find_attr_value_('embText', node)
if value is not None and 'embText' not in already_processed:
already_processed.add('embText')
@@ -11664,112 +9282,61 @@ def buildAttributes(self, node, attrs, already_processed):
else:
raise_parse_error(node, 'Bad boolean attribute')
super(ImageRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
super(ImageRegionType, self).buildChildren(child_, node, nodeName_, True)
pass
- def __hash__(self):
- return hash(self.id)
# end class ImageRegionType
class TextRegionType(RegionType):
- """Pure text is represented as a text region. This includes
- drop capitals, but practically ornate text may be
- considered as a graphic.
- The angle the rectangle encapsulating the region
- has to be rotated in clockwise direction
- in order to correct the present skew
- (negative values indicate anti-clockwise rotation).
- (The rotated image can be further referenced
- via “AlternativeImage”.)
- Range: -179.999,180
- The nature of the text in the region
- The degree of space in points between the lines of
- text (line spacing)
- The direction in which text within lines
- should be read (order of words and characters),
- in addition to “textLineOrder”.
- The order of text lines within the block,
- in addition to “readingDirection”.
- The angle the baseline of text within the region
- has to be rotated (relative to the rectangle
- encapsulating the region) in clockwise direction
- in order to correct the present skew,
- in addition to “orientation”
- (negative values indicate anti-clockwise rotation).
- Range: -179.999,180
- Defines whether a region of text is indented or not
- Text align
- The primary language used in the region
- The secondary language used in the region
- The primary script used in the region
- The secondary script used in the region"""
- __hash__ = GeneratedsSuper.__hash__
- member_data_items_ = [
- MemberSpec_('orientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('type_', 'pc:TextTypeSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('leading', 'int', 0, 1, {'use': 'optional'}),
- MemberSpec_('readingDirection', 'pc:ReadingDirectionSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('textLineOrder', 'pc:TextLineOrderSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('readingOrientation', 'float', 0, 1, {'use': 'optional'}),
- MemberSpec_('indented', 'boolean', 0, 1, {'use': 'optional'}),
- MemberSpec_('align', 'pc:AlignSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('primaryLanguage', 'pc:LanguageSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('secondaryLanguage', 'pc:LanguageSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('primaryScript', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('secondaryScript', 'pc:ScriptSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('production', 'pc:ProductionSimpleType', 0, 1, {'use': 'optional'}),
- MemberSpec_('TextLine', 'TextLineType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'TextLine', 'type': 'TextLineType'}, None),
- MemberSpec_('TextEquiv', 'TextEquivType', 1, 1, {'maxOccurs': 'unbounded', 'minOccurs': '0', 'name': 'TextEquiv', 'type': 'TextEquivType'}, None),
- MemberSpec_('TextStyle', 'TextStyleType', 0, 1, {'maxOccurs': '1', 'minOccurs': '0', 'name': 'TextStyle', 'type': 'TextStyleType'}, None),
- ]
+ """Pure text is represented as a text region. This includes drop
+ capitals, but practically ornate text may be considered as a
+ graphic. The angle the rectangle encapsulating the region has to
+ be rotated in clockwise direction in order to correct the
+ present skew (negative values indicate anti-clockwise rotation).
+ (The rotated image can be further referenced via
+ “AlternativeImage”.) Range: -179.999,180 The nature of the text
+ in the region The degree of space in points between the lines of
+ text (line spacing) The direction in which text within lines
+ should be read (order of words and characters), in addition to
+ “textLineOrder”. The order of text lines within the block, in
+ addition to “readingDirection”. The angle the baseline of text
+ within the region has to be rotated (relative to the rectangle
+ encapsulating the region) in clockwise direction in order to
+ correct the present skew, in addition to “orientation” (negative
+ values indicate anti-clockwise rotation). Range: -179.999,180
+ Defines whether a region of text is indented or not Text align
+ The primary language used in the region The secondary language
+ used in the region The primary script used in the region The
+ secondary script used in the region"""
subclass = None
superclass = RegionType
- def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, type_=None, leading=None, readingDirection=None, textLineOrder=None, readingOrientation=None, indented=None, align=None, primaryLanguage=None, secondaryLanguage=None, primaryScript=None, secondaryScript=None, production=None, TextLine=None, TextEquiv=None, TextStyle=None, gds_collector_=None, **kwargs_):
- self.gds_collector_ = gds_collector_
- self.gds_elementtree_node_ = None
+ def __init__(self, id=None, custom=None, comments=None, continuation=None, AlternativeImage=None, Coords=None, UserDefined=None, Labels=None, Roles=None, TextRegion=None, ImageRegion=None, LineDrawingRegion=None, GraphicRegion=None, TableRegion=None, ChartRegion=None, SeparatorRegion=None, MathsRegion=None, ChemRegion=None, MusicRegion=None, AdvertRegion=None, NoiseRegion=None, UnknownRegion=None, CustomRegion=None, orientation=None, type_=None, leading=None, readingDirection=None, textLineOrder=None, readingOrientation=None, indented=None, align=None, primaryLanguage=None, secondaryLanguage=None, primaryScript=None, secondaryScript=None, production=None, TextLine=None, TextEquiv=None, TextStyle=None, **kwargs_):
self.original_tagname_ = None
self.parent_object_ = kwargs_.get('parent_object_')
- self.ns_prefix_ = None
super(TextRegionType, self).__init__(id, custom, comments, continuation, AlternativeImage, Coords, UserDefined, Labels, Roles, TextRegion, ImageRegion, LineDrawingRegion, GraphicRegion, TableRegion, ChartRegion, SeparatorRegion, MathsRegion, ChemRegion, MusicRegion, AdvertRegion, NoiseRegion, UnknownRegion, CustomRegion, **kwargs_)
self.orientation = _cast(float, orientation)
- self.orientation_nsprefix_ = None
self.type_ = _cast(None, type_)
- self.type__nsprefix_ = None
self.leading = _cast(int, leading)
- self.leading_nsprefix_ = None
self.readingDirection = _cast(None, readingDirection)
- self.readingDirection_nsprefix_ = None
self.textLineOrder = _cast(None, textLineOrder)
- self.textLineOrder_nsprefix_ = None
self.readingOrientation = _cast(float, readingOrientation)
- self.readingOrientation_nsprefix_ = None
self.indented = _cast(bool, indented)
- self.indented_nsprefix_ = None
self.align = _cast(None, align)
- self.align_nsprefix_ = None
self.primaryLanguage = _cast(None, primaryLanguage)
- self.primaryLanguage_nsprefix_ = None
self.secondaryLanguage = _cast(None, secondaryLanguage)
- self.secondaryLanguage_nsprefix_ = None
self.primaryScript = _cast(None, primaryScript)
- self.primaryScript_nsprefix_ = None
self.secondaryScript = _cast(None, secondaryScript)
- self.secondaryScript_nsprefix_ = None
self.production = _cast(None, production)
- self.production_nsprefix_ = None
if TextLine is None:
self.TextLine = []
else:
self.TextLine = TextLine
- self.TextLine_nsprefix_ = None
if TextEquiv is None:
self.TextEquiv = []
else:
self.TextEquiv = TextEquiv
- self.TextEquiv_nsprefix_ = None
self.TextStyle = TextStyle
- self.TextStyle_nsprefix_ = None
def factory(*args_, **kwargs_):
if CurrentSubclassModule_ is not None:
subclass = getSubclassFromModule_(
@@ -11781,16 +9348,14 @@ def factory(*args_, **kwargs_):
else:
return TextRegionType(*args_, **kwargs_)
factory = staticmethod(factory)
- def get_ns_prefix_(self):
- return self.ns_prefix_
- def set_ns_prefix_(self, ns_prefix):
- self.ns_prefix_ = ns_prefix
def get_TextLine(self):
return self.TextLine
def set_TextLine(self, TextLine):
self.TextLine = TextLine
def add_TextLine(self, value):
self.TextLine.append(value)
+ def add_TextLine(self, value):
+ self.TextLine.append(value)
def insert_TextLine_at(self, index, value):
self.TextLine.insert(index, value)
def replace_TextLine_at(self, index, value):
@@ -11801,6 +9366,8 @@ def set_TextEquiv(self, TextEquiv):
self.TextEquiv = TextEquiv
def add_TextEquiv(self, value):
self.TextEquiv.append(value)
+ def add_TextEquiv(self, value):
+ self.TextEquiv.append(value)
def insert_TextEquiv_at(self, index, value):
self.TextEquiv.insert(index, value)
def replace_TextEquiv_at(self, index, value):
@@ -11861,97 +9428,6 @@ def get_production(self):
return self.production
def set_production(self, production):
self.production = production
- def validate_TextTypeSimpleType(self, value):
- # Validate type pc:TextTypeSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['paragraph', 'heading', 'caption', 'header', 'footer', 'page-number', 'drop-capital', 'credit', 'floating', 'signature-mark', 'catch-word', 'marginalia', 'footnote', 'footnote-continued', 'endnote', 'TOC-entry', 'list-label', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on TextTypeSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ReadingDirectionSimpleType(self, value):
- # Validate type pc:ReadingDirectionSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['left-to-right', 'right-to-left', 'top-to-bottom', 'bottom-to-top']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ReadingDirectionSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_TextLineOrderSimpleType(self, value):
- # Validate type pc:TextLineOrderSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['top-to-bottom', 'bottom-to-top', 'left-to-right', 'right-to-left']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on TextLineOrderSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_AlignSimpleType(self, value):
- # Validate type pc:AlignSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['left', 'centre', 'right', 'justify']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on AlignSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_LanguageSimpleType(self, value):
- # Validate type pc:LanguageSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Abkhaz', 'Afar', 'Afrikaans', 'Akan', 'Albanian', 'Amharic', 'Arabic', 'Aragonese', 'Armenian', 'Assamese', 'Avaric', 'Avestan', 'Aymara', 'Azerbaijani', 'Bambara', 'Bashkir', 'Basque', 'Belarusian', 'Bengali', 'Bihari', 'Bislama', 'Bosnian', 'Breton', 'Bulgarian', 'Burmese', 'Cambodian', 'Cantonese', 'Catalan', 'Chamorro', 'Chechen', 'Chichewa', 'Chinese', 'Chuvash', 'Cornish', 'Corsican', 'Cree', 'Croatian', 'Czech', 'Danish', 'Divehi', 'Dutch', 'Dzongkha', 'English', 'Esperanto', 'Estonian', 'Ewe', 'Faroese', 'Fijian', 'Finnish', 'French', 'Fula', 'Gaelic', 'Galician', 'Ganda', 'Georgian', 'German', 'Greek', 'Guaraní', 'Gujarati', 'Haitian', 'Hausa', 'Hebrew', 'Herero', 'Hindi', 'Hiri Motu', 'Hungarian', 'Icelandic', 'Ido', 'Igbo', 'Indonesian', 'Interlingua', 'Interlingue', 'Inuktitut', 'Inupiaq', 'Irish', 'Italian', 'Japanese', 'Javanese', 'Kalaallisut', 'Kannada', 'Kanuri', 'Kashmiri', 'Kazakh', 'Khmer', 'Kikuyu', 'Kinyarwanda', 'Kirundi', 'Komi', 'Kongo', 'Korean', 'Kurdish', 'Kwanyama', 'Kyrgyz', 'Lao', 'Latin', 'Latvian', 'Limburgish', 'Lingala', 'Lithuanian', 'Luba-Katanga', 'Luxembourgish', 'Macedonian', 'Malagasy', 'Malay', 'Malayalam', 'Maltese', 'Manx', 'Māori', 'Marathi', 'Marshallese', 'Mongolian', 'Nauru', 'Navajo', 'Ndonga', 'Nepali', 'North Ndebele', 'Northern Sami', 'Norwegian', 'Norwegian Bokmål', 'Norwegian Nynorsk', 'Nuosu', 'Occitan', 'Ojibwe', 'Old Church Slavonic', 'Oriya', 'Oromo', 'Ossetian', 'Pāli', 'Panjabi', 'Pashto', 'Persian', 'Polish', 'Portuguese', 'Punjabi', 'Quechua', 'Romanian', 'Romansh', 'Russian', 'Samoan', 'Sango', 'Sanskrit', 'Sardinian', 'Serbian', 'Shona', 'Sindhi', 'Sinhala', 'Slovak', 'Slovene', 'Somali', 'South Ndebele', 'Southern Sotho', 'Spanish', 'Sundanese', 'Swahili', 'Swati', 'Swedish', 'Tagalog', 'Tahitian', 'Tajik', 'Tamil', 'Tatar', 'Telugu', 'Thai', 'Tibetan', 'Tigrinya', 'Tonga', 'Tsonga', 'Tswana', 'Turkish', 'Turkmen', 'Twi', 'Uighur', 'Ukrainian', 'Urdu', 'Uzbek', 'Venda', 'Vietnamese', 'Volapük', 'Walloon', 'Welsh', 'Western Frisian', 'Wolof', 'Xhosa', 'Yiddish', 'Yoruba', 'Zhuang', 'Zulu', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on LanguageSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ScriptSimpleType(self, value):
- # Validate type pc:ScriptSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['Adlm - Adlam', 'Afak - Afaka', 'Aghb - Caucasian Albanian', 'Ahom - Ahom, Tai Ahom', 'Arab - Arabic', 'Aran - Arabic (Nastaliq variant)', 'Armi - Imperial Aramaic', 'Armn - Armenian', 'Avst - Avestan', 'Bali - Balinese', 'Bamu - Bamum', 'Bass - Bassa Vah', 'Batk - Batak', 'Beng - Bengali', 'Bhks - Bhaiksuki', 'Blis - Blissymbols', 'Bopo - Bopomofo', 'Brah - Brahmi', 'Brai - Braille', 'Bugi - Buginese', 'Buhd - Buhid', 'Cakm - Chakma', 'Cans - Unified Canadian Aboriginal Syllabics', 'Cari - Carian', 'Cham - Cham', 'Cher - Cherokee', 'Cirt - Cirth', 'Copt - Coptic', 'Cprt - Cypriot', 'Cyrl - Cyrillic', 'Cyrs - Cyrillic (Old Church Slavonic variant)', 'Deva - Devanagari (Nagari)', 'Dsrt - Deseret (Mormon)', 'Dupl - Duployan shorthand, Duployan stenography', 'Egyd - Egyptian demotic', 'Egyh - Egyptian hieratic', 'Egyp - Egyptian hieroglyphs', 'Elba - Elbasan', 'Ethi - Ethiopic', 'Geok - Khutsuri (Asomtavruli and Nuskhuri)', 'Geor - Georgian (Mkhedruli)', 'Glag - Glagolitic', 'Goth - Gothic', 'Gran - Grantha', 'Grek - Greek', 'Gujr - Gujarati', 'Guru - Gurmukhi', 'Hanb - Han with Bopomofo', 'Hang - Hangul', 'Hani - Han (Hanzi, Kanji, Hanja)', 'Hano - Hanunoo (Hanunóo)', 'Hans - Han (Simplified variant)', 'Hant - Han (Traditional variant)', 'Hatr - Hatran', 'Hebr - Hebrew', 'Hira - Hiragana', 'Hluw - Anatolian Hieroglyphs', 'Hmng - Pahawh Hmong', 'Hrkt - Japanese syllabaries', 'Hung - Old Hungarian (Hungarian Runic)', 'Inds - Indus (Harappan)', 'Ital - Old Italic (Etruscan, Oscan etc.)', 'Jamo - Jamo', 'Java - Javanese', 'Jpan - Japanese', 'Jurc - Jurchen', 'Kali - Kayah Li', 'Kana - Katakana', 'Khar - Kharoshthi', 'Khmr - Khmer', 'Khoj - Khojki', 'Kitl - Khitan large script', 'Kits - Khitan small script', 'Knda - Kannada', 'Kore - Korean (alias for Hangul + Han)', 'Kpel - Kpelle', 'Kthi - Kaithi', 'Lana - Tai Tham (Lanna)', 'Laoo - Lao', 'Latf - Latin (Fraktur variant)', 'Latg - Latin (Gaelic variant)', 'Latn - Latin', 'Leke - Leke', 'Lepc - Lepcha (Róng)', 'Limb - Limbu', 'Lina - Linear A', 'Linb - Linear B', 'Lisu - Lisu (Fraser)', 'Loma - Loma', 'Lyci - Lycian', 'Lydi - Lydian', 'Mahj - Mahajani', 'Mand - Mandaic, Mandaean', 'Mani - Manichaean', 'Marc - Marchen', 'Maya - Mayan hieroglyphs', 'Mend - Mende Kikakui', 'Merc - Meroitic Cursive', 'Mero - Meroitic Hieroglyphs', 'Mlym - Malayalam', 'Modi - Modi, Moḍī', 'Mong - Mongolian', 'Moon - Moon (Moon code, Moon script, Moon type)', 'Mroo - Mro, Mru', 'Mtei - Meitei Mayek (Meithei, Meetei)', 'Mult - Multani', 'Mymr - Myanmar (Burmese)', 'Narb - Old North Arabian (Ancient North Arabian)', 'Nbat - Nabataean', 'Newa - Newa, Newar, Newari', 'Nkgb - Nakhi Geba', 'Nkoo - N’Ko', 'Nshu - Nüshu', 'Ogam - Ogham', 'Olck - Ol Chiki (Ol Cemet’, Ol, Santali)', 'Orkh - Old Turkic, Orkhon Runic', 'Orya - Oriya', 'Osge - Osage', 'Osma - Osmanya', 'Palm - Palmyrene', 'Pauc - Pau Cin Hau', 'Perm - Old Permic', 'Phag - Phags-pa', 'Phli - Inscriptional Pahlavi', 'Phlp - Psalter Pahlavi', 'Phlv - Book Pahlavi', 'Phnx - Phoenician', 'Piqd - Klingon (KLI pIqaD)', 'Plrd - Miao (Pollard)', 'Prti - Inscriptional Parthian', 'Rjng - Rejang (Redjang, Kaganga)', 'Roro - Rongorongo', 'Runr - Runic', 'Samr - Samaritan', 'Sara - Sarati', 'Sarb - Old South Arabian', 'Saur - Saurashtra', 'Sgnw - SignWriting', 'Shaw - Shavian (Shaw)', 'Shrd - Sharada, Śāradā', 'Sidd - Siddham', 'Sind - Khudawadi, Sindhi', 'Sinh - Sinhala', 'Sora - Sora Sompeng', 'Sund - Sundanese', 'Sylo - Syloti Nagri', 'Syrc - Syriac', 'Syre - Syriac (Estrangelo variant)', 'Syrj - Syriac (Western variant)', 'Syrn - Syriac (Eastern variant)', 'Tagb - Tagbanwa', 'Takr - Takri', 'Tale - Tai Le', 'Talu - New Tai Lue', 'Taml - Tamil', 'Tang - Tangut', 'Tavt - Tai Viet', 'Telu - Telugu', 'Teng - Tengwar', 'Tfng - Tifinagh (Berber)', 'Tglg - Tagalog (Baybayin, Alibata)', 'Thaa - Thaana', 'Thai - Thai', 'Tibt - Tibetan', 'Tirh - Tirhuta', 'Ugar - Ugaritic', 'Vaii - Vai', 'Visp - Visible Speech', 'Wara - Warang Citi (Varang Kshiti)', 'Wole - Woleai', 'Xpeo - Old Persian', 'Xsux - Cuneiform, Sumero-Akkadian', 'Yiii - Yi', 'Zinh - Code for inherited script', 'Zmth - Mathematical notation', 'Zsye - Symbols (Emoji variant)', 'Zsym - Symbols', 'Zxxx - Code for unwritten documents', 'Zyyy - Code for undetermined script', 'Zzzz - Code for uncoded script', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ScriptSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
- def validate_ProductionSimpleType(self, value):
- # Validate type pc:ProductionSimpleType, a restriction on string.
- if value is not None and Validate_simpletypes_ and self.gds_collector_ is not None:
- if not isinstance(value, str):
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s is not of the correct base simple type (str)' % {"value": value, "lineno": lineno, })
- return False
- value = value
- enumerations = ['printed', 'typewritten', 'handwritten-cursive', 'handwritten-printscript', 'medieval-manuscript', 'other']
- if value not in enumerations:
- lineno = self.gds_get_node_lineno_()
- self.gds_collector_.add_message('Value "%(value)s"%(lineno)s does not match xsd enumeration restriction on ProductionSimpleType' % {"value" : encode_str_2_3(value), "lineno": lineno} )
- result = False
def hasContent_(self):
if (
self.TextLine or
@@ -11962,7 +9438,7 @@ def hasContent_(self):
return True
else:
return False
- def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='TextRegionType', pretty_print=True):
+ def export(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='TextRegionType', pretty_print=True):
imported_ns_def_ = GenerateDSNamespaceDefs_.get('TextRegionType')
if imported_ns_def_ is not None:
namespacedef_ = imported_ns_def_
@@ -11972,8 +9448,6 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='T
eol_ = ''
if self.original_tagname_ is not None:
name_ = self.original_tagname_
- if UseCapturedNS_ and self.ns_prefix_:
- namespaceprefix_ = self.ns_prefix_ + ':'
showIndent(outfile, level, pretty_print)
outfile.write('<%s%s%s' % (namespaceprefix_, name_, namespacedef_ and ' ' + namespacedef_ or '', ))
already_processed = set()
@@ -11985,23 +9459,23 @@ def export(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='T
outfile.write('%s%s>%s' % (namespaceprefix_, name_, eol_))
else:
outfile.write('/>%s' % (eol_, ))
- def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='', name_='TextRegionType'):
+ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='pc:', name_='TextRegionType'):
super(TextRegionType, self).exportAttributes(outfile, level, already_processed, namespaceprefix_, name_='TextRegionType')
if self.orientation is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
outfile.write(' orientation="%s"' % self.gds_format_float(self.orientation, input_name='orientation'))
if self.type_ is not None and 'type_' not in already_processed:
already_processed.add('type_')
- outfile.write(' type=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.type_), input_name='type')), ))
+ outfile.write(' type=%s' % (quote_attrib(self.type_), ))
if self.leading is not None and 'leading' not in already_processed:
already_processed.add('leading')
outfile.write(' leading="%s"' % self.gds_format_integer(self.leading, input_name='leading'))
if self.readingDirection is not None and 'readingDirection' not in already_processed:
already_processed.add('readingDirection')
- outfile.write(' readingDirection=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.readingDirection), input_name='readingDirection')), ))
+ outfile.write(' readingDirection=%s' % (quote_attrib(self.readingDirection), ))
if self.textLineOrder is not None and 'textLineOrder' not in already_processed:
already_processed.add('textLineOrder')
- outfile.write(' textLineOrder=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.textLineOrder), input_name='textLineOrder')), ))
+ outfile.write(' textLineOrder=%s' % (quote_attrib(self.textLineOrder), ))
if self.readingOrientation is not None and 'readingOrientation' not in already_processed:
already_processed.add('readingOrientation')
outfile.write(' readingOrientation="%s"' % self.gds_format_float(self.readingOrientation, input_name='readingOrientation'))
@@ -12010,78 +9484,75 @@ def exportAttributes(self, outfile, level, already_processed, namespaceprefix_='
outfile.write(' indented="%s"' % self.gds_format_boolean(self.indented, input_name='indented'))
if self.align is not None and 'align' not in already_processed:
already_processed.add('align')
- outfile.write(' align=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.align), input_name='align')), ))
+ outfile.write(' align=%s' % (quote_attrib(self.align), ))
if self.primaryLanguage is not None and 'primaryLanguage' not in already_processed:
already_processed.add('primaryLanguage')
- outfile.write(' primaryLanguage=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.primaryLanguage), input_name='primaryLanguage')), ))
+ outfile.write(' primaryLanguage=%s' % (quote_attrib(self.primaryLanguage), ))
if self.secondaryLanguage is not None and 'secondaryLanguage' not in already_processed:
already_processed.add('secondaryLanguage')
- outfile.write(' secondaryLanguage=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.secondaryLanguage), input_name='secondaryLanguage')), ))
+ outfile.write(' secondaryLanguage=%s' % (quote_attrib(self.secondaryLanguage), ))
if self.primaryScript is not None and 'primaryScript' not in already_processed:
already_processed.add('primaryScript')
- outfile.write(' primaryScript=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.primaryScript), input_name='primaryScript')), ))
+ outfile.write(' primaryScript=%s' % (quote_attrib(self.primaryScript), ))
if self.secondaryScript is not None and 'secondaryScript' not in already_processed:
already_processed.add('secondaryScript')
- outfile.write(' secondaryScript=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.secondaryScript), input_name='secondaryScript')), ))
+ outfile.write(' secondaryScript=%s' % (quote_attrib(self.secondaryScript), ))
if self.production is not None and 'production' not in already_processed:
already_processed.add('production')
- outfile.write(' production=%s' % (self.gds_encode(self.gds_format_string(quote_attrib(self.production), input_name='production')), ))
- def exportChildren(self, outfile, level, namespaceprefix_='', namespacedef_='', name_='TextRegionType', fromsubclass_=False, pretty_print=True):
- super(TextRegionType, self).exportChildren(outfile, level, namespaceprefix_, namespacedef_, name_, True, pretty_print=pretty_print)
+ outfile.write(' production=%s' % (quote_attrib(self.production), ))
+ def exportChildren(self, outfile, level, namespaceprefix_='pc:', namespacedef_='', name_='TextRegionType', fromsubclass_=False, pretty_print=True):
+ super(TextRegionType, self).exportChildren(outfile, level, namespaceprefix_, name_, True, pretty_print=pretty_print)
if pretty_print:
eol_ = '\n'
else:
eol_ = ''
for TextLine_ in self.TextLine:
- namespaceprefix_ = self.TextLine_nsprefix_ + ':' if (UseCapturedNS_ and self.TextLine_nsprefix_) else ''
TextLine_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextLine', pretty_print=pretty_print)
for TextEquiv_ in self.TextEquiv:
- namespaceprefix_ = self.TextEquiv_nsprefix_ + ':' if (UseCapturedNS_ and self.TextEquiv_nsprefix_) else ''
TextEquiv_.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextEquiv', pretty_print=pretty_print)
if self.TextStyle is not None:
- namespaceprefix_ = self.TextStyle_nsprefix_ + ':' if (UseCapturedNS_ and self.TextStyle_nsprefix_) else ''
self.TextStyle.export(outfile, level, namespaceprefix_, namespacedef_='', name_='TextStyle', pretty_print=pretty_print)
- def build(self, node, gds_collector_=None):
- self.gds_collector_ = gds_collector_
- if SaveElementTreeNode:
- self.gds_elementtree_node_ = node
+ def build(self, node):
already_processed = set()
- self.ns_prefix_ = node.prefix
self.buildAttributes(node, node.attrib, already_processed)
for child in node:
nodeName_ = Tag_pattern_.match(child.tag).groups()[-1]
- self.buildChildren(child, node, nodeName_, gds_collector_=gds_collector_)
+ self.buildChildren(child, node, nodeName_)
return self
def buildAttributes(self, node, attrs, already_processed):
value = find_attr_value_('orientation', node)
if value is not None and 'orientation' not in already_processed:
already_processed.add('orientation')
- value = self.gds_parse_float(value, node, 'orientation')
- self.orientation = value
+ try:
+ self.orientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (orientation): %s' % exp)
value = find_attr_value_('type', node)
if value is not None and 'type' not in already_processed:
already_processed.add('type')
self.type_ = value
- self.validate_TextTypeSimpleType(self.type_) # validate type TextTypeSimpleType
value = find_attr_value_('leading', node)
if value is not None and 'leading' not in already_processed:
already_processed.add('leading')
- self.leading = self.gds_parse_integer(value, node, 'leading')
+ try:
+ self.leading = int(value)
+ except ValueError as exp:
+ raise_parse_error(node, 'Bad integer attribute: %s' % exp)
value = find_attr_value_('readingDirection', node)
if value is not None and 'readingDirection' not in already_processed:
already_processed.add('readingDirection')
self.readingDirection = value
- self.validate_ReadingDirectionSimpleType(self.readingDirection) # validate type ReadingDirectionSimpleType
value = find_attr_value_('textLineOrder', node)
if value is not None and 'textLineOrder' not in already_processed:
already_processed.add('textLineOrder')
self.textLineOrder = value
- self.validate_TextLineOrderSimpleType(self.textLineOrder) # validate type TextLineOrderSimpleType
value = find_attr_value_('readingOrientation', node)
if value is not None and 'readingOrientation' not in already_processed:
already_processed.add('readingOrientation')
- value = self.gds_parse_float(value, node, 'readingOrientation')
- self.readingOrientation = value
+ try:
+ self.readingOrientation = float(value)
+ except ValueError as exp:
+ raise ValueError('Bad float/double attribute (readingOrientation): %s' % exp)
value = find_attr_value_('indented', node)
if value is not None and 'indented' not in already_processed:
already_processed.add('indented')
@@ -12095,52 +9566,44 @@ def buildAttributes(self, node, attrs, already_processed):
if value is not None and 'align' not in already_processed:
already_processed.add('align')
self.align = value
- self.validate_AlignSimpleType(self.align) # validate type AlignSimpleType
value = find_attr_value_('primaryLanguage', node)
if value is not None and 'primaryLanguage' not in already_processed:
already_processed.add('primaryLanguage')
self.primaryLanguage = value
- self.validate_LanguageSimpleType(self.primaryLanguage) # validate type LanguageSimpleType
value = find_attr_value_('secondaryLanguage', node)
if value is not None and 'secondaryLanguage' not in already_processed:
already_processed.add('secondaryLanguage')
self.secondaryLanguage = value
- self.validate_LanguageSimpleType(self.secondaryLanguage) # validate type LanguageSimpleType
value = find_attr_value_('primaryScript', node)
if value is not None and 'primaryScript' not in already_processed:
already_processed.add('primaryScript')
self.primaryScript = value
- self.validate_ScriptSimpleType(self.primaryScript) # validate type ScriptSimpleType
value = find_attr_value_('secondaryScript', node)
if value is not None and 'secondaryScript' not in already_processed:
already_processed.add('secondaryScript')
self.secondaryScript = value
- self.validate_ScriptSimpleType(self.secondaryScript) # validate type ScriptSimpleType
value = find_attr_value_('production', node)
if value is not None and 'production' not in already_processed:
already_processed.add('production')
self.production = value
- self.validate_ProductionSimpleType(self.production) # validate type ProductionSimpleType
super(TextRegionType, self).buildAttributes(node, attrs, already_processed)
- def buildChildren(self, child_, node, nodeName_, fromsubclass_=False, gds_collector_=None):
+ def buildChildren(self, child_, node, nodeName_, fromsubclass_=False):
if nodeName_ == 'TextLine':
obj_ = TextLineType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextLine.append(obj_)
obj_.original_tagname_ = 'TextLine'
elif nodeName_ == 'TextEquiv':
obj_ = TextEquivType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextEquiv.append(obj_)
obj_.original_tagname_ = 'TextEquiv'
elif nodeName_ == 'TextStyle':
obj_ = TextStyleType.factory(parent_object_=self)
- obj_.build(child_, gds_collector_=gds_collector_)
+ obj_.build(child_)
self.TextStyle = obj_
obj_.original_tagname_ = 'TextStyle'
super(TextRegionType, self).buildChildren(child_, node, nodeName_, True)
- def __hash__(self):
- return hash(self.id)
# end class TextRegionType
@@ -12167,26 +9630,7 @@ def get_root_tag(node):
return tag, rootClass
-def get_required_ns_prefix_defs(rootNode):
- '''Get all name space prefix definitions required in this XML doc.
- Return a dictionary of definitions and a char string of definitions.
- '''
- nsmap = {
- prefix: uri
- for node in rootNode.iter()
- for (prefix, uri) in node.nsmap.items()
- if prefix is not None
- }
- namespacedefs = ' '.join([
- 'xmlns:{}="{}"'.format(prefix, uri)
- for prefix, uri in nsmap.items()
- ])
- return nsmap, namespacedefs
-
-
-def parse(inFileName, silence=False, print_warnings=True):
- global CapturedNsmap_
- gds_collector = GdsCollector_()
+def parse(inFileName, silence=False):
parser = None
doc = parsexml_(inFileName, parser)
rootNode = doc.getroot()
@@ -12195,62 +9639,43 @@ def parse(inFileName, silence=False, print_warnings=True):
rootTag = 'PcGts'
rootClass = PcGts
rootObj = rootClass.factory()
- rootObj.build(rootNode, gds_collector_=gds_collector)
- CapturedNsmap_, namespacedefs = get_required_ns_prefix_defs(rootNode)
- if not SaveElementTreeNode:
- doc = None
- rootNode = None
+ rootObj.build(rootNode)
+ # Enable Python to collect the space used by the DOM.
+ doc = None
if not silence:
sys.stdout.write('\n')
rootObj.export(
sys.stdout, 0, name_=rootTag,
- namespacedef_=namespacedefs,
+ namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"',
pretty_print=True)
- if print_warnings and len(gds_collector.get_messages()) > 0:
- separator = ('-' * 50) + '\n'
- sys.stderr.write(separator)
- sys.stderr.write('----- Warnings -- count: {} -----\n'.format(
- len(gds_collector.get_messages()), ))
- gds_collector.write_messages(sys.stderr)
- sys.stderr.write(separator)
return rootObj
-def parseEtree(inFileName, silence=False, print_warnings=True):
+def parseEtree(inFileName, silence=False):
parser = None
doc = parsexml_(inFileName, parser)
- gds_collector = GdsCollector_()
rootNode = doc.getroot()
rootTag, rootClass = get_root_tag(rootNode)
if rootClass is None:
rootTag = 'PcGts'
rootClass = PcGts
rootObj = rootClass.factory()
- rootObj.build(rootNode, gds_collector_=gds_collector)
+ rootObj.build(rootNode)
# Enable Python to collect the space used by the DOM.
+ doc = None
mapping = {}
rootElement = rootObj.to_etree(None, name_=rootTag, mapping_=mapping)
reverse_mapping = rootObj.gds_reverse_node_mapping(mapping)
- if not SaveElementTreeNode:
- doc = None
- rootNode = None
if not silence:
content = etree_.tostring(
rootElement, pretty_print=True,
xml_declaration=True, encoding="utf-8")
- sys.stdout.write(str(content))
+ sys.stdout.write(content)
sys.stdout.write('\n')
- if print_warnings and len(gds_collector.get_messages()) > 0:
- separator = ('-' * 50) + '\n'
- sys.stderr.write(separator)
- sys.stderr.write('----- Warnings -- count: {} -----\n'.format(
- len(gds_collector.get_messages()), ))
- gds_collector.write_messages(sys.stderr)
- sys.stderr.write(separator)
return rootObj, rootElement, mapping, reverse_mapping
-def parseString(inString, silence=False, print_warnings=True):
+def parseString(inString, silence=False):
'''Parse a string, create the object tree, and export it.
Arguments:
@@ -12261,58 +9686,39 @@ def parseString(inString, silence=False, print_warnings=True):
'''
parser = None
rootNode= parsexmlstring_(inString, parser)
- gds_collector = GdsCollector_()
rootTag, rootClass = get_root_tag(rootNode)
if rootClass is None:
rootTag = 'PcGts'
rootClass = PcGts
rootObj = rootClass.factory()
- rootObj.build(rootNode, gds_collector_=gds_collector)
- if not SaveElementTreeNode:
- rootNode = None
+ rootObj.build(rootNode)
+ # Enable Python to collect the space used by the DOM.
if not silence:
sys.stdout.write('\n')
rootObj.export(
sys.stdout, 0, name_=rootTag,
namespacedef_='xmlns:pc="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15"')
- if print_warnings and len(gds_collector.get_messages()) > 0:
- separator = ('-' * 50) + '\n'
- sys.stderr.write(separator)
- sys.stderr.write('----- Warnings -- count: {} -----\n'.format(
- len(gds_collector.get_messages()), ))
- gds_collector.write_messages(sys.stderr)
- sys.stderr.write(separator)
return rootObj
-def parseLiteral(inFileName, silence=False, print_warnings=True):
+def parseLiteral(inFileName, silence=False):
parser = None
doc = parsexml_(inFileName, parser)
- gds_collector = GdsCollector_()
rootNode = doc.getroot()
rootTag, rootClass = get_root_tag(rootNode)
if rootClass is None:
rootTag = 'PcGts'
rootClass = PcGts
rootObj = rootClass.factory()
- rootObj.build(rootNode, gds_collector_=gds_collector)
+ rootObj.build(rootNode)
# Enable Python to collect the space used by the DOM.
- if not SaveElementTreeNode:
- doc = None
- rootNode = None
+ doc = None
if not silence:
sys.stdout.write('#from ocrd_page_generateds import *\n\n')
sys.stdout.write('import ocrd_page_generateds as model_\n\n')
sys.stdout.write('rootObj = model_.rootClass(\n')
rootObj.exportLiteral(sys.stdout, 0, name_=rootTag)
sys.stdout.write(')\n')
- if print_warnings and len(gds_collector.get_messages()) > 0:
- separator = ('-' * 50) + '\n'
- sys.stderr.write(separator)
- sys.stderr.write('----- Warnings -- count: {} -----\n'.format(
- len(gds_collector.get_messages()), ))
- gds_collector.write_messages(sys.stderr)
- sys.stderr.write(separator)
return rootObj
@@ -12328,8 +9734,6 @@ def main():
#import pdb; pdb.set_trace()
main()
-RenameMappings_ = {
-}
__all__ = [
"AdvertRegionType",
diff --git a/ocrd_utils/ocrd_utils/__init__.py b/ocrd_utils/ocrd_utils/__init__.py
index 8ba1f68ff..f2021175e 100644
--- a/ocrd_utils/ocrd_utils/__init__.py
+++ b/ocrd_utils/ocrd_utils/__init__.py
@@ -409,7 +409,7 @@ def transpose_image(image, method):
columns become rows (but counted from the bottom),
i.e. all pixels get mirrored at the opposite diagonal;
width becomes height and vice versa
-
+
Return a new PIL.Image.
"""
LOG.debug('transposing image with %s', membername(Image, method))
@@ -800,6 +800,8 @@ def parse_json_string_or_file(value='{}'): # pylint: disable=unused-argument
ret = json.load(f)
except FileNotFoundError:
ret = json.loads(value.strip())
+ except OSError:
+ ret = json.loads(value.strip())
if not isinstance(ret, dict):
err = ValueError("Not a valid JSON object: '%s' (parsed as '%s')" % (value, ret))
except json.decoder.JSONDecodeError as e:
diff --git a/ocrd_utils/setup.py b/ocrd_utils/setup.py
index 0ea5cbf4c..78d8346c0 100644
--- a/ocrd_utils/setup.py
+++ b/ocrd_utils/setup.py
@@ -5,7 +5,7 @@
setup(
name='ocrd_utils',
- version='2.4.1',
+ version='2.4.4',
description='OCR-D framework - shared code, helpers, constants',
long_description=open('README.md').read(),
long_description_content_type='text/markdown',
diff --git a/requirements_test.txt b/requirements_test.txt
index a98365ccd..65c79c751 100644
--- a/requirements_test.txt
+++ b/requirements_test.txt
@@ -1,5 +1,5 @@
pytest >= 4.0.0
-generateDS == 2.35.13
+generateDS == 2.30.11
coverage >= 4.5.2
sphinx
codecov >= 2.0.15
diff --git a/tests/model/test_ocrd_page.py b/tests/model/test_ocrd_page.py
index 90a586abf..7f53dff90 100644
--- a/tests/model/test_ocrd_page.py
+++ b/tests/model/test_ocrd_page.py
@@ -33,7 +33,7 @@
-
+
Berliniſche
@@ -56,7 +56,7 @@ def test_to_xml(self):
# with open('/tmp/test.xml', 'w') as f:
# f.write(to_xml(self.pcgts))
self.assertIn(' xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15 http://schema.primaresearch.org/PAGE/gts/pagecontent/2019-07-15/pagecontent.xsd"', to_xml(self.pcgts)[:1000])
- self.assertIn('