5 Various bits of information used by the interpreter are collected in
8 - exit(sts): raise SystemExit
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)
18 #include "structseq.h"
20 #include "frameobject.h"
26 #define WIN32_LEAN_AND_MEAN
28 #endif /* MS_WINDOWS */
31 extern void *PyWin_DLLhModule
;
32 /* A string loaded from the DLL at startup: */
33 extern const char *PyWin_DLLVersionString
;
44 #ifdef HAVE_LANGINFO_H
50 PySys_GetObject(char *name
)
52 PyThreadState
*tstate
= PyThreadState_GET();
53 PyObject
*sd
= tstate
->interp
->sysdict
;
56 return PyDict_GetItemString(sd
, name
);
60 PySys_GetFile(char *name
, FILE *def
)
63 PyObject
*v
= PySys_GetObject(name
);
64 if (v
!= NULL
&& PyFile_Check(v
))
65 fp
= PyFile_AsFile(v
);
72 PySys_SetObject(char *name
, PyObject
*v
)
74 PyThreadState
*tstate
= PyThreadState_GET();
75 PyObject
*sd
= tstate
->interp
->sysdict
;
77 if (PyDict_GetItemString(sd
, name
) == NULL
)
80 return PyDict_DelItemString(sd
, name
);
83 return PyDict_SetItemString(sd
, name
, v
);
87 sys_displayhook(PyObject
*self
, PyObject
*o
)
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__");
99 /* Print value except if None */
100 /* After printing, also assign to '_' */
101 /* Before, set '_' to None to avoid recursion */
106 if (PyObject_SetAttrString(builtins
, "_", Py_None
) != 0)
108 if (Py_FlushLine() != 0)
110 outf
= PySys_GetObject("stdout");
112 PyErr_SetString(PyExc_RuntimeError
, "lost sys.stdout");
115 if (PyFile_WriteObject(o
, outf
, 0) != 0)
117 PyFile_SoftSpace(outf
, 1);
118 if (Py_FlushLine() != 0)
120 if (PyObject_SetAttrString(builtins
, "_", o
) != 0)
126 PyDoc_STRVAR(displayhook_doc
,
127 "displayhook(object) -> None\n"
129 "Print an object to sys.stdout and also save it in __builtin__.\n"
133 sys_excepthook(PyObject
* self
, PyObject
* args
)
135 PyObject
*exc
, *value
, *tb
;
136 if (!PyArg_UnpackTuple(args
, "excepthook", 3, 3, &exc
, &value
, &tb
))
138 PyErr_Display(exc
, value
, tb
);
143 PyDoc_STRVAR(excepthook_doc
,
144 "excepthook(exctype, value, traceback) -> None\n"
146 "Handle an exception by displaying it with a traceback on sys.stderr.\n"
150 sys_exc_info(PyObject
*self
, PyObject
*noargs
)
152 PyThreadState
*tstate
;
153 tstate
= PyThreadState_GET();
154 return Py_BuildValue(
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."
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)
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
);
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
);
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."
207 sys_exit(PyObject
*self
, PyObject
*args
)
209 PyObject
*exit_code
= 0;
210 if (!PyArg_UnpackTuple(args
, "exit", 0, 1, &exit_code
))
212 /* Raise SystemExit so callers may catch it or clean up. */
213 PyErr_SetObject(PyExc_SystemExit
, exit_code
);
217 PyDoc_STRVAR(exit_doc
,
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
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\
243 sys_setdefaultencoding(PyObject
*self
, PyObject
*args
)
246 if (!PyArg_ParseTuple(args
, "s:setdefaultencoding", &encoding
))
248 if (PyUnicode_SetDefaultEncoding(encoding
))
254 PyDoc_STRVAR(setdefaultencoding_doc
,
255 "setdefaultencoding(encoding)\n\
257 Set the current default string encoding used by the Unicode implementation."
261 sys_getfilesystemencoding(PyObject
*self
)
263 if (Py_FileSystemDefaultEncoding
)
264 return PyString_FromString(Py_FileSystemDefaultEncoding
);
269 PyDoc_STRVAR(getfilesystemencoding_doc
,
270 "getfilesystemencoding() -> string\n\
272 Return the encoding used to convert Unicode filenames in\n\
273 operating system filenames."
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
};
287 static char *whatnames
[7] = {"call", "exception", "line", "return",
288 "c_call", "c_exception", "c_return"};
291 for (i
= 0; i
< 7; ++i
) {
292 if (whatstrings
[i
] == NULL
) {
293 name
= PyString_InternFromString(whatnames
[i
]);
296 whatstrings
[i
] = name
;
304 call_trampoline(PyThreadState
*tstate
, PyObject
* callback
,
305 PyFrameObject
*frame
, int what
, PyObject
*arg
)
307 PyObject
*args
= PyTuple_New(3);
314 whatstr
= whatstrings
[what
];
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);
328 PyTraceBack_Here(frame
);
336 profile_trampoline(PyObject
*self
, PyFrameObject
*frame
,
337 int what
, PyObject
*arg
)
339 PyThreadState
*tstate
= frame
->f_tstate
;
344 result
= call_trampoline(tstate
, self
, frame
, what
, arg
);
345 if (result
== NULL
) {
346 PyEval_SetProfile(NULL
, NULL
);
354 trace_trampoline(PyObject
*self
, PyFrameObject
*frame
,
355 int what
, PyObject
*arg
)
357 PyThreadState
*tstate
= frame
->f_tstate
;
361 if (what
== PyTrace_CALL
)
364 callback
= frame
->f_trace
;
365 if (callback
== NULL
)
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
;
374 if (result
!= Py_None
) {
375 PyObject
*temp
= frame
->f_trace
;
376 frame
->f_trace
= NULL
;
378 frame
->f_trace
= result
;
387 sys_settrace(PyObject
*self
, PyObject
*args
)
389 if (trace_init() == -1)
392 PyEval_SetTrace(NULL
, NULL
);
394 PyEval_SetTrace(trace_trampoline
, args
);
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."
407 sys_gettrace(PyObject
*self
, PyObject
*args
)
409 PyThreadState
*tstate
= PyThreadState_GET();
410 PyObject
*temp
= tstate
->c_traceobj
;
418 PyDoc_STRVAR(gettrace_doc
,
421 Return the global debug tracing function set with sys.settrace.\n\
422 See the debugger chapter in the library manual."
426 sys_setprofile(PyObject
*self
, PyObject
*args
)
428 if (trace_init() == -1)
431 PyEval_SetProfile(NULL
, NULL
);
433 PyEval_SetProfile(profile_trampoline
, args
);
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."
446 sys_getprofile(PyObject
*self
, PyObject
*args
)
448 PyThreadState
*tstate
= PyThreadState_GET();
449 PyObject
*temp
= tstate
->c_profileobj
;
457 PyDoc_STRVAR(getprofile_doc
,
460 Return the profiling function set with sys.setprofile.\n\
461 See the profiler chapter in the library manual."
465 sys_setcheckinterval(PyObject
*self
, PyObject
*args
)
467 if (!PyArg_ParseTuple(args
, "i:setcheckinterval", &_Py_CheckInterval
))
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."
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()."
492 sys_settscdump(PyObject
*self
, PyObject
*args
)
495 PyThreadState
*tstate
= PyThreadState_Get();
497 if (!PyArg_ParseTuple(args
, "i:settscdump", &bool))
500 tstate
->interp
->tscdump
= 1;
502 tstate
->interp
->tscdump
= 0;
508 PyDoc_STRVAR(settscdump_doc
,
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."
518 sys_setrecursionlimit(PyObject
*self
, PyObject
*args
)
521 if (!PyArg_ParseTuple(args
, "i:setrecursionlimit", &new_limit
))
523 if (new_limit
<= 0) {
524 PyErr_SetString(PyExc_ValueError
,
525 "recursion limit must be positive");
528 Py_SetRecursionLimit(new_limit
);
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\
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."
557 PyDoc_STRVAR(getwindowsversion_doc
,
558 "getwindowsversion()\n\
560 Return information about the running version of Windows.\n\
561 The result is a tuple of (major, minor, build, platform, text)\n\
562 All elements are numbers, except text which is a string.\n\
563 Platform may be 0 for win32s, 1 for Windows 9x/ME, 2 for Windows NT/2000/XP\n\
568 sys_getwindowsversion(PyObject
*self
)
571 ver
.dwOSVersionInfoSize
= sizeof(ver
);
572 if (!GetVersionEx(&ver
))
573 return PyErr_SetFromWindowsErr(0);
574 return Py_BuildValue("HHHHs",
582 #endif /* MS_WINDOWS */
586 sys_setdlopenflags(PyObject
*self
, PyObject
*args
)
589 PyThreadState
*tstate
= PyThreadState_GET();
590 if (!PyArg_ParseTuple(args
, "i:setdlopenflags", &new_val
))
594 tstate
->interp
->dlopenflags
= new_val
;
599 PyDoc_STRVAR(setdlopenflags_doc
,
600 "setdlopenflags(n) -> None\n\
602 Set the flags used by the interpreter for dlopen calls, such as when the\n\
603 interpreter loads extension modules. Among other things, this will enable\n\
604 a lazy resolving of symbols when importing a module, if called as\n\
605 sys.setdlopenflags(0). To share symbols across extension modules, call as\n\
606 sys.setdlopenflags(ctypes.RTLD_GLOBAL). Symbolic names for the flag modules\n\
607 can be either found in the ctypes module, or in the DLFCN module. If DLFCN\n\
608 is not available, it can be generated from /usr/include/dlfcn.h using the\n\
612 sys_getdlopenflags(PyObject
*self
, PyObject
*args
)
614 PyThreadState
*tstate
= PyThreadState_GET();
617 return PyInt_FromLong(tstate
->interp
->dlopenflags
);
620 PyDoc_STRVAR(getdlopenflags_doc
,
621 "getdlopenflags() -> int\n\
623 Return the current value of the flags that are used for dlopen calls.\n\
624 The flag constants are defined in the ctypes and DLFCN modules.");
626 #endif /* HAVE_DLOPEN */
629 /* Link with -lmalloc (or -lmpc) on an SGI */
633 sys_mdebug(PyObject
*self
, PyObject
*args
)
636 if (!PyArg_ParseTuple(args
, "i:mdebug", &flag
))
638 mallopt(M_DEBUG
, flag
);
642 #endif /* USE_MALLOPT */
645 sys_getsizeof(PyObject
*self
, PyObject
*args
, PyObject
*kwds
)
647 PyObject
*res
= NULL
;
648 static PyObject
*str__sizeof__
= NULL
, *gc_head_size
= NULL
;
649 static char *kwlist
[] = {"object", "default", 0};
650 PyObject
*o
, *dflt
= NULL
;
652 if (!PyArg_ParseTupleAndKeywords(args
, kwds
, "O|O:getsizeof",
656 /* Initialize static variable for GC head size */
657 if (gc_head_size
== NULL
) {
658 gc_head_size
= PyInt_FromSsize_t(sizeof(PyGC_Head
));
659 if (gc_head_size
== NULL
)
663 /* Make sure the type is initialized. float gets initialized late */
664 if (PyType_Ready(Py_TYPE(o
)) < 0)
667 /* Instance of old-style class */
668 if (PyInstance_Check(o
))
669 res
= PyInt_FromSsize_t(PyInstance_Type
.tp_basicsize
);
670 /* all other objects */
672 PyObject
*method
= _PyObject_LookupSpecial(o
, "__sizeof__",
674 if (method
== NULL
) {
675 if (!PyErr_Occurred())
676 PyErr_Format(PyExc_TypeError
,
677 "Type %.100s doesn't define __sizeof__",
678 Py_TYPE(o
)->tp_name
);
681 res
= PyObject_CallFunctionObjArgs(method
, NULL
);
686 /* Has a default value been given? */
687 if ((res
== NULL
) && (dflt
!= NULL
) &&
688 PyErr_ExceptionMatches(PyExc_TypeError
))
694 else if (res
== NULL
)
697 /* add gc_head size */
698 if (PyObject_IS_GC(o
)) {
700 res
= PyNumber_Add(tmp
, gc_head_size
);
706 PyDoc_STRVAR(getsizeof_doc
,
707 "getsizeof(object, default) -> int\n\
709 Return the size of object in bytes.");
712 sys_getrefcount(PyObject
*self
, PyObject
*arg
)
714 return PyInt_FromSsize_t(arg
->ob_refcnt
);
719 sys_gettotalrefcount(PyObject
*self
)
721 return PyInt_FromSsize_t(_Py_GetRefTotal());
723 #endif /* Py_REF_DEBUG */
725 PyDoc_STRVAR(getrefcount_doc
,
726 "getrefcount(object) -> integer\n\
728 Return the reference count of object. The count returned is generally\n\
729 one higher than you might expect, because it includes the (temporary)\n\
730 reference as an argument to getrefcount()."
735 sys_getcounts(PyObject
*self
)
737 extern PyObject
*get_counts(void);
743 PyDoc_STRVAR(getframe_doc
,
744 "_getframe([depth]) -> frameobject\n\
746 Return a frame object from the call stack. If optional integer depth is\n\
747 given, return the frame object that many calls below the top of the stack.\n\
748 If that is deeper than the call stack, ValueError is raised. The default\n\
749 for depth is zero, returning the frame at the top of the call stack.\n\
751 This function should be used for internal and specialized\n\
756 sys_getframe(PyObject
*self
, PyObject
*args
)
758 PyFrameObject
*f
= PyThreadState_GET()->frame
;
761 if (!PyArg_ParseTuple(args
, "|i:_getframe", &depth
))
764 while (depth
> 0 && f
!= NULL
) {
769 PyErr_SetString(PyExc_ValueError
,
770 "call stack is not deep enough");
777 PyDoc_STRVAR(current_frames_doc
,
778 "_current_frames() -> dictionary\n\
780 Return a dictionary mapping each current thread T's thread id to T's\n\
781 current stack frame.\n\
783 This function should be used for specialized purposes only."
787 sys_current_frames(PyObject
*self
, PyObject
*noargs
)
789 return _PyThread_CurrentFrames();
792 PyDoc_STRVAR(call_tracing_doc
,
793 "call_tracing(func, args) -> object\n\
795 Call func(*args), while tracing is enabled. The tracing state is\n\
796 saved, and restored afterwards. This is intended to be called from\n\
797 a debugger from a checkpoint, to recursively debug some other code."
801 sys_call_tracing(PyObject
*self
, PyObject
*args
)
803 PyObject
*func
, *funcargs
;
804 if (!PyArg_UnpackTuple(args
, "call_tracing", 2, 2, &func
, &funcargs
))
806 return _PyEval_CallTracing(func
, funcargs
);
809 PyDoc_STRVAR(callstats_doc
,
810 "callstats() -> tuple of integers\n\
812 Return a tuple of function call statistics, if CALL_PROFILE was defined\n\
813 when Python was built. Otherwise, return None.\n\
815 When enabled, this function returns detailed, implementation-specific\n\
816 details about the number of function calls executed. The return value is\n\
817 a 11-tuple where the entries in the tuple are counts of:\n\
818 0. all function calls\n\
819 1. calls to PyFunction_Type objects\n\
820 2. PyFunction calls that do not create an argument tuple\n\
821 3. PyFunction calls that do not create an argument tuple\n\
822 and bypass PyEval_EvalCodeEx()\n\
824 5. PyMethod calls on bound methods\n\
826 7. PyCFunction calls\n\
827 8. generator calls\n\
828 9. All other calls\n\
829 10. Number of stack pops performed by call_function()"
837 /* Defined in objects.c because it uses static globals if that file */
838 extern PyObject
*_Py_GetObjects(PyObject
*, PyObject
*);
841 #ifdef DYNAMIC_EXECUTION_PROFILE
842 /* Defined in ceval.c because it uses static globals if that file */
843 extern PyObject
*_Py_GetDXProfile(PyObject
*, PyObject
*);
851 sys_clear_type_cache(PyObject
* self
, PyObject
* args
)
857 PyDoc_STRVAR(sys_clear_type_cache__doc__
,
858 "_clear_type_cache() -> None\n\
859 Clear the internal type lookup cache.");
862 static PyMethodDef sys_methods
[] = {
863 /* Might as well keep this in alphabetic order */
864 {"callstats", (PyCFunction
)PyEval_GetCallStats
, METH_NOARGS
,
866 {"_clear_type_cache", sys_clear_type_cache
, METH_NOARGS
,
867 sys_clear_type_cache__doc__
},
868 {"_current_frames", sys_current_frames
, METH_NOARGS
,
870 {"displayhook", sys_displayhook
, METH_O
, displayhook_doc
},
871 {"exc_info", sys_exc_info
, METH_NOARGS
, exc_info_doc
},
872 {"exc_clear", sys_exc_clear
, METH_NOARGS
, exc_clear_doc
},
873 {"excepthook", sys_excepthook
, METH_VARARGS
, excepthook_doc
},
874 {"exit", sys_exit
, METH_VARARGS
, exit_doc
},
875 #ifdef Py_USING_UNICODE
876 {"getdefaultencoding", (PyCFunction
)sys_getdefaultencoding
,
877 METH_NOARGS
, getdefaultencoding_doc
},
880 {"getdlopenflags", (PyCFunction
)sys_getdlopenflags
, METH_NOARGS
,
884 {"getcounts", (PyCFunction
)sys_getcounts
, METH_NOARGS
},
886 #ifdef DYNAMIC_EXECUTION_PROFILE
887 {"getdxp", _Py_GetDXProfile
, METH_VARARGS
},
889 #ifdef Py_USING_UNICODE
890 {"getfilesystemencoding", (PyCFunction
)sys_getfilesystemencoding
,
891 METH_NOARGS
, getfilesystemencoding_doc
},
894 {"getobjects", _Py_GetObjects
, METH_VARARGS
},
897 {"gettotalrefcount", (PyCFunction
)sys_gettotalrefcount
, METH_NOARGS
},
899 {"getrefcount", (PyCFunction
)sys_getrefcount
, METH_O
, getrefcount_doc
},
900 {"getrecursionlimit", (PyCFunction
)sys_getrecursionlimit
, METH_NOARGS
,
901 getrecursionlimit_doc
},
902 {"getsizeof", (PyCFunction
)sys_getsizeof
,
903 METH_VARARGS
| METH_KEYWORDS
, getsizeof_doc
},
904 {"_getframe", sys_getframe
, METH_VARARGS
, getframe_doc
},
906 {"getwindowsversion", (PyCFunction
)sys_getwindowsversion
, METH_NOARGS
,
907 getwindowsversion_doc
},
908 #endif /* MS_WINDOWS */
910 {"mdebug", sys_mdebug
, METH_VARARGS
},
912 #ifdef Py_USING_UNICODE
913 {"setdefaultencoding", sys_setdefaultencoding
, METH_VARARGS
,
914 setdefaultencoding_doc
},
916 {"setcheckinterval", sys_setcheckinterval
, METH_VARARGS
,
917 setcheckinterval_doc
},
918 {"getcheckinterval", sys_getcheckinterval
, METH_NOARGS
,
919 getcheckinterval_doc
},
921 {"setdlopenflags", sys_setdlopenflags
, METH_VARARGS
,
924 {"setprofile", sys_setprofile
, METH_O
, setprofile_doc
},
925 {"getprofile", sys_getprofile
, METH_NOARGS
, getprofile_doc
},
926 {"setrecursionlimit", sys_setrecursionlimit
, METH_VARARGS
,
927 setrecursionlimit_doc
},
929 {"settscdump", sys_settscdump
, METH_VARARGS
, settscdump_doc
},
931 {"settrace", sys_settrace
, METH_O
, settrace_doc
},
932 {"gettrace", sys_gettrace
, METH_NOARGS
, gettrace_doc
},
933 {"call_tracing", sys_call_tracing
, METH_VARARGS
, call_tracing_doc
},
934 {NULL
, NULL
} /* sentinel */
938 list_builtin_module_names(void)
940 PyObject
*list
= PyList_New(0);
944 for (i
= 0; PyImport_Inittab
[i
].name
!= NULL
; i
++) {
945 PyObject
*name
= PyString_FromString(
946 PyImport_Inittab
[i
].name
);
949 PyList_Append(list
, name
);
952 if (PyList_Sort(list
) != 0) {
957 PyObject
*v
= PyList_AsTuple(list
);
964 static PyObject
*warnoptions
= NULL
;
967 PySys_ResetWarnOptions(void)
969 if (warnoptions
== NULL
|| !PyList_Check(warnoptions
))
971 PyList_SetSlice(warnoptions
, 0, PyList_GET_SIZE(warnoptions
), NULL
);
975 PySys_AddWarnOption(char *s
)
979 if (warnoptions
== NULL
|| !PyList_Check(warnoptions
)) {
980 Py_XDECREF(warnoptions
);
981 warnoptions
= PyList_New(0);
982 if (warnoptions
== NULL
)
985 str
= PyString_FromString(s
);
987 PyList_Append(warnoptions
, str
);
993 PySys_HasWarnOptions(void)
995 return (warnoptions
!= NULL
&& (PyList_Size(warnoptions
) > 0)) ? 1 : 0;
998 /* XXX This doc string is too long to be a single string literal in VC++ 5.0.
999 Two literals concatenated works just fine. If you have a K&R compiler
1000 or other abomination that however *does* understand longer strings,
1001 get rid of the !!! comment in the middle and the quotes that surround it. */
1002 PyDoc_VAR(sys_doc
) =
1004 "This module provides access to some objects used or maintained by the\n\
1005 interpreter and to functions that interact strongly with the interpreter.\n\
1009 argv -- command line arguments; argv[0] is the script pathname if known\n\
1010 path -- module search path; path[0] is the script directory, else ''\n\
1011 modules -- dictionary of loaded modules\n\
1013 displayhook -- called to show results in an interactive session\n\
1014 excepthook -- called to handle any uncaught exception other than SystemExit\n\
1015 To customize printing in an interactive session or to install a custom\n\
1016 top-level exception handler, assign other functions to replace these.\n\
1018 exitfunc -- if sys.exitfunc exists, this routine is called when Python exits\n\
1019 Assigning to sys.exitfunc is deprecated; use the atexit module instead.\n\
1021 stdin -- standard input file object; used by raw_input() and input()\n\
1022 stdout -- standard output file object; used by the print statement\n\
1023 stderr -- standard error object; used for error messages\n\
1024 By assigning other file objects (or objects that behave like files)\n\
1025 to these, it is possible to redirect all of the interpreter's I/O.\n\
1027 last_type -- type of last uncaught exception\n\
1028 last_value -- value of last uncaught exception\n\
1029 last_traceback -- traceback of last uncaught exception\n\
1030 These three are only available in an interactive session after a\n\
1031 traceback has been printed.\n\
1033 exc_type -- type of exception currently being handled\n\
1034 exc_value -- value of exception currently being handled\n\
1035 exc_traceback -- traceback of exception currently being handled\n\
1036 The function exc_info() should be used instead of these three,\n\
1037 because it is thread-safe.\n\
1040 /* concatenating string here */
1045 float_info -- a dict with information about the float inplementation.\n\
1046 long_info -- a struct sequence with information about the long implementation.\n\
1047 maxint -- the largest supported integer (the smallest is -maxint-1)\n\
1048 maxsize -- the largest supported length of containers.\n\
1049 maxunicode -- the largest supported character\n\
1050 builtin_module_names -- tuple of module names built into this interpreter\n\
1051 version -- the version of this interpreter as a string\n\
1052 version_info -- version information as a named tuple\n\
1053 hexversion -- version information encoded as a single integer\n\
1054 copyright -- copyright notice pertaining to this interpreter\n\
1055 platform -- platform identifier\n\
1056 executable -- pathname of this Python interpreter\n\
1057 prefix -- prefix used to find the Python library\n\
1058 exec_prefix -- prefix used to find the machine-specific Python library\n\
1059 float_repr_style -- string indicating the style of repr() output for floats\n\
1063 /* concatenating string here */
1065 "dllhandle -- [Windows only] integer handle of the Python DLL\n\
1066 winver -- [Windows only] version number of the Python DLL\n\
1069 #endif /* MS_WINDOWS */
1071 "__stdin__ -- the original stdin; don't touch!\n\
1072 __stdout__ -- the original stdout; don't touch!\n\
1073 __stderr__ -- the original stderr; don't touch!\n\
1074 __displayhook__ -- the original displayhook; don't touch!\n\
1075 __excepthook__ -- the original excepthook; don't touch!\n\
1079 displayhook() -- print an object to the screen, and save it in __builtin__._\n\
1080 excepthook() -- print an exception and its traceback to sys.stderr\n\
1081 exc_info() -- return thread-safe information about the current exception\n\
1082 exc_clear() -- clear the exception state for the current thread\n\
1083 exit() -- exit the interpreter by raising SystemExit\n\
1084 getdlopenflags() -- returns flags to be used for dlopen() calls\n\
1085 getprofile() -- get the global profiling function\n\
1086 getrefcount() -- return the reference count for an object (plus one :-)\n\
1087 getrecursionlimit() -- return the max recursion depth for the interpreter\n\
1088 getsizeof() -- return the size of an object in bytes\n\
1089 gettrace() -- get the global debug tracing function\n\
1090 setcheckinterval() -- control how often the interpreter checks for events\n\
1091 setdlopenflags() -- set the flags to be used for dlopen() calls\n\
1092 setprofile() -- set the global profiling function\n\
1093 setrecursionlimit() -- set the max recursion depth for the interpreter\n\
1094 settrace() -- set the global debug tracing function\n\
1097 /* end of sys_doc */ ;
1100 _check_and_flush (FILE *stream
)
1102 int prev_fail
= ferror (stream
);
1103 return fflush (stream
) || prev_fail
? EOF
: 0;
1106 /* Subversion branch and revision management */
1107 static const char _patchlevel_revision
[] = PY_PATCHLEVEL_REVISION
;
1108 static const char headurl
[] = "$HeadURL$";
1109 static int svn_initialized
;
1110 static char patchlevel_revision
[50]; /* Just the number */
1111 static char branch
[50];
1112 static char shortbranch
[50];
1113 static const char *svn_revision
;
1116 svnversion_init(void)
1118 const char *python
, *br_start
, *br_end
, *br_end2
, *svnversion
;
1122 if (svn_initialized
)
1125 python
= strstr(headurl
, "/python/");
1127 /* XXX quick hack to get bzr working */
1128 *patchlevel_revision
= '\0';
1130 strcpy(shortbranch
, "unknown");
1133 /* Py_FatalError("subversion keywords missing"); */
1136 br_start
= python
+ 8;
1137 br_end
= strchr(br_start
, '/');
1140 /* Works even for trunk,
1141 as we are in trunk/Python/sysmodule.c */
1142 br_end2
= strchr(br_end
+1, '/');
1144 istag
= strncmp(br_start
, "tags", 4) == 0;
1145 if (strncmp(br_start
, "trunk", 5) == 0) {
1146 strcpy(branch
, "trunk");
1147 strcpy(shortbranch
, "trunk");
1150 else if (istag
|| strncmp(br_start
, "branches", 8) == 0) {
1151 len
= br_end2
- br_start
;
1152 strncpy(branch
, br_start
, len
);
1155 len
= br_end2
- (br_end
+ 1);
1156 strncpy(shortbranch
, br_end
+ 1, len
);
1157 shortbranch
[len
] = '\0';
1160 Py_FatalError("bad HeadURL");
1165 svnversion
= _Py_svnversion();
1166 if (strcmp(svnversion
, "Unversioned directory") != 0 && strcmp(svnversion
, "exported") != 0)
1167 svn_revision
= svnversion
;
1169 len
= strlen(_patchlevel_revision
);
1171 assert(len
< (sizeof(patchlevel_revision
) + 13));
1172 strncpy(patchlevel_revision
, _patchlevel_revision
+ 11,
1174 patchlevel_revision
[len
- 13] = '\0';
1175 svn_revision
= patchlevel_revision
;
1180 svn_initialized
= 1;
1183 /* Return svnversion output if available.
1184 Else return Revision of patchlevel.h if on branch.
1185 Else return empty string */
1187 Py_SubversionRevision()
1190 return svn_revision
;
1194 Py_SubversionShortBranch()
1201 PyDoc_STRVAR(flags__doc__
,
1204 Flags provided through command line arguments or environment vars.");
1206 static PyTypeObject FlagsType
= {0, 0, 0, 0, 0, 0};
1208 static PyStructSequence_Field flags_fields
[] = {
1210 {"py3k_warning", "-3"},
1211 {"division_warning", "-Q"},
1212 {"division_new", "-Qnew"},
1214 {"interactive", "-i"},
1215 {"optimize", "-O or -OO"},
1216 {"dont_write_bytecode", "-B"},
1217 {"no_user_site", "-s"},
1219 {"ignore_environment", "-E"},
1220 {"tabcheck", "-t or -tt"},
1223 {"riscos_wimp", "???"},
1225 /* {"unbuffered", "-u"}, */
1227 /* {"skip_first", "-x"}, */
1228 {"bytes_warning", "-b"},
1232 static PyStructSequence_Desc flags_desc
= {
1233 "sys.flags", /* name */
1234 flags__doc__
, /* doc */
1235 flags_fields
, /* fields */
1249 seq
= PyStructSequence_New(&FlagsType
);
1253 #define SetFlag(flag) \
1254 PyStructSequence_SET_ITEM(seq, pos++, PyInt_FromLong(flag))
1256 SetFlag(Py_DebugFlag
);
1257 SetFlag(Py_Py3kWarningFlag
);
1258 SetFlag(Py_DivisionWarningFlag
);
1259 SetFlag(_Py_QnewFlag
);
1260 SetFlag(Py_InspectFlag
);
1261 SetFlag(Py_InteractiveFlag
);
1262 SetFlag(Py_OptimizeFlag
);
1263 SetFlag(Py_DontWriteBytecodeFlag
);
1264 SetFlag(Py_NoUserSiteDirectory
);
1265 SetFlag(Py_NoSiteFlag
);
1266 SetFlag(Py_IgnoreEnvironmentFlag
);
1267 SetFlag(Py_TabcheckFlag
);
1268 SetFlag(Py_VerboseFlag
);
1270 SetFlag(Py_RISCOSWimpFlag
);
1272 /* SetFlag(saw_unbuffered_flag); */
1273 SetFlag(Py_UnicodeFlag
);
1274 /* SetFlag(skipfirstline); */
1275 SetFlag(Py_BytesWarningFlag
);
1278 if (PyErr_Occurred()) {
1284 PyDoc_STRVAR(version_info__doc__
,
1285 "sys.version_info\n\
1287 Version information as a named tuple.");
1289 static PyTypeObject VersionInfoType
= {0, 0, 0, 0, 0, 0};
1291 static PyStructSequence_Field version_info_fields
[] = {
1292 {"major", "Major release number"},
1293 {"minor", "Minor release number"},
1294 {"micro", "Patch release number"},
1295 {"releaselevel", "'alpha', 'beta', 'candidate', or 'release'"},
1296 {"serial", "Serial release number"},
1300 static PyStructSequence_Desc version_info_desc
= {
1301 "sys.version_info", /* name */
1302 version_info__doc__
, /* doc */
1303 version_info_fields
, /* fields */
1308 make_version_info(void)
1310 PyObject
*version_info
;
1314 version_info
= PyStructSequence_New(&VersionInfoType
);
1315 if (version_info
== NULL
) {
1320 * These release level checks are mutually exclusive and cover
1321 * the field, so don't get too fancy with the pre-processor!
1323 #if PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_ALPHA
1325 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_BETA
1327 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_GAMMA
1329 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_FINAL
1333 #define SetIntItem(flag) \
1334 PyStructSequence_SET_ITEM(version_info, pos++, PyInt_FromLong(flag))
1335 #define SetStrItem(flag) \
1336 PyStructSequence_SET_ITEM(version_info, pos++, PyString_FromString(flag))
1338 SetIntItem(PY_MAJOR_VERSION
);
1339 SetIntItem(PY_MINOR_VERSION
);
1340 SetIntItem(PY_MICRO_VERSION
);
1342 SetIntItem(PY_RELEASE_SERIAL
);
1346 if (PyErr_Occurred()) {
1347 Py_CLEAR(version_info
);
1350 return version_info
;
1356 PyObject
*m
, *v
, *sysdict
;
1357 PyObject
*sysin
, *sysout
, *syserr
;
1360 m
= Py_InitModule3("sys", sys_methods
, sys_doc
);
1363 sysdict
= PyModule_GetDict(m
);
1364 #define SET_SYS_FROM_STRING(key, value) \
1367 PyDict_SetItemString(sysdict, key, v); \
1370 /* Check that stdin is not a directory
1371 Using shell redirection, you can redirect stdin to a directory,
1372 crashing the Python interpreter. Catch this common mistake here
1373 and output a useful error message. Note that under MS Windows,
1374 the shell already prevents that. */
1375 #if !defined(MS_WINDOWS)
1378 if (fstat(fileno(stdin
), &sb
) == 0 &&
1379 S_ISDIR(sb
.st_mode
)) {
1380 /* There's nothing more we can do. */
1381 /* Py_FatalError() will core dump, so just exit. */
1382 PySys_WriteStderr("Python error: <stdin> is a directory, cannot continue\n");
1388 /* Closing the standard FILE* if sys.std* goes aways causes problems
1389 * for embedded Python usages. Closing them when somebody explicitly
1390 * invokes .close() might be possible, but the FAQ promises they get
1391 * never closed. However, we still need to get write errors when
1392 * writing fails (e.g. because stdout is redirected), so we flush the
1393 * streams and check for errors before the file objects are deleted.
1394 * On OS X, fflush()ing stdin causes an error, so we exempt stdin
1395 * from that procedure.
1397 sysin
= PyFile_FromFile(stdin
, "<stdin>", "r", NULL
);
1398 sysout
= PyFile_FromFile(stdout
, "<stdout>", "w", _check_and_flush
);
1399 syserr
= PyFile_FromFile(stderr
, "<stderr>", "w", _check_and_flush
);
1400 if (PyErr_Occurred())
1403 PyDict_SetItemString(sysdict
, "stdin", sysin
);
1404 PyDict_SetItemString(sysdict
, "stdout", sysout
);
1405 PyDict_SetItemString(sysdict
, "stderr", syserr
);
1406 /* Make backup copies for cleanup */
1407 PyDict_SetItemString(sysdict
, "__stdin__", sysin
);
1408 PyDict_SetItemString(sysdict
, "__stdout__", sysout
);
1409 PyDict_SetItemString(sysdict
, "__stderr__", syserr
);
1410 PyDict_SetItemString(sysdict
, "__displayhook__",
1411 PyDict_GetItemString(sysdict
, "displayhook"));
1412 PyDict_SetItemString(sysdict
, "__excepthook__",
1413 PyDict_GetItemString(sysdict
, "excepthook"));
1418 SET_SYS_FROM_STRING("version",
1419 PyString_FromString(Py_GetVersion()));
1420 SET_SYS_FROM_STRING("hexversion",
1421 PyInt_FromLong(PY_VERSION_HEX
));
1423 SET_SYS_FROM_STRING("subversion",
1424 Py_BuildValue("(ssz)", "CPython", branch
,
1426 SET_SYS_FROM_STRING("dont_write_bytecode",
1427 PyBool_FromLong(Py_DontWriteBytecodeFlag
));
1428 SET_SYS_FROM_STRING("api_version",
1429 PyInt_FromLong(PYTHON_API_VERSION
));
1430 SET_SYS_FROM_STRING("copyright",
1431 PyString_FromString(Py_GetCopyright()));
1432 SET_SYS_FROM_STRING("platform",
1433 PyString_FromString(Py_GetPlatform()));
1434 SET_SYS_FROM_STRING("executable",
1435 PyString_FromString(Py_GetProgramFullPath()));
1436 SET_SYS_FROM_STRING("prefix",
1437 PyString_FromString(Py_GetPrefix()));
1438 SET_SYS_FROM_STRING("exec_prefix",
1439 PyString_FromString(Py_GetExecPrefix()));
1440 SET_SYS_FROM_STRING("maxsize",
1441 PyInt_FromSsize_t(PY_SSIZE_T_MAX
));
1442 SET_SYS_FROM_STRING("maxint",
1443 PyInt_FromLong(PyInt_GetMax()));
1444 SET_SYS_FROM_STRING("py3kwarning",
1445 PyBool_FromLong(Py_Py3kWarningFlag
));
1446 SET_SYS_FROM_STRING("float_info",
1448 SET_SYS_FROM_STRING("long_info",
1450 #ifdef Py_USING_UNICODE
1451 SET_SYS_FROM_STRING("maxunicode",
1452 PyInt_FromLong(PyUnicode_GetMax()));
1454 SET_SYS_FROM_STRING("builtin_module_names",
1455 list_builtin_module_names());
1457 /* Assumes that longs are at least 2 bytes long.
1459 unsigned long number
= 1;
1462 s
= (char *) &number
;
1467 SET_SYS_FROM_STRING("byteorder",
1468 PyString_FromString(value
));
1471 SET_SYS_FROM_STRING("dllhandle",
1472 PyLong_FromVoidPtr(PyWin_DLLhModule
));
1473 SET_SYS_FROM_STRING("winver",
1474 PyString_FromString(PyWin_DLLVersionString
));
1476 if (warnoptions
== NULL
) {
1477 warnoptions
= PyList_New(0);
1480 Py_INCREF(warnoptions
);
1482 if (warnoptions
!= NULL
) {
1483 PyDict_SetItemString(sysdict
, "warnoptions", warnoptions
);
1487 if (VersionInfoType
.tp_name
== 0)
1488 PyStructSequence_InitType(&VersionInfoType
, &version_info_desc
);
1489 SET_SYS_FROM_STRING("version_info", make_version_info());
1490 /* prevent user from creating new instances */
1491 VersionInfoType
.tp_init
= NULL
;
1492 VersionInfoType
.tp_new
= NULL
;
1495 if (FlagsType
.tp_name
== 0)
1496 PyStructSequence_InitType(&FlagsType
, &flags_desc
);
1497 SET_SYS_FROM_STRING("flags", make_flags());
1498 /* prevent user from creating new instances */
1499 FlagsType
.tp_init
= NULL
;
1500 FlagsType
.tp_new
= NULL
;
1502 /* float repr style: 0.03 (short) vs 0.029999999999999999 (legacy) */
1503 #ifndef PY_NO_SHORT_FLOAT_REPR
1504 SET_SYS_FROM_STRING("float_repr_style",
1505 PyString_FromString("short"));
1507 SET_SYS_FROM_STRING("float_repr_style",
1508 PyString_FromString("legacy"));
1511 #undef SET_SYS_FROM_STRING
1512 if (PyErr_Occurred())
1518 makepathobject(char *path
, int delim
)
1526 while ((p
= strchr(p
, delim
)) != NULL
) {
1533 for (i
= 0; ; i
++) {
1534 p
= strchr(path
, delim
);
1536 p
= strchr(path
, '\0'); /* End of string */
1537 w
= PyString_FromStringAndSize(path
, (Py_ssize_t
) (p
- path
));
1542 PyList_SetItem(v
, i
, w
);
1551 PySys_SetPath(char *path
)
1554 if ((v
= makepathobject(path
, DELIM
)) == NULL
)
1555 Py_FatalError("can't create sys.path");
1556 if (PySys_SetObject("path", v
) != 0)
1557 Py_FatalError("can't assign sys.path");
1562 makeargvobject(int argc
, char **argv
)
1565 if (argc
<= 0 || argv
== NULL
) {
1566 /* Ensure at least one (empty) argument is seen */
1567 static char *empty_argv
[1] = {""};
1571 av
= PyList_New(argc
);
1574 for (i
= 0; i
< argc
; i
++) {
1578 /* argv[0] is the script pathname if known */
1580 char* fn
= decc$
translate_vms(argv
[0]);
1581 if ((fn
== (char *)0) || fn
== (char *)-1)
1582 v
= PyString_FromString(argv
[0]);
1584 v
= PyString_FromString(
1585 decc$
translate_vms(argv
[0]));
1587 v
= PyString_FromString(argv
[i
]);
1589 PyObject
*v
= PyString_FromString(argv
[i
]);
1596 PyList_SetItem(av
, i
, v
);
1603 PySys_SetArgv(int argc
, char **argv
)
1605 #if defined(HAVE_REALPATH)
1606 char fullpath
[MAXPATHLEN
];
1607 #elif defined(MS_WINDOWS) && !defined(MS_WINCE)
1608 char fullpath
[MAX_PATH
];
1610 PyObject
*av
= makeargvobject(argc
, argv
);
1611 PyObject
*path
= PySys_GetObject("path");
1613 Py_FatalError("no mem for sys.argv");
1614 if (PySys_SetObject("argv", av
) != 0)
1615 Py_FatalError("can't assign sys.argv");
1617 char *argv0
= argv
[0];
1621 #ifdef HAVE_READLINK
1622 char link
[MAXPATHLEN
+1];
1623 char argv0copy
[2*MAXPATHLEN
+1];
1625 if (argc
> 0 && argv0
!= NULL
&& strcmp(argv0
, "-c") != 0)
1626 nr
= readlink(argv0
, link
, MAXPATHLEN
);
1628 /* It's a symlink */
1631 argv0
= link
; /* Link to absolute path */
1632 else if (strchr(link
, SEP
) == NULL
)
1633 ; /* Link without path */
1635 /* Must join(dirname(argv0), link) */
1636 char *q
= strrchr(argv0
, SEP
);
1638 argv0
= link
; /* argv0 without path */
1640 /* Must make a copy */
1641 strcpy(argv0copy
, argv0
);
1642 q
= strrchr(argv0copy
, SEP
);
1648 #endif /* HAVE_READLINK */
1649 #if SEP == '\\' /* Special case for MS filename syntax */
1650 if (argc
> 0 && argv0
!= NULL
&& strcmp(argv0
, "-c") != 0) {
1652 #if defined(MS_WINDOWS) && !defined(MS_WINCE)
1653 /* This code here replaces the first element in argv with the full
1654 path that it represents. Under CE, there are no relative paths so
1655 the argument must be the full path anyway. */
1657 if (GetFullPathName(argv0
,
1664 p
= strrchr(argv0
, SEP
);
1665 /* Test for alternate separator */
1666 q
= strrchr(p
? p
: argv0
, '/');
1671 if (n
> 1 && p
[-1] != ':')
1672 n
--; /* Drop trailing separator */
1675 #else /* All other filename syntaxes */
1676 if (argc
> 0 && argv0
!= NULL
&& strcmp(argv0
, "-c") != 0) {
1677 #if defined(HAVE_REALPATH)
1678 if (realpath(argv0
, fullpath
)) {
1682 p
= strrchr(argv0
, SEP
);
1687 #else /* don't include trailing separator */
1690 #if SEP == '/' /* Special case for Unix filename syntax */
1692 n
--; /* Drop trailing separator */
1695 #endif /* All others */
1696 a
= PyString_FromStringAndSize(argv0
, n
);
1698 Py_FatalError("no mem for sys.path insertion");
1699 if (PyList_Insert(path
, 0, a
) < 0)
1700 Py_FatalError("sys.path.insert(0) failed");
1707 /* APIs to write to sys.stdout or sys.stderr using a printf-like interface.
1708 Adapted from code submitted by Just van Rossum.
1710 PySys_WriteStdout(format, ...)
1711 PySys_WriteStderr(format, ...)
1713 The first function writes to sys.stdout; the second to sys.stderr. When
1714 there is a problem, they write to the real (C level) stdout or stderr;
1715 no exceptions are raised.
1717 Both take a printf-style format string as their first argument followed
1718 by a variable length argument list determined by the format string.
1722 The format should limit the total size of the formatted output string to
1723 1000 bytes. In particular, this means that no unrestricted "%s" formats
1724 should occur; these should be limited using "%.<N>s where <N> is a
1725 decimal number calculated so that <N> plus the maximum size of other
1726 formatted text does not exceed 1000 bytes. Also watch out for "%f",
1727 which can print hundreds of digits for very large numbers.
1732 mywrite(char *name
, FILE *fp
, const char *format
, va_list va
)
1735 PyObject
*error_type
, *error_value
, *error_traceback
;
1737 PyErr_Fetch(&error_type
, &error_value
, &error_traceback
);
1738 file
= PySys_GetObject(name
);
1739 if (file
== NULL
|| PyFile_AsFile(file
) == fp
)
1740 vfprintf(fp
, format
, va
);
1743 const int written
= PyOS_vsnprintf(buffer
, sizeof(buffer
),
1745 if (PyFile_WriteString(buffer
, file
) != 0) {
1749 if (written
< 0 || (size_t)written
>= sizeof(buffer
)) {
1750 const char *truncated
= "... truncated";
1751 if (PyFile_WriteString(truncated
, file
) != 0) {
1753 fputs(truncated
, fp
);
1757 PyErr_Restore(error_type
, error_value
, error_traceback
);
1761 PySys_WriteStdout(const char *format
, ...)
1765 va_start(va
, format
);
1766 mywrite("stdout", stdout
, format
, va
);
1771 PySys_WriteStderr(const char *format
, ...)
1775 va_start(va
, format
);
1776 mywrite("stderr", stderr
, format
, va
);