[Python-checkins] r43681 - python/trunk/Lib/xmlcore/dom/expatbuilder.py python/trunk/Lib/xmlcore/dom/minicompat.py python/trunk/Lib/xmlcore/dom/minidom.py python/trunk/Lib/xmlcore/dom/xmlbuilder.py

fred.drake python-checkins at python.org
Thu Apr 6 03:29:07 CEST 2006


Author: fred.drake
Date: Thu Apr 6 03:29:04 2006
New Revision: 43681
Modified:
 python/trunk/Lib/xmlcore/dom/expatbuilder.py
 python/trunk/Lib/xmlcore/dom/minicompat.py
 python/trunk/Lib/xmlcore/dom/minidom.py
 python/trunk/Lib/xmlcore/dom/xmlbuilder.py
Log:
remove much of the Python-version compatibility cruft; the minimum Python
version this should support is Python 2.3
Modified: python/trunk/Lib/xmlcore/dom/expatbuilder.py
==============================================================================
--- python/trunk/Lib/xmlcore/dom/expatbuilder.py	(original)
+++ python/trunk/Lib/xmlcore/dom/expatbuilder.py	Thu Apr 6 03:29:04 2006
@@ -59,7 +59,7 @@
 "NMTOKENS": minidom.TypeInfo(None, "nmtokens"),
 }
 
-class ElementInfo(NewStyle):
+class ElementInfo(object):
 __slots__ = '_attr_info', '_model', 'tagName'
 
 def __init__(self, tagName, model=None):
@@ -460,7 +460,7 @@
 # where allowed.
 _ALLOWED_FILTER_RETURNS = (FILTER_ACCEPT, FILTER_REJECT, FILTER_SKIP)
 
-class FilterVisibilityController(NewStyle):
+class FilterVisibilityController(object):
 """Wrapper around a DOMBuilderFilter which implements the checks
 to make the whatToShow filter attribute work."""
 
@@ -518,7 +518,7 @@
 }
 
 
-class FilterCrutch(NewStyle):
+class FilterCrutch(object):
 __slots__ = '_builder', '_level', '_old_start', '_old_end'
 
 def __init__(self, builder):
@@ -908,7 +908,7 @@
 raise ParseEscape()
 
 
-def parse(file, namespaces=1):
+def parse(file, namespaces=True):
 """Parse a document, returning the resulting Document node.
 
 'file' may be either a file name or an open file object.
@@ -929,7 +929,7 @@
 return result
 
 
-def parseString(string, namespaces=1):
+def parseString(string, namespaces=True):
 """Parse a document from a string, returning the resulting
 Document node.
 """
@@ -940,7 +940,7 @@
 return builder.parseString(string)
 
 
-def parseFragment(file, context, namespaces=1):
+def parseFragment(file, context, namespaces=True):
 """Parse a fragment of a document, given the context from which it
 was originally extracted. context should be the parent of the
 node(s) which are in the fragment.
@@ -963,7 +963,7 @@
 return result
 
 
