libposixfile.tex 5.51 KB
Newer Older
1 2 3 4 5 6 7 8 9
% Manual text and implementation by Jaap Vermeulen
\section{Standard Module \sectcode{posixfile}}
\bimodindex{posixfile}
\indexii{posix}{file object}

This module implements some additional functionality over the built-in
file objects.  In particular, it implements file locking, control over
the file flags, and an easy interface to duplicate the file object.
The module defines a new file object, the posixfile object.  It
10 11 12
has all the standard file object methods and adds the methods
described below.  This module only works for certain flavors of
\UNIX{}, since it uses \code{fcntl()} for file locking.
13 14

To instantiate a posixfile object, use the \code{open()} function in
15 16
the posixfile module.  The resulting object looks and feels roughly
the same as a standard file object.
17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35

The posixfile module defines the following constants:

\renewcommand{\indexsubitem}{(in module posixfile)}
\begin{datadesc}{SEEK_SET}
offset is calculated from the start of the file
\end{datadesc}

\begin{datadesc}{SEEK_CUR}
offset is calculated from the current position in the file
\end{datadesc}

\begin{datadesc}{SEEK_END}
offset is calculated from the end of the file
\end{datadesc}

The posixfile module defines the following functions:

\renewcommand{\indexsubitem}{(in module posixfile)}
36 37

\begin{funcdesc}{open}{filename\optional{\, mode\optional{\, bufsize}}}
38
 Create a new posixfile object with the given filename and mode.  The
39
 \var{filename}, \var{mode} and \var{bufsize} arguments are
Guido van Rossum's avatar
Guido van Rossum committed
40
 interpreted the same way as by the built-in \code{open()} function.
41 42
\end{funcdesc}

43
\begin{funcdesc}{fileopen}{fileobject}
44 45 46 47 48 49 50 51
 Create a new posixfile object with the given standard file object.
 The resulting object has the same filename and mode as the original
 file object.
\end{funcdesc}

The posixfile object defines the following additional methods:

\renewcommand{\indexsubitem}{(posixfile method)}
52 53
\begin{funcdesc}{lock}{fmt\, \optional{len\optional{\, start
\optional{\, whence}}}}
54
 Lock the specified section of the file that the file object is
55 56 57 58 59
 referring to.  The format is explained
 below in a table.  The \var{len} argument specifies the length of the
 section that should be locked. The default is \code{0}. \var{start}
 specifies the starting offset of the section, where the default is
 \code{0}.  The \var{whence} argument specifies where the offset is
60 61 62 63 64 65
 relative to. It accepts one of the constants \code{SEEK_SET},
 \code{SEEK_CUR} or \code{SEEK_END}.  The default is \code{SEEK_SET}.
 For more information about the arguments refer to the fcntl
 manual page on your system.
\end{funcdesc}

66
\begin{funcdesc}{flags}{\optional{flags}}
67 68 69
 Set the specified flags for the file that the file object is referring
 to.  The new flags are ORed with the old flags, unless specified
 otherwise.  The format is explained below in a table.  Without
70 71
 the \var{flags} argument
 a string indicating the current flags is returned (this is
72
 the same as the '?' modifier).  For more information about the flags
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
 refer to the fcntl manual page on your system.
\end{funcdesc}

\begin{funcdesc}{dup}{}
 Duplicate the file object and the underlying file pointer and file
 descriptor.  The resulting object behaves as if it were newly
 opened.
\end{funcdesc}

\begin{funcdesc}{dup2}{fd}
 Duplicate the file object and the underlying file pointer and file
 descriptor.  The new object will have the given file descriptor.
 Otherwise the resulting object behaves as if it were newly opened.
\end{funcdesc}

\begin{funcdesc}{file}{}
 Return the standard file object that the posixfile object is based
 on.  This is sometimes necessary for functions that insist on a
 standard file object.
\end{funcdesc}

All methods return \code{IOError} when the request fails.

Format characters for the \code{lock()} method have the following meaning:

98 99 100 101 102
\begin{tableiii}{|c|l|c|}{samp}{Format}{Meaning}{}
  \lineiii{u}{unlock the specified region}{}
  \lineiii{r}{request a read lock for the specified section}{}
  \lineiii{w}{request a write lock for the specified section}{}
\end{tableiii}
103 104 105 106 107

In addition the following modifiers can be added to the format:

\begin{tableiii}{|c|l|c|}{samp}{Modifier}{Meaning}{Notes}
  \lineiii{|}{wait until the lock has been granted}{}
108 109
  \lineiii{?}{return the first lock conflicting with the requested lock, or
              \code{None} if there is no conflict.}{(1)} 
110 111 112 113 114 115 116 117 118 119 120
\end{tableiii}

Note:

(1) The lock returned is in the format \code{(mode, len, start,
whence, pid)} where mode is a character representing the type of lock
('r' or 'w').  This modifier prevents a request from being granted; it
is for query purposes only.

Format character for the \code{flags()} method have the following meaning:

121 122 123 124 125 126
\begin{tableiii}{|c|l|c|}{samp}{Format}{Meaning}{}
  \lineiii{a}{append only flag}{}
  \lineiii{c}{close on exec flag}{}
  \lineiii{n}{no delay flag (also called non-blocking flag)}{}
  \lineiii{s}{synchronization flag}{}
\end{tableiii}
127 128 129 130 131 132 133 134 135 136 137 138 139 140

In addition the following modifiers can be added to the format:

\begin{tableiii}{|c|l|c|}{samp}{Modifier}{Meaning}{Notes}
  \lineiii{!}{turn the specified flags 'off', instead of the default 'on'}{(1)}
  \lineiii{=}{replace the flags, instead of the default 'OR' operation}{(1)}
  \lineiii{?}{return a string in which the characters represent the flags that
  are set.}{(2)}
\end{tableiii}

Note:

(1) The \code{!} and \code{=} modifiers are mutually exclusive.

141
(2) This string represents the flags after they may have been altered
142 143 144 145 146 147 148 149 150 151 152 153 154
by the same call.

Examples:

\bcode\begin{verbatim}
from posixfile import *

file = open('/tmp/test', 'w')
file.lock('w|')
...
file.lock('u')
file.close()
\end{verbatim}\ecode