[Zope-Checkins] CVS: Packages/ZConfig - schema.py:1.8

Fred L. Drake, Jr. fred@zope.com
Tue, 7 Jan 2003 13:31:06 -0500


Update of /cvs-repository/Packages/ZConfig
In directory cvs.zope.org:/tmp/cvs-serv10851

Modified Files:
	schema.py 
Log Message:
More general reorganization.


=== Packages/ZConfig/schema.py 1.7 => 1.8 ===
--- Packages/ZConfig/schema.py:1.7	Tue Jan  7 12:11:44 2003
+++ Packages/ZConfig/schema.py	Tue Jan  7 13:31:03 2003
@@ -70,10 +70,10 @@
 
     def startElement(self, name, attrs):
         attrs = dict(attrs)
-        if name == "schema":
+        if name == self._top_level:
             if self._schema is not None:
                 self.error("schema element improperly nested")
-            self.start_schema(attrs)
+            getattr(self, "start_" + name)(attrs)
         elif name in self._handled_tags:
             if self._schema is None:
                 self.error(name + " element outside of schema")
@@ -107,46 +107,9 @@
 
     def endDocument(self):
         if self._schema is None:
-            self.error("no schema found")
-
-    # schema loading logic
-
-    def characters_default(self, data):
-        self._stack[-1].adddefault(data, self._position)
-
-    def characters_description(self, data):
-        self._stack[-1].description = data
-
-    def characters_example(self, data):
-        self._stack[-1].example = data
-
-    def characters_metadefault(self, data):
-        self._stack[-1].metadefault = data
-
-    def start_import(self, attrs):
-        src = attrs.get("src", "").strip()
-        pkg = attrs.get("package", "").strip()
-        if not (src or pkg):
-            self.error("import must specify either src or package")
-        if src and pkg:
-            self.error("import may only specify one of src or package")
-        if src:
-            src = url.urljoin(self._url, src)
-            src, fragment = url.urldefrag(src)
-            if fragment:
-                self.error("import src many not include a fragment identifier")
-            urls = [src]
-        else:
-            urls = self._loader.schemaPackageURLs(pkg)
-            if not urls:
-                self.error("could not locate schema component " + `pkg`)
-        for s in urls:
-            schema = self._loader.loadURL(s)
-            for n in schema.gettypenames():
-                self._schema.addtype(schema.gettype(n))
+            self.error("no %s found" % self._top_level)
 
-    def end_import(self):
-        pass
+    # helper methods
 
     def get_position(self):
         if self._locator:
@@ -178,6 +141,9 @@
             prefix = ''
         self._prefixes.append(prefix)
 
+    def pop_prefix(self):
+        del self._prefixes[-1]
+
     def get_classname(self, name):
         if name.startswith("."):
             return self._prefixes[-1] + name
@@ -201,6 +167,102 @@
         datatype = self.get_datatype(attrs, "datatype", "null")
         return keytype, valuetype, datatype
 
+    def get_required(self, attrs):
+        if attrs.has_key("required"):
+            v = attrs["required"]
+            if v == "yes":
+                return True
+            elif v == "no":
+                return False
+            self.error("value for 'required' must be 'yes' or 'no'")
+        else:
+            return False
+
+    def get_ordinality(self, attrs):
+        min, max = 0, info.Unbounded
+        if self.get_required(attrs):
+            min = 1
+        return min, max
+
+    def get_sectiontype(self, attrs):
+        type = attrs.get("type")
+        if not type:
+            self.error("section must specify type")
+        return self._schema.gettype(type)
+
+    def get_key_info(self, attrs, element):
+        any, name, attribute = self.get_name_info(attrs, element)
+        if any == '*':
+            self.error(element + " may not specify '*' for name")
+        if not name and any != '+':
+            self.error(element + " name may not be omitted or empty")
+        datatype = self.get_datatype(attrs, "datatype", "string")
+        handler = self.get_handler(attrs)
+        return name or any, datatype, handler, attribute
+
+    def get_name_info(self, attrs, element):
+        name = attrs.get("name")
+        if not name:
+            self.error(element + " name must be specified and non-empty")
+        aname = attrs.get("attribute")
+        if aname:
+            aname = self.identifier(aname)
+            if aname.startswith("getSection"):
+                # reserved; used for SectionValue methods to get meta-info
+                self.error("attribute names may not start with 'getSection'")
+        if name in ("*", "+"):
+            if not aname:
+                self.error(
+                    "container attribute must be specified and non-empty"
+                    " when using '*' or '+' for a section name")
+            return name, None, aname
+        else:
+            # run the keytype converter to make sure this is a valid key
+            name = self._stack[-1].keytype(name)
+            if not aname:
+                aname = self.basic_key(name)
+                aname = self.identifier(aname.replace('-', '_'))
+            return None, self.basic_key(name), aname
+
+    # schema loading logic
+
+    def characters_default(self, data):
+        self._stack[-1].adddefault(data, self._position)
+
+    def characters_description(self, data):
+        self._stack[-1].description = data
+
+    def characters_example(self, data):
+        self._stack[-1].example = data
+
+    def characters_metadefault(self, data):
+        self._stack[-1].metadefault = data
+
+    def start_import(self, attrs):
+        src = attrs.get("src", "").strip()
+        pkg = attrs.get("package", "").strip()
+        if not (src or pkg):
+            self.error("import must specify either src or package")
+        if src and pkg:
+            self.error("import may only specify one of src or package")
+        if src:
+            src = url.urljoin(self._url, src)
+            src, fragment = url.urldefrag(src)
+            if fragment:
+                self.error("import src many not include a fragment identifier")
+            urls = [src]
+        else:
+            urls = self._loader.schemaPackageURLs(pkg)
+            if not urls:
+                self.error("could not locate schema component " + `pkg`)
+        for s in urls:
+            schema = self._loader.loadURL(s)
+            for n in schema.gettypenames():
+                self._schema.addtype(schema.gettype(n))
+
+    def end_import(self):
+        pass
+
     def start_sectiontype(self, attrs):
         name = attrs.get("type")
         if not name:
