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 an integer, 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_CLEAR(frame
->f_trace
);
373 if (result
!= Py_None
) {
374 PyObject
*temp
= frame
->f_trace
;
375 frame
->f_trace
= NULL
;
377 frame
->f_trace
= result
;
386 sys_settrace(PyObject
*self
, PyObject
*args
)
388 if (trace_init() == -1)
391 PyEval_SetTrace(NULL
, NULL
);
393 PyEval_SetTrace(trace_trampoline
, args
);
398 PyDoc_STRVAR(settrace_doc
,
399 "settrace(function)\n\
401 Set the global debug tracing function. It will be called on each\n\
402 function call. See the debugger chapter in the library manual."
406 sys_gettrace(PyObject
*self
, PyObject
*args
)
408 PyThreadState
*tstate
= PyThreadState_GET();
409 PyObject
*temp
= tstate
->c_traceobj
;
417 PyDoc_STRVAR(gettrace_doc
,
420 Return the global debug tracing function set with sys.settrace.\n\
421 See the debugger chapter in the library manual."
425 sys_setprofile(PyObject
*self
, PyObject
*args
)
427 if (trace_init() == -1)
430 PyEval_SetProfile(NULL
, NULL
);
432 PyEval_SetProfile(profile_trampoline
, args
);
437 PyDoc_STRVAR(setprofile_doc
,
438 "setprofile(function)\n\
440 Set the profiling function. It will be called on each function call\n\
441 and return. See the profiler chapter in the library manual."
445 sys_getprofile(PyObject
*self
, PyObject
*args
)
447 PyThreadState
*tstate
= PyThreadState_GET();
448 PyObject
*temp
= tstate
->c_profileobj
;
456 PyDoc_STRVAR(getprofile_doc
,
459 Return the profiling function set with sys.setprofile.\n\
460 See the profiler chapter in the library manual."
464 sys_setcheckinterval(PyObject
*self
, PyObject
*args
)
466 if (!PyArg_ParseTuple(args
, "i:setcheckinterval", &_Py_CheckInterval
))
468 _Py_Ticker
= _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 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 compatibility, 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 */
595 sys_getwindowsversion(PyObject
*self
)
600 ver
.dwOSVersionInfoSize
= sizeof(ver
);
601 if (!GetVersionEx((OSVERSIONINFO
*) &ver
))
602 return PyErr_SetFromWindowsErr(0);
604 version
= PyStructSequence_New(&WindowsVersionType
);
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 if (PyErr_Occurred()) {
625 #endif /* MS_WINDOWS */
629 sys_setdlopenflags(PyObject
*self
, PyObject
*args
)
632 PyThreadState
*tstate
= PyThreadState_GET();
633 if (!PyArg_ParseTuple(args
, "i:setdlopenflags", &new_val
))
637 tstate
->interp
->dlopenflags
= new_val
;
642 PyDoc_STRVAR(setdlopenflags_doc
,
643 "setdlopenflags(n) -> None\n\
645 Set the flags used by the interpreter for dlopen calls, such as when the\n\
646 interpreter loads extension modules. Among other things, this will enable\n\
647 a lazy resolving of symbols when importing a module, if called as\n\
648 sys.setdlopenflags(0). To share symbols across extension modules, call as\n\
649 sys.setdlopenflags(ctypes.RTLD_GLOBAL). Symbolic names for the flag modules\n\
650 can be either found in the ctypes module, or in the DLFCN module. If DLFCN\n\
651 is not available, it can be generated from /usr/include/dlfcn.h using the\n\
655 sys_getdlopenflags(PyObject
*self
, PyObject
*args
)
657 PyThreadState
*tstate
= PyThreadState_GET();
660 return PyInt_FromLong(tstate
->interp
->dlopenflags
);
663 PyDoc_STRVAR(getdlopenflags_doc
,
664 "getdlopenflags() -> int\n\
666 Return the current value of the flags that are used for dlopen calls.\n\
667 The flag constants are defined in the ctypes and DLFCN modules.");
669 #endif /* HAVE_DLOPEN */
672 /* Link with -lmalloc (or -lmpc) on an SGI */
676 sys_mdebug(PyObject
*self
, PyObject
*args
)
679 if (!PyArg_ParseTuple(args
, "i:mdebug", &flag
))
681 mallopt(M_DEBUG
, flag
);
685 #endif /* USE_MALLOPT */
688 _PySys_GetSizeOf(PyObject
*o
)
690 static PyObject
*str__sizeof__
= NULL
;
691 PyObject
*res
= NULL
;
694 /* Make sure the type is initialized. float gets initialized late */
695 if (PyType_Ready(Py_TYPE(o
)) < 0)
698 /* Instance of old-style class */
699 if (PyInstance_Check(o
))
700 size
= PyInstance_Type
.tp_basicsize
;
701 /* all other objects */
703 PyObject
*method
= _PyObject_LookupSpecial(o
, "__sizeof__",
705 if (method
== NULL
) {
706 if (!PyErr_Occurred())
707 PyErr_Format(PyExc_TypeError
,
708 "Type %.100s doesn't define __sizeof__",
709 Py_TYPE(o
)->tp_name
);
712 res
= PyObject_CallFunctionObjArgs(method
, NULL
);
719 size
= (size_t)PyInt_AsSsize_t(res
);
721 if (size
== -1 && PyErr_Occurred())
726 PyErr_SetString(PyExc_ValueError
, "__sizeof__() should return >= 0");
730 /* add gc_head size */
731 if (PyObject_IS_GC(o
))
732 return ((size_t)size
) + sizeof(PyGC_Head
);
737 sys_getsizeof(PyObject
*self
, PyObject
*args
, PyObject
*kwds
)
739 static char *kwlist
[] = {"object", "default", 0};
741 PyObject
*o
, *dflt
= NULL
;
743 if (!PyArg_ParseTupleAndKeywords(args
, kwds
, "O|O:getsizeof",
747 size
= _PySys_GetSizeOf(o
);
749 if (size
== (size_t)-1 && PyErr_Occurred()) {
750 /* Has a default value been given */
751 if (dflt
!= NULL
&& PyErr_ExceptionMatches(PyExc_TypeError
)) {
760 return PyInt_FromSize_t(size
);
763 PyDoc_STRVAR(getsizeof_doc
,
764 "getsizeof(object, default) -> int\n\
766 Return the size of object in bytes.");
769 sys_getrefcount(PyObject
*self
, PyObject
*arg
)
771 return PyInt_FromSsize_t(arg
->ob_refcnt
);
776 sys_gettotalrefcount(PyObject
*self
)
778 return PyInt_FromSsize_t(_Py_GetRefTotal());
780 #endif /* Py_REF_DEBUG */
782 PyDoc_STRVAR(getrefcount_doc
,
783 "getrefcount(object) -> integer\n\
785 Return the reference count of object. The count returned is generally\n\
786 one higher than you might expect, because it includes the (temporary)\n\
787 reference as an argument to getrefcount()."
792 sys_getcounts(PyObject
*self
)
794 extern PyObject
*get_counts(void);
800 PyDoc_STRVAR(getframe_doc
,
801 "_getframe([depth]) -> frameobject\n\
803 Return a frame object from the call stack. If optional integer depth is\n\
804 given, return the frame object that many calls below the top of the stack.\n\
805 If that is deeper than the call stack, ValueError is raised. The default\n\
806 for depth is zero, returning the frame at the top of the call stack.\n\
808 This function should be used for internal and specialized\n\
813 sys_getframe(PyObject
*self
, PyObject
*args
)
815 PyFrameObject
*f
= PyThreadState_GET()->frame
;
818 if (!PyArg_ParseTuple(args
, "|i:_getframe", &depth
))
821 while (depth
> 0 && f
!= NULL
) {
826 PyErr_SetString(PyExc_ValueError
,
827 "call stack is not deep enough");
834 PyDoc_STRVAR(current_frames_doc
,
835 "_current_frames() -> dictionary\n\
837 Return a dictionary mapping each current thread T's thread id to T's\n\
838 current stack frame.\n\
840 This function should be used for specialized purposes only."
844 sys_current_frames(PyObject
*self
, PyObject
*noargs
)
846 return _PyThread_CurrentFrames();
849 PyDoc_STRVAR(call_tracing_doc
,
850 "call_tracing(func, args) -> object\n\
852 Call func(*args), while tracing is enabled. The tracing state is\n\
853 saved, and restored afterwards. This is intended to be called from\n\
854 a debugger from a checkpoint, to recursively debug some other code."
858 sys_call_tracing(PyObject
*self
, PyObject
*args
)
860 PyObject
*func
, *funcargs
;
861 if (!PyArg_ParseTuple(args
, "OO!:call_tracing", &func
, &PyTuple_Type
, &funcargs
))
863 return _PyEval_CallTracing(func
, funcargs
);
866 PyDoc_STRVAR(callstats_doc
,
867 "callstats() -> tuple of integers\n\
869 Return a tuple of function call statistics, if CALL_PROFILE was defined\n\
870 when Python was built. Otherwise, return None.\n\
872 When enabled, this function returns detailed, implementation-specific\n\
873 details about the number of function calls executed. The return value is\n\
874 a 11-tuple where the entries in the tuple are counts of:\n\
875 0. all function calls\n\
876 1. calls to PyFunction_Type objects\n\
877 2. PyFunction calls that do not create an argument tuple\n\
878 3. PyFunction calls that do not create an argument tuple\n\
879 and bypass PyEval_EvalCodeEx()\n\
881 5. PyMethod calls on bound methods\n\
883 7. PyCFunction calls\n\
884 8. generator calls\n\
885 9. All other calls\n\
886 10. Number of stack pops performed by call_function()"
894 /* Defined in objects.c because it uses static globals if that file */
895 extern PyObject
*_Py_GetObjects(PyObject
*, PyObject
*);
898 #ifdef DYNAMIC_EXECUTION_PROFILE
899 /* Defined in ceval.c because it uses static globals if that file */
900 extern PyObject
*_Py_GetDXProfile(PyObject
*, PyObject
*);
908 sys_clear_type_cache(PyObject
* self
, PyObject
* args
)
914 PyDoc_STRVAR(sys_clear_type_cache__doc__
,
915 "_clear_type_cache() -> None\n\
916 Clear the internal type lookup cache.");
919 static PyMethodDef sys_methods
[] = {
920 /* Might as well keep this in alphabetic order */
921 {"callstats", (PyCFunction
)PyEval_GetCallStats
, METH_NOARGS
,
923 {"_clear_type_cache", sys_clear_type_cache
, METH_NOARGS
,
924 sys_clear_type_cache__doc__
},
925 {"_current_frames", sys_current_frames
, METH_NOARGS
,
927 {"displayhook", sys_displayhook
, METH_O
, displayhook_doc
},
928 {"exc_info", sys_exc_info
, METH_NOARGS
, exc_info_doc
},
929 {"exc_clear", sys_exc_clear
, METH_NOARGS
, exc_clear_doc
},
930 {"excepthook", sys_excepthook
, METH_VARARGS
, excepthook_doc
},
931 {"exit", sys_exit
, METH_VARARGS
, exit_doc
},
932 #ifdef Py_USING_UNICODE
933 {"getdefaultencoding", (PyCFunction
)sys_getdefaultencoding
,
934 METH_NOARGS
, getdefaultencoding_doc
},
937 {"getdlopenflags", (PyCFunction
)sys_getdlopenflags
, METH_NOARGS
,
941 {"getcounts", (PyCFunction
)sys_getcounts
, METH_NOARGS
},
943 #ifdef DYNAMIC_EXECUTION_PROFILE
944 {"getdxp", _Py_GetDXProfile
, METH_VARARGS
},
946 #ifdef Py_USING_UNICODE
947 {"getfilesystemencoding", (PyCFunction
)sys_getfilesystemencoding
,
948 METH_NOARGS
, getfilesystemencoding_doc
},
951 {"getobjects", _Py_GetObjects
, METH_VARARGS
},
954 {"gettotalrefcount", (PyCFunction
)sys_gettotalrefcount
, METH_NOARGS
},
956 {"getrefcount", (PyCFunction
)sys_getrefcount
, METH_O
, getrefcount_doc
},
957 {"getrecursionlimit", (PyCFunction
)sys_getrecursionlimit
, METH_NOARGS
,
958 getrecursionlimit_doc
},
959 {"getsizeof", (PyCFunction
)sys_getsizeof
,
960 METH_VARARGS
| METH_KEYWORDS
, getsizeof_doc
},
961 {"_getframe", sys_getframe
, METH_VARARGS
, getframe_doc
},
963 {"getwindowsversion", (PyCFunction
)sys_getwindowsversion
, METH_NOARGS
,
964 getwindowsversion_doc
},
965 #endif /* MS_WINDOWS */
967 {"mdebug", sys_mdebug
, METH_VARARGS
},
969 #ifdef Py_USING_UNICODE
970 {"setdefaultencoding", sys_setdefaultencoding
, METH_VARARGS
,
971 setdefaultencoding_doc
},
973 {"setcheckinterval", sys_setcheckinterval
, METH_VARARGS
,
974 setcheckinterval_doc
},
975 {"getcheckinterval", sys_getcheckinterval
, METH_NOARGS
,
976 getcheckinterval_doc
},
978 {"setdlopenflags", sys_setdlopenflags
, METH_VARARGS
,
981 {"setprofile", sys_setprofile
, METH_O
, setprofile_doc
},
982 {"getprofile", sys_getprofile
, METH_NOARGS
, getprofile_doc
},
983 {"setrecursionlimit", sys_setrecursionlimit
, METH_VARARGS
,
984 setrecursionlimit_doc
},
986 {"settscdump", sys_settscdump
, METH_VARARGS
, settscdump_doc
},
988 {"settrace", sys_settrace
, METH_O
, settrace_doc
},
989 {"gettrace", sys_gettrace
, METH_NOARGS
, gettrace_doc
},
990 {"call_tracing", sys_call_tracing
, METH_VARARGS
, call_tracing_doc
},
991 {NULL
, NULL
} /* sentinel */
995 list_builtin_module_names(void)
997 PyObject
*list
= PyList_New(0);
1001 for (i
= 0; PyImport_Inittab
[i
].name
!= NULL
; i
++) {
1002 PyObject
*name
= PyString_FromString(
1003 PyImport_Inittab
[i
].name
);
1006 PyList_Append(list
, name
);
1009 if (PyList_Sort(list
) != 0) {
1014 PyObject
*v
= PyList_AsTuple(list
);
1021 static PyObject
*warnoptions
= NULL
;
1024 PySys_ResetWarnOptions(void)
1026 if (warnoptions
== NULL
|| !PyList_Check(warnoptions
))
1028 PyList_SetSlice(warnoptions
, 0, PyList_GET_SIZE(warnoptions
), NULL
);
1032 PySys_AddWarnOption(char *s
)
1036 if (warnoptions
== NULL
|| !PyList_Check(warnoptions
)) {
1037 Py_XDECREF(warnoptions
);
1038 warnoptions
= PyList_New(0);
1039 if (warnoptions
== NULL
)
1042 str
= PyString_FromString(s
);
1044 PyList_Append(warnoptions
, str
);
1050 PySys_HasWarnOptions(void)
1052 return (warnoptions
!= NULL
&& (PyList_Size(warnoptions
) > 0)) ? 1 : 0;
1055 /* XXX This doc string is too long to be a single string literal in VC++ 5.0.
1056 Two literals concatenated works just fine. If you have a K&R compiler
1057 or other abomination that however *does* understand longer strings,
1058 get rid of the !!! comment in the middle and the quotes that surround it. */
1059 PyDoc_VAR(sys_doc
) =
1061 "This module provides access to some objects used or maintained by the\n\
1062 interpreter and to functions that interact strongly with the interpreter.\n\
1066 argv -- command line arguments; argv[0] is the script pathname if known\n\
1067 path -- module search path; path[0] is the script directory, else ''\n\
1068 modules -- dictionary of loaded modules\n\
1070 displayhook -- called to show results in an interactive session\n\
1071 excepthook -- called to handle any uncaught exception other than SystemExit\n\
1072 To customize printing in an interactive session or to install a custom\n\
1073 top-level exception handler, assign other functions to replace these.\n\
1075 exitfunc -- if sys.exitfunc exists, this routine is called when Python exits\n\
1076 Assigning to sys.exitfunc is deprecated; use the atexit module instead.\n\
1078 stdin -- standard input file object; used by raw_input() and input()\n\
1079 stdout -- standard output file object; used by the print statement\n\
1080 stderr -- standard error object; used for error messages\n\
1081 By assigning other file objects (or objects that behave like files)\n\
1082 to these, it is possible to redirect all of the interpreter's I/O.\n\
1084 last_type -- type of last uncaught exception\n\
1085 last_value -- value of last uncaught exception\n\
1086 last_traceback -- traceback of last uncaught exception\n\
1087 These three are only available in an interactive session after a\n\
1088 traceback has been printed.\n\
1090 exc_type -- type of exception currently being handled\n\
1091 exc_value -- value of exception currently being handled\n\
1092 exc_traceback -- traceback of exception currently being handled\n\
1093 The function exc_info() should be used instead of these three,\n\
1094 because it is thread-safe.\n\
1097 /* concatenating string here */
1102 float_info -- a dict with information about the float inplementation.\n\
1103 long_info -- a struct sequence with information about the long implementation.\n\
1104 maxint -- the largest supported integer (the smallest is -maxint-1)\n\
1105 maxsize -- the largest supported length of containers.\n\
1106 maxunicode -- the largest supported character\n\
1107 builtin_module_names -- tuple of module names built into this interpreter\n\
1108 version -- the version of this interpreter as a string\n\
1109 version_info -- version information as a named tuple\n\
1110 hexversion -- version information encoded as a single integer\n\
1111 copyright -- copyright notice pertaining to this interpreter\n\
1112 platform -- platform identifier\n\
1113 executable -- absolute path of the executable binary of the Python interpreter\n\
1114 prefix -- prefix used to find the Python library\n\
1115 exec_prefix -- prefix used to find the machine-specific Python library\n\
1116 float_repr_style -- string indicating the style of repr() output for floats\n\
1120 /* concatenating string here */
1122 "dllhandle -- [Windows only] integer handle of the Python DLL\n\
1123 winver -- [Windows only] version number of the Python DLL\n\
1126 #endif /* MS_WINDOWS */
1128 "__stdin__ -- the original stdin; don't touch!\n\
1129 __stdout__ -- the original stdout; don't touch!\n\
1130 __stderr__ -- the original stderr; don't touch!\n\
1131 __displayhook__ -- the original displayhook; don't touch!\n\
1132 __excepthook__ -- the original excepthook; don't touch!\n\
1136 displayhook() -- print an object to the screen, and save it in __builtin__._\n\
1137 excepthook() -- print an exception and its traceback to sys.stderr\n\
1138 exc_info() -- return thread-safe information about the current exception\n\
1139 exc_clear() -- clear the exception state for the current thread\n\
1140 exit() -- exit the interpreter by raising SystemExit\n\
1141 getdlopenflags() -- returns flags to be used for dlopen() calls\n\
1142 getprofile() -- get the global profiling function\n\
1143 getrefcount() -- return the reference count for an object (plus one :-)\n\
1144 getrecursionlimit() -- return the max recursion depth for the interpreter\n\
1145 getsizeof() -- return the size of an object in bytes\n\
1146 gettrace() -- get the global debug tracing function\n\
1147 setcheckinterval() -- control how often the interpreter checks for events\n\
1148 setdlopenflags() -- set the flags to be used for dlopen() calls\n\
1149 setprofile() -- set the global profiling function\n\
1150 setrecursionlimit() -- set the max recursion depth for the interpreter\n\
1151 settrace() -- set the global debug tracing function\n\
1154 /* end of sys_doc */ ;
1157 _check_and_flush (FILE *stream
)
1159 int prev_fail
= ferror (stream
);
1160 return fflush (stream
) || prev_fail
? EOF
: 0;
1163 /* Subversion branch and revision management */
1164 static int svn_initialized
;
1165 static char patchlevel_revision
[50]; /* Just the number */
1166 static char branch
[50];
1167 static char shortbranch
[50];
1168 static const char *svn_revision
;
1171 svnversion_init(void)
1173 if (svn_initialized
)
1175 svn_initialized
= 1;
1176 *patchlevel_revision
= '\0';
1178 strcpy(shortbranch
, "unknown");
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"},
1229 {"hash_randomization", "-R"},
1233 static PyStructSequence_Desc flags_desc
= {
1234 "sys.flags", /* name */
1235 flags__doc__
, /* doc */
1236 flags_fields
, /* fields */
1250 seq
= PyStructSequence_New(&FlagsType
);
1254 #define SetFlag(flag) \
1255 PyStructSequence_SET_ITEM(seq, pos++, PyInt_FromLong(flag))
1257 SetFlag(Py_DebugFlag
);
1258 SetFlag(Py_Py3kWarningFlag
);
1259 SetFlag(Py_DivisionWarningFlag
);
1260 SetFlag(_Py_QnewFlag
);
1261 SetFlag(Py_InspectFlag
);
1262 SetFlag(Py_InteractiveFlag
);
1263 SetFlag(Py_OptimizeFlag
);
1264 SetFlag(Py_DontWriteBytecodeFlag
);
1265 SetFlag(Py_NoUserSiteDirectory
);
1266 SetFlag(Py_NoSiteFlag
);
1267 SetFlag(Py_IgnoreEnvironmentFlag
);
1268 SetFlag(Py_TabcheckFlag
);
1269 SetFlag(Py_VerboseFlag
);
1271 SetFlag(Py_RISCOSWimpFlag
);
1273 /* SetFlag(saw_unbuffered_flag); */
1274 SetFlag(Py_UnicodeFlag
);
1275 /* SetFlag(skipfirstline); */
1276 SetFlag(Py_BytesWarningFlag
);
1277 SetFlag(Py_HashRandomizationFlag
);
1280 if (PyErr_Occurred()) {
1287 PyDoc_STRVAR(version_info__doc__
,
1288 "sys.version_info\n\
1290 Version information as a named tuple.");
1292 static PyTypeObject VersionInfoType
= {0, 0, 0, 0, 0, 0};
1294 static PyStructSequence_Field version_info_fields
[] = {
1295 {"major", "Major release number"},
1296 {"minor", "Minor release number"},
1297 {"micro", "Patch release number"},
1298 {"releaselevel", "'alpha', 'beta', 'candidate', or 'release'"},
1299 {"serial", "Serial release number"},
1303 static PyStructSequence_Desc version_info_desc
= {
1304 "sys.version_info", /* name */
1305 version_info__doc__
, /* doc */
1306 version_info_fields
, /* fields */
1311 make_version_info(void)
1313 PyObject
*version_info
;
1317 version_info
= PyStructSequence_New(&VersionInfoType
);
1318 if (version_info
== NULL
) {
1323 * These release level checks are mutually exclusive and cover
1324 * the field, so don't get too fancy with the pre-processor!
1326 #if PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_ALPHA
1328 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_BETA
1330 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_GAMMA
1332 #elif PY_RELEASE_LEVEL == PY_RELEASE_LEVEL_FINAL
1336 #define SetIntItem(flag) \
1337 PyStructSequence_SET_ITEM(version_info, pos++, PyInt_FromLong(flag))
1338 #define SetStrItem(flag) \
1339 PyStructSequence_SET_ITEM(version_info, pos++, PyString_FromString(flag))
1341 SetIntItem(PY_MAJOR_VERSION
);
1342 SetIntItem(PY_MINOR_VERSION
);
1343 SetIntItem(PY_MICRO_VERSION
);
1345 SetIntItem(PY_RELEASE_SERIAL
);
1349 if (PyErr_Occurred()) {
1350 Py_CLEAR(version_info
);
1353 return version_info
;
1359 PyObject
*m
, *v
, *sysdict
;
1360 PyObject
*sysin
, *sysout
, *syserr
;
1363 m
= Py_InitModule3("sys", sys_methods
, sys_doc
);
1366 sysdict
= PyModule_GetDict(m
);
1367 #define SET_SYS_FROM_STRING(key, value) \
1370 PyDict_SetItemString(sysdict, key, v); \
1373 /* Check that stdin is not a directory
1374 Using shell redirection, you can redirect stdin to a directory,
1375 crashing the Python interpreter. Catch this common mistake here
1376 and output a useful error message. Note that under MS Windows,
1377 the shell already prevents that. */
1378 #if !defined(MS_WINDOWS)
1381 if (fstat(fileno(stdin
), &sb
) == 0 &&
1382 S_ISDIR(sb
.st_mode
)) {
1383 /* There's nothing more we can do. */
1384 /* Py_FatalError() will core dump, so just exit. */
1385 PySys_WriteStderr("Python error: <stdin> is a directory, cannot continue\n");
1391 /* Closing the standard FILE* if sys.std* goes aways causes problems
1392 * for embedded Python usages. Closing them when somebody explicitly
1393 * invokes .close() might be possible, but the FAQ promises they get
1394 * never closed. However, we still need to get write errors when
1395 * writing fails (e.g. because stdout is redirected), so we flush the
1396 * streams and check for errors before the file objects are deleted.
1397 * On OS X, fflush()ing stdin causes an error, so we exempt stdin
1398 * from that procedure.
1400 sysin
= PyFile_FromFile(stdin
, "<stdin>", "r", NULL
);
1401 sysout
= PyFile_FromFile(stdout
, "<stdout>", "w", _check_and_flush
);
1402 syserr
= PyFile_FromFile(stderr
, "<stderr>", "w", _check_and_flush
);
1403 if (PyErr_Occurred())
1406 PyDict_SetItemString(sysdict
, "stdin", sysin
);
1407 PyDict_SetItemString(sysdict
, "stdout", sysout
);
1408 PyDict_SetItemString(sysdict
, "stderr", syserr
);
1409 /* Make backup copies for cleanup */
1410 PyDict_SetItemString(sysdict
, "__stdin__", sysin
);
1411 PyDict_SetItemString(sysdict
, "__stdout__", sysout
);
1412 PyDict_SetItemString(sysdict
, "__stderr__", syserr
);
1413 PyDict_SetItemString(sysdict
, "__displayhook__",
1414 PyDict_GetItemString(sysdict
, "displayhook"));
1415 PyDict_SetItemString(sysdict
, "__excepthook__",
1416 PyDict_GetItemString(sysdict
, "excepthook"));
1421 SET_SYS_FROM_STRING("version",
1422 PyString_FromString(Py_GetVersion()));
1423 SET_SYS_FROM_STRING("hexversion",
1424 PyInt_FromLong(PY_VERSION_HEX
));
1426 SET_SYS_FROM_STRING("subversion",
1427 Py_BuildValue("(ssz)", "CPython", branch
,
1429 SET_SYS_FROM_STRING("_mercurial",
1430 Py_BuildValue("(szz)", "CPython", _Py_hgidentifier(),
1432 SET_SYS_FROM_STRING("dont_write_bytecode",
1433 PyBool_FromLong(Py_DontWriteBytecodeFlag
));
1434 SET_SYS_FROM_STRING("api_version",
1435 PyInt_FromLong(PYTHON_API_VERSION
));
1436 SET_SYS_FROM_STRING("copyright",
1437 PyString_FromString(Py_GetCopyright()));
1438 SET_SYS_FROM_STRING("platform",
1439 PyString_FromString(Py_GetPlatform()));
1440 SET_SYS_FROM_STRING("executable",
1441 PyString_FromString(Py_GetProgramFullPath()));
1442 SET_SYS_FROM_STRING("prefix",
1443 PyString_FromString(Py_GetPrefix()));
1444 SET_SYS_FROM_STRING("exec_prefix",
1445 PyString_FromString(Py_GetExecPrefix()));
1446 SET_SYS_FROM_STRING("maxsize",
1447 PyInt_FromSsize_t(PY_SSIZE_T_MAX
));
1448 SET_SYS_FROM_STRING("maxint",
1449 PyInt_FromLong(PyInt_GetMax()));
1450 SET_SYS_FROM_STRING("py3kwarning",
1451 PyBool_FromLong(Py_Py3kWarningFlag
));
1452 SET_SYS_FROM_STRING("float_info",
1454 SET_SYS_FROM_STRING("long_info",
1456 #ifdef Py_USING_UNICODE
1457 SET_SYS_FROM_STRING("maxunicode",
1458 PyInt_FromLong(PyUnicode_GetMax()));
1460 SET_SYS_FROM_STRING("builtin_module_names",
1461 list_builtin_module_names());
1463 /* Assumes that longs are at least 2 bytes long.
1465 unsigned long number
= 1;
1468 s
= (char *) &number
;
1473 SET_SYS_FROM_STRING("byteorder",
1474 PyString_FromString(value
));
1477 SET_SYS_FROM_STRING("dllhandle",
1478 PyLong_FromVoidPtr(PyWin_DLLhModule
));
1479 SET_SYS_FROM_STRING("winver",
1480 PyString_FromString(PyWin_DLLVersionString
));
1482 if (warnoptions
== NULL
) {
1483 warnoptions
= PyList_New(0);
1486 Py_INCREF(warnoptions
);
1488 if (warnoptions
!= NULL
) {
1489 PyDict_SetItemString(sysdict
, "warnoptions", warnoptions
);
1493 if (VersionInfoType
.tp_name
== 0)
1494 PyStructSequence_InitType(&VersionInfoType
, &version_info_desc
);
1495 SET_SYS_FROM_STRING("version_info", make_version_info());
1496 /* prevent user from creating new instances */
1497 VersionInfoType
.tp_init
= NULL
;
1498 VersionInfoType
.tp_new
= NULL
;
1501 if (FlagsType
.tp_name
== 0)
1502 PyStructSequence_InitType(&FlagsType
, &flags_desc
);
1503 SET_SYS_FROM_STRING("flags", make_flags());
1504 /* prevent user from creating new instances */
1505 FlagsType
.tp_init
= NULL
;
1506 FlagsType
.tp_new
= NULL
;
1509 #if defined(MS_WINDOWS)
1510 /* getwindowsversion */
1511 if (WindowsVersionType
.tp_name
== 0)
1512 PyStructSequence_InitType(&WindowsVersionType
, &windows_version_desc
);
1513 /* prevent user from creating new instances */
1514 WindowsVersionType
.tp_init
= NULL
;
1515 WindowsVersionType
.tp_new
= NULL
;
1518 /* float repr style: 0.03 (short) vs 0.029999999999999999 (legacy) */
1519 #ifndef PY_NO_SHORT_FLOAT_REPR
1520 SET_SYS_FROM_STRING("float_repr_style",
1521 PyString_FromString("short"));
1523 SET_SYS_FROM_STRING("float_repr_style",
1524 PyString_FromString("legacy"));
1527 #undef SET_SYS_FROM_STRING
1528 if (PyErr_Occurred())
1534 makepathobject(char *path
, int delim
)
1542 while ((p
= strchr(p
, delim
)) != NULL
) {
1549 for (i
= 0; ; i
++) {
1550 p
= strchr(path
, delim
);
1552 p
= strchr(path
, '\0'); /* End of string */
1553 w
= PyString_FromStringAndSize(path
, (Py_ssize_t
) (p
- path
));
1558 PyList_SetItem(v
, i
, w
);
1567 PySys_SetPath(char *path
)
1570 if ((v
= makepathobject(path
, DELIM
)) == NULL
)
1571 Py_FatalError("can't create sys.path");
1572 if (PySys_SetObject("path", v
) != 0)
1573 Py_FatalError("can't assign sys.path");
1578 makeargvobject(int argc
, char **argv
)
1581 if (argc
<= 0 || argv
== NULL
) {
1582 /* Ensure at least one (empty) argument is seen */
1583 static char *empty_argv
[1] = {""};
1587 av
= PyList_New(argc
);
1590 for (i
= 0; i
< argc
; i
++) {
1594 /* argv[0] is the script pathname if known */
1596 char* fn
= decc$
translate_vms(argv
[0]);
1597 if ((fn
== (char *)0) || fn
== (char *)-1)
1598 v
= PyString_FromString(argv
[0]);
1600 v
= PyString_FromString(
1601 decc$
translate_vms(argv
[0]));
1603 v
= PyString_FromString(argv
[i
]);
1605 PyObject
*v
= PyString_FromString(argv
[i
]);
1612 PyList_SetItem(av
, i
, v
);
1619 PySys_SetArgvEx(int argc
, char **argv
, int updatepath
)
1621 #if defined(HAVE_REALPATH)
1622 char fullpath
[MAXPATHLEN
];
1623 #elif defined(MS_WINDOWS) && !defined(MS_WINCE)
1624 char fullpath
[MAX_PATH
];
1626 PyObject
*av
= makeargvobject(argc
, argv
);
1627 PyObject
*path
= PySys_GetObject("path");
1629 Py_FatalError("no mem for sys.argv");
1630 if (PySys_SetObject("argv", av
) != 0)
1631 Py_FatalError("can't assign sys.argv");
1632 if (updatepath
&& path
!= NULL
) {
1633 char *argv0
= argv
[0];
1637 #ifdef HAVE_READLINK
1638 char link
[MAXPATHLEN
+1];
1639 char argv0copy
[2*MAXPATHLEN
+1];
1641 if (argc
> 0 && argv0
!= NULL
&& strcmp(argv0
, "-c") != 0)
1642 nr
= readlink(argv0
, link
, MAXPATHLEN
);
1644 /* It's a symlink */
1647 argv0
= link
; /* Link to absolute path */
1648 else if (strchr(link
, SEP
) == NULL
)
1649 ; /* Link without path */
1651 /* Must join(dirname(argv0), link) */
1652 char *q
= strrchr(argv0
, SEP
);
1654 argv0
= link
; /* argv0 without path */
1656 /* Must make a copy */
1657 strcpy(argv0copy
, argv0
);
1658 q
= strrchr(argv0copy
, SEP
);
1664 #endif /* HAVE_READLINK */
1665 #if SEP == '\\' /* Special case for MS filename syntax */
1666 if (argc
> 0 && argv0
!= NULL
&& strcmp(argv0
, "-c") != 0) {
1668 #if defined(MS_WINDOWS) && !defined(MS_WINCE)
1669 /* This code here replaces the first element in argv with the full
1670 path that it represents. Under CE, there are no relative paths so
1671 the argument must be the full path anyway. */
1673 if (GetFullPathName(argv0
,
1680 p
= strrchr(argv0
, SEP
);
1681 /* Test for alternate separator */
1682 q
= strrchr(p
? p
: argv0
, '/');
1687 if (n
> 1 && p
[-1] != ':')
1688 n
--; /* Drop trailing separator */
1691 #else /* All other filename syntaxes */
1692 if (argc
> 0 && argv0
!= NULL
&& strcmp(argv0
, "-c") != 0) {
1693 #if defined(HAVE_REALPATH)
1694 if (realpath(argv0
, fullpath
)) {
1698 p
= strrchr(argv0
, SEP
);
1703 #else /* don't include trailing separator */
1706 #if SEP == '/' /* Special case for Unix filename syntax */
1708 n
--; /* Drop trailing separator */
1711 #endif /* All others */
1712 a
= PyString_FromStringAndSize(argv0
, n
);
1714 Py_FatalError("no mem for sys.path insertion");
1715 if (PyList_Insert(path
, 0, a
) < 0)
1716 Py_FatalError("sys.path.insert(0) failed");
1723 PySys_SetArgv(int argc
, char **argv
)
1725 PySys_SetArgvEx(argc
, argv
, 1);
1729 /* APIs to write to sys.stdout or sys.stderr using a printf-like interface.
1730 Adapted from code submitted by Just van Rossum.
1732 PySys_WriteStdout(format, ...)
1733 PySys_WriteStderr(format, ...)
1735 The first function writes to sys.stdout; the second to sys.stderr. When
1736 there is a problem, they write to the real (C level) stdout or stderr;
1737 no exceptions are raised.
1739 Both take a printf-style format string as their first argument followed
1740 by a variable length argument list determined by the format string.
1744 The format should limit the total size of the formatted output string to
1745 1000 bytes. In particular, this means that no unrestricted "%s" formats
1746 should occur; these should be limited using "%.<N>s where <N> is a
1747 decimal number calculated so that <N> plus the maximum size of other
1748 formatted text does not exceed 1000 bytes. Also watch out for "%f",
1749 which can print hundreds of digits for very large numbers.
1754 mywrite(char *name
, FILE *fp
, const char *format
, va_list va
)
1757 PyObject
*error_type
, *error_value
, *error_traceback
;
1759 PyErr_Fetch(&error_type
, &error_value
, &error_traceback
);
1760 file
= PySys_GetObject(name
);
1761 if (file
== NULL
|| PyFile_AsFile(file
) == fp
)
1762 vfprintf(fp
, format
, va
);
1765 const int written
= PyOS_vsnprintf(buffer
, sizeof(buffer
),
1767 if (PyFile_WriteString(buffer
, file
) != 0) {
1771 if (written
< 0 || (size_t)written
>= sizeof(buffer
)) {
1772 const char *truncated
= "... truncated";
1773 if (PyFile_WriteString(truncated
, file
) != 0) {
1775 fputs(truncated
, fp
);
1779 PyErr_Restore(error_type
, error_value
, error_traceback
);
1783 PySys_WriteStdout(const char *format
, ...)
1787 va_start(va
, format
);
1788 mywrite("stdout", stdout
, format
, va
);
1793 PySys_WriteStderr(const char *format
, ...)
1797 va_start(va
, format
);
1798 mywrite("stderr", stderr
, format
, va
);