summaryrefslogtreecommitdiffstats
path: root/Lib/ConfigParser.py
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2002-12-30 23:51:45 (GMT)
committerFred Drake <fdrake@acm.org>2002-12-30 23:51:45 (GMT)
commit8d5dd98a2e69591ee527d0063a0d237e87bb80e7 (patch)
treeab5f7250199bff897e93064cb72f2165bb4364fd /Lib/ConfigParser.py
parent81e4aa70541c1640d186b4f43999ad8c2679678e (diff)
downloadcpython-8d5dd98a2e69591ee527d0063a0d237e87bb80e7.zip
cpython-8d5dd98a2e69591ee527d0063a0d237e87bb80e7.tar.gz
cpython-8d5dd98a2e69591ee527d0063a0d237e87bb80e7.tar.bz2
- added InterpolationSyntaxError to __all__
- added docstring to exceptions
Diffstat (limited to 'Lib/ConfigParser.py')
-rw-r--r--Lib/ConfigParser.py29
1 files changed, 25 insertions, 4 deletions
diff --git a/Lib/ConfigParser.py b/Lib/ConfigParser.py
index a48d54b..24a4f23 100644
--- a/Lib/ConfigParser.py
+++ b/Lib/ConfigParser.py
@@ -89,9 +89,10 @@ ConfigParser -- responsible for for parsing a list of
import re
-__all__ = ["NoSectionError","DuplicateSectionError","NoOptionError",
- "InterpolationError","InterpolationDepthError","ParsingError",
- "MissingSectionHeaderError","ConfigParser",
+__all__ = ["NoSectionError", "DuplicateSectionError", "NoOptionError",
+ "InterpolationError", "InterpolationDepthError",
+ "InterpolationSyntaxError", "ParsingError",
+ "MissingSectionHeaderError", "ConfigParser",
"DEFAULTSECT", "MAX_INTERPOLATION_DEPTH"]
DEFAULTSECT = "DEFAULT"
@@ -102,24 +103,34 @@ MAX_INTERPOLATION_DEPTH = 10
# exception classes
class Error(Exception):
+ """Base class for ConfigParser exceptions."""
+
def __init__(self, msg=''):
self._msg = msg
Exception.__init__(self, msg)
+
def __repr__(self):
return self._msg
+
__str__ = __repr__
class NoSectionError(Error):
+ """Raised when no section matches a requested option."""
+
def __init__(self, section):
Error.__init__(self, 'No section: %s' % section)
self.section = section
class DuplicateSectionError(Error):
+ """Raised when a section is multiply-created."""
+
def __init__(self, section):
Error.__init__(self, "Section %s already exists" % section)
self.section = section
class NoOptionError(Error):
+ """A requested option was not found."""
+
def __init__(self, option, section):
Error.__init__(self, "No option `%s' in section: %s" %
(option, section))
@@ -127,6 +138,8 @@ class NoOptionError(Error):
self.section = section
class InterpolationError(Error):
+ """A string substitution required a setting which was not available."""
+
def __init__(self, reference, option, section, rawval):
Error.__init__(self,
"Bad value substitution:\n"
@@ -139,9 +152,13 @@ class InterpolationError(Error):
self.option = option
self.section = section
-class InterpolationSyntaxError(Error): pass
+class InterpolationSyntaxError(Error):
+ """Raised when the source text into which substitutions are made
+ does not conform to the required syntax."""
class InterpolationDepthError(Error):
+ """Raised when substitutions are nested too deeply."""
+
def __init__(self, option, section, rawval):
Error.__init__(self,
"Value interpolation too deeply recursive:\n"
@@ -153,6 +170,8 @@ class InterpolationDepthError(Error):
self.section = section
class ParsingError(Error):
+ """Raised when a configuration file does not follow legal syntax."""
+
def __init__(self, filename):
Error.__init__(self, 'File contains parsing errors: %s' % filename)
self.filename = filename
@@ -163,6 +182,8 @@ class ParsingError(Error):
self._msg = self._msg + '\n\t[line %2d]: %s' % (lineno, line)
class MissingSectionHeaderError(ParsingError):
+ """Raised when a key-value pair is found before any section header."""
+
def __init__(self, filename, lineno, line):
Error.__init__(
self,