-def parseFragmentString(string, context, namespaces=1):
+def parseFragmentString(string, context, namespaces=True):
 """Parse a fragment of a document from a string, given the context
 from which it was originally extracted. context should be the
 parent of the node(s) which are in the fragment.
Modified: python/trunk/Lib/xmlcore/dom/minicompat.py
==============================================================================
--- python/trunk/Lib/xmlcore/dom/minicompat.py	(original)
+++ python/trunk/Lib/xmlcore/dom/minicompat.py	Thu Apr 6 03:29:04 2006
@@ -4,10 +4,6 @@
 #
 # The following names are defined:
 #
-# isinstance -- version of the isinstance() function that accepts
-# tuples as the second parameter regardless of the
-# Python version
-#
 # NodeList -- lightest possible NodeList implementation
 #
 # EmptyNodeList -- lightest possible NodeList that is guarateed to
@@ -15,8 +11,6 @@
 #
 # StringTypes -- tuple of defined string types
 #
-# GetattrMagic -- base class used to make _get_<attr> be magically
-# invoked when available
 # defproperty -- function used in conjunction with GetattrMagic;
 # using these together is needed to make them work
 # as efficiently as possible in both Python 2.2+
@@ -41,14 +35,8 @@
 #
 # defproperty() should be used for each version of
 # the relevant _get_<property>() function.
-#
-# NewStyle -- base class to cause __slots__ to be honored in
-# the new world
-#
-# True, False -- only for Python 2.2 and earlier
 
-__all__ = ["NodeList", "EmptyNodeList", "NewStyle",
- "StringTypes", "defproperty", "GetattrMagic"]
+__all__ = ["NodeList", "EmptyNodeList", "StringTypes", "defproperty"]
 
 import xmlcore.dom
 
@@ -60,125 +48,62 @@
 StringTypes = type(''), type(unicode(''))
 
 
-# define True and False only if not defined as built-ins
-try:
- True
-except NameError:
- True = 1
- False = 0
- __all__.extend(["True", "False"])
+class NodeList(list):
+ __slots__ = ()
 
+ def item(self, index):
+ if 0 <= index < len(self):
+ return self[index]
 
-try:
- isinstance('', StringTypes)
-except TypeError:
- #
- # Wrap isinstance() to make it compatible with the version in
- # Python 2.2 and newer.
- #
- _isinstance = isinstance
- def isinstance(obj, type_or_seq):
- try:
- return _isinstance(obj, type_or_seq)
- except TypeError:
- for t in type_or_seq:
- if _isinstance(obj, t):
- return 1
- return 0
- __all__.append("isinstance")
-
-
-if list is type([]):
- class NodeList(list):
- __slots__ = ()
-
- def item(self, index):
- if 0 <= index < len(self):
- return self[index]
-
- def _get_length(self):
- return len(self)
-
- def _set_length(self, value):
- raise xmlcore.dom.NoModificationAllowedErr(
- "attempt to modify read-only attribute 'length'")
-
- length = property(_get_length, _set_length,
- doc="The number of nodes in the NodeList.")
-
- def __getstate__(self):
- return list(self)
-
- def __setstate__(self, state):
- self[:] = state
-
- class EmptyNodeList(tuple):
- __slots__ = ()
-
- def __add__(self, other):
- NL = NodeList()
- NL.extend(other)
- return NL
-
- def __radd__(self, other):
- NL = NodeList()
- NL.extend(other)
- return NL
-
- def item(self, index):
- return None
-
- def _get_length(self):
- return 0
-
- def _set_length(self, value):
- raise xmlcore.dom.NoModificationAllowedErr(
- "attempt to modify read-only attribute 'length'")
+ def _get_length(self):
+ return len(self)
 
- length = property(_get_length, _set_length,
- doc="The number of nodes in the NodeList.")
+ def _set_length(self, value):
+ raise xml.dom.NoModificationAllowedErr(
+ "attempt to modify read-only attribute 'length'")
 
-else:
- def NodeList():
- return []
+ length = property(_get_length, _set_length,
+ doc="The number of nodes in the NodeList.")
 
- def EmptyNodeList():
- return []
+ def __getstate__(self):
+ return list(self)
 
+ def __setstate__(self, state):
+ self[:] = state
 
-try:
- property
-except NameError:
- def defproperty(klass, name, doc):
- # taken care of by the base __getattr__()
- pass
-
- class GetattrMagic:
- def __getattr__(self, key):
- if key.startswith("_"):
- raise AttributeError, key
-
- try:
- get = getattr(self, "_get_" + key)
- except AttributeError:
- raise AttributeError, key
- return get()
+class EmptyNodeList(tuple):
+ __slots__ = ()
 
- class NewStyle:
- pass
+ def __add__(self, other):
+ NL = NodeList()
+ NL.extend(other)
+ return NL
 
-else:
- def defproperty(klass, name, doc):
- get = getattr(klass, ("_get_" + name)).im_func
- def set(self, value, name=name):
- raise xmlcore.dom.NoModificationAllowedErr(
- "attempt to modify read-only attribute " + repr(name))
- assert not hasattr(klass, "_set_" + name), \
- "expected not to find _set_" + name
- prop = property(get, set, doc=doc)
- setattr(klass, name, prop)
+ def __radd__(self, other):
+ NL = NodeList()
+ NL.extend(other)
+ return NL
+
+ def item(self, index):
+ return None
+
+ def _get_length(self):
+ return 0
+
+ def _set_length(self, value):
+ raise xml.dom.NoModificationAllowedErr(
+ "attempt to modify read-only attribute 'length'")
+
+ length = property(_get_length, _set_length,
+ doc="The number of nodes in the NodeList.")
 
- class GetattrMagic:
- pass
 
- NewStyle = object
+def defproperty(klass, name, doc):
+ get = getattr(klass, ("_get_" + name)).im_func
+ def set(self, value, name=name):
+ raise xml.dom.NoModificationAllowedErr(
+ "attempt to modify read-only attribute " + repr(name))
+ assert not hasattr(klass, "_set_" + name), \
+ "expected not to find _set_" + name
+ prop = property(get, set, doc=doc)
+ setattr(klass, name, prop)
Modified: python/trunk/Lib/xmlcore/dom/minidom.py
==============================================================================
--- python/trunk/Lib/xmlcore/dom/minidom.py	(original)
+++ python/trunk/Lib/xmlcore/dom/minidom.py	Thu Apr 6 03:29:04 2006
@@ -31,7 +31,7 @@
 xmlcore.dom.Node.ENTITY_REFERENCE_NODE)
 
 
-class Node(xmlcore.dom.Node, GetattrMagic):
+class Node(xmlcore.dom.Node):
 namespaceURI = None # this is non-null only for elements and attributes
 parentNode = None
 ownerDocument = None
@@ -459,7 +459,7 @@
 defproperty(Attr, "schemaType", doc="Schema type for this attribute.")
 
 
-class NamedNodeMap(NewStyle, GetattrMagic):
+class NamedNodeMap(object):
 """The attribute list is a transient interface to the underlying
 dictionaries. Mutations here will change the underlying element's
 dictionary.
