diff options
author | Guido van Rossum <guido@python.org> | 1999-10-04 18:57:27 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1999-10-04 18:57:27 (GMT) |
commit | 6a8d84b0c1508d0a3f10f716f3faf3863b41f758 (patch) | |
tree | eb9c723300fd2312dc0b070a0c012ff02a02c912 /Lib/ConfigParser.py | |
parent | 2438a485c84bd52a72ae11502bd21e89f1048be6 (diff) | |
download | cpython-6a8d84b0c1508d0a3f10f716f3faf3863b41f758.zip cpython-6a8d84b0c1508d0a3f10f716f3faf3863b41f758.tar.gz cpython-6a8d84b0c1508d0a3f10f716f3faf3863b41f758.tar.bz2 |
Urmpfh!
Withdraw the change that Fred just checked in -- it was a poorly
documented feature, not a bug, to ignore I/O errors in read().
The new docstring explains the reason for the feature:
"""
this is designed so that you can specifiy a list of potential
configuration file locations (e.g. current directory, user's home
directory, systemwide directory), and all existing configuration files
in the list will be read.
"""
Also add a lower-level function, readfp(), which takes an open file
object (and optionally a filename).
XXX There are some other problems with this module, but I don't have
time to dig into these; in particular, there are complaints that the
%(name)s substitution from the [DEFAULTS] section doesn't work
correctly.
Diffstat (limited to 'Lib/ConfigParser.py')
-rw-r--r-- | Lib/ConfigParser.py | 51 |
1 files changed, 43 insertions, 8 deletions
diff --git a/Lib/ConfigParser.py b/Lib/ConfigParser.py index 2d0e0c6..b0475a3 100644 --- a/Lib/ConfigParser.py +++ b/Lib/ConfigParser.py @@ -37,7 +37,14 @@ ConfigParser -- responsible for for parsing a list of return list of configuration options for the named section read(filenames) - read and parse the list of named configuration files + read and parse the list of named configuration files, given by + name. A single filename is also allowed. Non-existing files + are ignored. + + readfp(fp, filename=None) + read and parse one configuration file, given as a file object. + The filename defaults to fp.name; it is only used in error + messages. get(section, option, raw=0, vars=None) return a string value for the named option. All % interpolations are @@ -166,14 +173,42 @@ class ConfigParser: return opts.keys() def read(self, filenames): - """Read and parse a list of filenames.""" + + """Read and parse a filename or a list of filenames. + + Files that cannot be opened are silently ignored; this is + designed so that you can specifiy a list of potential + configuration file locations (e.g. current directory, user's + home directory, systemwide directory), and all existing + configuration files in the list will be read. A single + filename may also be given. + """ if type(filenames) is type(''): filenames = [filenames] - for file in filenames: - fp = open(file) - self.__read(fp) + for filename in filenames: + try: + fp = open(filename) + except IOError: + continue + self.__read(fp, filename) fp.close() + def readfp(self, fp, filename=None): + """Like read() but the argument must be a file-like object. + + The `fp' argument must have a `readline' method. Optional + second argument is the `filename', which if not given, is + taken from fp.name. If fp has no `name' attribute, `<???>' is + used. + + """ + if filename is None: + try: + filename = fp.name + except AttributeError: + filename = '<???>' + self.__read(fp, filename) + def get(self, section, option, raw=0, vars=None): """Get an option value for a given section. @@ -255,7 +290,7 @@ class ConfigParser: r'(?P<value>.*)$' # everything up to eol ) - def __read(self, fp): + def __read(self, fp, fpname): """Parse a sectioned setup file. The sections in setup file contains a title line at the top, @@ -302,7 +337,7 @@ class ConfigParser: optname = None # no section header in the file? elif cursect is None: - raise MissingSectionHeaderError(fp.name, lineno, `line`) + raise MissingSectionHeaderError(fpname, lineno, `line`) # an option line? else: mo = self.OPTCRE.match(line) @@ -320,7 +355,7 @@ class ConfigParser: # raised at the end of the file and will contain a # list of all bogus lines if not e: - e = ParsingError(fp.name) + e = ParsingError(fpname) e.append(lineno, `line`) # if any parsing errors occurred, raise an exception if e: |