Browse Source

M XMLSchema.py

-- [ 1482042 ] schema import bug rpc/enc Axis 1.4 WSDL
 
   fixed issue with lazy eval of imports when schemaLocation attribute is not provided.
main
Joshua Boverhof 18 years ago
parent
commit
56cd1534eb
1 changed files with 27 additions and 12 deletions
  1. +27
    -12
      XMLSchema.py

+ 27
- 12
XMLSchema.py View File

@@ -588,24 +588,39 @@ class XMLSchemaComponent(XMLBase, MarkerInterface):
name -- name of item. name -- name of item.
collection -- collection in parent Schema instance to search. collection -- collection in parent Schema instance to search.
""" """
obj = None
parent = GetSchema(self) parent = GetSchema(self)
if parent.targetNamespace == namespace: if parent.targetNamespace == namespace:
try: try:
obj = getattr(parent, collection)[name] obj = getattr(parent, collection)[name]
except KeyError, ex: except KeyError, ex:
raise KeyError, "targetNamespace(%s) collection(%s) has no item(%s)"\
%(namespace, collection, name)
elif parent.imports.has_key(namespace):
schema = parent.imports[namespace].getSchema()
if schema is None:
raise SchemaError, 'no schema instance for imported namespace (%s).'\
%(namespace)
try:
obj = getattr(schema, collection)[name]
except KeyError, ex:
raise KeyError, "targetNamespace(%s) collection(%s) has no item(%s)"\
raise KeyError, 'targetNamespace(%s) collection(%s) has no item(%s)'\
%(namespace, collection, name) %(namespace, collection, name)
return obj
if not parent.imports.has_key(namespace):
return None
# Lazy Eval
schema = parent.imports[namespace]
if not isinstance(schema, XMLSchema):
schema = schema.getSchema()
if schema is not None:
parent.imports[namespace] = schema
if schema is None:
raise SchemaError, 'no schema instance for imported namespace (%s).'\
%(namespace)
if not isinstance(schema, XMLSchema):
raise TypeError, 'expecting XMLSchema instance not "%r"' %schema
try:
obj = getattr(schema, collection)[name]
except KeyError, ex:
raise KeyError, 'targetNamespace(%s) collection(%s) has no item(%s)'\
%(namespace, collection, name)
return obj return obj


def getXMLNS(self, prefix=None): def getXMLNS(self, prefix=None):


Loading…
Cancel
Save