@@ -613,7 +613,7 @@
 AttributeList = NamedNodeMap
 
 
-class TypeInfo(NewStyle):
+class TypeInfo(object):
 __slots__ = 'namespace', 'name'
 
 def __init__(self, namespace, name):
@@ -1146,7 +1146,7 @@
 writer.write("<![CDATA[%s]]>" % self.data)
 
 
-class ReadOnlySequentialNamedNodeMap(NewStyle, GetattrMagic):
+class ReadOnlySequentialNamedNodeMap(object):
 __slots__ = '_seq',
 
 def __init__(self, seq=()):
@@ -1418,7 +1418,7 @@
 def _create_document(self):
 return Document()
 
-class ElementInfo(NewStyle):
+class ElementInfo(object):
 """Object that represents content-model information for an element.
 
 This implementation is not expected to be used in practice; DOM
Modified: python/trunk/Lib/xmlcore/dom/xmlbuilder.py
==============================================================================
--- python/trunk/Lib/xmlcore/dom/xmlbuilder.py	(original)
+++ python/trunk/Lib/xmlcore/dom/xmlbuilder.py	Thu Apr 6 03:29:04 2006
@@ -3,8 +3,6 @@
 import copy
 import xmlcore.dom
 
-from xmlcore.dom.minicompat import *
-
 from xmlcore.dom.NodeFilter import NodeFilter
 
 
@@ -211,7 +209,7 @@
 return name.lower().replace('-', '_')
 
 
-class DOMEntityResolver(NewStyle):
+class DOMEntityResolver(object):
 __slots__ = '_opener',
 
 def resolveEntity(self, publicId, systemId):
@@ -255,7 +253,7 @@
 return param.split("=", 1)[1].lower()
 
 
-class DOMInputSource(NewStyle):
+class DOMInputSource(object):
 __slots__ = ('byteStream', 'characterStream', 'stringData',
 'encoding', 'publicId', 'systemId', 'baseURI')
 


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /