move sections
[python/dscho.git] / Python / sysmodule.c
blob97ce8cdc4e5de9ccaba74cc8664838f1d09ccd7b
2 /* System module */
4 /*
5 Various bits of information used by the interpreter are collected in
6 module 'sys'.
7 Function member:
8 - exit(sts): raise SystemExit
9 Data members:
10 - stdin, stdout, stderr: standard file objects
11 - modules: the table of modules (dictionary)
12 - path: module search path (list of strings)
13 - argv: script arguments (list of strings)
14 - ps1, ps2: optional primary and secondary prompts (strings)
17 #include "Python.h"
18 #include "structseq.h"
19 #include "code.h"
20 #include "frameobject.h"
21 #include "eval.h"
23 #include "osdefs.h"
25 #ifdef MS_WINDOWS
26 #define WIN32_LEAN_AND_MEAN
27 #include "windows.h"
28 #endif /* MS_WINDOWS */
30 #ifdef MS_COREDLL
31 extern void *PyWin_DLLhModule;
32 /* A string loaded from the DLL at startup: */
33 extern const char *PyWin_DLLVersionString;
34 #endif
36 #ifdef __VMS
37 #include <unixlib.h>
38 #endif
40 #ifdef MS_WINDOWS
41 #include <windows.h>
42 #endif
44 #ifdef HAVE_LANGINFO_H
45 #include <locale.h>
46 #include <langinfo.h>
47 #endif
49 PyObject *
50 PySys_GetObject(char *name)
52 PyThreadState *tstate = PyThreadState_GET();
53 PyObject *sd = tstate->interp->sysdict;
54 if (sd == NULL)
55 return NULL;
56 return PyDict_GetItemString(sd, name);
59 FILE *
60 PySys_GetFile(char *name, FILE *def)
62 FILE *fp = NULL;
63 PyObject *v = PySys_GetObject(name);
64 if (v != NULL && PyFile_Check(v))
65 fp = PyFile_AsFile(v);
66 if (fp == NULL)
67 fp = def;
68 return fp;
71 int
72 PySys_SetObject(char *name, PyObject *v)
74 PyThreadState *tstate = PyThreadState_GET();
75 PyObject *sd = tstate->interp->sysdict;
76 if (v == NULL) {
77 if (PyDict_GetItemString(sd, name) == NULL)
78 return 0;
79 else
80 return PyDict_DelItemString(sd, name);
82 else
83 return PyDict_SetItemString(sd, name, v);
86 static PyObject *
87 sys_displayhook(PyObject *self, PyObject *o)
89 PyObject *outf;
90 PyInterpreterState *interp = PyThreadState_GET()->interp;
91 PyObject *modules = interp->modules;
92 PyObject *builtins = PyDict_GetItemString(modules, "__builtin__");
94 if (builtins == NULL) {
95 PyErr_SetString(PyExc_RuntimeError, "lost __builtin__");
96 return NULL;
99 /* Print value except if None */
100 /* After printing, also assign to '_' */
101 /* Before, set '_' to None to avoid recursion */
102 if (o == Py_None) {
103 Py_INCREF(Py_None);
104 return Py_None;
106 if (PyObject_SetAttrString(builtins, "_", Py_None) != 0)
107 return NULL;
108 if (Py_FlushLine() != 0)
109 return NULL;
110 outf = PySys_GetObject("stdout");
111 if (outf == NULL) {
112 PyErr_SetString(PyExc_RuntimeError, "lost sys.stdout");
113 return NULL;
115 if (PyFile_WriteObject(o, outf, 0) != 0)
116 return NULL;
117 PyFile_SoftSpace(outf, 1);
118 if (Py_FlushLine() != 0)
119 return NULL;
120 if (PyObject_SetAttrString(builtins, "_", o) != 0)
121 return NULL;
122 Py_INCREF(Py_None);
123 return Py_None;
126 PyDoc_STRVAR(displayhook_doc,
127 "displayhook(object) -> None\n"
128 "\n"
129 "Print an object to sys.stdout and also save it in __builtin__._\n"
132 static PyObject *
133 sys_excepthook(PyObject* self, PyObject* args)
135 PyObject *exc, *value, *tb;
136 if (!PyArg_UnpackTuple(args, "excepthook", 3, 3, &exc, &value, &tb))
137 return NULL;
138 PyErr_Display(exc, value, tb);
139 Py_INCREF(Py_None);
140 return Py_None;
143 PyDoc_STRVAR(excepthook_doc,
144 "excepthook(exctype, value, traceback) -> None\n"
145 "\n"
146 "Handle an exception by displaying it with a traceback on sys.stderr.\n"
149 static PyObject *
150 sys_exc_info(PyObject *self, PyObject *noargs)
152 PyThreadState *tstate;
153 tstate = PyThreadState_GET();
154 return Py_BuildValue(
155 "(OOO)",
156 tstate->exc_type != NULL ? tstate->exc_type : Py_None,
157 tstate->exc_value != NULL ? tstate->exc_value : Py_None,
158 tstate->exc_traceback != NULL ?
159 tstate->exc_traceback : Py_None);
162 PyDoc_STRVAR(exc_info_doc,
163 "exc_info() -> (type, value, traceback)\n\
165 Return information about the most recent exception caught by an except\n\
166 clause in the current stack frame or in an older stack frame."
169 static PyObject *
170 sys_exc_clear(PyObject *self, PyObject *noargs)
172 PyThreadState *tstate;
173 PyObject *tmp_type, *tmp_value, *tmp_tb;
175 if (PyErr_WarnPy3k("sys.exc_clear() not supported in 3.x; "
176 "use except clauses", 1) < 0)
177 return NULL;
179 tstate = PyThreadState_GET();
180 tmp_type = tstate->exc_type;
181 tmp_value = tstate->exc_value;
182 tmp_tb = tstate->exc_traceback;
183 tstate->exc_type = NULL;
184 tstate->exc_value = NULL;
185 tstate->exc_traceback = NULL;
186 Py_XDECREF(tmp_type);
187 Py_XDECREF(tmp_value);
188 Py_XDECREF(tmp_tb);
189 /* For b/w compatibility */
190 PySys_SetObject("exc_type", Py_None);
191 PySys_SetObject("exc_value", Py_None);
192 PySys_SetObject("exc_traceback", Py_None);
193 Py_INCREF(Py_None);
194 return Py_None;
197 PyDoc_STRVAR(exc_clear_doc,
198 "exc_clear() -> None\n\
200 Clear global information on the current exception. Subsequent calls to\n\
201 exc_info() will return (None,None,None) until another exception is raised\n\
202 in the current thread or the execution stack returns to a frame where\n\
203 another exception is being handled."
206 static PyObject *
207 sys_exit(PyObject *self, PyObject *args)
209 PyObject *exit_code = 0;
210 if (!PyArg_UnpackTuple(args, "exit", 0, 1, &exit_code))
211 return NULL;
212 /* Raise SystemExit so callers may catch it or clean up. */
213 PyErr_SetObject(PyExc_SystemExit, exit_code);
214 return NULL;
217 PyDoc_STRVAR(exit_doc,
218 "exit([status])\n\
220 Exit the interpreter by raising SystemExit(status).\n\
221 If the status is omitted or None, it defaults to zero (i.e., success).\n\
222 If the status is numeric, it will be used as the system exit status.\n\
223 If it is another kind of object, it will be printed and the system\n\
224 exit status will be one (i.e., failure)."
227 #ifdef Py_USING_UNICODE
229 static PyObject *
230 sys_getdefaultencoding(PyObject *self)
232 return PyString_FromString(PyUnicode_GetDefaultEncoding());
235 PyDoc_STRVAR(getdefaultencoding_doc,
236 "getdefaultencoding() -> string\n\
238 Return the current default string encoding used by the Unicode \n\
239 implementation."
242 static PyObject *
243 sys_setdefaultencoding(PyObject *self, PyObject *args)
245 char *encoding;
246 if (!PyArg_ParseTuple(args, "s:setdefaultencoding", &encoding))
247 return NULL;
248 if (PyUnicode_SetDefaultEncoding(encoding))
249 return NULL;
250 Py_INCREF(Py_None);
251 return Py_None;
254 PyDoc_STRVAR(setdefaultencoding_doc,
255 "setdefaultencoding(encoding)\n\
257 Set the current default string encoding used by the Unicode implementation."
260 static PyObject *
261 sys_getfilesystemencoding(PyObject *self)
263 if (Py_FileSystemDefaultEncoding)
264 return PyString_FromString(Py_FileSystemDefaultEncoding);
265 Py_INCREF(Py_None);
266 return Py_None;
269 PyDoc_STRVAR(getfilesystemencoding_doc,
270 "getfilesystemencoding() -> string\n\
272 Return the encoding used to convert Unicode filenames in\n\
273 operating system filenames."
276 #endif
279 * Cached interned string objects used for calling the profile and
280 * trace functions. Initialized by trace_init().
282 static PyObject *whatstrings[7] = {NULL, NULL, NULL, NULL, NULL, NULL, NULL};
284 static int
285 trace_init(void)
287 static char *whatnames[7] = {"call", "exception", "line", "return",
288 "c_call", "c_exception", "c_return"};
289 PyObject *name;
290 int i;
291 for (i = 0; i < 7; ++i) {
292 if (whatstrings[i] == NULL) {
293 name = PyString_InternFromString(whatnames[i]);
294 if (name == NULL)
295 return -1;
296 whatstrings[i] = name;
299 return 0;
303 static PyObject *
304 call_trampoline(PyThreadState *tstate, PyObject* callback,
305 PyFrameObject *frame, int what, PyObject *arg)
307 PyObject *args = PyTuple_New(3);
308 PyObject *whatstr;
309 PyObject *result;
311 if (args == NULL)
312 return NULL;
313 Py_INCREF(frame);
314 whatstr = whatstrings[what];
315 Py_INCREF(whatstr);
316 if (arg == NULL)
317 arg = Py_None;
318 Py_INCREF(arg);
319 PyTuple_SET_ITEM(args, 0, (PyObject *)frame);
320 PyTuple_SET_ITEM(args, 1, whatstr);
321 PyTuple_SET_ITEM(args, 2, arg);
323 /* call the Python-level function */
324 PyFrame_FastToLocals(frame);
325 result = PyEval_CallObject(callback, args);
326 PyFrame_LocalsToFast(frame, 1);
327 if (result == NULL)
328 PyTraceBack_Here(frame);
330 /* cleanup */
331 Py_DECREF(args);
332 return result;
335 static int
336 profile_trampoline(PyObject *self, PyFrameObject *frame,
337 int what, PyObject *arg)
339 PyThreadState *tstate = frame->f_tstate;
340 PyObject *result;
342 if (arg == NULL)
343 arg = Py_None;
344 result = call_trampoline(tstate, self, frame, what, arg);
345 if (result == NULL) {
346 PyEval_SetProfile(NULL, NULL);
347 return -1;
349 Py_DECREF(result);
350 return 0;
353 static int
354 trace_trampoline(PyObject *self, PyFrameObject *frame,
355 int what, PyObject *arg)
357 PyThreadState *tstate = frame->f_tstate;
358 PyObject *callback;
359 PyObject *result;
361 if (what == PyTrace_CALL)
362 callback = self;
363 else
364 callback = frame->f_trace;
365 if (callback == NULL)
366 return 0;
367 result = call_trampoline(tstate, callback, frame, what, arg);
368 if (result == NULL) {
369 PyEval_SetTrace(NULL, NULL);
370 Py_XDECREF(frame->f_trace);
371 frame->f_trace = NULL;
372 return -1;
374 if (result != Py_None) {
375 PyObject *temp = frame->f_trace;
376 frame->f_trace = NULL;
377 Py_XDECREF(temp);
378 frame->f_trace = result;
380 else {
381 Py_DECREF(result);
383 return 0;
386 static PyObject *
387 sys_settrace(PyObject *self, PyObject *args)
389 if (trace_init() == -1)
390 return NULL;
391 if (args == Py_None)
392 PyEval_SetTrace(NULL, NULL);
393 else
394 PyEval_SetTrace(trace_trampoline, args);
395 Py_INCREF(Py_None);
396 return Py_None;
399 PyDoc_STRVAR(settrace_doc,
400 "settrace(function)\n\
402 Set the global debug tracing function. It will be called on each\n\
403 function call. See the debugger chapter in the library manual."
406 static PyObject *
407 sys_gettrace(PyObject *self, PyObject *args)
409 PyThreadState *tstate = PyThreadState_GET();
410 PyObject *temp = tstate->c_traceobj;
412 if (temp == NULL)
413 temp = Py_None;
414 Py_INCREF(temp);
415 return temp;
418 PyDoc_STRVAR(gettrace_doc,
419 "gettrace()\n\
421 Return the global debug tracing function set with sys.settrace.\n\
422 See the debugger chapter in the library manual."
425 static PyObject *
426 sys_setprofile(PyObject *self, PyObject *args)
428 if (trace_init() == -1)
429 return NULL;
430 if (args == Py_None)
431 PyEval_SetProfile(NULL, NULL);
432 else
433 PyEval_SetProfile(profile_trampoline, args);
434 Py_INCREF(Py_None);
435 return Py_None;
438 PyDoc_STRVAR(setprofile_doc,
439 "setprofile(function)\n\
441 Set the profiling function. It will be called on each function call\n\
442 and return. See the profiler chapter in the library manual."
445 static PyObject *
446 sys_getprofile(PyObject *self, PyObject *args)
448 PyThreadState *tstate = PyThreadState_GET();
449 PyObject *temp = tstate->c_profileobj;
451 if (temp == NULL)
452 temp = Py_None;
453 Py_INCREF(temp);
454 return temp;
457 PyDoc_STRVAR(getprofile_doc,
458 "getprofile()\n\
460 Return the profiling function set with sys.setprofile.\n\
461 See the profiler chapter in the library manual."
464 static PyObject *
465 sys_setcheckinterval(PyObject *self, PyObject *args)
467 if (!PyArg_ParseTuple(args, "i:setcheckinterval", &_Py_CheckInterval))
468 return NULL;
469 Py_INCREF(Py_None);
470 return Py_None;
473 PyDoc_STRVAR(setcheckinterval_doc,
474 "setcheckinterval(n)\n\
476 Tell the Python interpreter to check for asynchronous events every\n\
477 n instructions. This also affects how often thread switches occur."
480 static PyObject *
481 sys_getcheckinterval(PyObject *self, PyObject *args)
483 return PyInt_FromLong(_Py_CheckInterval);
486 PyDoc_STRVAR(getcheckinterval_doc,
487 "getcheckinterval() -> current check interval; see setcheckinterval()."
490 #ifdef WITH_TSC
491 static PyObject *
492 sys_settscdump(PyObject *self, PyObject *args)
494 int bool;
495 PyThreadState *tstate = PyThreadState_Get();
497 if (!PyArg_ParseTuple(args, "i:settscdump", &bool))
498 return NULL;
499 if (bool)
500 tstate->interp->tscdump = 1;
501 else
502 tstate->interp->tscdump = 0;
503 Py_INCREF(Py_None);
504 return Py_None;
508 PyDoc_STRVAR(settscdump_doc,
509 "settscdump(bool)\n\
511 If true, tell the Python interpreter to dump VM measurements to\n\
512 stderr. If false, turn off dump. The measurements are based on the\n\
513 processor's time-stamp counter."
515 #endif /* TSC */
517 static PyObject *
518 sys_setrecursionlimit(PyObject *self, PyObject *args)
520 int new_limit;
521 if (!PyArg_ParseTuple(args, "i:setrecursionlimit", &new_limit))
522 return NULL;
523 if (new_limit <= 0) {
524 PyErr_SetString(PyExc_ValueError,
525 "recursion limit must be positive");
526 return NULL;
528 Py_SetRecursionLimit(new_limit);
529 Py_INCREF(Py_None);
530 return Py_None;
533 PyDoc_STRVAR(setrecursionlimit_doc,
534 "setrecursionlimit(n)\n\
536 Set the maximum depth of the Python interpreter stack to n. This\n\
537 limit prevents infinite recursion from causing an overflow of the C\n\
538 stack and crashing Python. The highest possible limit is platform-\n\
539 dependent."
542 static PyObject *
543 sys_getrecursionlimit(PyObject *self)
545 return PyInt_FromLong(Py_GetRecursionLimit());
548 PyDoc_STRVAR(getrecursionlimit_doc,
549 "getrecursionlimit()\n\
551 Return the current value of the recursion limit, the maximum depth\n\
552 of the Python interpreter stack. This limit prevents infinite\n\
553 recursion from causing an overflow of the C stack and crashing Python."
556 #ifdef MS_WINDOWS
557 PyDoc_STRVAR(getwindowsversion_doc,
558 "getwindowsversion()\n\
560 Return information about the running version of Windows as a named tuple.\n\
561 The members are named: major, minor, build, platform, service_pack,\n\
562 service_pack_major, service_pack_minor, suite_mask, and product_type. For\n\
563 backward compatibiliy, only the first 5 items are available by indexing.\n\
564 All elements are numbers, except service_pack which is a string. Platform\n\
565 may be 0 for win32s, 1 for Windows 9x/ME, 2 for Windows NT/2000/XP/Vista/7,\n\
566 3 for Windows CE. Product_type may be 1 for a workstation, 2 for a domain\n\
567 controller, 3 for a server."
570 static PyTypeObject WindowsVersionType = {0, 0, 0, 0, 0, 0};
572 static PyStructSequence_Field windows_version_fields[] = {
573 {"major", "Major version number"},
574 {"minor", "Minor version number"},
575 {"build", "Build number"},
576 {"platform", "Operating system platform"},
577 {"service_pack", "Latest Service Pack installed on the system"},
578 {"service_pack_major", "Service Pack major version number"},
579 {"service_pack_minor", "Service Pack minor version number"},
580 {"suite_mask", "Bit mask identifying available product suites"},
581 {"product_type", "System product type"},
585 static PyStructSequence_Desc windows_version_desc = {
586 "sys.getwindowsversion", /* name */
587 getwindowsversion_doc, /* doc */
588 windows_version_fields, /* fields */
589 5 /* For backward compatibility,
590 only the first 5 items are accessible
591 via indexing, the rest are name only */
594 static PyObject *
595 sys_getwindowsversion(PyObject *self)
597 PyObject *version;
598 int pos = 0;
599 OSVERSIONINFOEX ver;
600 ver.dwOSVersionInfoSize = sizeof(ver);
601 if (!GetVersionEx((OSVERSIONINFO*) &ver))
602 return PyErr_SetFromWindowsErr(0);
604 version = PyStructSequence_New(&WindowsVersionType);
605 if (version == NULL)
606 return NULL;
608 PyStructSequence_SET_ITEM(version, pos++, PyInt_FromLong(ver.dwMajorVersion));
609 PyStructSequence_SET_ITEM(version, pos++, PyInt_FromLong(ver.dwMinorVersion));
610 PyStructSequence_SET_ITEM(version, pos++, PyInt_FromLong(ver.dwBuildNumber));
611 PyStructSequence_SET_ITEM(version, pos++, PyInt_FromLong(ver.dwPlatformId));
612 PyStructSequence_SET_ITEM(version, pos++, PyString_FromString(ver.szCSDVersion));
613 PyStructSequence_SET_ITEM(version, pos++, PyInt_FromLong(ver.wServicePackMajor));
614 PyStructSequence_SET_ITEM(version, pos++, PyInt_FromLong(ver.wServicePackMinor));
615 PyStructSequence_SET_ITEM(version, pos++, PyInt_FromLong(ver.wSuiteMask));
616 PyStructSequence_SET_ITEM(version, pos++, PyInt_FromLong(ver.wProductType));
618 return version;
621 #endif /* MS_WINDOWS */
623 #ifdef HAVE_DLOPEN
624 static PyObject *
625 sys_setdlopenflags(PyObject *self, PyObject *args)
627 int new_val;
628 PyThreadState *tstate = PyThreadState_GET();
629 if (!PyArg_ParseTuple(args, "i:setdlopenflags", &new_val))
630 return NULL;
631 if (!tstate)
632 return NULL;
633 tstate->interp->dlopenflags = new_val;
634 Py_INCREF(Py_None);
635 return Py_None;
638 PyDoc_STRVAR(setdlopenflags_doc,
639 "setdlopenflags(n) -> None\n\
641 Set the flags used by the interpreter for dlopen calls, such as when the\n\
642 interpreter loads extension modules. Among other things, this will enable\n\
643 a lazy resolving of symbols when importing a module, if called as\n\
644 sys.setdlopenflags(0). To share symbols across extension modules, call as\n\
645 sys.setdlopenflags(ctypes.RTLD_GLOBAL). Symbolic names for the flag modules\n\
646 can be either found in the ctypes module, or in the DLFCN module. If DLFCN\n\
647 is not available, it can be generated from /usr/include/dlfcn.h using the\n\
648 h2py script.");
650 static PyObject *
651 sys_getdlopenflags(PyObject *self, PyObject *args)
653 PyThreadState *tstate = PyThreadState_GET();
654 if (!tstate)
655 return NULL;
656 return PyInt_FromLong(tstate->interp->dlopenflags);
659 PyDoc_STRVAR(getdlopenflags_doc,
660 "getdlopenflags() -> int\n\
662 Return the current value of the flags that are used for dlopen calls.\n\
663 The flag constants are defined in the ctypes and DLFCN modules.");
665 #endif /* HAVE_DLOPEN */
667 #ifdef USE_MALLOPT
668 /* Link with -lmalloc (or -lmpc) on an SGI */
669 #include <malloc.h>
671 static PyObject *
672 sys_mdebug(PyObject *self, PyObject *args)
674 int flag;
675 if (!PyArg_ParseTuple(args, "i:mdebug", &flag))
676 return NULL;
677 mallopt(M_DEBUG, flag);
678 Py_INCREF(Py_None);
679 return Py_None;
681 #endif /* USE_MALLOPT */
683 static PyObject *
684 sys_getsizeof(PyObject *self, PyObject *args, PyObject *kwds)
686 PyObject *res = NULL;
687 static PyObject *str__sizeof__ = NULL, *gc_head_size = NULL;
688 static char *kwlist[] = {"object", "default", 0};
689 PyObject *o, *dflt = NULL;
691 if (!PyArg_ParseTupleAndKeywords(args, kwds, "O|O:getsizeof",
692 kwlist, &o, &dflt))
693 return NULL;
695 /* Initialize static variable for GC head size */
696 if (gc_head_size == NULL) {
697 gc_head_size = PyInt_FromSsize_t(sizeof(PyGC_Head));
698 if (gc_head_size == NULL)
699 return NULL;
702 /* Make sure the type is initialized. float gets initialized late */
703 if (PyType_Ready(Py_TYPE(o)) < 0)
704 return NULL;
706 /* Instance of old-style class */
707 if (PyInstance_Check(o))
708 res = PyInt_FromSsize_t(PyInstance_Type.tp_basicsize);
709 /* all other objects */
710 else {
711 PyObject *method = _PyObject_LookupSpecial(o, "__sizeof__",
712 &str__sizeof__);
713 if (method == NULL) {
714 if (!PyErr_Occurred())
715 PyErr_Format(PyExc_TypeError,
716 "Type %.100s doesn't define __sizeof__",
717 Py_TYPE(o)->tp_name);
719 else {
720 res = PyObject_CallFunctionObjArgs(method, NULL);
721 Py_DECREF(method);
725 /* Has a default value been given? */
726 if ((res == NULL) && (dflt != NULL) &&
727 PyErr_ExceptionMatches(PyExc_TypeError))
729 PyErr_Clear();
730 Py_INCREF(dflt);
731 return dflt;
733 else if (res == NULL)
734 return res;
736 /* add gc_head size */
737 if (PyObject_IS_GC(o)) {
738 PyObject *tmp = res;
739 res = PyNumber_Add(tmp, gc_head_size);
740 Py_DECREF(tmp);
742 return res;
745 PyDoc_STRVAR(getsizeof_doc,
746 "getsizeof(object, default) -> int\n\
748 Return the size of object in bytes.");
750 static PyObject *
751 sys_getrefcount(PyObject *self, PyObject *arg)
753 return PyInt_FromSsize_t(arg->ob_refcnt);
756 #ifdef Py_REF_DEBUG
757 static PyObject *
758 sys_gettotalrefcount(PyObject *self)
760 return PyInt_FromSsize_t(_Py_GetRefTotal());
762 #endif /* Py_REF_DEBUG */
764 PyDoc_STRVAR(getrefcount_doc,
765 "getrefcount(object) -> integer\n\
767 Return the reference count of object. The count returned is generally\n\
768 one higher than you might expect, because it includes the (temporary)\n\
769 reference as an argument to getrefcount()."
772 #ifdef COUNT_ALLOCS
773 static PyObject *
774 sys_getcounts(PyObject *self)
776 extern PyObject *get_counts(void);
778 return get_counts();
780 #endif
782 PyDoc_STRVAR(getframe_doc,
783 "_getframe([depth]) -> frameobject\n\
785 Return a frame object from the call stack. If optional integer depth is\n\
786 given, return the frame object that many calls below the top of the stack.\n\
787 If that is deeper than the call stack, ValueError is raised. The default\n\
788 for depth is zero, returning the frame at the top of the call stack.\n\
790 This function should be used for internal and specialized\n\
791 purposes only."
794 static PyObject *
795 sys_getframe(PyObject *self, PyObject *args)
797 PyFrameObject *f = PyThreadState_GET()->frame;
798 int depth = -1;
800 if (!PyArg_ParseTuple(args, "|i:_getframe", &depth))
801 return NULL;
803 while (depth > 0 && f != NULL) {
804 f = f->f_back;
805 --depth;
807 if (f == NULL) {
808 PyErr_SetString(PyExc_ValueError,
809 "call stack is not deep enough");
810 return NULL;
812 Py_INCREF(f);
813 return (PyObject*)f;
816 PyDoc_STRVAR(current_frames_doc,
817 "_current_frames() -> dictionary\n\
819 Return a dictionary mapping each current thread T's thread id to T's\n\
820 current stack frame.\n\
822 This function should be used for specialized purposes only."
825 static PyObject *
826 sys_current_frames(PyObject *self, PyObject *noargs)
828 return _PyThread_CurrentFrames();
831 PyDoc_STRVAR(call_tracing_doc,
832 "call_tracing(func, args) -> object\n\
834 Call func(*args), while tracing is enabled. The tracing state is\n\
835 saved, and restored afterwards. This is intended to be called from\n\
836 a debugger from a checkpoint, to recursively debug some other code."
839 static PyObject *
840 sys_call_tracing(PyObject *self, PyObject *args)
842 PyObject *func, *funcargs;
843 if (!PyArg_ParseTuple(args, "OO!:call_tracing", &func, &PyTuple_Type, &funcargs))
844 return NULL;
845 return _PyEval_CallTracing(func, funcargs);
848 PyDoc_STRVAR(callstats_doc,
849 "callstats() -> tuple of integers\n\
851 Return a tuple of function call statistics, if CALL_PROFILE was defined\n\
852 when Python was built. Otherwise, return None.\n\
854 When enabled, this function returns detailed, implementation-specific\n\
855 details about the number of function calls executed. The return value is\n\
856 a 11-tuple where the entries in the tuple are counts of:\n\
857 0. all function calls\n\
858 1. calls to PyFunction_Type objects\n\
859 2. PyFunction calls that do not create an argument tuple\n\
860 3. PyFunction calls that do not create an argument tuple\n\
861 and bypass PyEval_EvalCodeEx()\n\
862 4. PyMethod calls\n\
863 5. PyMethod calls on bound methods\n\
864 6. PyType calls\n\
865 7. PyCFunction calls\n\
866 8. generator calls\n\
867 9. All other calls\n\
868 10. Number of stack pops performed by call_function()"
871 #ifdef __cplusplus
872 extern "C" {
873 #endif
875 #ifdef Py_TRACE_REFS
876 /* Defined in objects.c because it uses static globals if that file */
877 extern PyObject *_Py_GetObjects(PyObject *, PyObject *);
878 #endif
880 #ifdef DYNAMIC_EXECUTION_PROFILE
881 /* Defined in ceval.c because it uses static globals if that file */
882 extern PyObject *_Py_GetDXProfile(PyObject *, PyObject *);
883 #endif
885 #ifdef __cplusplus
887 #endif
889 static PyObject *
890 sys_clear_type_cache(PyObject* self, PyObject* args)
892 PyType_ClearCache();
893 Py_RETURN_NONE;
896 PyDoc_STRVAR(sys_clear_type_cache__doc__,
897 "_clear_type_cache() -> None\n\
898 Clear the internal type lookup cache.");
901 static PyMethodDef sys_methods[] = {
902 /* Might as well keep this in alphabetic order */
903 {"callstats", (PyCFunction)PyEval_GetCallStats, METH_NOARGS,
904 callstats_doc},
905 {"_clear_type_cache", sys_clear_type_cache, METH_NOARGS,
906 sys_clear_type_cache__doc__},
907 {"_current_frames", sys_current_frames, METH_NOARGS,
908 current_frames_doc},
909 {"displayhook", sys_displayhook, METH_O, displayhook_doc},
910 {"exc_info", sys_exc_info, METH_NOARGS, exc_info_doc},
911 {"exc_clear", sys_exc_clear, METH_NOARGS, exc_clear_doc},
912 {"excepthook", sys_excepthook, METH_VARARGS, excepthook_doc},
913 {"exit", sys_exit, METH_VARARGS, exit_doc},
914 #ifdef Py_USING_UNICODE
915 {"getdefaultencoding", (PyCFunction)sys_getdefaultencoding,
916 METH_NOARGS, getdefaultencoding_doc},
917 #endif
918 #ifdef HAVE_DLOPEN
919 {"getdlopenflags", (PyCFunction)sys_getdlopenflags, METH_NOARGS,
920 getdlopenflags_doc},
921 #endif
922 #ifdef COUNT_ALLOCS
923 {"getcounts", (PyCFunction)sys_getcounts, METH_NOARGS},
924 #endif
925 #ifdef DYNAMIC_EXECUTION_PROFILE
926 {"getdxp", _Py_GetDXProfile, METH_VARARGS},
927 #endif
928 #ifdef Py_USING_UNICODE
929 {"getfilesystemencoding", (PyCFunction)sys_getfilesystemencoding,
930 METH_NOARGS, getfilesystemencoding_doc},
931 #endif
932 #ifdef Py_TRACE_REFS
933 {"getobjects", _Py_GetObjects, METH_VARARGS},
934 #endif
935 #ifdef Py_REF_DEBUG
936 {"gettotalrefcount", (PyCFunction)sys_gettotalrefcount, METH_NOARGS},
937 #endif
938 {"getrefcount", (PyCFunction)sys_getrefcount, METH_O, getrefcount_doc},
939 {"getrecursionlimit", (PyCFunction)sys_getrecursionlimit, METH_NOARGS,
940 getrecursionlimit_doc},
941 {"getsizeof", (PyCFunction)sys_getsizeof,
942 METH_VARARGS | METH_KEYWORDS, getsizeof_doc},
943 {"_getframe", sys_getframe, METH_VARARGS, getframe_doc},
944 #ifdef MS_WINDOWS
945 {"getwindowsversion", (PyCFunction)sys_getwindowsversion, METH_NOARGS,
946 getwindowsversion_doc},
947 #endif /* MS_WINDOWS */
948 #ifdef USE_MALLOPT
949 {"mdebug", sys_mdebug, METH_VARARGS},
950 #endif
951 #ifdef Py_USING_UNICODE
952 {"setdefaultencoding", sys_setdefaultencoding, METH_VARARGS,
953 setdefaultencoding_doc},
954 #endif
955 {"setcheckinterval", sys_setcheckinterval, METH_VARARGS,
956 setcheckinterval_doc},
957 {"getcheckinterval", sys_getcheckinterval, METH_NOARGS,
958 getcheckinterval_doc},
959 #ifdef HAVE_DLOPEN
960 {"setdlopenflags", sys_setdlopenflags, METH_VARARGS,
961 setdlopenflags_doc},
962 #endif
963 {"setprofile", sys_setprofile, METH_O, setprofile_doc},
964 {"getprofile", sys_getprofile, METH_NOARGS, getprofile_doc},
965 {"setrecursionlimit", sys_setrecursionlimit, METH_VARARGS,
966 setrecursionlimit_doc},
967 #ifdef WITH_TSC
968 {"settscdump", sys_settscdump, METH_VARARGS, settscdump_doc},
969 #endif
970 {"settrace", sys_settrace, METH_O, settrace_doc},
971 {"gettrace", sys_gettrace, METH_NOARGS, gettrace_doc},
972 {"call_tracing", sys_call_tracing, METH_VARARGS, call_tracing_doc},
973 {NULL, NULL} /* sentinel */
976 static PyObject *
977 list_builtin_module_names(void)
979 PyObject *list = PyList_New(0);
980 int i;
981 if (list == NULL)
982 return NULL;
983 for (i = 0; PyImport_Inittab[i].name != NULL; i++) {
984 PyObject *name = PyString_FromString(
985 PyImport_Inittab[i].name);
986 if (name == NULL)
987 break;
988 PyList_Append(list, name);
989 Py_DECREF(name);
991 if (PyList_Sort(list) != 0) {
992 Py_DECREF(list);
993 list = NULL;
995 if (list) {
996 PyObject *v = PyList_AsTuple(list);
997 Py_DECREF(list);
998 list = v;
1000 return list;
1003 static PyObject *warnoptions = NULL;
1005 void
1006 PySys_ResetWarnOptions(void)
1008 if (warnoptions == NULL || !PyList_Check(warnoptions))
1009 return;
1010 PyList_SetSlice(warnoptions, 0, PyList_GET_SIZE(warnoptions), NULL);
1013 void
1014 PySys_AddWarnOption(char *s)
1016 PyObject *str;
1018 if (warnoptions == NULL || !PyList_Check(warnoptions)) {
1019 Py_XDECREF(warnoptions);
1020 warnoptions = PyList_New(0);
1021 if (warnoptions == NULL)
1022 return;
1024 str = PyString_FromString(s);
1025 if (str != NULL) {
1026 PyList_Append(warnoptions, str);
1027 Py_DECREF(str);
1032 PySys_HasWarnOptions(void)
1034 return (warnoptions != NULL && (PyList_Size(warnoptions) > 0)) ? 1 : 0;
1037 /* XXX This doc string is too long to be a single string literal in VC++ 5.0.
1038 Two literals concatenated works just fine. If you have a K&R compiler
1039 or other abomination that however *does* understand longer strings,
1040 get rid of the !!! comment in the middle and the quotes that surround it. */
1041 PyDoc_VAR(sys_doc) =
1042 PyDoc_STR(
1043 "This module provides access to some objects used or maintained by the\n\
1044 interpreter and to functions that interact strongly with the interpreter.\n\
1046 Dynamic objects:\n\
1048 argv -- command line arguments; argv[0] is the script pathname if known\n\
1049 path -- module search path; path[0] is the script directory, else ''\n\
1050 modules -- dictionary of loaded modules\n\
1052 displayhook -- called to show results in an interactive session\n\
1053 excepthook -- called to handle any uncaught exception other than SystemExit\n\
1054 To customize printing in an interactive session or to install a custom\n\
1055 top-level exception handler, assign other functions to replace these.\n\
1057 exitfunc -- if sys.exitfunc exists, this routine is called when Python exits\n\
1058 Assigning to sys.exitfunc is deprecated; use the atexit module instead.\n\
1060 stdin -- standard input file object; used by raw_input() and input()\n\
1061 stdout -- standard output file object; used by the print statement\n\
1062 stderr -- standard error object; used for error messages\n\
1063 By assigning other file objects (or objects that behave like files)\n\
1064 to these, it is possible to redirect all of the interpreter's I/O.\n\
1066 last_type -- type of last uncaught exception\n\
1067 last_value -- value of last uncaught exception\n\
1068 last_traceback -- traceback of last uncaught exception\n\
1069 These three are only available in an interactive session after a\n\
1070 traceback has been printed.\n\
1072 exc_type -- type of exception currently being handled\n\
1073 exc_value -- value of exception currently being handled\n\
1074 exc_traceback -- traceback of exception currently being handled\n\
1075 The function exc_info() should be used instead of these three,\n\
1076 because it is thread-safe.\n\
1079 /* concatenating string here */
1080 PyDoc_STR(
1081 "\n\
1082 Static objects:\n\
1084 float_info -- a dict with information about the float inplementation.\n\
1085 long_info -- a struct sequence with information about the long implementation.\n\
1086 maxint -- the largest supported integer (the smallest is -maxint-1)\n\
1087 maxsize -- the largest supported length of containers.\n\
1088 maxunicode -- the largest supported character\n\
1089 builtin_module_names -- tuple of module names built into this interpreter\n\
1090 version -- the version of this interpreter as a string\n\
1091 version_info -- version information as a named tuple\n\
1092 hexversion -- version information encoded as a single integer\n\
1093 copyright -- copyright notice pertaining to this interpreter\n\
1094 platform -- platform identifier\n\
1095 executable -- pathname of this Python interpreter\n\
1096 prefix -- prefix used to find the Python library\n\
1097 exec_prefix -- prefix used to find the machine-specific Python library\n\
1098 float_repr_style -- string indicating the style of repr() output for floats\n\
1101 #ifdef MS_WINDOWS
1102 /* concatenating string here */
1103 PyDoc_STR(
1104 "dllhandle -- [Windows only] integer handle of the Python DLL\n\
1105 winver -- [Windows only] version number of the Python DLL\n\
1108 #endif /* MS_WINDOWS */
1109 PyDoc_STR(
1110 "__stdin__ -- the original stdin; don't touch!\n\
1111 __stdout__ -- the original stdout; don't touch!\n\
1112 __stderr__ -- the original stderr; don't touch!\n\
1113 __displayhook__ -- the original displayhook; don't touch!\n\
1114 __excepthook__ -- the original excepthook; don't touch!\n\
1116 Functions:\n\
1118 displayhook() -- print an object to the screen, and save it in __builtin__._\n\
1119 excepthook() -- print an exception and its traceback to sys.stderr\n\
1120 exc_info() -- return thread-safe information about the current exception\n\
1121 exc_clear() -- clear the exception state for the current thread\n\
1122 exit() -- exit the interpreter by raising SystemExit\n\
1123 getdlopenflags() -- returns flags to be used for dlopen() calls\n\
1124 getprofile() -- get the global profiling function\n\
1125 getrefcount() -- return the reference count for an object (plus one :-)\n\
1126 getrecursionlimit() -- return the max recursion depth for the interpreter\n\
1127 getsizeof() -- return the size of an object in bytes\n\
1128 gettrace() -- get the global debug tracing function\n\
1129 setcheckinterval() -- control how often the interpreter checks for events\n\
1130 setdlopenflags() -- set the flags to be used for dlopen() calls\n\
1131 setprofile() -- set the global profiling function\n\
1132 setrecursionlimit() -- set the max recursion depth for the interpreter\n\
1133 settrace() -- set the global debug tracing function\n\
1136 /* end of sys_doc */ ;
1138 static int
1139 _check_and_flush (FILE *stream)
1141 int prev_fail = ferror (stream);
1142 return fflush (stream) || prev_fail ? EOF : 0;
1145 /* Subversion branch and revision management */
1146 static const char _patchlevel_revision[] = PY_PATCHLEVEL_REVISION;
1147 static const char headurl[] = "$HeadURL$";
1148 static int svn_initialized;
1149 static char patchlevel_revision[50]; /* Just the number */
1150 static char branch[50];
1151 static char shortbranch[50];
1152 static const char *svn_revision;
1154 static void
1155 svnversion_init(void)
1157 const char *python, *br_start, *br_end, *br_end2, *svnversion;
1158 Py_ssize_t len;
1159 int istag;
1161 if (svn_initialized)
1162 return;
1164 python = strstr(headurl, "/python/");
1165 if (!python) {
1166 /* XXX quick hack to get bzr working */
1167 *patchlevel_revision = '\0';
1168 strcpy(branch, "");
1169 strcpy(shortbranch, "unknown");
1170 svn_revision = "";
1171 return;
1172 /* Py_FatalError("subversion keywords missing"); */
1175 br_start = python + 8;
1176 br_end = strchr(br_start, '/');
1177 assert(br_end);
1179 /* Works even for trunk,
1180 as we are in trunk/Python/sysmodule.c */
1181 br_end2 = strchr(br_end+1, '/');
1183 istag = strncmp(br_start, "tags", 4) == 0;
1184 if (strncmp(br_start, "trunk", 5) == 0) {
1185 strcpy(branch, "trunk");
1186 strcpy(shortbranch, "trunk");
1189 else if (istag || strncmp(br_start, "branches", 8) == 0) {
1190 len = br_end2 - br_start;
1191 strncpy(branch, br_start, len);
1192 branch[len] = '\0';
1194 len = br_end2 - (br_end + 1);
1195 strncpy(shortbranch, br_end + 1, len);
1196 shortbranch[len] = '\0';
1198 else {
1199 Py_FatalError("bad HeadURL");
1200 return;
1204 svnversion = _Py_svnversion();
1205 if (strcmp(svnversion, "Unversioned directory") != 0 && strcmp(svnversion, "exported") != 0)
1206 svn_revision = svnversion;
1207 else if (istag) {
1208 len = strlen(_patchlevel_revision);
1209 assert(len >= 13);
1210 assert(len < (sizeof(patchlevel_revision) + 13));
1211 strncpy(patchlevel_revision, _patchlevel_revision + 11,
1212 len - 13);
1213 patchlevel_revision[len - 13] = '\0';
1214 svn_revision = patchlevel_revision;
1216 else
1217 svn_revision = "";
1219 svn_initialized = 1;
1222 /* Return svnversion output if available.
1223 Else return Revision of patchlevel.h if on branch.
1224 Else return empty string */
1225 const char*
1226 Py_SubversionRevision()
1228 svnversion_init();
1229 return svn_revision;
1232 const char*
1233 Py_SubversionShortBranch()
1235 svnversion_init();
1236 return shortbranch;
1240 PyDoc_STRVAR(flags__doc__,
1241 "sys.flags\n\
1243 Flags provided through command line arguments or environment vars.");
1245 static PyTypeObject FlagsType = {0, 0, 0, 0, 0, 0};
1247 static PyStructSequence_Field flags_fields[] = {
1248 {"debug", "-d"},
1249 {"py3k_warning", "-3"},
1250 {"division_warning", "-Q"},
1251 {"division_new", "-Qnew"},
1252 {"inspect", "-i"},
1253 {"interactive", "-i"},
1254 {"optimize", "-O or -OO"},
1255 {"dont_write_bytecode", "-B"},
1256 {"no_user_site", "-s"},
1257 {"no_site", "-S"},
1258 {"ignore_environment", "-E"},
1259 {"tabcheck", "-t or -tt"},
1260 {"verbose", "-v"},
1261 #ifdef RISCOS
1262 {"riscos_wimp", "???"},
1263 #endif
1264 /* {"unbuffered", "-u"}, */
1265 {"unicode", "-U"},
1266 /* {"skip_first", "-x"}, */
1267 {"bytes_warning", "-b"},
1271 static PyStructSequence_Desc flags_desc = {
1272 "sys.flags", /* name */
1273 flags__doc__, /* doc */
1274 flags_fields, /* fields */
1275 #ifdef RISCOS
1277 #else
1279 #endif
1282 static PyObject*
1283 make_flags(void)
1285 int pos = 0;
1286 PyObject *seq;
1288 seq = PyStructSequence_New(&FlagsType);
1289 if (seq == NULL)
1290 return NULL;
1292 #define SetFlag(flag) \
1293 PyStructSequence_SET_ITEM(seq, pos++, PyInt_FromLong(flag))
1295 SetFlag(Py_DebugFlag);
1296 SetFlag(Py_Py3kWarningFlag);
1297 SetFlag(Py_DivisionWarningFlag);
1298 SetFlag(_Py_QnewFlag);
1299 SetFlag(Py_InspectFlag);
1300 SetFlag(Py_InteractiveFlag);
1301 SetFlag(Py_OptimizeFlag);
1302 SetFlag(Py_DontWriteBytecodeFlag);
1303 SetFlag(Py_NoUserSiteDirectory);
1304 SetFlag(Py_NoSiteFlag);
1305 SetFlag(Py_IgnoreEnvironmentFlag);
1306 SetFlag(Py_TabcheckFlag);
1307 SetFlag(Py_VerboseFlag);
1308 #ifdef RISCOS
1309 SetFlag(Py_RISCOSWimpFlag);
1310 #endif
1311 /* SetFlag(saw_unbuffered_flag); */
1312 SetFlag(Py_UnicodeFlag);
1313 /* SetFlag(skipfirstline); */
1314 SetFlag(Py_BytesWarningFlag);
1315 #undef SetFlag
1317 if (PyErr_Occurred()) {
1318 return NULL;
1320 return seq;
1323 PyDoc_STRVAR(version_info__doc__,
1324 "sys.version_info\n\
1326 Version information as a named tuple.");
1328 static PyTypeObject VersionInfoType = {0, 0, 0, 0, 0, 0};
1330 static PyStructSequence_Field version_info_fields[] = {
1331 {"major", "Major release number"},
1332 {"minor", "Minor release number"},
1333 {"micro", "Patch release number"},
1334 {"releaselevel", "'alpha', 'beta', 'candidate', or 'release'"},
1335 {"serial", "Serial release number"},
1339 static PyStructSequence_Desc version_info_desc = {
1340 "sys.version_info", /* name */
1341 version_info__doc__, /* doc */
1342 version_info_fields, /* fields */
1346 static PyObject *
1347 make_version_info(void)
1349 PyObject *version_info;
1350 char *s;
1351 int pos = 0;
1353 version_info = PyStructSequence_New(&VersionInfoType);
1354 if (version_info == NULL) {
1355 return NULL;
1359 * These release level checks are mutually exclusive and cover
1360 * the field, so don't get too fancy with the pre-processor!
1362 #if PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_ALPHA
1363 s = "alpha";
1364 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_BETA
1365 s = "beta";
1366 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_GAMMA
1367 s = "candidate";
1368 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_FINAL
1369 s = "final";
1370 #endif
1372 #define SetIntItem(flag) \
1373 PyStructSequence_SET_ITEM(version_info, pos++, PyInt_FromLong(flag))
1374 #define SetStrItem(flag) \
1375 PyStructSequence_SET_ITEM(version_info, pos++, PyString_FromString(flag))
1377 SetIntItem(PY_MAJOR_VERSION);
1378 SetIntItem(PY_MINOR_VERSION);
1379 SetIntItem(PY_MICRO_VERSION);
1380 SetStrItem(s);
1381 SetIntItem(PY_RELEASE_SERIAL);
1382 #undef SetIntItem
1383 #undef SetStrItem
1385 if (PyErr_Occurred()) {
1386 Py_CLEAR(version_info);
1387 return NULL;
1389 return version_info;
1392 PyObject *
1393 _PySys_Init(void)
1395 PyObject *m, *v, *sysdict;
1396 PyObject *sysin, *sysout, *syserr;
1397 char *s;
1399 m = Py_InitModule3("sys", sys_methods, sys_doc);
1400 if (m == NULL)
1401 return NULL;
1402 sysdict = PyModule_GetDict(m);
1403 #define SET_SYS_FROM_STRING(key, value) \
1404 v = value; \
1405 if (v != NULL) \
1406 PyDict_SetItemString(sysdict, key, v); \
1407 Py_XDECREF(v)
1409 /* Check that stdin is not a directory
1410 Using shell redirection, you can redirect stdin to a directory,
1411 crashing the Python interpreter. Catch this common mistake here
1412 and output a useful error message. Note that under MS Windows,
1413 the shell already prevents that. */
1414 #if !defined(MS_WINDOWS)
1416 struct stat sb;
1417 if (fstat(fileno(stdin), &sb) == 0 &&
1418 S_ISDIR(sb.st_mode)) {
1419 /* There's nothing more we can do. */
1420 /* Py_FatalError() will core dump, so just exit. */
1421 PySys_WriteStderr("Python error: <stdin> is a directory, cannot continue\n");
1422 exit(EXIT_FAILURE);
1425 #endif
1427 /* Closing the standard FILE* if sys.std* goes aways causes problems
1428 * for embedded Python usages. Closing them when somebody explicitly
1429 * invokes .close() might be possible, but the FAQ promises they get
1430 * never closed. However, we still need to get write errors when
1431 * writing fails (e.g. because stdout is redirected), so we flush the
1432 * streams and check for errors before the file objects are deleted.
1433 * On OS X, fflush()ing stdin causes an error, so we exempt stdin
1434 * from that procedure.
1436 sysin = PyFile_FromFile(stdin, "<stdin>", "r", NULL);
1437 sysout = PyFile_FromFile(stdout, "<stdout>", "w", _check_and_flush);
1438 syserr = PyFile_FromFile(stderr, "<stderr>", "w", _check_and_flush);
1439 if (PyErr_Occurred())
1440 return NULL;
1442 PyDict_SetItemString(sysdict, "stdin", sysin);
1443 PyDict_SetItemString(sysdict, "stdout", sysout);
1444 PyDict_SetItemString(sysdict, "stderr", syserr);
1445 /* Make backup copies for cleanup */
1446 PyDict_SetItemString(sysdict, "__stdin__", sysin);
1447 PyDict_SetItemString(sysdict, "__stdout__", sysout);
1448 PyDict_SetItemString(sysdict, "__stderr__", syserr);
1449 PyDict_SetItemString(sysdict, "__displayhook__",
1450 PyDict_GetItemString(sysdict, "displayhook"));
1451 PyDict_SetItemString(sysdict, "__excepthook__",
1452 PyDict_GetItemString(sysdict, "excepthook"));
1453 Py_XDECREF(sysin);
1454 Py_XDECREF(sysout);
1455 Py_XDECREF(syserr);
1457 SET_SYS_FROM_STRING("version",
1458 PyString_FromString(Py_GetVersion()));
1459 SET_SYS_FROM_STRING("hexversion",
1460 PyInt_FromLong(PY_VERSION_HEX));
1461 svnversion_init();
1462 SET_SYS_FROM_STRING("subversion",
1463 Py_BuildValue("(ssz)", "CPython", branch,
1464 svn_revision));
1465 SET_SYS_FROM_STRING("dont_write_bytecode",
1466 PyBool_FromLong(Py_DontWriteBytecodeFlag));
1467 SET_SYS_FROM_STRING("api_version",
1468 PyInt_FromLong(PYTHON_API_VERSION));
1469 SET_SYS_FROM_STRING("copyright",
1470 PyString_FromString(Py_GetCopyright()));
1471 SET_SYS_FROM_STRING("platform",
1472 PyString_FromString(Py_GetPlatform()));
1473 SET_SYS_FROM_STRING("executable",
1474 PyString_FromString(Py_GetProgramFullPath()));
1475 SET_SYS_FROM_STRING("prefix",
1476 PyString_FromString(Py_GetPrefix()));
1477 SET_SYS_FROM_STRING("exec_prefix",
1478 PyString_FromString(Py_GetExecPrefix()));
1479 SET_SYS_FROM_STRING("maxsize",
1480 PyInt_FromSsize_t(PY_SSIZE_T_MAX));
1481 SET_SYS_FROM_STRING("maxint",
1482 PyInt_FromLong(PyInt_GetMax()));
1483 SET_SYS_FROM_STRING("py3kwarning",
1484 PyBool_FromLong(Py_Py3kWarningFlag));
1485 SET_SYS_FROM_STRING("float_info",
1486 PyFloat_GetInfo());
1487 SET_SYS_FROM_STRING("long_info",
1488 PyLong_GetInfo());
1489 #ifdef Py_USING_UNICODE
1490 SET_SYS_FROM_STRING("maxunicode",
1491 PyInt_FromLong(PyUnicode_GetMax()));
1492 #endif
1493 SET_SYS_FROM_STRING("builtin_module_names",
1494 list_builtin_module_names());
1496 /* Assumes that longs are at least 2 bytes long.
1497 Should be safe! */
1498 unsigned long number = 1;
1499 char *value;
1501 s = (char *) &number;
1502 if (s[0] == 0)
1503 value = "big";
1504 else
1505 value = "little";
1506 SET_SYS_FROM_STRING("byteorder",
1507 PyString_FromString(value));
1509 #ifdef MS_COREDLL
1510 SET_SYS_FROM_STRING("dllhandle",
1511 PyLong_FromVoidPtr(PyWin_DLLhModule));
1512 SET_SYS_FROM_STRING("winver",
1513 PyString_FromString(PyWin_DLLVersionString));
1514 #endif
1515 if (warnoptions == NULL) {
1516 warnoptions = PyList_New(0);
1518 else {
1519 Py_INCREF(warnoptions);
1521 if (warnoptions != NULL) {
1522 PyDict_SetItemString(sysdict, "warnoptions", warnoptions);
1525 /* version_info */
1526 if (VersionInfoType.tp_name == 0)
1527 PyStructSequence_InitType(&VersionInfoType, &version_info_desc);
1528 SET_SYS_FROM_STRING("version_info", make_version_info());
1529 /* prevent user from creating new instances */
1530 VersionInfoType.tp_init = NULL;
1531 VersionInfoType.tp_new = NULL;
1533 /* flags */
1534 if (FlagsType.tp_name == 0)
1535 PyStructSequence_InitType(&FlagsType, &flags_desc);
1536 SET_SYS_FROM_STRING("flags", make_flags());
1537 /* prevent user from creating new instances */
1538 FlagsType.tp_init = NULL;
1539 FlagsType.tp_new = NULL;
1542 #if defined(MS_WINDOWS)
1543 /* getwindowsversion */
1544 if (WindowsVersionType.tp_name == 0)
1545 PyStructSequence_InitType(&WindowsVersionType, &windows_version_desc);
1546 /* prevent user from creating new instances */
1547 WindowsVersionType.tp_init = NULL;
1548 WindowsVersionType.tp_new = NULL;
1549 #endif
1551 /* float repr style: 0.03 (short) vs 0.029999999999999999 (legacy) */
1552 #ifndef PY_NO_SHORT_FLOAT_REPR
1553 SET_SYS_FROM_STRING("float_repr_style",
1554 PyString_FromString("short"));
1555 #else
1556 SET_SYS_FROM_STRING("float_repr_style",
1557 PyString_FromString("legacy"));
1558 #endif
1560 #undef SET_SYS_FROM_STRING
1561 if (PyErr_Occurred())
1562 return NULL;
1563 return m;
1566 static PyObject *
1567 makepathobject(char *path, int delim)
1569 int i, n;
1570 char *p;
1571 PyObject *v, *w;
1573 n = 1;
1574 p = path;
1575 while ((p = strchr(p, delim)) != NULL) {
1576 n++;
1577 p++;
1579 v = PyList_New(n);
1580 if (v == NULL)
1581 return NULL;
1582 for (i = 0; ; i++) {
1583 p = strchr(path, delim);
1584 if (p == NULL)
1585 p = strchr(path, '\0'); /* End of string */
1586 w = PyString_FromStringAndSize(path, (Py_ssize_t) (p - path));
1587 if (w == NULL) {
1588 Py_DECREF(v);
1589 return NULL;
1591 PyList_SetItem(v, i, w);
1592 if (*p == '\0')
1593 break;
1594 path = p+1;
1596 return v;
1599 void
1600 PySys_SetPath(char *path)
1602 PyObject *v;
1603 if ((v = makepathobject(path, DELIM)) == NULL)
1604 Py_FatalError("can't create sys.path");
1605 if (PySys_SetObject("path", v) != 0)
1606 Py_FatalError("can't assign sys.path");
1607 Py_DECREF(v);
1610 static PyObject *
1611 makeargvobject(int argc, char **argv)
1613 PyObject *av;
1614 if (argc <= 0 || argv == NULL) {
1615 /* Ensure at least one (empty) argument is seen */
1616 static char *empty_argv[1] = {""};
1617 argv = empty_argv;
1618 argc = 1;
1620 av = PyList_New(argc);
1621 if (av != NULL) {
1622 int i;
1623 for (i = 0; i < argc; i++) {
1624 #ifdef __VMS
1625 PyObject *v;
1627 /* argv[0] is the script pathname if known */
1628 if (i == 0) {
1629 char* fn = decc$translate_vms(argv[0]);
1630 if ((fn == (char *)0) || fn == (char *)-1)
1631 v = PyString_FromString(argv[0]);
1632 else
1633 v = PyString_FromString(
1634 decc$translate_vms(argv[0]));
1635 } else
1636 v = PyString_FromString(argv[i]);
1637 #else
1638 PyObject *v = PyString_FromString(argv[i]);
1639 #endif
1640 if (v == NULL) {
1641 Py_DECREF(av);
1642 av = NULL;
1643 break;
1645 PyList_SetItem(av, i, v);
1648 return av;
1651 void
1652 PySys_SetArgvEx(int argc, char **argv, int updatepath)
1654 #if defined(HAVE_REALPATH)
1655 char fullpath[MAXPATHLEN];
1656 #elif defined(MS_WINDOWS) && !defined(MS_WINCE)
1657 char fullpath[MAX_PATH];
1658 #endif
1659 PyObject *av = makeargvobject(argc, argv);
1660 PyObject *path = PySys_GetObject("path");
1661 if (av == NULL)
1662 Py_FatalError("no mem for sys.argv");
1663 if (PySys_SetObject("argv", av) != 0)
1664 Py_FatalError("can't assign sys.argv");
1665 if (updatepath && path != NULL) {
1666 char *argv0 = argv[0];
1667 char *p = NULL;
1668 Py_ssize_t n = 0;
1669 PyObject *a;
1670 #ifdef HAVE_READLINK
1671 char link[MAXPATHLEN+1];
1672 char argv0copy[2*MAXPATHLEN+1];
1673 int nr = 0;
1674 if (argc > 0 && argv0 != NULL && strcmp(argv0, "-c") != 0)
1675 nr = readlink(argv0, link, MAXPATHLEN);
1676 if (nr > 0) {
1677 /* It's a symlink */
1678 link[nr] = '\0';
1679 if (link[0] == SEP)
1680 argv0 = link; /* Link to absolute path */
1681 else if (strchr(link, SEP) == NULL)
1682 ; /* Link without path */
1683 else {
1684 /* Must join(dirname(argv0), link) */
1685 char *q = strrchr(argv0, SEP);
1686 if (q == NULL)
1687 argv0 = link; /* argv0 without path */
1688 else {
1689 /* Must make a copy */
1690 strcpy(argv0copy, argv0);
1691 q = strrchr(argv0copy, SEP);
1692 strcpy(q+1, link);
1693 argv0 = argv0copy;
1697 #endif /* HAVE_READLINK */
1698 #if SEP == '\\' /* Special case for MS filename syntax */
1699 if (argc > 0 && argv0 != NULL && strcmp(argv0, "-c") != 0) {
1700 char *q;
1701 #if defined(MS_WINDOWS) && !defined(MS_WINCE)
1702 /* This code here replaces the first element in argv with the full
1703 path that it represents. Under CE, there are no relative paths so
1704 the argument must be the full path anyway. */
1705 char *ptemp;
1706 if (GetFullPathName(argv0,
1707 sizeof(fullpath),
1708 fullpath,
1709 &ptemp)) {
1710 argv0 = fullpath;
1712 #endif
1713 p = strrchr(argv0, SEP);
1714 /* Test for alternate separator */
1715 q = strrchr(p ? p : argv0, '/');
1716 if (q != NULL)
1717 p = q;
1718 if (p != NULL) {
1719 n = p + 1 - argv0;
1720 if (n > 1 && p[-1] != ':')
1721 n--; /* Drop trailing separator */
1724 #else /* All other filename syntaxes */
1725 if (argc > 0 && argv0 != NULL && strcmp(argv0, "-c") != 0) {
1726 #if defined(HAVE_REALPATH)
1727 if (realpath(argv0, fullpath)) {
1728 argv0 = fullpath;
1730 #endif
1731 p = strrchr(argv0, SEP);
1733 if (p != NULL) {
1734 #ifndef RISCOS
1735 n = p + 1 - argv0;
1736 #else /* don't include trailing separator */
1737 n = p - argv0;
1738 #endif /* RISCOS */
1739 #if SEP == '/' /* Special case for Unix filename syntax */
1740 if (n > 1)
1741 n--; /* Drop trailing separator */
1742 #endif /* Unix */
1744 #endif /* All others */
1745 a = PyString_FromStringAndSize(argv0, n);
1746 if (a == NULL)
1747 Py_FatalError("no mem for sys.path insertion");
1748 if (PyList_Insert(path, 0, a) < 0)
1749 Py_FatalError("sys.path.insert(0) failed");
1750 Py_DECREF(a);
1752 Py_DECREF(av);
1755 void
1756 PySys_SetArgv(int argc, char **argv)
1758 PySys_SetArgvEx(argc, argv, 1);
1762 /* APIs to write to sys.stdout or sys.stderr using a printf-like interface.
1763 Adapted from code submitted by Just van Rossum.
1765 PySys_WriteStdout(format, ...)
1766 PySys_WriteStderr(format, ...)
1768 The first function writes to sys.stdout; the second to sys.stderr. When
1769 there is a problem, they write to the real (C level) stdout or stderr;
1770 no exceptions are raised.
1772 Both take a printf-style format string as their first argument followed
1773 by a variable length argument list determined by the format string.
1775 *** WARNING ***
1777 The format should limit the total size of the formatted output string to
1778 1000 bytes. In particular, this means that no unrestricted "%s" formats
1779 should occur; these should be limited using "%.<N>s where <N> is a
1780 decimal number calculated so that <N> plus the maximum size of other
1781 formatted text does not exceed 1000 bytes. Also watch out for "%f",
1782 which can print hundreds of digits for very large numbers.
1786 static void
1787 mywrite(char *name, FILE *fp, const char *format, va_list va)
1789 PyObject *file;
1790 PyObject *error_type, *error_value, *error_traceback;
1792 PyErr_Fetch(&error_type, &error_value, &error_traceback);
1793 file = PySys_GetObject(name);
1794 if (file == NULL || PyFile_AsFile(file) == fp)
1795 vfprintf(fp, format, va);
1796 else {
1797 char buffer[1001];
1798 const int written = PyOS_vsnprintf(buffer, sizeof(buffer),
1799 format, va);
1800 if (PyFile_WriteString(buffer, file) != 0) {
1801 PyErr_Clear();
1802 fputs(buffer, fp);
1804 if (written < 0 || (size_t)written >= sizeof(buffer)) {
1805 const char *truncated = "... truncated";
1806 if (PyFile_WriteString(truncated, file) != 0) {
1807 PyErr_Clear();
1808 fputs(truncated, fp);
1812 PyErr_Restore(error_type, error_value, error_traceback);
1815 void
1816 PySys_WriteStdout(const char *format, ...)
1818 va_list va;
1820 va_start(va, format);
1821 mywrite("stdout", stdout, format, va);
1822 va_end(va);
1825 void
1826 PySys_WriteStderr(const char *format, ...)
1828 va_list va;
1830 va_start(va, format);
1831 mywrite("stderr", stderr, format, va);
1832 va_end(va);