mirror of
https://github.com/johndoe6345789/typthon.git
synced 2026-04-24 13:45:05 +00:00
Fixed additional patterns: - _PyOpcode_* → _TyOpcode_* (all opcode metadata) - _PyUOpName → _TyUOpName - _PyFunction_* → _TyFunction_* - _PyListIterObject → _TyListIterObject - _Py_T_OBJECT → _Ty_T_OBJECT - Py_BEGIN_ALLOW_THREADS, Py_END_ALLOW_THREADS → Ty_* - PyDoc_STRVAR, PyDoc_STR → TyDoc_* - PyInterpreterState, PyThread_*, PyTime_t → Ty* - PyStructSequence_* → TyStructSequence_* - PyLockStatus → TyLockStatus - PyVarObject_HEAD_INIT → TyVarObject_HEAD_INIT - PyBaseExceptionObject → TyBaseExceptionObject - Fixed _PyExc_ → _TyExc_ in exception macros Build is progressing further. Co-authored-by: johndoe6345789 <224850594+johndoe6345789@users.noreply.github.com>
109 lines
3.5 KiB
C
109 lines
3.5 KiB
C
#ifndef Ty_INTERNAL_TRACEBACK_H
|
|
#define Ty_INTERNAL_TRACEBACK_H
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#ifndef Ty_BUILD_CORE
|
|
# error "this header requires Ty_BUILD_CORE define"
|
|
#endif
|
|
|
|
// Export for '_ctypes' shared extension
|
|
PyAPI_FUNC(int) _Ty_DisplaySourceLine(TyObject *, TyObject *, int, int, int *, TyObject **);
|
|
|
|
// Export for 'pyexact' shared extension
|
|
PyAPI_FUNC(void) _TyTraceback_Add(const char *, const char *, int);
|
|
|
|
/* Write the Python traceback into the file 'fd'. For example:
|
|
|
|
Traceback (most recent call first):
|
|
File "xxx", line xxx in <xxx>
|
|
File "xxx", line xxx in <xxx>
|
|
...
|
|
File "xxx", line xxx in <xxx>
|
|
|
|
This function is written for debug purpose only, to dump the traceback in
|
|
the worst case: after a segmentation fault, at fatal error, etc. That's why,
|
|
it is very limited. Strings are truncated to 100 characters and encoded to
|
|
ASCII with backslashreplace. It doesn't write the source code, only the
|
|
function name, filename and line number of each frame. Write only the first
|
|
100 frames: if the traceback is truncated, write the line " ...".
|
|
|
|
This function is signal safe. */
|
|
|
|
extern void _Ty_DumpTraceback(
|
|
int fd,
|
|
TyThreadState *tstate);
|
|
|
|
/* Write the traceback of all threads into the file 'fd'. current_thread can be
|
|
NULL.
|
|
|
|
Return NULL on success, or an error message on error.
|
|
|
|
This function is written for debug purpose only. It calls
|
|
_Ty_DumpTraceback() for each thread, and so has the same limitations. It
|
|
only write the traceback of the first 100 threads: write "..." if there are
|
|
more threads.
|
|
|
|
If current_tstate is NULL, the function tries to get the Python thread state
|
|
of the current thread. It is not an error if the function is unable to get
|
|
the current Python thread state.
|
|
|
|
If interp is NULL, the function tries to get the interpreter state from
|
|
the current Python thread state, or from
|
|
_TyGILState_GetInterpreterStateUnsafe() in last resort.
|
|
|
|
It is better to pass NULL to interp and current_tstate, the function tries
|
|
different options to retrieve this information.
|
|
|
|
This function is signal safe. */
|
|
|
|
extern const char* _Ty_DumpTracebackThreads(
|
|
int fd,
|
|
TyInterpreterState *interp,
|
|
TyThreadState *current_tstate);
|
|
|
|
/* Write a Unicode object into the file descriptor fd. Encode the string to
|
|
ASCII using the backslashreplace error handler.
|
|
|
|
Do nothing if text is not a Unicode object.
|
|
|
|
This function is signal safe. */
|
|
extern void _Ty_DumpASCII(int fd, TyObject *text);
|
|
|
|
/* Format an integer as decimal into the file descriptor fd.
|
|
|
|
This function is signal safe. */
|
|
extern void _Ty_DumpDecimal(
|
|
int fd,
|
|
size_t value);
|
|
|
|
/* Format an integer as hexadecimal with width digits into fd file descriptor.
|
|
The function is signal safe. */
|
|
extern void _Ty_DumpHexadecimal(
|
|
int fd,
|
|
uintptr_t value,
|
|
Ty_ssize_t width);
|
|
|
|
extern TyObject* _PyTraceBack_FromFrame(
|
|
TyObject *tb_next,
|
|
PyFrameObject *frame);
|
|
|
|
#define EXCEPTION_TB_HEADER "Traceback (most recent call last):\n"
|
|
#define EXCEPTION_GROUP_TB_HEADER "Exception Group Traceback (most recent call last):\n"
|
|
|
|
/* Write the traceback tb to file f. Prefix each line with
|
|
indent spaces followed by the margin (if it is not NULL). */
|
|
extern int _PyTraceBack_Print(
|
|
TyObject *tb, const char *header, TyObject *f);
|
|
extern int _Ty_WriteIndentedMargin(int, const char*, TyObject *);
|
|
extern int _Ty_WriteIndent(int, TyObject *);
|
|
|
|
// Export for the faulthandler module
|
|
PyAPI_FUNC(void) _Ty_DumpStack(int fd);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /* !Ty_INTERNAL_TRACEBACK_H */
|