@@ -236,32 +298,9 @@
         self._stack.append(sectinfo)
 
     def end_sectiontype(self):
-        del self._prefixes[-1]
+        self.pop_prefix()
         self._stack.pop()
 
-    def get_required(self, attrs):
-        if attrs.has_key("required"):
-            v = attrs["required"]
-            if v == "yes":
-                return True
-            elif v == "no":
-                return False
-            self.error("value for 'required' must be 'yes' or 'no'")
-        else:
-            return False
-
-    def get_ordinality(self, attrs):
-        min, max = 0, info.Unbounded
-        if self.get_required(attrs):
-            min = 1
-        return min, max
-
-    def get_sectiontype(self, attrs):
-        type = attrs.get("type")
-        if not type:
-            self.error("section must specify type")
-        return self._schema.gettype(type)
-
     def start_section(self, attrs):
         sectiontype = self.get_sectiontype(attrs)
         handler = self.get_handler(attrs)
@@ -306,20 +345,10 @@
         self._stack.append(self._group)
 
     def end_sectiongroup(self):
-        del self._prefixes[-1]
+        self.pop_prefix()
         self._group = None
         self._stack.pop()
 
-    def get_key_info(self, attrs, element):
-        any, name, attribute = self.get_name_info(attrs, element)
-        if any == '*':
-            self.error(element + " may not specify '*' for name")
-        if not name and any != '+':
-            self.error(element + " name may not be omitted or empty")
-        datatype = self.get_datatype(attrs, "datatype", "string")
-        handler = self.get_handler(attrs)
-        return name or any, datatype, handler, attribute
-
     def start_key(self, attrs):
         name, datatype, handler, attribute = self.get_key_info(attrs, "key")
         min = self.get_required(attrs) and 1 or 0
@@ -350,30 +379,6 @@
     def end_multikey(self):
         self._stack.pop().finish()
 
-    def get_name_info(self, attrs, element):
-        name = attrs.get("name")
-        if not name:
-            self.error(element + " name must be specified and non-empty")
-        aname = attrs.get("attribute")
-        if aname:
-            aname = self.identifier(aname)
-            if aname.startswith("getSection"):
-                # reserved; used for SectionValue methods to get meta-info
-                self.error("attribute names may not start with 'getSection'")
-        if name in ("*", "+"):
-            if not aname:
-                self.error(
-                    "container attribute must be specified and non-empty"
-                    " when using '*' or '+' for a section name")
-            return name, None, aname
-        else:
-            # run the keytype converter to make sure this is a valid key
-            name = self._stack[-1].keytype(name)
-            if not aname:
-                aname = self.basic_key(name)
-                aname = self.identifier(aname.replace('-', '_'))
-            return None, self.basic_key(name), aname
-
     # datatype conversion wrappers
 
     def basic_key(self, s):
@@ -381,18 +386,12 @@
             return self._basic_key(s)
         except ValueError, e:
             self.error(e[0])
-        except ZConfig.SchemaError, e:
-            self.initerror(e)
-            raise
 
     def identifier(self, s):
         try:
             return self._identifier(s)
         except ValueError, e:
             self.error(e[0])
-        except ZConfig.SchemaError, e:
-            self.initerror(e)
-            raise
 
     # exception setup helpers
 
@@ -411,6 +410,7 @@
 
     # needed by startElement() and endElement()
     _handled_tags = BaseParser._handled_tags + ("schema",)
+    _top_level = "schema"
 
     def start_schema(self, attrs):
         self.push_prefix(attrs)
@@ -429,5 +429,5 @@
     def end_schema(self):
         del self._stack[-1]
         assert not self._stack
-        del self._prefixes[-1]
+        self.pop_prefix()
         assert not self._prefixes