summaryrefslogtreecommitdiffstats
path: root/Doc
diff options
context:
space:
mode:
Diffstat (limited to 'Doc')
-rw-r--r--Doc/lib/lib.tex1
-rw-r--r--Doc/lib/libcfgparser.tex116
-rw-r--r--Doc/lib/libundoc.tex3
3 files changed, 117 insertions, 3 deletions
diff --git a/Doc/lib/lib.tex b/Doc/lib/lib.tex
index ae2b890..020a932 100644
--- a/Doc/lib/lib.tex
+++ b/Doc/lib/lib.tex
@@ -113,6 +113,7 @@ add new extensions to Python and how to embed it in other applications.
%\input{librand}
\input{libbisect}
\input{libarray}
+\input{libcfgparser}
\input{libfileinput}
\input{libcalendar}
\input{libcmd}
diff --git a/Doc/lib/libcfgparser.tex b/Doc/lib/libcfgparser.tex
new file mode 100644
index 0000000..7f09581
--- /dev/null
+++ b/Doc/lib/libcfgparser.tex
@@ -0,0 +1,116 @@
+\section{\module{ConfigParser} ---
+ Configuration file parser.}
+
+\declaremodule{standard}{ConfigParser}
+
+\modulesynopsis{Configuration file parser.}
+\sectionauthor{Christopher G. Petrilli}{petrilli@amber.org}
+
+This module defines the class \class{ConfigParser}. The
+\class{ConfigParser} class implements a basic configuration file
+parser language which provides a structure similar to what you would
+find on Microsoft Windows INI files. You can use this to write Python
+programs which can be customized by end users easily.
+
+The configuration file consists of sections, lead by a
+\samp{[section]} header and followed by \samp{name: value} entries,
+with continuations in the style of \rfc{959}. The optional values
+can contain format strings which refer to other values in the same
+section, or values in a special \code{DEFAULT} section. Additional
+defaults can provided upon instantiation of the class.
+
+For example:
+
+\begin{verbatim}
+foodir: %(dir)s/whatever
+\end{verbatim}
+
+would resolve the \samp{\%(dir)s} to the value of dir. All reference
+expansions are done late, on demand.
+
+Intrinsic defaults can be specified by passing them into the
+\class{ConfigParser} constructor as a dictionary.
+
+\begin{classdesc}{ConfigParser}{\optional{defaults}}
+Return a new instance of the \class{ConfigParser} class. When
+\var{defaults} is given, it is initialized into the dictionairy of
+intrinsic defaults. They keys must be strings, and the values must be
+appropriate for the \samp{\%()s} string interpolation. Note that
+\var{__name__} is always an intrinsic default; it's value is the
+section name.
+\end{classdesc}
+
+\begin{excdesc}{NoSectionError}
+Exception raised when a specified section is not found.
+\end{excdesc}
+
+\begin{excdesc}{DuplicateSectionError}
+Exception raised when mutliple sections with the same name are found.
+\end{excdesc}
+
+\begin{excdesc}{NoOptionError}
+Exception raised when a specified option is not found in the specified
+section.
+\end{excdesc}
+
+\begin{excdesc}{InterpolationError}
+Exception raised when problems occur performing string interpolation.
+\end{excdesc}
+
+\begin{excdesc}{MissingSectionHeaderError}
+Exception raised when attempting to parse a file which has no section
+headers.
+\end{excdesc}
+
+\begin{excdesc}{ParsingError}
+Exception raised when errors occur attempting to parse a file.
+\end{excdesc}
+
+\subsection{ConfigParser Objects \label{ConfigParser-objects}}
+
+\class{ConfigParser} instances have the following methods:
+
+\begin{methoddesc}{defaults}{}
+Return a dictionairy containing the instance-wide defaults.
+\end{methoddesc}
+
+\begin{methoddesc}{sections}{}
+Return a list of the sections available.
+\end{methoddesc}
+
+\begin{methoddesc}{has_section}{section}
+Indicates whether the named section is present in the
+configuration. The \code{DEFAULT} section is not acknowledged.
+\end{methoddesc}
+
+\begin{methoddesc}{options}{section}
+Returns a list of options available in the specified \var{section}.
+\end{methoddesc}
+
+\begin{methoddesc}{read}{filenames}
+Read and parse a list of filenames.
+\end{methoddesc}
+
+\begin{methoddesc}{get}{section, option\optional{, raw}}
+Get an \var{option} value for the provided \var{section}. All the
+\samp{\%} interpolations are expanded in the return values, based on
+the defaults passed into the constructor, unless the \var{raw}
+argument is true.
+\end{methoddesc}
+
+\begin{methoddesc}{getint}{section, option}
+A convenience method which coerces the \var{option} in the specified
+\var{section} to an integer.
+\end{methoddesc}
+
+\begin{methoddesc}{getfloat}{section, option}
+A convenience method which coerces the \var{option} in the specified
+\var{section} to a floating point number.
+\end{methoddesc}
+
+\begin{methoddesc}{getboolean}{section, option}
+A convenience method which coerces the \var{option} in the specified
+\var{section} to a boolean value. Note that the only accepted values
+for the option are \code{0} and \code{1}, any others will raise
+\exception{ValueError}.
+\end{methoddesc}
diff --git a/Doc/lib/libundoc.tex b/Doc/lib/libundoc.tex
index 4420468..bb7274d 100644
--- a/Doc/lib/libundoc.tex
+++ b/Doc/lib/libundoc.tex
@@ -43,9 +43,6 @@ This is a package rather than a module.
Some of these are very old and/or not very robust; marked with ``hmm''.
\begin{description}
-\item[ConfigParser.py]
---- Parse a file of sectioned configuration parameters
-
\item[cmp.py]
--- Efficiently compare files