\section{\module{mhlib} --- Access to MH mailboxes} % LaTeX'ized from the comments in the module by Skip Montanaro % <skip@mojam.com>. \declaremodule{standard}{mhlib} \modulesynopsis{Manipulate MH mailboxes from Python.} The \module{mhlib} module provides a Python interface to MH folders and their contents. The module contains three basic classes, \class{MH}, which represents a particular collection of folders, \class{Folder}, which represents a single folder, and \class{Message}, which represents a single message. \begin{classdesc}{MH}{\optional{path\optional{, profile}}} \class{MH} represents a collection of MH folders. \end{classdesc} \begin{classdesc}{Folder}{mh, name} The \class{Folder} class represents a single folder and its messages. \end{classdesc} \begin{classdesc}{Message}{folder, number\optional{, name}} \class{Message} objects represent individual messages in a folder. The Message class is derived from \class{mimetools.Message}. \end{classdesc} \subsection{MH Objects \label{mh-objects}} \class{MH} instances have the following methods: \begin{methoddesc}[MH]{error}{format\optional{, ...}} Print an error message -- can be overridden. \end{methoddesc} \begin{methoddesc}[MH]{getprofile}{key} Return a profile entry (\code{None} if not set). \end{methoddesc} \begin{methoddesc}[MH]{getpath}{} Return the mailbox pathname. \end{methoddesc} \begin{methoddesc}[MH]{getcontext}{} Return the current folder name. \end{methoddesc} \begin{methoddesc}[MH]{setcontext}{name} Set the current folder name. \end{methoddesc} \begin{methoddesc}[MH]{listfolders}{} Return a list of top-level folders. \end{methoddesc} \begin{methoddesc}[MH]{listallfolders}{} Return a list of all folders. \end{methoddesc} \begin{methoddesc}[MH]{listsubfolders}{name} Return a list of direct subfolders of the given folder. \end{methoddesc} \begin{methoddesc}[MH]{listallsubfolders}{name} Return a list of all subfolders of the given folder. \end{methoddesc} \begin{methoddesc}[MH]{makefolder}{name} Create a new folder. \end{methoddesc} \begin{methoddesc}[MH]{deletefolder}{name} Delete a folder -- must have no subfolders. \end{methoddesc} \begin{methoddesc}[MH]{openfolder}{name} Return a new open folder object. \end{methoddesc} \subsection{Folder Objects \label{mh-folder-objects}} \class{Folder} instances represent open folders and have the following methods: \begin{methoddesc}[Folder]{error}{format\optional{, ...}} Print an error message -- can be overridden. \end{methoddesc} \begin{methoddesc}[Folder]{getfullname}{} Return the folder's full pathname. \end{methoddesc} \begin{methoddesc}[Folder]{getsequencesfilename}{} Return the full pathname of the folder's sequences file. \end{methoddesc} \begin{methoddesc}[Folder]{getmessagefilename}{n} Return the full pathname of message \var{n} of the folder. \end{methoddesc} \begin{methoddesc}[Folder]{listmessages}{} Return a list of messages in the folder (as numbers). \end{methoddesc} \begin{methoddesc}[Folder]{getcurrent}{} Return the current message number. \end{methoddesc} \begin{methoddesc}[Folder]{setcurrent}{n} Set the current message number to \var{n}. \end{methoddesc} \begin{methoddesc}[Folder]{parsesequence}{seq} Parse msgs syntax into list of messages. \end{methoddesc} \begin{methoddesc}[Folder]{getlast}{} Get last message, or \code{0} if no messages are in the folder. \end{methoddesc} \begin{methoddesc}[Folder]{setlast}{n} Set last message (internal use only). \end{methoddesc} \begin{methoddesc}[Folder]{getsequences}{} Return dictionary of sequences in folder. The sequence names are used as keys, and the values are the lists of message numbers in the sequences. \end{methoddesc} \begin{methoddesc}[Folder]{putsequences}{dict} Return dictionary of sequences in folder {name: list}. \end{methoddesc} \begin{methoddesc}[Folder]{removemessages}{list} Remove messages in list from folder. \end{methoddesc} \begin{methoddesc}[Folder]{refilemessages}{list, tofolder} Move messages in list to other folder. \end{methoddesc} \begin{methoddesc}[Folder]{movemessage}{n, tofolder, ton} Move one message to a given destination in another folder. \end{methoddesc} \begin{methoddesc}[Folder]{copymessage}{n, tofolder, ton} Copy one message to a given destination in another folder. \end{methoddesc} \subsection{Message Objects \label{mh-message-objects}} The \class{Message} class adds one method to those of \class{mimetools.Message}: \begin{methoddesc}[Message]{openmessage}{n} Return a new open message object (costs a file descriptor). \end{methoddesc}