| Fred Drake | 295da24 | 1998-08-10 19:42:37 +0000 | [diff] [blame] | 1 | \section{\module{os} --- | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 2 | Miscellaneous OS interfaces} | 
| Fred Drake | b91e934 | 1998-07-23 17:59:49 +0000 | [diff] [blame] | 3 |  | 
| Fred Drake | ec6baaf | 1999-04-21 18:13:31 +0000 | [diff] [blame] | 4 | \declaremodule{standard}{os} | 
| Fred Drake | b91e934 | 1998-07-23 17:59:49 +0000 | [diff] [blame] | 5 | \modulesynopsis{Miscellaneous OS interfaces.} | 
|  | 6 |  | 
| Fred Drake | c4f15af | 1998-03-10 03:17:26 +0000 | [diff] [blame] | 7 |  | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 8 | This module provides a more portable way of using operating system | 
|  | 9 | (OS) dependent functionality than importing an OS dependent built-in | 
| Fred Drake | 2f97901 | 1999-06-11 18:28:37 +0000 | [diff] [blame] | 10 | module like \refmodule{posix} or \module{nt}. | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 11 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 12 | This module searches for an OS dependent built-in module like | 
| Fred Drake | 2f97901 | 1999-06-11 18:28:37 +0000 | [diff] [blame] | 13 | \module{mac} or \refmodule{posix} and exports the same functions and data | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 14 | as found there.  The design of all Python's built-in OS dependent | 
|  | 15 | modules is such that as long as the same functionality is available, | 
|  | 16 | it uses the same interface; e.g., the function | 
| Fred Drake | ec6baaf | 1999-04-21 18:13:31 +0000 | [diff] [blame] | 17 | \code{os.stat(\var{path})} returns stat information about \var{path} in | 
|  | 18 | the same format (which happens to have originated with the | 
|  | 19 | \POSIX{} interface). | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 20 |  | 
|  | 21 | Extensions peculiar to a particular OS are also available through the | 
| Fred Drake | c4f15af | 1998-03-10 03:17:26 +0000 | [diff] [blame] | 22 | \module{os} module, but using them is of course a threat to | 
|  | 23 | portability! | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 24 |  | 
| Fred Drake | c4f15af | 1998-03-10 03:17:26 +0000 | [diff] [blame] | 25 | Note that after the first time \module{os} is imported, there is | 
|  | 26 | \emph{no} performance penalty in using functions from \module{os} | 
|  | 27 | instead of directly from the OS dependent built-in module, so there | 
|  | 28 | should be \emph{no} reason not to use \module{os}! | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 29 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 30 |  | 
| Fred Drake | 859dc53 | 1999-07-01 13:54:40 +0000 | [diff] [blame] | 31 | % Frank Stajano <fstajano@uk.research.att.com> complained that it | 
|  | 32 | % wasn't clear that the entries described in the subsections were all | 
|  | 33 | % available at the module level (most uses of subsections are | 
|  | 34 | % different); I think this is only a problem for the HTML version, | 
|  | 35 | % where the relationship may not be as clear. | 
|  | 36 | % | 
|  | 37 | \ifhtml | 
|  | 38 | The \module{os} module contains many functions and data values. | 
|  | 39 | The items below and in the following sub-sections are all available | 
|  | 40 | directly from the \module{os} module. | 
|  | 41 | \fi | 
|  | 42 |  | 
|  | 43 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 44 | \begin{excdesc}{error} | 
|  | 45 | This exception is raised when a function returns a | 
|  | 46 | system-related error (e.g., not for illegal argument types).  This is | 
|  | 47 | also known as the built-in exception \exception{OSError}.  The | 
|  | 48 | accompanying value is a pair containing the numeric error code from | 
|  | 49 | \cdata{errno} and the corresponding string, as would be printed by the | 
|  | 50 | C function \cfunction{perror()}.  See the module | 
|  | 51 | \refmodule{errno}\refbimodindex{errno}, which contains names for the | 
|  | 52 | error codes defined by the underlying operating system. | 
|  | 53 |  | 
|  | 54 | When exceptions are classes, this exception carries two attributes, | 
|  | 55 | \member{errno} and \member{strerror}.  The first holds the value of | 
|  | 56 | the C \cdata{errno} variable, and the latter holds the corresponding | 
|  | 57 | error message from \cfunction{strerror()}.  For exceptions that | 
|  | 58 | involve a file system path (e.g. \function{chdir()} or | 
|  | 59 | \function{unlink()}), the exception instance will contain a third | 
|  | 60 | attribute, \member{filename}, which is the file name passed to the | 
|  | 61 | function. | 
|  | 62 |  | 
|  | 63 | When exceptions are strings, the string for the exception is | 
|  | 64 | \code{'OSError'}. | 
|  | 65 | \end{excdesc} | 
| Guido van Rossum | 470be14 | 1995-03-17 16:07:09 +0000 | [diff] [blame] | 66 |  | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 67 | \begin{datadesc}{name} | 
| Guido van Rossum | 470be14 | 1995-03-17 16:07:09 +0000 | [diff] [blame] | 68 | The name of the OS dependent module imported.  The following names | 
|  | 69 | have currently been registered: \code{'posix'}, \code{'nt'}, | 
| Fred Drake | 933d5a7 | 1999-09-17 14:38:39 +0000 | [diff] [blame] | 70 | \code{'dos'}, \code{'mac'}, \code{'os2'}, \code{'ce'}, \code{'java'}. | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 71 | \end{datadesc} | 
|  | 72 |  | 
|  | 73 | \begin{datadesc}{path} | 
|  | 74 | The corresponding OS dependent standard module for pathname | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 75 | operations, e.g., \module{posixpath} or \module{macpath}.  Thus, given | 
|  | 76 | the proper imports, \code{os.path.split(\var{file})} is equivalent to but | 
|  | 77 | more portable than \code{posixpath.split(\var{file})}.  Note that this | 
|  | 78 | is also a valid module: it may be imported directly as | 
|  | 79 | \refmodule{os.path}. | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 80 | \end{datadesc} | 
|  | 81 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 82 |  | 
|  | 83 |  | 
|  | 84 | \subsection{Process Parameters \label{os-procinfo}} | 
|  | 85 |  | 
|  | 86 | These functions and data items provide information and operate on the | 
|  | 87 | current process and user. | 
|  | 88 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 89 | \begin{datadesc}{environ} | 
| Fred Drake | 0e1de8b | 1999-04-29 12:57:32 +0000 | [diff] [blame] | 90 | A mapping object representing the string environment. For example, | 
|  | 91 | \code{environ['HOME']} is the pathname of your home directory (on some | 
|  | 92 | platforms), and is equivalent to \code{getenv("HOME")} in C. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 93 |  | 
|  | 94 | If the platform supports the \function{putenv()} function, this | 
|  | 95 | mapping may be used to modify the environment as well as query the | 
|  | 96 | environment.  \function{putenv()} will be called automatically when | 
|  | 97 | the mapping is modified. | 
|  | 98 |  | 
|  | 99 | If \function{putenv()} is not provided, this mapping may be passed to | 
|  | 100 | the appropriate process-creation functions to cause child processes to | 
|  | 101 | use a modified environment. | 
|  | 102 | \end{datadesc} | 
|  | 103 |  | 
| Fred Drake | 6db897c | 1999-07-12 16:49:30 +0000 | [diff] [blame] | 104 | \begin{funcdescni}{chdir}{path} | 
|  | 105 | \funclineni{getcwd}{} | 
|  | 106 | These functions are described in ``Files and Directories'' (section | 
|  | 107 | \ref{os-file-dir}). | 
|  | 108 | \end{funcdescni} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 109 |  | 
| Fred Drake | 18f7a45 | 1999-12-09 22:11:43 +0000 | [diff] [blame] | 110 | \begin{funcdesc}{ctermid}{} | 
|  | 111 | Return the filename corresponding to the controlling terminal of the | 
|  | 112 | process. | 
|  | 113 | Availability: \UNIX{}. | 
|  | 114 | \end{funcdesc} | 
|  | 115 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 116 | \begin{funcdesc}{getegid}{} | 
|  | 117 | Return the current process' effective group id. | 
|  | 118 | Availability: \UNIX{}. | 
|  | 119 | \end{funcdesc} | 
|  | 120 |  | 
|  | 121 | \begin{funcdesc}{geteuid}{} | 
| Fred Drake | 6b330ba8 | 1999-05-25 13:42:26 +0000 | [diff] [blame] | 122 | \index{user!effective id} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 123 | Return the current process' effective user id. | 
|  | 124 | Availability: \UNIX{}. | 
|  | 125 | \end{funcdesc} | 
|  | 126 |  | 
|  | 127 | \begin{funcdesc}{getgid}{} | 
| Fred Drake | 6b330ba8 | 1999-05-25 13:42:26 +0000 | [diff] [blame] | 128 | \index{process!group} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 129 | Return the current process' group id. | 
|  | 130 | Availability: \UNIX{}. | 
|  | 131 | \end{funcdesc} | 
|  | 132 |  | 
| Fred Drake | 88f6ca2 | 1999-12-15 19:39:04 +0000 | [diff] [blame] | 133 | \begin{funcdesc}{getgroups}{} | 
|  | 134 | Return list of supplemental group ids associated with the current | 
|  | 135 | process. | 
|  | 136 | Availability: \UNIX{}. | 
|  | 137 | \end{funcdesc} | 
|  | 138 |  | 
|  | 139 | \begin{funcdesc}{getlogin}{} | 
|  | 140 | Return the actual login name for the current process, even if there | 
|  | 141 | are multiple login names which map to the same user id. | 
|  | 142 | Availability: \UNIX{}. | 
|  | 143 | \end{funcdesc} | 
|  | 144 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 145 | \begin{funcdesc}{getpgrp}{} | 
|  | 146 | \index{process!group} | 
|  | 147 | Return the current process group id. | 
|  | 148 | Availability: \UNIX{}. | 
|  | 149 | \end{funcdesc} | 
|  | 150 |  | 
|  | 151 | \begin{funcdesc}{getpid}{} | 
|  | 152 | \index{process!id} | 
|  | 153 | Return the current process id. | 
|  | 154 | Availability: \UNIX{}, Windows. | 
|  | 155 | \end{funcdesc} | 
|  | 156 |  | 
|  | 157 | \begin{funcdesc}{getppid}{} | 
|  | 158 | \index{process!id of parent} | 
|  | 159 | Return the parent's process id. | 
|  | 160 | Availability: \UNIX{}. | 
|  | 161 | \end{funcdesc} | 
|  | 162 |  | 
|  | 163 | \begin{funcdesc}{getuid}{} | 
| Fred Drake | 6b330ba8 | 1999-05-25 13:42:26 +0000 | [diff] [blame] | 164 | \index{user!id} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 165 | Return the current process' user id. | 
|  | 166 | Availability: \UNIX{}. | 
|  | 167 | \end{funcdesc} | 
|  | 168 |  | 
|  | 169 | \begin{funcdesc}{putenv}{varname, value} | 
|  | 170 | \index{environment variables!setting} | 
|  | 171 | Set the environment variable named \var{varname} to the string | 
|  | 172 | \var{value}.  Such changes to the environment affect subprocesses | 
|  | 173 | started with \function{os.system()}, \function{popen()} or | 
|  | 174 | \function{fork()} and \function{execv()}. | 
|  | 175 | Availability: most flavors of \UNIX{}, Windows. | 
|  | 176 |  | 
|  | 177 | When \function{putenv()} is | 
|  | 178 | supported, assignments to items in \code{os.environ} are automatically | 
|  | 179 | translated into corresponding calls to \function{putenv()}; however, | 
|  | 180 | calls to \function{putenv()} don't update \code{os.environ}, so it is | 
|  | 181 | actually preferable to assign to items of \code{os.environ}. | 
|  | 182 | \end{funcdesc} | 
|  | 183 |  | 
|  | 184 | \begin{funcdesc}{setgid}{gid} | 
|  | 185 | Set the current process' group id. | 
|  | 186 | Availability: \UNIX{}. | 
|  | 187 | \end{funcdesc} | 
|  | 188 |  | 
|  | 189 | \begin{funcdesc}{setpgrp}{} | 
|  | 190 | Calls the system call \cfunction{setpgrp()} or \cfunction{setpgrp(0, | 
|  | 191 | 0)} depending on which version is implemented (if any).  See the | 
|  | 192 | \UNIX{} manual for the semantics. | 
|  | 193 | Availability: \UNIX{}. | 
|  | 194 | \end{funcdesc} | 
|  | 195 |  | 
|  | 196 | \begin{funcdesc}{setpgid}{pid, pgrp} | 
|  | 197 | Calls the system call \cfunction{setpgid()}.  See the \UNIX{} manual | 
|  | 198 | for the semantics. | 
|  | 199 | Availability: \UNIX{}. | 
|  | 200 | \end{funcdesc} | 
|  | 201 |  | 
|  | 202 | \begin{funcdesc}{setsid}{} | 
|  | 203 | Calls the system call \cfunction{setsid()}.  See the \UNIX{} manual | 
|  | 204 | for the semantics. | 
|  | 205 | Availability: \UNIX{}. | 
|  | 206 | \end{funcdesc} | 
|  | 207 |  | 
|  | 208 | \begin{funcdesc}{setuid}{uid} | 
| Fred Drake | 6b330ba8 | 1999-05-25 13:42:26 +0000 | [diff] [blame] | 209 | \index{user!id, setting} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 210 | Set the current process' user id. | 
|  | 211 | Availability: \UNIX{}. | 
|  | 212 | \end{funcdesc} | 
|  | 213 |  | 
|  | 214 | % placed in this section since it relates to errno.... a little weak ;-( | 
|  | 215 | \begin{funcdesc}{strerror}{code} | 
|  | 216 | Return the error message corresponding to the error code in | 
|  | 217 | \var{code}. | 
|  | 218 | Availability: \UNIX{}, Windows. | 
|  | 219 | \end{funcdesc} | 
|  | 220 |  | 
|  | 221 | \begin{funcdesc}{umask}{mask} | 
|  | 222 | Set the current numeric umask and returns the previous umask. | 
|  | 223 | Availability: \UNIX{}, Windows. | 
|  | 224 | \end{funcdesc} | 
|  | 225 |  | 
|  | 226 | \begin{funcdesc}{uname}{} | 
|  | 227 | Return a 5-tuple containing information identifying the current | 
|  | 228 | operating system.  The tuple contains 5 strings: | 
|  | 229 | \code{(\var{sysname}, \var{nodename}, \var{release}, \var{version}, | 
|  | 230 | \var{machine})}.  Some systems truncate the nodename to 8 | 
|  | 231 | characters or to the leading component; a better way to get the | 
|  | 232 | hostname is \function{socket.gethostname()} | 
|  | 233 | \withsubitem{(in module socket)}{\ttindex{gethostname()}} | 
|  | 234 | or even | 
|  | 235 | \withsubitem{(in module socket)}{\ttindex{gethostbyaddr()}} | 
|  | 236 | \code{socket.gethostbyaddr(socket.gethostname())}. | 
|  | 237 | Availability: recent flavors of \UNIX{}. | 
|  | 238 | \end{funcdesc} | 
|  | 239 |  | 
|  | 240 |  | 
|  | 241 |  | 
|  | 242 | \subsection{File Object Creation \label{os-newstreams}} | 
|  | 243 |  | 
|  | 244 | These functions create new file objects. | 
|  | 245 |  | 
|  | 246 |  | 
|  | 247 | \begin{funcdesc}{fdopen}{fd\optional{, mode\optional{, bufsize}}} | 
|  | 248 | Return an open file object connected to the file descriptor \var{fd}. | 
| Fred Drake | 8c9fc00 | 1999-08-05 13:41:31 +0000 | [diff] [blame] | 249 | \index{I/O control!buffering} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 250 | The \var{mode} and \var{bufsize} arguments have the same meaning as | 
|  | 251 | the corresponding arguments to the built-in \function{open()} | 
|  | 252 | function. | 
|  | 253 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 254 | \end{funcdesc} | 
|  | 255 |  | 
|  | 256 | \begin{funcdesc}{popen}{command\optional{, mode\optional{, bufsize}}} | 
|  | 257 | Open a pipe to or from \var{command}.  The return value is an open | 
|  | 258 | file object connected to the pipe, which can be read or written | 
|  | 259 | depending on whether \var{mode} is \code{'r'} (default) or \code{'w'}. | 
|  | 260 | The \var{bufsize} argument has the same meaning as the corresponding | 
|  | 261 | argument to the built-in \function{open()} function.  The exit status of | 
|  | 262 | the command (encoded in the format specified for \function{wait()}) is | 
|  | 263 | available as the return value of the \method{close()} method of the file | 
|  | 264 | object, except that when the exit status is zero (termination without | 
| Fred Drake | 38e5d27 | 2000-04-03 20:13:55 +0000 | [diff] [blame^] | 265 | errors), \code{None} is returned.  \strong{Note:} This function | 
|  | 266 | behaves unreliably under Windows due to the native implementation of | 
|  | 267 | \cfunction{popen()}. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 268 | Availability: \UNIX{}, Windows. | 
|  | 269 | \end{funcdesc} | 
|  | 270 |  | 
| Fred Drake | 18f7a45 | 1999-12-09 22:11:43 +0000 | [diff] [blame] | 271 | \begin{funcdesc}{tmpfile}{} | 
|  | 272 | Return a new file object opened in update mode (\samp{w+}).  The file | 
|  | 273 | has no directory entries associated with it and will be automatically | 
|  | 274 | deleted once there are no file descriptors for the file. | 
|  | 275 | Availability: \UNIX{}. | 
|  | 276 | \end{funcdesc} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 277 |  | 
|  | 278 |  | 
|  | 279 | \subsection{File Descriptor Operations \label{os-fd-ops}} | 
|  | 280 |  | 
|  | 281 | These functions operate on I/O streams referred to | 
|  | 282 | using file descriptors. | 
|  | 283 |  | 
|  | 284 |  | 
|  | 285 | \begin{funcdesc}{close}{fd} | 
|  | 286 | Close file descriptor \var{fd}. | 
|  | 287 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 288 |  | 
|  | 289 | Note: this function is intended for low-level I/O and must be applied | 
|  | 290 | to a file descriptor as returned by \function{open()} or | 
|  | 291 | \function{pipe()}.  To close a ``file object'' returned by the | 
|  | 292 | built-in function \function{open()} or by \function{popen()} or | 
|  | 293 | \function{fdopen()}, use its \method{close()} method. | 
|  | 294 | \end{funcdesc} | 
|  | 295 |  | 
|  | 296 | \begin{funcdesc}{dup}{fd} | 
|  | 297 | Return a duplicate of file descriptor \var{fd}. | 
|  | 298 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 299 | \end{funcdesc} | 
|  | 300 |  | 
|  | 301 | \begin{funcdesc}{dup2}{fd, fd2} | 
|  | 302 | Duplicate file descriptor \var{fd} to \var{fd2}, closing the latter | 
|  | 303 | first if necessary. | 
|  | 304 | Availability: \UNIX{}, Windows. | 
|  | 305 | \end{funcdesc} | 
|  | 306 |  | 
| Fred Drake | 88f6ca2 | 1999-12-15 19:39:04 +0000 | [diff] [blame] | 307 | \begin{funcdesc}{fpathconf}{fd, name} | 
|  | 308 | Return system configration information relevant to an open file. | 
|  | 309 | \var{name} specifies the configuration value to retrieve; it may be a | 
|  | 310 | string which is the name of a defined system value; these names are | 
|  | 311 | specified in a number of standards (\POSIX.1, Unix95, Unix98, and | 
|  | 312 | others).  Some platforms define additional names as well.  The names | 
|  | 313 | known to the host operating system are given in the | 
|  | 314 | \code{pathconf_names} dictionary.  For configuration variables not | 
|  | 315 | included in that mapping, passing an integer for \var{name} is also | 
|  | 316 | accepted. | 
|  | 317 | Availability: \UNIX{}. | 
|  | 318 |  | 
|  | 319 | If \var{name} is a string and is not known, \exception{ValueError} is | 
|  | 320 | raised.  If a specific value for \var{name} is not supported by the | 
|  | 321 | host system, even if it is included in \code{pathconf_names}, an | 
|  | 322 | \exception{OSError} is raised with \constant{errno.EINVAL} for the | 
|  | 323 | error number. | 
|  | 324 | \end{funcdesc} | 
|  | 325 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 326 | \begin{funcdesc}{fstat}{fd} | 
|  | 327 | Return status for file descriptor \var{fd}, like \function{stat()}. | 
|  | 328 | Availability: \UNIX{}, Windows. | 
|  | 329 | \end{funcdesc} | 
|  | 330 |  | 
|  | 331 | \begin{funcdesc}{fstatvfs}{fd} | 
|  | 332 | Return information about the filesystem containing the file associated | 
|  | 333 | with file descriptor \var{fd}, like \function{statvfs()}. | 
|  | 334 | Availability: \UNIX{}. | 
|  | 335 | \end{funcdesc} | 
|  | 336 |  | 
|  | 337 | \begin{funcdesc}{ftruncate}{fd, length} | 
|  | 338 | Truncate the file corresponding to file descriptor \var{fd}, | 
|  | 339 | so that it is at most \var{length} bytes in size. | 
|  | 340 | Availability: \UNIX{}. | 
|  | 341 | \end{funcdesc} | 
|  | 342 |  | 
|  | 343 | \begin{funcdesc}{lseek}{fd, pos, how} | 
|  | 344 | Set the current position of file descriptor \var{fd} to position | 
|  | 345 | \var{pos}, modified by \var{how}: \code{0} to set the position | 
|  | 346 | relative to the beginning of the file; \code{1} to set it relative to | 
|  | 347 | the current position; \code{2} to set it relative to the end of the | 
|  | 348 | file. | 
|  | 349 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 350 | \end{funcdesc} | 
|  | 351 |  | 
|  | 352 | \begin{funcdesc}{open}{file, flags\optional{, mode}} | 
|  | 353 | Open the file \var{file} and set various flags according to | 
|  | 354 | \var{flags} and possibly its mode according to \var{mode}. | 
|  | 355 | The default \var{mode} is \code{0777} (octal), and the current umask | 
|  | 356 | value is first masked out.  Return the file descriptor for the newly | 
|  | 357 | opened file. | 
|  | 358 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 359 |  | 
|  | 360 | For a description of the flag and mode values, see the C run-time | 
|  | 361 | documentation; flag constants (like \constant{O_RDONLY} and | 
|  | 362 | \constant{O_WRONLY}) are defined in this module too (see below). | 
|  | 363 |  | 
|  | 364 | Note: this function is intended for low-level I/O.  For normal usage, | 
|  | 365 | use the built-in function \function{open()}, which returns a ``file | 
|  | 366 | object'' with \method{read()} and \method{write()} methods (and many | 
|  | 367 | more). | 
|  | 368 | \end{funcdesc} | 
|  | 369 |  | 
|  | 370 | \begin{funcdesc}{pipe}{} | 
|  | 371 | Create a pipe.  Return a pair of file descriptors \code{(\var{r}, | 
|  | 372 | \var{w})} usable for reading and writing, respectively. | 
|  | 373 | Availability: \UNIX{}, Windows. | 
|  | 374 | \end{funcdesc} | 
|  | 375 |  | 
|  | 376 | \begin{funcdesc}{read}{fd, n} | 
|  | 377 | Read at most \var{n} bytes from file descriptor \var{fd}. | 
|  | 378 | Return a string containing the bytes read. | 
|  | 379 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 380 |  | 
|  | 381 | Note: this function is intended for low-level I/O and must be applied | 
|  | 382 | to a file descriptor as returned by \function{open()} or | 
|  | 383 | \function{pipe()}.  To read a ``file object'' returned by the | 
|  | 384 | built-in function \function{open()} or by \function{popen()} or | 
|  | 385 | \function{fdopen()}, or \code{sys.stdin}, use its | 
|  | 386 | \method{read()} or \method{readline()} methods. | 
|  | 387 | \end{funcdesc} | 
|  | 388 |  | 
|  | 389 | \begin{funcdesc}{tcgetpgrp}{fd} | 
|  | 390 | Return the process group associated with the terminal given by | 
|  | 391 | \var{fd} (an open file descriptor as returned by \function{open()}). | 
|  | 392 | Availability: \UNIX{}. | 
|  | 393 | \end{funcdesc} | 
|  | 394 |  | 
|  | 395 | \begin{funcdesc}{tcsetpgrp}{fd, pg} | 
|  | 396 | Set the process group associated with the terminal given by | 
|  | 397 | \var{fd} (an open file descriptor as returned by \function{open()}) | 
|  | 398 | to \var{pg}. | 
|  | 399 | Availability: \UNIX{}. | 
|  | 400 | \end{funcdesc} | 
|  | 401 |  | 
|  | 402 | \begin{funcdesc}{ttyname}{fd} | 
|  | 403 | Return a string which specifies the terminal device associated with | 
|  | 404 | file-descriptor \var{fd}.  If \var{fd} is not associated with a terminal | 
|  | 405 | device, an exception is raised. | 
|  | 406 | Availability: \UNIX{}. | 
|  | 407 | \end{funcdesc} | 
|  | 408 |  | 
|  | 409 | \begin{funcdesc}{write}{fd, str} | 
|  | 410 | Write the string \var{str} to file descriptor \var{fd}. | 
|  | 411 | Return the number of bytes actually written. | 
|  | 412 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 413 |  | 
|  | 414 | Note: this function is intended for low-level I/O and must be applied | 
|  | 415 | to a file descriptor as returned by \function{open()} or | 
|  | 416 | \function{pipe()}.  To write a ``file object'' returned by the | 
|  | 417 | built-in function \function{open()} or by \function{popen()} or | 
|  | 418 | \function{fdopen()}, or \code{sys.stdout} or \code{sys.stderr}, use | 
|  | 419 | its \method{write()} method. | 
|  | 420 | \end{funcdesc} | 
|  | 421 |  | 
|  | 422 |  | 
|  | 423 | The following data items are available for use in constructing the | 
|  | 424 | \var{flags} parameter to the \function{open()} function. | 
|  | 425 |  | 
|  | 426 | \begin{datadesc}{O_RDONLY} | 
|  | 427 | \dataline{O_WRONLY} | 
|  | 428 | \dataline{O_RDWR} | 
|  | 429 | \dataline{O_NDELAY} | 
|  | 430 | \dataline{O_NONBLOCK} | 
|  | 431 | \dataline{O_APPEND} | 
|  | 432 | \dataline{O_DSYNC} | 
|  | 433 | \dataline{O_RSYNC} | 
|  | 434 | \dataline{O_SYNC} | 
|  | 435 | \dataline{O_NOCTTY} | 
|  | 436 | \dataline{O_CREAT} | 
|  | 437 | \dataline{O_EXCL} | 
|  | 438 | \dataline{O_TRUNC} | 
|  | 439 | Options for the \var{flag} argument to the \function{open()} function. | 
|  | 440 | These can be bit-wise OR'd together. | 
|  | 441 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 442 | \end{datadesc} | 
|  | 443 |  | 
|  | 444 |  | 
|  | 445 | \subsection{Files and Directories \label{os-file-dir}} | 
|  | 446 |  | 
|  | 447 | \begin{funcdesc}{access}{path, mode} | 
| Fred Drake | 38e5d27 | 2000-04-03 20:13:55 +0000 | [diff] [blame^] | 448 | Check read/write/execute permissions for this process or existence of | 
|  | 449 | file \var{path}.  \var{mode} should be \constant{F_OK} to test the | 
|  | 450 | existence of \var{path}, or it can be the inclusive OR of one or more | 
|  | 451 | of \constant{R_OK}, \constant{W_OK}, and \constant{X_OK} to test | 
|  | 452 | permissions.  Return \code{1} if access is allowed, \code{0} if not. | 
|  | 453 | See the \UNIX{} man page \manpage{access}{2} for more information. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 454 | Availability: \UNIX{}. | 
|  | 455 | \end{funcdesc} | 
|  | 456 |  | 
| Fred Drake | 38e5d27 | 2000-04-03 20:13:55 +0000 | [diff] [blame^] | 457 | \begin{datadesc}{F_OK} | 
|  | 458 | Value to pass as the \var{mode} parameter of \function{access()} to | 
|  | 459 | test the existence of \var{path}. | 
|  | 460 | \end{datadesc} | 
|  | 461 |  | 
|  | 462 | \begin{datadesc}{R_OK} | 
|  | 463 | Value to include in the \var{mode} parameter of \function{access()} | 
|  | 464 | to test the readability of \var{path}. | 
|  | 465 | \end{datadesc} | 
|  | 466 |  | 
|  | 467 | \begin{datadesc}{W_OK} | 
|  | 468 | Value to include in the \var{mode} parameter of \function{access()} | 
|  | 469 | to test the writability of \var{path}. | 
|  | 470 | \end{datadesc} | 
|  | 471 |  | 
|  | 472 | \begin{datadesc}{X_OK} | 
|  | 473 | Value to include in the \var{mode} parameter of \function{access()} | 
|  | 474 | to determine if \var{path} can be executed. | 
|  | 475 | \end{datadesc} | 
|  | 476 |  | 
| Fred Drake | 6db897c | 1999-07-12 16:49:30 +0000 | [diff] [blame] | 477 | \begin{funcdesc}{chdir}{path} | 
|  | 478 | \index{directory!changing} | 
|  | 479 | Change the current working directory to \var{path}. | 
|  | 480 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 481 | \end{funcdesc} | 
|  | 482 |  | 
|  | 483 | \begin{funcdesc}{getcwd}{} | 
|  | 484 | Return a string representing the current working directory. | 
|  | 485 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 486 | \end{funcdesc} | 
|  | 487 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 488 | \begin{funcdesc}{chmod}{path, mode} | 
|  | 489 | Change the mode of \var{path} to the numeric \var{mode}. | 
|  | 490 | Availability: \UNIX{}, Windows. | 
|  | 491 | \end{funcdesc} | 
|  | 492 |  | 
|  | 493 | \begin{funcdesc}{chown}{path, uid, gid} | 
|  | 494 | Change the owner and group id of \var{path} to the numeric \var{uid} | 
|  | 495 | and \var{gid}. | 
|  | 496 | Availability: \UNIX{}. | 
|  | 497 | \end{funcdesc} | 
|  | 498 |  | 
|  | 499 | \begin{funcdesc}{link}{src, dst} | 
|  | 500 | Create a hard link pointing to \var{src} named \var{dst}. | 
|  | 501 | Availability: \UNIX{}. | 
|  | 502 | \end{funcdesc} | 
|  | 503 |  | 
|  | 504 | \begin{funcdesc}{listdir}{path} | 
|  | 505 | Return a list containing the names of the entries in the directory. | 
|  | 506 | The list is in arbitrary order.  It does not include the special | 
|  | 507 | entries \code{'.'} and \code{'..'} even if they are present in the | 
|  | 508 | directory. | 
|  | 509 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 510 | \end{funcdesc} | 
|  | 511 |  | 
|  | 512 | \begin{funcdesc}{lstat}{path} | 
|  | 513 | Like \function{stat()}, but do not follow symbolic links. | 
|  | 514 | Availability: \UNIX{}. | 
|  | 515 | \end{funcdesc} | 
|  | 516 |  | 
|  | 517 | \begin{funcdesc}{mkfifo}{path\optional{, mode}} | 
|  | 518 | Create a FIFO (a named pipe) named \var{path} with numeric mode | 
|  | 519 | \var{mode}.  The default \var{mode} is \code{0666} (octal).  The current | 
|  | 520 | umask value is first masked out from the mode. | 
|  | 521 | Availability: \UNIX{}. | 
|  | 522 |  | 
|  | 523 | FIFOs are pipes that can be accessed like regular files.  FIFOs exist | 
|  | 524 | until they are deleted (for example with \function{os.unlink()}). | 
|  | 525 | Generally, FIFOs are used as rendezvous between ``client'' and | 
|  | 526 | ``server'' type processes: the server opens the FIFO for reading, and | 
|  | 527 | the client opens it for writing.  Note that \function{mkfifo()} | 
|  | 528 | doesn't open the FIFO --- it just creates the rendezvous point. | 
|  | 529 | \end{funcdesc} | 
|  | 530 |  | 
|  | 531 | \begin{funcdesc}{mkdir}{path\optional{, mode}} | 
|  | 532 | Create a directory named \var{path} with numeric mode \var{mode}. | 
|  | 533 | The default \var{mode} is \code{0777} (octal).  On some systems, | 
|  | 534 | \var{mode} is ignored.  Where it is used, the current umask value is | 
|  | 535 | first masked out. | 
|  | 536 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 537 | \end{funcdesc} | 
|  | 538 |  | 
|  | 539 | \begin{funcdesc}{makedirs}{path\optional{, mode}} | 
|  | 540 | \index{directory!creating} | 
|  | 541 | Recursive directory creation function.  Like \function{mkdir()}, | 
|  | 542 | but makes all intermediate-level directories needed to contain the | 
|  | 543 | leaf directory.  Throws an \exception{error} exception if the leaf | 
|  | 544 | directory already exists or cannot be created.  The default \var{mode} | 
|  | 545 | is \code{0777} (octal). | 
|  | 546 | \versionadded{1.5.2} | 
|  | 547 | \end{funcdesc} | 
|  | 548 |  | 
| Fred Drake | 88f6ca2 | 1999-12-15 19:39:04 +0000 | [diff] [blame] | 549 | \begin{funcdesc}{pathconf}{path, name} | 
|  | 550 | Return system configration information relevant to a named file. | 
|  | 551 | \var{name} specifies the configuration value to retrieve; it may be a | 
|  | 552 | string which is the name of a defined system value; these names are | 
|  | 553 | specified in a number of standards (\POSIX.1, Unix95, Unix98, and | 
|  | 554 | others).  Some platforms define additional names as well.  The names | 
|  | 555 | known to the host operating system are given in the | 
|  | 556 | \code{pathconf_names} dictionary.  For configuration variables not | 
|  | 557 | included in that mapping, passing an integer for \var{name} is also | 
|  | 558 | accepted. | 
|  | 559 | Availability: \UNIX{}. | 
|  | 560 |  | 
|  | 561 | If \var{name} is a string and is not known, \exception{ValueError} is | 
|  | 562 | raised.  If a specific value for \var{name} is not supported by the | 
|  | 563 | host system, even if it is included in \code{pathconf_names}, an | 
|  | 564 | \exception{OSError} is raised with \constant{errno.EINVAL} for the | 
|  | 565 | error number. | 
|  | 566 | \end{funcdesc} | 
|  | 567 |  | 
|  | 568 | \begin{datadesc}{pathconf_names} | 
|  | 569 | Dictionary mapping names accepted by \function{pathconf()} and | 
|  | 570 | \function{fpathconf()} to the integer values defined for those names | 
|  | 571 | by the host operating system.  This can be used to determine the set | 
|  | 572 | of names known to the system. | 
|  | 573 | Availability: \UNIX. | 
|  | 574 | \end{datadesc} | 
|  | 575 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 576 | \begin{funcdesc}{readlink}{path} | 
|  | 577 | Return a string representing the path to which the symbolic link | 
|  | 578 | points. | 
|  | 579 | Availability: \UNIX{}. | 
|  | 580 | \end{funcdesc} | 
|  | 581 |  | 
|  | 582 | \begin{funcdesc}{remove}{path} | 
|  | 583 | Remove the file \var{path}.  See \function{rmdir()} below to remove a | 
|  | 584 | directory.  This is identical to the \function{unlink()} function | 
|  | 585 | documented below. | 
|  | 586 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 587 | \end{funcdesc} | 
|  | 588 |  | 
|  | 589 | \begin{funcdesc}{removedirs}{path} | 
|  | 590 | \index{directory!deleting} | 
|  | 591 | Recursive directory removal function.  Works like | 
|  | 592 | \function{rmdir()} except that, if the leaf directory is | 
|  | 593 | successfully removed, directories corresponding to rightmost path | 
|  | 594 | segments will be pruned way until either the whole path is consumed or | 
|  | 595 | an error is raised (which is ignored, because it generally means that | 
|  | 596 | a parent directory is not empty).  Throws an \exception{error} | 
|  | 597 | exception if the leaf directory could not be successfully removed. | 
|  | 598 | \versionadded{1.5.2} | 
|  | 599 | \end{funcdesc} | 
|  | 600 |  | 
|  | 601 | \begin{funcdesc}{rename}{src, dst} | 
|  | 602 | Rename the file or directory \var{src} to \var{dst}. | 
|  | 603 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 604 | \end{funcdesc} | 
|  | 605 |  | 
|  | 606 | \begin{funcdesc}{renames}{old, new} | 
|  | 607 | Recursive directory or file renaming function. | 
|  | 608 | Works like \function{rename()}, except creation of any intermediate | 
|  | 609 | directories needed to make the new pathname good is attempted first. | 
|  | 610 | After the rename, directories corresponding to rightmost path segments | 
|  | 611 | of the old name will be pruned away using \function{removedirs()}. | 
|  | 612 |  | 
|  | 613 | Note: this function can fail with the new directory structure made if | 
|  | 614 | you lack permissions needed to remove the leaf directory or file. | 
|  | 615 | \versionadded{1.5.2} | 
|  | 616 | \end{funcdesc} | 
|  | 617 |  | 
|  | 618 | \begin{funcdesc}{rmdir}{path} | 
|  | 619 | Remove the directory \var{path}. | 
|  | 620 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 621 | \end{funcdesc} | 
|  | 622 |  | 
|  | 623 | \begin{funcdesc}{stat}{path} | 
|  | 624 | Perform a \cfunction{stat()} system call on the given path.  The | 
|  | 625 | return value is a tuple of at least 10 integers giving the most | 
|  | 626 | important (and portable) members of the \emph{stat} structure, in the | 
|  | 627 | order | 
|  | 628 | \code{st_mode}, | 
|  | 629 | \code{st_ino}, | 
|  | 630 | \code{st_dev}, | 
|  | 631 | \code{st_nlink}, | 
|  | 632 | \code{st_uid}, | 
|  | 633 | \code{st_gid}, | 
|  | 634 | \code{st_size}, | 
|  | 635 | \code{st_atime}, | 
|  | 636 | \code{st_mtime}, | 
|  | 637 | \code{st_ctime}. | 
|  | 638 | More items may be added at the end by some implementations. | 
|  | 639 | (On MS Windows, some items are filled with dummy values.) | 
|  | 640 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 641 |  | 
|  | 642 | Note: The standard module \refmodule{stat}\refstmodindex{stat} defines | 
|  | 643 | functions and constants that are useful for extracting information | 
|  | 644 | from a \ctype{stat} structure. | 
|  | 645 | \end{funcdesc} | 
|  | 646 |  | 
|  | 647 | \begin{funcdesc}{statvfs}{path} | 
|  | 648 | Perform a \cfunction{statvfs()} system call on the given path.  The | 
| Guido van Rossum | 0c9608c | 1999-02-03 16:32:37 +0000 | [diff] [blame] | 649 | return value is a tuple of 10 integers giving the most common | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 650 | members of the \ctype{statvfs} structure, in the order | 
|  | 651 | \code{f_bsize}, | 
|  | 652 | \code{f_frsize}, | 
|  | 653 | \code{f_blocks}, | 
|  | 654 | \code{f_bfree}, | 
|  | 655 | \code{f_bavail}, | 
|  | 656 | \code{f_files}, | 
|  | 657 | \code{f_ffree}, | 
|  | 658 | \code{f_favail}, | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 659 | \code{f_flag}, | 
|  | 660 | \code{f_namemax}. | 
|  | 661 | Availability: \UNIX{}. | 
|  | 662 |  | 
|  | 663 | Note: The standard module \module{statvfs}\refstmodindex{statvfs} | 
|  | 664 | defines constants that are useful for extracting information | 
|  | 665 | from a \ctype{statvfs} structure. | 
|  | 666 | \end{funcdesc} | 
|  | 667 |  | 
|  | 668 | \begin{funcdesc}{symlink}{src, dst} | 
|  | 669 | Create a symbolic link pointing to \var{src} named \var{dst}. | 
|  | 670 | Availability: \UNIX{}. | 
|  | 671 | \end{funcdesc} | 
|  | 672 |  | 
| Fred Drake | 18f7a45 | 1999-12-09 22:11:43 +0000 | [diff] [blame] | 673 | \begin{funcdesc}{tempnam}{\optional{dir\optional{, prefix}}} | 
|  | 674 | Return a unique path name that is reasonable for creating a temporary | 
|  | 675 | file.  This will be an absolute path that names a potential directory | 
|  | 676 | entry in the directory \var{dir} or a common location for temporary | 
|  | 677 | files if \var{dir} is omitted or \code{None}.  If given and not | 
|  | 678 | \code{None}, \var{prefix} is used to provide a short prefix to the | 
|  | 679 | filename.  Applications are responsible for properly creating and | 
|  | 680 | managing files created using paths returned by \function{tempnam()}; | 
|  | 681 | no automatic cleanup is provided. | 
|  | 682 | \end{funcdesc} | 
|  | 683 |  | 
|  | 684 | \begin{funcdesc}{tmpnam}{} | 
|  | 685 | Return a unique path name that is reasonable for creating a temporary | 
|  | 686 | file.  This will be an absolute path that names a potential directory | 
|  | 687 | entry in a common location for temporary files.  Applications are | 
|  | 688 | responsible for properly creating and managing files created using | 
|  | 689 | paths returned by \function{tmpnam()}; no automatic cleanup is | 
|  | 690 | provided. | 
|  | 691 | \end{funcdesc} | 
|  | 692 |  | 
|  | 693 | \begin{datadesc}{TMP_MAX} | 
|  | 694 | The maximum number of unique names that \function{tmpnam()} will | 
|  | 695 | generate before reusing names. | 
|  | 696 | \end{datadesc} | 
|  | 697 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 698 | \begin{funcdesc}{unlink}{path} | 
|  | 699 | Remove the file \var{path}.  This is the same function as | 
|  | 700 | \function{remove()}; the \function{unlink()} name is its traditional | 
|  | 701 | \UNIX{} name. | 
|  | 702 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 703 | \end{funcdesc} | 
|  | 704 |  | 
|  | 705 | \begin{funcdesc}{utime}{path, (atime, mtime)} | 
|  | 706 | Set the access and modified time of the file to the given values. | 
|  | 707 | (The second argument is a tuple of two items.) | 
|  | 708 | Availability: Macintosh, \UNIX{}, Windows. | 
|  | 709 | \end{funcdesc} | 
|  | 710 |  | 
|  | 711 |  | 
|  | 712 | \subsection{Process Management \label{os-process}} | 
|  | 713 |  | 
| Fred Drake | 18f7a45 | 1999-12-09 22:11:43 +0000 | [diff] [blame] | 714 | These functions may be used to create and manage processes. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 715 |  | 
|  | 716 |  | 
| Fred Drake | 18f7a45 | 1999-12-09 22:11:43 +0000 | [diff] [blame] | 717 | \begin{funcdesc}{abort}{} | 
|  | 718 | Generate a \constant{SIGABRT} signal to the current process.  On | 
|  | 719 | \UNIX, the default behavior is to produce a core dump; on Windows, the | 
|  | 720 | process immediately returns an exit code of \code{3}.  Be aware that | 
|  | 721 | programs which use \function{signal.signal()} to register a handler | 
|  | 722 | for \constant{SIGABRT} will behave differently. | 
|  | 723 | Availability: \UNIX, Windows. | 
|  | 724 | \end{funcdesc} | 
|  | 725 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 726 | \begin{funcdesc}{execl}{path, arg0, arg1, ...} | 
|  | 727 | This is equivalent to | 
|  | 728 | \samp{execv(\var{path}, (\var{arg0}, \var{arg1}, ...))}. | 
|  | 729 | Availability: \UNIX{}, Windows. | 
|  | 730 | \end{funcdesc} | 
|  | 731 |  | 
|  | 732 | \begin{funcdesc}{execle}{path, arg0, arg1, ..., env} | 
|  | 733 | This is equivalent to | 
|  | 734 | \samp{execve(\var{path}, (\var{arg0}, \var{arg1}, ...), \var{env})}. | 
|  | 735 | Availability: \UNIX{}, Windows. | 
|  | 736 | \end{funcdesc} | 
|  | 737 |  | 
|  | 738 | \begin{funcdesc}{execlp}{path, arg0, arg1, ...} | 
|  | 739 | This is equivalent to | 
|  | 740 | \samp{execvp(\var{path}, (\var{arg0}, \var{arg1}, ...))}. | 
|  | 741 | Availability: \UNIX{}, Windows. | 
|  | 742 | \end{funcdesc} | 
|  | 743 |  | 
|  | 744 | \begin{funcdesc}{execv}{path, args} | 
|  | 745 | Execute the executable \var{path} with argument list \var{args}, | 
|  | 746 | replacing the current process (i.e., the Python interpreter). | 
|  | 747 | The argument list may be a tuple or list of strings. | 
|  | 748 | Availability: \UNIX{}, Windows. | 
|  | 749 | \end{funcdesc} | 
|  | 750 |  | 
|  | 751 | \begin{funcdesc}{execve}{path, args, env} | 
|  | 752 | Execute the executable \var{path} with argument list \var{args}, | 
|  | 753 | and environment \var{env}, | 
|  | 754 | replacing the current process (i.e., the Python interpreter). | 
|  | 755 | The argument list may be a tuple or list of strings. | 
|  | 756 | The environment must be a dictionary mapping strings to strings. | 
|  | 757 | Availability: \UNIX{}, Windows. | 
|  | 758 | \end{funcdesc} | 
|  | 759 |  | 
|  | 760 | \begin{funcdesc}{execvp}{path, args} | 
|  | 761 | This is like \samp{execv(\var{path}, \var{args})} but duplicates | 
|  | 762 | the shell's actions in searching for an executable file in a list of | 
|  | 763 | directories.  The directory list is obtained from | 
|  | 764 | \code{environ['PATH']}. | 
|  | 765 | Availability: \UNIX{}, Windows. | 
|  | 766 | \end{funcdesc} | 
|  | 767 |  | 
|  | 768 | \begin{funcdesc}{execvpe}{path, args, env} | 
|  | 769 | This is a cross between \function{execve()} and \function{execvp()}. | 
|  | 770 | The directory list is obtained from \code{\var{env}['PATH']}. | 
|  | 771 | Availability: \UNIX{}, Windows. | 
|  | 772 | \end{funcdesc} | 
|  | 773 |  | 
|  | 774 | \begin{funcdesc}{_exit}{n} | 
|  | 775 | Exit to the system with status \var{n}, without calling cleanup | 
|  | 776 | handlers, flushing stdio buffers, etc. | 
|  | 777 | Availability: \UNIX{}, Windows. | 
|  | 778 |  | 
|  | 779 | Note: the standard way to exit is \code{sys.exit(\var{n})}. | 
|  | 780 | \function{_exit()} should normally only be used in the child process | 
|  | 781 | after a \function{fork()}. | 
|  | 782 | \end{funcdesc} | 
|  | 783 |  | 
|  | 784 | \begin{funcdesc}{fork}{} | 
|  | 785 | Fork a child process.  Return \code{0} in the child, the child's | 
|  | 786 | process id in the parent. | 
|  | 787 | Availability: \UNIX{}. | 
|  | 788 | \end{funcdesc} | 
|  | 789 |  | 
|  | 790 | \begin{funcdesc}{kill}{pid, sig} | 
|  | 791 | \index{process!killing} | 
|  | 792 | \index{process!signalling} | 
|  | 793 | Kill the process \var{pid} with signal \var{sig}. | 
|  | 794 | Availability: \UNIX{}. | 
|  | 795 | \end{funcdesc} | 
|  | 796 |  | 
|  | 797 | \begin{funcdesc}{nice}{increment} | 
|  | 798 | Add \var{increment} to the process's ``niceness''.  Return the new | 
|  | 799 | niceness. | 
|  | 800 | Availability: \UNIX{}. | 
|  | 801 | \end{funcdesc} | 
|  | 802 |  | 
|  | 803 | \begin{funcdesc}{plock}{op} | 
|  | 804 | Lock program segments into memory.  The value of \var{op} | 
|  | 805 | (defined in \code{<sys/lock.h>}) determines which segments are locked. | 
| Fred Drake | 3906363 | 1999-02-26 14:05:02 +0000 | [diff] [blame] | 806 | Availability: \UNIX{}. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 807 | \end{funcdesc} | 
|  | 808 |  | 
|  | 809 | \begin{funcdesc}{spawnv}{mode, path, args} | 
|  | 810 | Execute the program \var{path} in a new process, passing the arguments | 
|  | 811 | specified in \var{args} as command-line parameters.  \var{args} may be | 
|  | 812 | a list or a tuple.  \var{mode} is a magic operational constant.  See | 
|  | 813 | the Visual \Cpp{} Runtime Library documentation for further | 
| Fred Drake | 2270208 | 1999-07-02 14:01:03 +0000 | [diff] [blame] | 814 | information; the constants are exposed to the Python programmer as | 
|  | 815 | listed below. | 
| Fred Drake | 15861b2 | 2000-02-29 05:19:38 +0000 | [diff] [blame] | 816 | Availability: \UNIX{}, Windows. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 817 | \versionadded{1.5.2} | 
|  | 818 | \end{funcdesc} | 
|  | 819 |  | 
|  | 820 | \begin{funcdesc}{spawnve}{mode, path, args, env} | 
|  | 821 | Execute the program \var{path} in a new process, passing the arguments | 
|  | 822 | specified in \var{args} as command-line parameters and the contents of | 
|  | 823 | the mapping \var{env} as the environment.  \var{args} may be a list or | 
|  | 824 | a tuple.  \var{mode} is a magic operational constant.  See the Visual | 
| Fred Drake | 2270208 | 1999-07-02 14:01:03 +0000 | [diff] [blame] | 825 | \Cpp{} Runtime Library documentation for further information; the | 
|  | 826 | constants are exposed to the Python programmer as listed below. | 
| Fred Drake | 15861b2 | 2000-02-29 05:19:38 +0000 | [diff] [blame] | 827 | Availability: \UNIX{}, Windows. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 828 | \versionadded{1.5.2} | 
|  | 829 | \end{funcdesc} | 
|  | 830 |  | 
| Fred Drake | 9329e5e | 1999-02-16 19:40:19 +0000 | [diff] [blame] | 831 | \begin{datadesc}{P_WAIT} | 
|  | 832 | \dataline{P_NOWAIT} | 
|  | 833 | \dataline{P_NOWAITO} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 834 | Possible values for the \var{mode} parameter to \function{spawnv()} | 
|  | 835 | and \function{spawnve()}. | 
| Fred Drake | 15861b2 | 2000-02-29 05:19:38 +0000 | [diff] [blame] | 836 | Availability: \UNIX{}, Windows. | 
|  | 837 | \versionadded{1.5.2} | 
|  | 838 | \end{datadesc} | 
|  | 839 |  | 
|  | 840 | \begin{datadesc}{P_OVERLAY} | 
|  | 841 | \dataline{P_DETACH} | 
|  | 842 | Possible values for the \var{mode} parameter to \function{spawnv()} | 
|  | 843 | and \function{spawnve()}.  These are less portable than those listed | 
|  | 844 | above. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 845 | Availability: Windows. | 
|  | 846 | \versionadded{1.5.2} | 
|  | 847 | \end{datadesc} | 
|  | 848 |  | 
|  | 849 | \begin{funcdesc}{system}{command} | 
|  | 850 | Execute the command (a string) in a subshell.  This is implemented by | 
|  | 851 | calling the Standard C function \cfunction{system()}, and has the | 
| Fred Drake | ec6baaf | 1999-04-21 18:13:31 +0000 | [diff] [blame] | 852 | same limitations.  Changes to \code{posix.environ}, \code{sys.stdin}, | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 853 | etc.\ are not reflected in the environment of the executed command. | 
|  | 854 | The return value is the exit status of the process encoded in the | 
| Fred Drake | 7a62128 | 1999-06-10 15:07:05 +0000 | [diff] [blame] | 855 | format specified for \function{wait()}, except on Windows 95 and 98, | 
| Fred Drake | a88ef00 | 1999-06-18 19:11:25 +0000 | [diff] [blame] | 856 | where it is always \code{0}.  Note that \POSIX{} does not specify the | 
|  | 857 | meaning of the return value of the C \cfunction{system()} function, | 
|  | 858 | so the return value of the Python function is system-dependent. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 859 | Availability: \UNIX{}, Windows. | 
|  | 860 | \end{funcdesc} | 
|  | 861 |  | 
|  | 862 | \begin{funcdesc}{times}{} | 
|  | 863 | Return a 5-tuple of floating point numbers indicating accumulated (CPU | 
|  | 864 | or other) | 
|  | 865 | times, in seconds.  The items are: user time, system time, children's | 
|  | 866 | user time, children's system time, and elapsed real time since a fixed | 
| Fred Drake | ec6baaf | 1999-04-21 18:13:31 +0000 | [diff] [blame] | 867 | point in the past, in that order.  See the \UNIX{} manual page | 
|  | 868 | \manpage{times}{2} or the corresponding Windows Platform API | 
|  | 869 | documentation. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 870 | Availability: \UNIX{}, Windows. | 
|  | 871 | \end{funcdesc} | 
|  | 872 |  | 
|  | 873 | \begin{funcdesc}{wait}{} | 
|  | 874 | Wait for completion of a child process, and return a tuple containing | 
|  | 875 | its pid and exit status indication: a 16-bit number, whose low byte is | 
|  | 876 | the signal number that killed the process, and whose high byte is the | 
|  | 877 | exit status (if the signal number is zero); the high bit of the low | 
|  | 878 | byte is set if a core file was produced. | 
|  | 879 | Availability: \UNIX{}. | 
|  | 880 | \end{funcdesc} | 
|  | 881 |  | 
|  | 882 | \begin{funcdesc}{waitpid}{pid, options} | 
| Fred Drake | 31e5e37 | 1999-08-13 13:36:33 +0000 | [diff] [blame] | 883 | Wait for completion of a child process given by process id \var{pid}, | 
|  | 884 | and return a tuple containing its process id and exit status | 
|  | 885 | indication (encoded as for \function{wait()}).  The semantics of the | 
|  | 886 | call are affected by the value of the integer \var{options}, which | 
|  | 887 | should be \code{0} for normal operation. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 888 | Availability: \UNIX{}. | 
| Fred Drake | 31e5e37 | 1999-08-13 13:36:33 +0000 | [diff] [blame] | 889 |  | 
|  | 890 | If \var{pid} is greater than \code{0}, \function{waitpid()} requests | 
|  | 891 | status information for that specific process.  If \var{pid} is | 
|  | 892 | \code{0}, the request is for the status of any child in the process | 
|  | 893 | group of the current process.  If \var{pid} is \code{-1}, the request | 
|  | 894 | pertains to any child of the current process.  If \var{pid} is less | 
|  | 895 | than \code{-1}, status is requested for any process in the process | 
|  | 896 | group \code{-\var{pid}} (the absolute value of \var{pid}). | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 897 | \end{funcdesc} | 
|  | 898 |  | 
|  | 899 | \begin{datadesc}{WNOHANG} | 
|  | 900 | The option for \function{waitpid()} to avoid hanging if no child | 
|  | 901 | process status is available immediately. | 
|  | 902 | Availability: \UNIX{}. | 
|  | 903 | \end{datadesc} | 
|  | 904 |  | 
| Fred Drake | 38e5d27 | 2000-04-03 20:13:55 +0000 | [diff] [blame^] | 905 | The following functions take a process status code as returned by | 
|  | 906 | \function{system()}, \function{wait()}, or \function{waitpid()} as a | 
|  | 907 | parameter.  They may be used to determine the disposition of a | 
|  | 908 | process. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 909 |  | 
|  | 910 | \begin{funcdesc}{WIFSTOPPED}{status} | 
|  | 911 | Return true if the process has been stopped. | 
|  | 912 | Availability: \UNIX{}. | 
|  | 913 | \end{funcdesc} | 
|  | 914 |  | 
|  | 915 | \begin{funcdesc}{WIFSIGNALED}{status} | 
|  | 916 | Return true if the process exited due to a signal. | 
|  | 917 | Availability: \UNIX{}. | 
|  | 918 | \end{funcdesc} | 
|  | 919 |  | 
|  | 920 | \begin{funcdesc}{WIFEXITED}{status} | 
|  | 921 | Return true if the process exited using the \manpage{exit}{2} system | 
|  | 922 | call. | 
|  | 923 | Availability: \UNIX{}. | 
|  | 924 | \end{funcdesc} | 
|  | 925 |  | 
|  | 926 | \begin{funcdesc}{WEXITSTATUS}{status} | 
|  | 927 | If \code{WIFEXITED(\var{status})} is true, return the integer | 
|  | 928 | parameter to the \manpage{exit}{2} system call.  Otherwise, the return | 
|  | 929 | value is meaningless. | 
|  | 930 | Availability: \UNIX{}. | 
|  | 931 | \end{funcdesc} | 
|  | 932 |  | 
|  | 933 | \begin{funcdesc}{WSTOPSIG}{status} | 
| Fred Drake | 35c3ffd | 1999-03-04 14:08:10 +0000 | [diff] [blame] | 934 | Return the signal which caused the process to stop. | 
|  | 935 | Availability: \UNIX{}. | 
|  | 936 | \end{funcdesc} | 
|  | 937 |  | 
|  | 938 | \begin{funcdesc}{WTERMSIG}{status} | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 939 | Return the signal which caused the process to exit. | 
|  | 940 | Availability: \UNIX{}. | 
|  | 941 | \end{funcdesc} | 
|  | 942 |  | 
|  | 943 |  | 
| Fred Drake | 88f6ca2 | 1999-12-15 19:39:04 +0000 | [diff] [blame] | 944 | \subsection{Miscellanenous System Information \label{os-path}} | 
|  | 945 |  | 
|  | 946 |  | 
|  | 947 | \begin{funcdesc}{confstr}{name} | 
|  | 948 | Return string-valued system configuration values. | 
|  | 949 | \var{name} specifies the configuration value to retrieve; it may be a | 
|  | 950 | string which is the name of a defined system value; these names are | 
|  | 951 | specified in a number of standards (\POSIX, Unix95, Unix98, and | 
|  | 952 | others).  Some platforms define additional names as well.  The names | 
|  | 953 | known to the host operating system are given in the | 
|  | 954 | \code{confstr_names} dictionary.  For configuration variables not | 
|  | 955 | included in that mapping, passing an integer for \var{name} is also | 
|  | 956 | accepted. | 
|  | 957 | Availability: \UNIX{}. | 
|  | 958 |  | 
|  | 959 | If the configuration value specified by \var{name} isn't defined, the | 
|  | 960 | empty string is returned. | 
|  | 961 |  | 
|  | 962 | If \var{name} is a string and is not known, \exception{ValueError} is | 
|  | 963 | raised.  If a specific value for \var{name} is not supported by the | 
|  | 964 | host system, even if it is included in \code{confstr_names}, an | 
|  | 965 | \exception{OSError} is raised with \constant{errno.EINVAL} for the | 
|  | 966 | error number. | 
|  | 967 | \end{funcdesc} | 
|  | 968 |  | 
|  | 969 | \begin{datadesc}{confstr_names} | 
|  | 970 | Dictionary mapping names accepted by \function{confstr()} to the | 
|  | 971 | integer values defined for those names by the host operating system. | 
|  | 972 | This can be used to determine the set of names known to the system. | 
|  | 973 | Availability: \UNIX. | 
|  | 974 | \end{datadesc} | 
|  | 975 |  | 
|  | 976 | \begin{funcdesc}{sysconf}{name} | 
|  | 977 | Return integer-valued system configuration values. | 
|  | 978 | If the configuration value specified by \var{name} isn't defined, | 
|  | 979 | \code{-1} is returned.  The comments regarding the \var{name} | 
|  | 980 | parameter for \function{confstr()} apply here as well; the dictionary | 
|  | 981 | that provides information on the known names is given by | 
|  | 982 | \code{sysconf_names}. | 
|  | 983 | Availability: \UNIX{}. | 
|  | 984 | \end{funcdesc} | 
|  | 985 |  | 
|  | 986 | \begin{datadesc}{sysconf_names} | 
|  | 987 | Dictionary mapping names accepted by \function{sysconf()} to the | 
|  | 988 | integer values defined for those names by the host operating system. | 
|  | 989 | This can be used to determine the set of names known to the system. | 
|  | 990 | Availability: \UNIX. | 
|  | 991 | \end{datadesc} | 
|  | 992 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 993 |  | 
|  | 994 | The follow data values are used to support path manipulation | 
|  | 995 | operations.  These are defined for all platforms. | 
|  | 996 |  | 
|  | 997 | Higher-level operations on pathnames are defined in the | 
|  | 998 | \refmodule{os.path} module. | 
|  | 999 |  | 
|  | 1000 |  | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 1001 | \begin{datadesc}{curdir} | 
|  | 1002 | The constant string used by the OS to refer to the current directory, | 
| Fred Drake | 1a3c2a0 | 1998-08-06 15:18:23 +0000 | [diff] [blame] | 1003 | e.g.\ \code{'.'} for \POSIX{} or \code{':'} for the Macintosh. | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 1004 | \end{datadesc} | 
|  | 1005 |  | 
|  | 1006 | \begin{datadesc}{pardir} | 
|  | 1007 | The constant string used by the OS to refer to the parent directory, | 
| Fred Drake | 1a3c2a0 | 1998-08-06 15:18:23 +0000 | [diff] [blame] | 1008 | e.g.\ \code{'..'} for \POSIX{} or \code{'::'} for the Macintosh. | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 1009 | \end{datadesc} | 
|  | 1010 |  | 
|  | 1011 | \begin{datadesc}{sep} | 
| Guido van Rossum | b2afc81 | 1997-08-29 22:37:44 +0000 | [diff] [blame] | 1012 | The character used by the OS to separate pathname components, | 
| Fred Drake | 1a3c2a0 | 1998-08-06 15:18:23 +0000 | [diff] [blame] | 1013 | e.g.\ \character{/} for \POSIX{} or \character{:} for the Macintosh. | 
|  | 1014 | Note that knowing this is not sufficient to be able to parse or | 
|  | 1015 | concatenate pathnames --- use \function{os.path.split()} and | 
|  | 1016 | \function{os.path.join()} --- but it is occasionally useful. | 
| Guido van Rossum | 5fdeeea | 1994-01-02 01:22:07 +0000 | [diff] [blame] | 1017 | \end{datadesc} | 
|  | 1018 |  | 
| Guido van Rossum | b2afc81 | 1997-08-29 22:37:44 +0000 | [diff] [blame] | 1019 | \begin{datadesc}{altsep} | 
|  | 1020 | An alternative character used by the OS to separate pathname components, | 
|  | 1021 | or \code{None} if only one separator character exists.  This is set to | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 1022 | \character{/} on DOS and Windows systems where \code{sep} is a backslash. | 
| Guido van Rossum | b2afc81 | 1997-08-29 22:37:44 +0000 | [diff] [blame] | 1023 | \end{datadesc} | 
|  | 1024 |  | 
| Guido van Rossum | 470be14 | 1995-03-17 16:07:09 +0000 | [diff] [blame] | 1025 | \begin{datadesc}{pathsep} | 
|  | 1026 | The character conventionally used by the OS to separate search patch | 
| Fred Drake | 1a3c2a0 | 1998-08-06 15:18:23 +0000 | [diff] [blame] | 1027 | components (as in \envvar{PATH}), e.g.\ \character{:} for \POSIX{} or | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 1028 | \character{;} for DOS and Windows. | 
| Guido van Rossum | 9c59ce9 | 1998-06-30 15:54:27 +0000 | [diff] [blame] | 1029 | \end{datadesc} | 
|  | 1030 |  | 
| Guido van Rossum | 470be14 | 1995-03-17 16:07:09 +0000 | [diff] [blame] | 1031 | \begin{datadesc}{defpath} | 
| Fred Drake | 1a3c2a0 | 1998-08-06 15:18:23 +0000 | [diff] [blame] | 1032 | The default search path used by \function{exec*p*()} if the environment | 
| Guido van Rossum | 470be14 | 1995-03-17 16:07:09 +0000 | [diff] [blame] | 1033 | doesn't have a \code{'PATH'} key. | 
|  | 1034 | \end{datadesc} | 
|  | 1035 |  | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 1036 | \begin{datadesc}{linesep} | 
|  | 1037 | The string used to separate (or, rather, terminate) lines on the | 
| Fred Drake | ec6baaf | 1999-04-21 18:13:31 +0000 | [diff] [blame] | 1038 | current platform.  This may be a single character, | 
|  | 1039 | e.g.\ \code{'\e n'} for \POSIX{} or \code{'\e r'} for MacOS, or multiple | 
|  | 1040 | characters, e.g.\ \code{'\e r\e n'} for MS-DOS and MS Windows. | 
| Fred Drake | 215fe2f | 1999-02-02 19:02:35 +0000 | [diff] [blame] | 1041 | \end{datadesc} |