blob: ea838ebd68ae381f1cf3ad28c1b159ff121ec064 [file] [log] [blame]
Guido van Rossumf70e43a1991-02-19 12:39:46 +00001/***********************************************************
Guido van Rossum6d023c91995-01-04 19:12:13 +00002Copyright 1991-1995 by Stichting Mathematisch Centrum, Amsterdam,
3The Netherlands.
Guido van Rossumf70e43a1991-02-19 12:39:46 +00004
5 All Rights Reserved
6
Guido van Rossumd266eb41996-10-25 14:44:06 +00007Permission to use, copy, modify, and distribute this software and its
8documentation for any purpose and without fee is hereby granted,
Guido van Rossumf70e43a1991-02-19 12:39:46 +00009provided that the above copyright notice appear in all copies and that
Guido van Rossumd266eb41996-10-25 14:44:06 +000010both that copyright notice and this permission notice appear in
Guido van Rossumf70e43a1991-02-19 12:39:46 +000011supporting documentation, and that the names of Stichting Mathematisch
Guido van Rossumd266eb41996-10-25 14:44:06 +000012Centrum or CWI or Corporation for National Research Initiatives or
13CNRI not be used in advertising or publicity pertaining to
14distribution of the software without specific, written prior
15permission.
Guido van Rossumf70e43a1991-02-19 12:39:46 +000016
Guido van Rossumd266eb41996-10-25 14:44:06 +000017While CWI is the initial source for this software, a modified version
18is made available by the Corporation for National Research Initiatives
19(CNRI) at the Internet address ftp://ftp.python.org.
20
21STICHTING MATHEMATISCH CENTRUM AND CNRI DISCLAIM ALL WARRANTIES WITH
22REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF
23MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH
24CENTRUM OR CNRI BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL
25DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
26PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
27TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
28PERFORMANCE OF THIS SOFTWARE.
Guido van Rossumf70e43a1991-02-19 12:39:46 +000029
30******************************************************************/
31
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000032/* System module */
33
34/*
35Various bits of information used by the interpreter are collected in
36module 'sys'.
Guido van Rossum3f5da241990-12-20 15:06:42 +000037Function member:
Guido van Rossumcc8914f1995-03-20 15:09:40 +000038- exit(sts): raise SystemExit
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000039Data members:
40- stdin, stdout, stderr: standard file objects
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000041- modules: the table of modules (dictionary)
Guido van Rossum3f5da241990-12-20 15:06:42 +000042- path: module search path (list of strings)
43- argv: script arguments (list of strings)
44- ps1, ps2: optional primary and secondary prompts (strings)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000045*/
46
Guido van Rossum65bf9f21997-04-29 18:33:38 +000047#include "Python.h"
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000048
Guido van Rossume2437a11992-03-23 18:20:18 +000049#include "osdefs.h"
Guido van Rossum3f5da241990-12-20 15:06:42 +000050
Guido van Rossum1254d791997-05-20 15:57:25 +000051#ifdef HAVE_UNISTD_H
Guido van Rossumc474dea1997-04-25 15:38:31 +000052#include <unistd.h>
53#endif
54
Guido van Rossum9b38a141996-09-11 23:12:24 +000055#ifdef MS_COREDLL
Guido van Rossumc606fe11996-04-09 02:37:57 +000056extern void *PyWin_DLLhModule;
Guido van Rossum6c1e5f21997-09-29 23:34:23 +000057/* A string loaded from the DLL at startup: */
58extern const char *PyWin_DLLVersionString;
Guido van Rossumc606fe11996-04-09 02:37:57 +000059#endif
60
Guido van Rossum65bf9f21997-04-29 18:33:38 +000061PyObject *
62PySys_GetObject(name)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000063 char *name;
64{
Guido van Rossum25ce5661997-08-02 03:10:38 +000065 PyThreadState *tstate = PyThreadState_Get();
66 PyObject *sd = tstate->interp->sysdict;
Guido van Rossumbe203361999-10-05 22:17:41 +000067 if (sd == NULL)
68 return NULL;
Guido van Rossum25ce5661997-08-02 03:10:38 +000069 return PyDict_GetItemString(sd, name);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000070}
71
72FILE *
Guido van Rossum65bf9f21997-04-29 18:33:38 +000073PySys_GetFile(name, def)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000074 char *name;
75 FILE *def;
76{
77 FILE *fp = NULL;
Guido van Rossum65bf9f21997-04-29 18:33:38 +000078 PyObject *v = PySys_GetObject(name);
79 if (v != NULL && PyFile_Check(v))
80 fp = PyFile_AsFile(v);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000081 if (fp == NULL)
82 fp = def;
83 return fp;
84}
85
86int
Guido van Rossum65bf9f21997-04-29 18:33:38 +000087PySys_SetObject(name, v)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000088 char *name;
Guido van Rossum65bf9f21997-04-29 18:33:38 +000089 PyObject *v;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000090{
Guido van Rossum25ce5661997-08-02 03:10:38 +000091 PyThreadState *tstate = PyThreadState_Get();
92 PyObject *sd = tstate->interp->sysdict;
Guido van Rossum5ad58c61992-01-26 18:15:48 +000093 if (v == NULL) {
Guido van Rossum25ce5661997-08-02 03:10:38 +000094 if (PyDict_GetItemString(sd, name) == NULL)
Guido van Rossum5ad58c61992-01-26 18:15:48 +000095 return 0;
96 else
Guido van Rossum25ce5661997-08-02 03:10:38 +000097 return PyDict_DelItemString(sd, name);
Guido van Rossum5ad58c61992-01-26 18:15:48 +000098 }
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000099 else
Guido van Rossum25ce5661997-08-02 03:10:38 +0000100 return PyDict_SetItemString(sd, name, v);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000101}
102
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000103static PyObject *
Guido van Rossuma027efa1997-05-05 20:56:21 +0000104sys_exc_info(self, args)
105 PyObject *self;
106 PyObject *args;
107{
108 PyThreadState *tstate;
Guido van Rossumffc0f4f2000-03-31 00:38:29 +0000109 if (!PyArg_ParseTuple(args, ":exc_info"))
Guido van Rossuma027efa1997-05-05 20:56:21 +0000110 return NULL;
111 tstate = PyThreadState_Get();
Guido van Rossuma027efa1997-05-05 20:56:21 +0000112 return Py_BuildValue(
113 "(OOO)",
114 tstate->exc_type != NULL ? tstate->exc_type : Py_None,
115 tstate->exc_value != NULL ? tstate->exc_value : Py_None,
116 tstate->exc_traceback != NULL ?
117 tstate->exc_traceback : Py_None);
118}
119
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000120static char exc_info_doc[] =
121"exc_info() -> (type, value, traceback)\n\
122\n\
123Return information about the exception that is currently being handled.\n\
124This should be called from inside an except clause only.";
125
Guido van Rossuma027efa1997-05-05 20:56:21 +0000126static PyObject *
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000127sys_exit(self, args)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000128 PyObject *self;
129 PyObject *args;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000130{
Guido van Rossum6a468bf1991-12-31 13:15:35 +0000131 /* Raise SystemExit so callers may catch it or clean up. */
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000132 PyErr_SetObject(PyExc_SystemExit, args);
Guido van Rossum6a468bf1991-12-31 13:15:35 +0000133 return NULL;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000134}
135
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000136static char exit_doc[] =
137"exit([status])\n\
138\n\
139Exit the interpreter by raising SystemExit(status).\n\
140If the status is omitted or None, it defaults to zero (i.e., success).\n\
141If the status numeric, it will be used as the system exit status.\n\
142If it is another kind of object, it will be printed and the system\n\
143exit status will be one (i.e., failure).";
144
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000145static PyObject *
Marc-André Lemburg99964b82000-06-07 09:13:41 +0000146sys_getdefaultencoding(self, args)
Fred Drake8b4d01d2000-05-09 19:57:01 +0000147 PyObject *self;
148 PyObject *args;
149{
Marc-André Lemburg99964b82000-06-07 09:13:41 +0000150 if (!PyArg_ParseTuple(args, ":getdefaultencoding"))
Fred Drake8b4d01d2000-05-09 19:57:01 +0000151 return NULL;
152 return PyString_FromString(PyUnicode_GetDefaultEncoding());
153}
154
Marc-André Lemburg99964b82000-06-07 09:13:41 +0000155static char getdefaultencoding_doc[] =
156"getdefaultencoding() -> string\n\
Fred Drake8b4d01d2000-05-09 19:57:01 +0000157\n\
158Return the current default string encoding used by the Unicode \n\
159implementation.";
160
161static PyObject *
Marc-André Lemburg99964b82000-06-07 09:13:41 +0000162sys_setdefaultencoding(self, args)
Fred Drake8b4d01d2000-05-09 19:57:01 +0000163 PyObject *self;
164 PyObject *args;
165{
166 char *encoding;
Marc-André Lemburg99964b82000-06-07 09:13:41 +0000167 if (!PyArg_ParseTuple(args, "s:setdefaultencoding", &encoding))
Fred Drake8b4d01d2000-05-09 19:57:01 +0000168 return NULL;
169 if (PyUnicode_SetDefaultEncoding(encoding))
170 return NULL;
171 Py_INCREF(Py_None);
172 return Py_None;
173}
174
Marc-André Lemburg99964b82000-06-07 09:13:41 +0000175static char setdefaultencoding_doc[] =
176"setdefaultencoding(encoding)\n\
Fred Drake8b4d01d2000-05-09 19:57:01 +0000177\n\
178Set the current default string encoding used by the Unicode implementation.";
179
180static PyObject *
Guido van Rossume2437a11992-03-23 18:20:18 +0000181sys_settrace(self, args)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000182 PyObject *self;
183 PyObject *args;
Guido van Rossume2437a11992-03-23 18:20:18 +0000184{
Guido van Rossuma027efa1997-05-05 20:56:21 +0000185 PyThreadState *tstate = PyThreadState_Get();
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000186 if (args == Py_None)
Guido van Rossume2437a11992-03-23 18:20:18 +0000187 args = NULL;
Guido van Rossume765f7d1992-04-05 14:17:55 +0000188 else
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000189 Py_XINCREF(args);
Guido van Rossuma027efa1997-05-05 20:56:21 +0000190 Py_XDECREF(tstate->sys_tracefunc);
191 tstate->sys_tracefunc = args;
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000192 Py_INCREF(Py_None);
193 return Py_None;
Guido van Rossume2437a11992-03-23 18:20:18 +0000194}
195
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000196static char settrace_doc[] =
197"settrace(function)\n\
198\n\
199Set the global debug tracing function. It will be called on each\n\
200function call. See the debugger chapter in the library manual.";
201
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000202static PyObject *
Guido van Rossume2437a11992-03-23 18:20:18 +0000203sys_setprofile(self, args)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000204 PyObject *self;
205 PyObject *args;
Guido van Rossume2437a11992-03-23 18:20:18 +0000206{
Guido van Rossuma027efa1997-05-05 20:56:21 +0000207 PyThreadState *tstate = PyThreadState_Get();
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000208 if (args == Py_None)
Guido van Rossume2437a11992-03-23 18:20:18 +0000209 args = NULL;
Guido van Rossume765f7d1992-04-05 14:17:55 +0000210 else
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000211 Py_XINCREF(args);
Guido van Rossuma027efa1997-05-05 20:56:21 +0000212 Py_XDECREF(tstate->sys_profilefunc);
213 tstate->sys_profilefunc = args;
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000214 Py_INCREF(Py_None);
215 return Py_None;
Guido van Rossume2437a11992-03-23 18:20:18 +0000216}
217
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000218static char setprofile_doc[] =
219"setprofile(function)\n\
220\n\
221Set the profiling function. It will be called on each function call\n\
222and return. See the profiler chapter in the library manual.";
223
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000224static PyObject *
Guido van Rossuma0d7a231995-01-09 17:46:13 +0000225sys_setcheckinterval(self, args)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000226 PyObject *self;
227 PyObject *args;
Guido van Rossuma0d7a231995-01-09 17:46:13 +0000228{
Guido van Rossuma027efa1997-05-05 20:56:21 +0000229 PyThreadState *tstate = PyThreadState_Get();
Guido van Rossum43713e52000-02-29 13:59:29 +0000230 if (!PyArg_ParseTuple(args, "i:setcheckinterval", &tstate->interp->checkinterval))
Guido van Rossuma0d7a231995-01-09 17:46:13 +0000231 return NULL;
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000232 Py_INCREF(Py_None);
233 return Py_None;
Guido van Rossuma0d7a231995-01-09 17:46:13 +0000234}
235
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000236static char setcheckinterval_doc[] =
237"setcheckinterval(n)\n\
238\n\
239Tell the Python interpreter to check for asynchronous events every\n\
240n instructions. This also affects how often thread switches occur.";
241
Guido van Rossum14b4adb1992-09-03 20:25:30 +0000242#ifdef USE_MALLOPT
243/* Link with -lmalloc (or -lmpc) on an SGI */
244#include <malloc.h>
245
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000246static PyObject *
Guido van Rossum14b4adb1992-09-03 20:25:30 +0000247sys_mdebug(self, args)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000248 PyObject *self;
249 PyObject *args;
Guido van Rossum14b4adb1992-09-03 20:25:30 +0000250{
251 int flag;
Guido van Rossumffc0f4f2000-03-31 00:38:29 +0000252 if (!PyArg_ParseTuple(args, "i:mdebug", &flag))
Guido van Rossum14b4adb1992-09-03 20:25:30 +0000253 return NULL;
254 mallopt(M_DEBUG, flag);
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000255 Py_INCREF(Py_None);
256 return Py_None;
Guido van Rossum14b4adb1992-09-03 20:25:30 +0000257}
258#endif /* USE_MALLOPT */
259
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000260static PyObject *
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000261sys_getrefcount(self, args)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000262 PyObject *self;
263 PyObject *args;
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000264{
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000265 PyObject *arg;
Guido van Rossumffc0f4f2000-03-31 00:38:29 +0000266 if (!PyArg_ParseTuple(args, "O:getrefcount", &arg))
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000267 return NULL;
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000268 return PyInt_FromLong((long) arg->ob_refcnt);
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000269}
270
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000271static char getrefcount_doc[] =
272"getrefcount(object) -> integer\n\
273\n\
274Return the current reference count for the object. This includes the\n\
275temporary reference in the argument list, so it is at least 2.";
276
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000277#ifdef COUNT_ALLOCS
278static PyObject *
279sys_getcounts(self, args)
280 PyObject *self, *args;
281{
282 extern PyObject *get_counts Py_PROTO((void));
283
Guido van Rossumffc0f4f2000-03-31 00:38:29 +0000284 if (!PyArg_ParseTuple(args, ":getcounts"))
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000285 return NULL;
286 return get_counts();
287}
288#endif
289
Guido van Rossum7f3f2c11996-05-23 22:45:41 +0000290#ifdef Py_TRACE_REFS
Guido van Rossumded690f1996-05-24 20:48:31 +0000291/* Defined in objects.c because it uses static globals if that file */
292extern PyObject *_Py_GetObjects Py_PROTO((PyObject *, PyObject *));
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000293#endif
Guido van Rossumded690f1996-05-24 20:48:31 +0000294
Guido van Rossum43f1b8d1997-01-24 04:07:45 +0000295#ifdef DYNAMIC_EXECUTION_PROFILE
296/* Defined in ceval.c because it uses static globals if that file */
297extern PyObject *_Py_GetDXProfile Py_PROTO((PyObject *, PyObject *));
298#endif
299
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000300static PyMethodDef sys_methods[] = {
Guido van Rossum43f1b8d1997-01-24 04:07:45 +0000301 /* Might as well keep this in alphabetic order */
Guido van Rossumffc0f4f2000-03-31 00:38:29 +0000302 {"exc_info", sys_exc_info, 1, exc_info_doc},
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000303 {"exit", sys_exit, 0, exit_doc},
Marc-André Lemburg99964b82000-06-07 09:13:41 +0000304 {"getdefaultencoding", sys_getdefaultencoding, 1, getdefaultencoding_doc},
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000305#ifdef COUNT_ALLOCS
Guido van Rossumffc0f4f2000-03-31 00:38:29 +0000306 {"getcounts", sys_getcounts, 1},
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000307#endif
Guido van Rossum43f1b8d1997-01-24 04:07:45 +0000308#ifdef DYNAMIC_EXECUTION_PROFILE
309 {"getdxp", _Py_GetDXProfile, 1},
310#endif
Guido van Rossum7f3f2c11996-05-23 22:45:41 +0000311#ifdef Py_TRACE_REFS
Guido van Rossumded690f1996-05-24 20:48:31 +0000312 {"getobjects", _Py_GetObjects, 1},
Sjoerd Mullender6ec3c651995-08-29 09:18:14 +0000313#endif
Guido van Rossumffc0f4f2000-03-31 00:38:29 +0000314 {"getrefcount", sys_getrefcount, 1, getrefcount_doc},
Guido van Rossum14b4adb1992-09-03 20:25:30 +0000315#ifdef USE_MALLOPT
Guido van Rossumffc0f4f2000-03-31 00:38:29 +0000316 {"mdebug", sys_mdebug, 1},
Guido van Rossum14b4adb1992-09-03 20:25:30 +0000317#endif
Marc-André Lemburg99964b82000-06-07 09:13:41 +0000318 {"setdefaultencoding", sys_setdefaultencoding, 1, setdefaultencoding_doc},
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000319 {"setcheckinterval", sys_setcheckinterval, 1, setcheckinterval_doc},
320 {"setprofile", sys_setprofile, 0, setprofile_doc},
321 {"settrace", sys_settrace, 0, settrace_doc},
Guido van Rossum3f5da241990-12-20 15:06:42 +0000322 {NULL, NULL} /* sentinel */
323};
324
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000325static PyObject *
Guido van Rossum34679b71993-01-26 13:33:44 +0000326list_builtin_module_names()
327{
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000328 PyObject *list = PyList_New(0);
Guido van Rossum34679b71993-01-26 13:33:44 +0000329 int i;
330 if (list == NULL)
331 return NULL;
Guido van Rossum25c649f1997-11-04 17:04:34 +0000332 for (i = 0; PyImport_Inittab[i].name != NULL; i++) {
Guido van Rossuma027efa1997-05-05 20:56:21 +0000333 PyObject *name = PyString_FromString(
Guido van Rossum25c649f1997-11-04 17:04:34 +0000334 PyImport_Inittab[i].name);
Guido van Rossum34679b71993-01-26 13:33:44 +0000335 if (name == NULL)
336 break;
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000337 PyList_Append(list, name);
338 Py_DECREF(name);
Guido van Rossum34679b71993-01-26 13:33:44 +0000339 }
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000340 if (PyList_Sort(list) != 0) {
341 Py_DECREF(list);
Guido van Rossum1d5735e1994-08-30 08:27:36 +0000342 list = NULL;
343 }
Guido van Rossum8f49e121997-01-06 22:55:54 +0000344 if (list) {
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000345 PyObject *v = PyList_AsTuple(list);
346 Py_DECREF(list);
Guido van Rossum8f49e121997-01-06 22:55:54 +0000347 list = v;
348 }
Guido van Rossum34679b71993-01-26 13:33:44 +0000349 return list;
350}
351
Guido van Rossum40552d01998-08-06 03:34:39 +0000352/* XXX This doc string is too long to be a single string literal in VC++ 5.0.
353 Two literals concatenated works just fine. If you have a K&R compiler
354 or other abomination that however *does* understand longer strings,
355 get rid of the !!! comment in the middle and the quotes that surround it. */
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000356static char sys_doc[] =
357"This module provides access to some objects used or maintained by the\n\
358interpreter and to functions that interact strongly with the interpreter.\n\
359\n\
360Dynamic objects:\n\
361\n\
362argv -- command line arguments; argv[0] is the script pathname if known\n\
363path -- module search path; path[0] is the script directory, else ''\n\
364modules -- dictionary of loaded modules\n\
365exitfunc -- you may set this to a function to be called when Python exits\n\
366\n\
367stdin -- standard input file object; used by raw_input() and input()\n\
368stdout -- standard output file object; used by the print statement\n\
369stderr -- standard error object; used for error messages\n\
370 By assigning another file object (or an object that behaves like a file)\n\
371 to one of these, it is possible to redirect all of the interpreter's I/O.\n\
372\n\
373last_type -- type of last uncaught exception\n\
374last_value -- value of last uncaught exception\n\
375last_traceback -- traceback of last uncaught exception\n\
376 These three are only available in an interactive session after a\n\
377 traceback has been printed.\n\
378\n\
379exc_type -- type of exception currently being handled\n\
380exc_value -- value of exception currently being handled\n\
381exc_traceback -- traceback of exception currently being handled\n\
382 The function exc_info() should be used instead of these three,\n\
383 because it is thread-safe.\n\
Guido van Rossuma71b5f41999-01-14 19:07:00 +0000384"
385#ifndef MS_WIN16
386/* Concatenating string here */
387"\n\
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000388Static objects:\n\
389\n\
390maxint -- the largest supported integer (the smallest is -maxint-1)\n\
391builtin_module_names -- tuple of module names built into this intepreter\n\
Fred Drake801c08d2000-04-13 15:29:10 +0000392version -- the version of this interpreter as a string\n\
393version_info -- version information as a tuple\n\
394hexversion -- version information encoded as a single integer\n\
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000395copyright -- copyright notice pertaining to this interpreter\n\
396platform -- platform identifier\n\
397executable -- pathname of this Python interpreter\n\
398prefix -- prefix used to find the Python library\n\
399exec_prefix -- prefix used to find the machine-specific Python library\n\
400dllhandle -- [Windows only] integer handle of the Python DLL\n\
401winver -- [Windows only] version number of the Python DLL\n\
402__stdin__ -- the original stdin; don't use!\n\
403__stdout__ -- the original stdout; don't use!\n\
404__stderr__ -- the original stderr; don't use!\n\
405\n\
406Functions:\n\
407\n\
408exc_info() -- return thread-safe information about the current exception\n\
409exit() -- exit the interpreter by raising SystemExit\n\
410getrefcount() -- return the reference count for an object (plus one :-)\n\
411setcheckinterval() -- control how often the interpreter checks for events\n\
412setprofile() -- set the global profiling function\n\
413settrace() -- set the global debug tracing function\n\
414";
Guido van Rossuma71b5f41999-01-14 19:07:00 +0000415#endif
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000416
Guido van Rossum25ce5661997-08-02 03:10:38 +0000417PyObject *
418_PySys_Init()
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000419{
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000420 extern int fclose Py_PROTO((FILE *));
Guido van Rossum25ce5661997-08-02 03:10:38 +0000421 PyObject *m, *v, *sysdict;
422 PyObject *sysin, *sysout, *syserr;
Fred Drake6d27c1e2000-04-13 20:03:20 +0000423 char *s;
Guido van Rossum25ce5661997-08-02 03:10:38 +0000424
Guido van Rossumc3bc31e1998-06-27 19:43:25 +0000425 m = Py_InitModule3("sys", sys_methods, sys_doc);
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000426 sysdict = PyModule_GetDict(m);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000427
428 sysin = PyFile_FromFile(stdin, "<stdin>", "r", NULL);
429 sysout = PyFile_FromFile(stdout, "<stdout>", "w", NULL);
430 syserr = PyFile_FromFile(stderr, "<stderr>", "w", NULL);
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000431 if (PyErr_Occurred())
Guido van Rossum25ce5661997-08-02 03:10:38 +0000432 return NULL;
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000433 PyDict_SetItemString(sysdict, "stdin", sysin);
434 PyDict_SetItemString(sysdict, "stdout", sysout);
435 PyDict_SetItemString(sysdict, "stderr", syserr);
Guido van Rossumbd36dba1998-02-19 20:53:06 +0000436 /* Make backup copies for cleanup */
437 PyDict_SetItemString(sysdict, "__stdin__", sysin);
438 PyDict_SetItemString(sysdict, "__stdout__", sysout);
439 PyDict_SetItemString(sysdict, "__stderr__", syserr);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000440 Py_XDECREF(sysin);
441 Py_XDECREF(sysout);
442 Py_XDECREF(syserr);
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000443 PyDict_SetItemString(sysdict, "version",
444 v = PyString_FromString(Py_GetVersion()));
Barry Warsaw54892c41999-01-27 16:33:19 +0000445 Py_XDECREF(v);
Guido van Rossume0d7dae1999-01-03 12:55:39 +0000446 PyDict_SetItemString(sysdict, "hexversion",
447 v = PyInt_FromLong(PY_VERSION_HEX));
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000448 Py_XDECREF(v);
Fred Drake93a20bf2000-04-13 17:44:51 +0000449 /*
450 * These release level checks are mutually exclusive and cover
451 * the field, so don't get too fancy with the pre-processor!
452 */
453#if PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_ALPHA
Fred Drake6d27c1e2000-04-13 20:03:20 +0000454 s = "alpha";
Fred Drake93a20bf2000-04-13 17:44:51 +0000455#endif
456#if PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_BETA
Fred Drake6d27c1e2000-04-13 20:03:20 +0000457 s = "beta";
Fred Drake93a20bf2000-04-13 17:44:51 +0000458#endif
459#if PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_GAMMA
Fred Drake6d27c1e2000-04-13 20:03:20 +0000460 s = "candidate";
Fred Drake93a20bf2000-04-13 17:44:51 +0000461#endif
Fred Drake801c08d2000-04-13 15:29:10 +0000462#if PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_FINAL
Fred Drake6d27c1e2000-04-13 20:03:20 +0000463 s = "final";
Fred Drake93a20bf2000-04-13 17:44:51 +0000464#endif
Fred Drake801c08d2000-04-13 15:29:10 +0000465 PyDict_SetItemString(sysdict, "version_info",
Fred Drake6d27c1e2000-04-13 20:03:20 +0000466 v = Py_BuildValue("iiisi", PY_MAJOR_VERSION,
Fred Drake801c08d2000-04-13 15:29:10 +0000467 PY_MINOR_VERSION,
Fred Drake6d27c1e2000-04-13 20:03:20 +0000468 PY_MICRO_VERSION, s,
Fred Drake93a20bf2000-04-13 17:44:51 +0000469 PY_RELEASE_SERIAL));
Fred Drake801c08d2000-04-13 15:29:10 +0000470 Py_XDECREF(v);
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000471 PyDict_SetItemString(sysdict, "copyright",
472 v = PyString_FromString(Py_GetCopyright()));
473 Py_XDECREF(v);
474 PyDict_SetItemString(sysdict, "platform",
475 v = PyString_FromString(Py_GetPlatform()));
476 Py_XDECREF(v);
Guido van Rossumb2c8ec41997-05-22 20:41:20 +0000477 PyDict_SetItemString(sysdict, "executable",
478 v = PyString_FromString(Py_GetProgramFullPath()));
479 Py_XDECREF(v);
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000480 PyDict_SetItemString(sysdict, "prefix",
481 v = PyString_FromString(Py_GetPrefix()));
482 Py_XDECREF(v);
483 PyDict_SetItemString(sysdict, "exec_prefix",
484 v = PyString_FromString(Py_GetExecPrefix()));
485 Py_XDECREF(v);
486 PyDict_SetItemString(sysdict, "maxint",
487 v = PyInt_FromLong(PyInt_GetMax()));
488 Py_XDECREF(v);
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000489 PyDict_SetItemString(sysdict, "builtin_module_names",
Guido van Rossum1ae940a1995-01-02 19:04:15 +0000490 v = list_builtin_module_names());
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000491 Py_XDECREF(v);
Guido van Rossum8b9ea871996-08-23 18:14:47 +0000492#ifdef MS_COREDLL
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000493 PyDict_SetItemString(sysdict, "dllhandle",
494 v = PyInt_FromLong((int)PyWin_DLLhModule));
495 Py_XDECREF(v);
496 PyDict_SetItemString(sysdict, "winver",
Guido van Rossum6c1e5f21997-09-29 23:34:23 +0000497 v = PyString_FromString(PyWin_DLLVersionString));
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000498 Py_XDECREF(v);
Guido van Rossumc606fe11996-04-09 02:37:57 +0000499#endif
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000500 if (PyErr_Occurred())
Guido van Rossum25ce5661997-08-02 03:10:38 +0000501 return NULL;
502 return m;
Guido van Rossum5b3138b1990-11-18 17:41:40 +0000503}
504
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000505static PyObject *
Guido van Rossum3f5da241990-12-20 15:06:42 +0000506makepathobject(path, delim)
507 char *path;
508 int delim;
Guido van Rossum5b3138b1990-11-18 17:41:40 +0000509{
Guido van Rossum3f5da241990-12-20 15:06:42 +0000510 int i, n;
511 char *p;
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000512 PyObject *v, *w;
Guido van Rossum3f5da241990-12-20 15:06:42 +0000513
514 n = 1;
515 p = path;
516 while ((p = strchr(p, delim)) != NULL) {
517 n++;
518 p++;
Guido van Rossum5b3138b1990-11-18 17:41:40 +0000519 }
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000520 v = PyList_New(n);
Guido van Rossum3f5da241990-12-20 15:06:42 +0000521 if (v == NULL)
522 return NULL;
523 for (i = 0; ; i++) {
524 p = strchr(path, delim);
525 if (p == NULL)
526 p = strchr(path, '\0'); /* End of string */
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000527 w = PyString_FromStringAndSize(path, (int) (p - path));
Guido van Rossum3f5da241990-12-20 15:06:42 +0000528 if (w == NULL) {
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000529 Py_DECREF(v);
Guido van Rossum3f5da241990-12-20 15:06:42 +0000530 return NULL;
531 }
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000532 PyList_SetItem(v, i, w);
Guido van Rossum3f5da241990-12-20 15:06:42 +0000533 if (*p == '\0')
534 break;
535 path = p+1;
536 }
537 return v;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000538}
539
540void
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000541PySys_SetPath(path)
Guido van Rossum3f5da241990-12-20 15:06:42 +0000542 char *path;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000543{
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000544 PyObject *v;
Guido van Rossum3f5da241990-12-20 15:06:42 +0000545 if ((v = makepathobject(path, DELIM)) == NULL)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000546 Py_FatalError("can't create sys.path");
547 if (PySys_SetObject("path", v) != 0)
548 Py_FatalError("can't assign sys.path");
549 Py_DECREF(v);
Guido van Rossum3f5da241990-12-20 15:06:42 +0000550}
551
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000552static PyObject *
Guido van Rossum3f5da241990-12-20 15:06:42 +0000553makeargvobject(argc, argv)
554 int argc;
555 char **argv;
556{
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000557 PyObject *av;
Guido van Rossumee3a2991992-01-14 18:42:53 +0000558 if (argc <= 0 || argv == NULL) {
559 /* Ensure at least one (empty) argument is seen */
560 static char *empty_argv[1] = {""};
561 argv = empty_argv;
562 argc = 1;
563 }
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000564 av = PyList_New(argc);
Guido van Rossum3f5da241990-12-20 15:06:42 +0000565 if (av != NULL) {
Guido van Rossum5b3138b1990-11-18 17:41:40 +0000566 int i;
Guido van Rossum3f5da241990-12-20 15:06:42 +0000567 for (i = 0; i < argc; i++) {
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000568 PyObject *v = PyString_FromString(argv[i]);
Guido van Rossum3f5da241990-12-20 15:06:42 +0000569 if (v == NULL) {
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000570 Py_DECREF(av);
Guido van Rossum3f5da241990-12-20 15:06:42 +0000571 av = NULL;
572 break;
Guido van Rossum5b3138b1990-11-18 17:41:40 +0000573 }
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000574 PyList_SetItem(av, i, v);
Guido van Rossum5b3138b1990-11-18 17:41:40 +0000575 }
Guido van Rossum5b3138b1990-11-18 17:41:40 +0000576 }
Guido van Rossum3f5da241990-12-20 15:06:42 +0000577 return av;
578}
579
580void
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000581PySys_SetArgv(argc, argv)
Guido van Rossum3f5da241990-12-20 15:06:42 +0000582 int argc;
583 char **argv;
584{
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000585 PyObject *av = makeargvobject(argc, argv);
586 PyObject *path = PySys_GetObject("path");
Guido van Rossum3f5da241990-12-20 15:06:42 +0000587 if (av == NULL)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000588 Py_FatalError("no mem for sys.argv");
589 if (PySys_SetObject("argv", av) != 0)
590 Py_FatalError("can't assign sys.argv");
Guido van Rossum94a96671996-07-30 20:35:50 +0000591 if (path != NULL) {
Guido van Rossumc474dea1997-04-25 15:38:31 +0000592 char *argv0 = argv[0];
Guido van Rossum94a96671996-07-30 20:35:50 +0000593 char *p = NULL;
Guido van Rossumcc883411996-09-10 14:44:21 +0000594 int n = 0;
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000595 PyObject *a;
Guido van Rossumc474dea1997-04-25 15:38:31 +0000596#ifdef HAVE_READLINK
597 char link[MAXPATHLEN+1];
598 char argv0copy[2*MAXPATHLEN+1];
599 int nr = 0;
600 if (argc > 0 && argv0 != NULL)
601 nr = readlink(argv0, link, MAXPATHLEN);
602 if (nr > 0) {
603 /* It's a symlink */
604 link[nr] = '\0';
605 if (link[0] == SEP)
606 argv0 = link; /* Link to absolute path */
607 else if (strchr(link, SEP) == NULL)
608 ; /* Link without path */
609 else {
610 /* Must join(dirname(argv0), link) */
611 char *q = strrchr(argv0, SEP);
612 if (q == NULL)
613 argv0 = link; /* argv0 without path */
614 else {
615 /* Must make a copy */
616 strcpy(argv0copy, argv0);
617 q = strrchr(argv0copy, SEP);
618 strcpy(q+1, link);
619 argv0 = argv0copy;
620 }
621 }
622 }
623#endif /* HAVE_READLINK */
Guido van Rossumcc883411996-09-10 14:44:21 +0000624#if SEP == '\\' /* Special case for MS filename syntax */
Guido van Rossumc474dea1997-04-25 15:38:31 +0000625 if (argc > 0 && argv0 != NULL) {
Guido van Rossumcc883411996-09-10 14:44:21 +0000626 char *q;
Guido van Rossumc474dea1997-04-25 15:38:31 +0000627 p = strrchr(argv0, SEP);
Guido van Rossumcc883411996-09-10 14:44:21 +0000628 /* Test for alternate separator */
Guido van Rossumc474dea1997-04-25 15:38:31 +0000629 q = strrchr(p ? p : argv0, '/');
Guido van Rossumcc883411996-09-10 14:44:21 +0000630 if (q != NULL)
631 p = q;
632 if (p != NULL) {
Guido van Rossumc474dea1997-04-25 15:38:31 +0000633 n = p + 1 - argv0;
Guido van Rossumcc883411996-09-10 14:44:21 +0000634 if (n > 1 && p[-1] != ':')
635 n--; /* Drop trailing separator */
636 }
637 }
638#else /* All other filename syntaxes */
Guido van Rossumc474dea1997-04-25 15:38:31 +0000639 if (argc > 0 && argv0 != NULL)
640 p = strrchr(argv0, SEP);
Guido van Rossumcc883411996-09-10 14:44:21 +0000641 if (p != NULL) {
Guido van Rossumc474dea1997-04-25 15:38:31 +0000642 n = p + 1 - argv0;
Guido van Rossumcc883411996-09-10 14:44:21 +0000643#if SEP == '/' /* Special case for Unix filename syntax */
644 if (n > 1)
645 n--; /* Drop trailing separator */
646#endif /* Unix */
647 }
648#endif /* All others */
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000649 a = PyString_FromStringAndSize(argv0, n);
Guido van Rossum94a96671996-07-30 20:35:50 +0000650 if (a == NULL)
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000651 Py_FatalError("no mem for sys.path insertion");
652 if (PyList_Insert(path, 0, a) < 0)
653 Py_FatalError("sys.path.insert(0) failed");
654 Py_DECREF(a);
Guido van Rossuma63d9f41996-07-24 01:31:37 +0000655 }
Guido van Rossum65bf9f21997-04-29 18:33:38 +0000656 Py_DECREF(av);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000657}
Guido van Rossuma890e681998-05-12 14:59:24 +0000658
659
660/* APIs to write to sys.stdout or sys.stderr using a printf-like interface.
661 Adapted from code submitted by Just van Rossum.
662
663 PySys_WriteStdout(format, ...)
664 PySys_WriteStderr(format, ...)
665
666 The first function writes to sys.stdout; the second to sys.stderr. When
667 there is a problem, they write to the real (C level) stdout or stderr;
Guido van Rossum8442af31998-10-12 18:22:10 +0000668 no exceptions are raised.
Guido van Rossuma890e681998-05-12 14:59:24 +0000669
670 Both take a printf-style format string as their first argument followed
671 by a variable length argument list determined by the format string.
672
673 *** WARNING ***
674
675 The format should limit the total size of the formatted output string to
676 1000 bytes. In particular, this means that no unrestricted "%s" formats
677 should occur; these should be limited using "%.<N>s where <N> is a
678 decimal number calculated so that <N> plus the maximum size of other
679 formatted text does not exceed 1000 bytes. Also watch out for "%f",
680 which can print hundreds of digits for very large numbers.
681
682 */
683
684static void
685mywrite(name, fp, format, va)
686 char *name;
687 FILE *fp;
688 const char *format;
689 va_list va;
690{
691 PyObject *file;
Guido van Rossum8442af31998-10-12 18:22:10 +0000692 PyObject *error_type, *error_value, *error_traceback;
Guido van Rossuma890e681998-05-12 14:59:24 +0000693
Guido van Rossum8442af31998-10-12 18:22:10 +0000694 PyErr_Fetch(&error_type, &error_value, &error_traceback);
Guido van Rossuma890e681998-05-12 14:59:24 +0000695 file = PySys_GetObject(name);
696 if (file == NULL || PyFile_AsFile(file) == fp)
697 vfprintf(fp, format, va);
698 else {
699 char buffer[1001];
Guido van Rossum8442af31998-10-12 18:22:10 +0000700 if (vsprintf(buffer, format, va) >= sizeof(buffer))
701 Py_FatalError("PySys_WriteStdout/err: buffer overrun");
Guido van Rossuma890e681998-05-12 14:59:24 +0000702 if (PyFile_WriteString(buffer, file) != 0) {
703 PyErr_Clear();
704 fputs(buffer, fp);
705 }
706 }
Guido van Rossum8442af31998-10-12 18:22:10 +0000707 PyErr_Restore(error_type, error_value, error_traceback);
Guido van Rossuma890e681998-05-12 14:59:24 +0000708}
709
710void
711#ifdef HAVE_STDARG_PROTOTYPES
712PySys_WriteStdout(const char *format, ...)
713#else
714PySys_WriteStdout(va_alist)
715 va_dcl
716#endif
717{
718 va_list va;
719
720#ifdef HAVE_STDARG_PROTOTYPES
721 va_start(va, format);
722#else
723 char *format;
724 va_start(va);
725 format = va_arg(va, char *);
726#endif
727 mywrite("stdout", stdout, format, va);
728 va_end(va);
729}
730
731void
732#ifdef HAVE_STDARG_PROTOTYPES
733PySys_WriteStderr(const char *format, ...)
734#else
735PySys_WriteStderr(va_alist)
736 va_dcl
737#endif
738{
739 va_list va;
740
741#ifdef HAVE_STDARG_PROTOTYPES
742 va_start(va, format);
743#else
744 char *format;
745 va_start(va);
746 format = va_arg(va, char *);
747#endif
748 mywrite("stderr", stderr, format, va);
749 va_end(va);
750}