summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2004-03-20 08:15:30 (GMT)
committerFred Drake <fdrake@acm.org>2004-03-20 08:15:30 (GMT)
commit6fd0b0d5bacb38ac88e74a767f11df2bb73ae49b (patch)
treede4d0d2fc4f3ad9e462719cecb61975ba8082e62 /Lib
parent9de0a2ba9dba2794927b895e9a8473c9437bebd1 (diff)
downloadcpython-6fd0b0d5bacb38ac88e74a767f11df2bb73ae49b.zip
cpython-6fd0b0d5bacb38ac88e74a767f11df2bb73ae49b.tar.gz
cpython-6fd0b0d5bacb38ac88e74a767f11df2bb73ae49b.tar.bz2
commit the portion of PyXML patch #919008 that is relevant to the
standard library: str() of xml.sax.SAXParseException should not fail if the line and/or column number returned by the locator are None (tests added)
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/test_sax.py35
-rw-r--r--Lib/xml/sax/_exceptions.py9
2 files changed, 42 insertions, 2 deletions
diff --git a/Lib/test/test_sax.py b/Lib/test/test_sax.py
index af97888..8e279ce 100644
--- a/Lib/test/test_sax.py
+++ b/Lib/test/test_sax.py
@@ -489,6 +489,41 @@ def test_expat_incomplete():
else:
return 0
+def test_sax_parse_exception_str():
+ # pass various values from a locator to the SAXParseException to
+ # make sure that the __str__() doesn't fall apart when None is
+ # passed instead of an integer line and column number
+ #
+ # use "normal" values for the locator:
+ str(SAXParseException("message", None,
+ DummyLocator(1, 1)))
+ # use None for the line number:
+ str(SAXParseException("message", None,
+ DummyLocator(None, 1)))
+ # use None for the column number:
+ str(SAXParseException("message", None,
+ DummyLocator(1, None)))
+ # use None for both:
+ str(SAXParseException("message", None,
+ DummyLocator(None, None)))
+ return 1
+
+class DummyLocator:
+ def __init__(self, lineno, colno):
+ self._lineno = lineno
+ self._colno = colno
+
+ def getPublicId(self):
+ return "pubid"
+
+ def getSystemId(self):
+ return "sysid"
+
+ def getLineNumber(self):
+ return self._lineno
+
+ def getColumnNumber(self):
+ return self._colno
# ===========================================================================
#
diff --git a/Lib/xml/sax/_exceptions.py b/Lib/xml/sax/_exceptions.py
index 7f128f6..628e80d 100644
--- a/Lib/xml/sax/_exceptions.py
+++ b/Lib/xml/sax/_exceptions.py
@@ -91,8 +91,13 @@ class SAXParseException(SAXException):
sysid = self.getSystemId()
if sysid is None:
sysid = "<unknown>"
- return "%s:%d:%d: %s" % (sysid, self.getLineNumber(),
- self.getColumnNumber(), self._msg)
+ linenum = self.getLineNumber()
+ if linenum is None:
+ linenum = "?"
+ colnum = self.getColumnNumber()
+ if colnum is None:
+ colnum = "?"
+ return "%s:%s:%s: %s" % (sysid, linenum, colnum, self._msg)
# ===== SAXNOTRECOGNIZEDEXCEPTION =====