404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.139.85.198: ~ $
#ifndef Py_INTERNAL_RUNTIME_H
#define Py_INTERNAL_RUNTIME_H
#ifdef __cplusplus
extern "C" {
#endif

#ifndef Py_BUILD_CORE
#  error "this header requires Py_BUILD_CORE define"
#endif

#include "pycore_atomic.h"          /* _Py_atomic_address */
#include "pycore_gil.h"             // struct _gil_runtime_state
#include "pycore_global_objects.h"  // struct _Py_global_objects
#include "pycore_interp.h"          // PyInterpreterState
#include "pycore_unicodeobject.h"   // struct _Py_unicode_runtime_ids


/* ceval state */

struct _ceval_runtime_state {
    /* Request for checking signals. It is shared by all interpreters (see
       bpo-40513). Any thread of any interpreter can receive a signal, but only
       the main thread of the main interpreter can handle signals: see
       _Py_ThreadCanHandleSignals(). */
    _Py_atomic_int signals_pending;
    struct _gil_runtime_state gil;
};

/* GIL state */

struct _gilstate_runtime_state {
    /* bpo-26558: Flag to disable PyGILState_Check().
       If set to non-zero, PyGILState_Check() always return 1. */
    int check_enabled;
    /* Assuming the current thread holds the GIL, this is the
       PyThreadState for the current thread. */
    _Py_atomic_address tstate_current;
    /* The single PyInterpreterState used by this process'
       GILState implementation
    */
    /* TODO: Given interp_main, it may be possible to kill this ref */
    PyInterpreterState *autoInterpreterState;
    Py_tss_t autoTSSkey;
};

/* Runtime audit hook state */

typedef struct _Py_AuditHookEntry {
    struct _Py_AuditHookEntry *next;
    Py_AuditHookFunction hookCFunction;
    void *userData;
} _Py_AuditHookEntry;

/* Full Python runtime state */

/* _PyRuntimeState holds the global state for the CPython runtime.
   That data is exposed in the internal API as a static variable (_PyRuntime).
   */
typedef struct pyruntimestate {
    /* Has been initialized to a safe state.

       In order to be effective, this must be set to 0 during or right
       after allocation. */
    int _initialized;

    /* Is running Py_PreInitialize()? */
    int preinitializing;

    /* Is Python preinitialized? Set to 1 by Py_PreInitialize() */
    int preinitialized;

    /* Is Python core initialized? Set to 1 by _Py_InitializeCore() */
    int core_initialized;

    /* Is Python fully initialized? Set to 1 by Py_Initialize() */
    int initialized;

    /* Set by Py_FinalizeEx(). Only reset to NULL if Py_Initialize()
       is called again.

       Use _PyRuntimeState_GetFinalizing() and _PyRuntimeState_SetFinalizing()
       to access it, don't access it directly. */
    _Py_atomic_address _finalizing;

    struct pyinterpreters {
        PyThread_type_lock mutex;
        /* The linked list of interpreters, newest first. */
        PyInterpreterState *head;
        /* The runtime's initial interpreter, which has a special role
           in the operation of the runtime.  It is also often the only
           interpreter. */
        PyInterpreterState *main;
        /* _next_interp_id is an auto-numbered sequence of small
           integers.  It gets initialized in _PyInterpreterState_Init(),
           which is called in Py_Initialize(), and used in
           PyInterpreterState_New().  A negative interpreter ID
           indicates an error occurred.  The main interpreter will
           always have an ID of 0.  Overflow results in a RuntimeError.
           If that becomes a problem later then we can adjust, e.g. by
           using a Python int. */
        int64_t next_id;
    } interpreters;
    // XXX Remove this field once we have a tp_* slot.
    struct _xidregistry {
        PyThread_type_lock mutex;
        struct _xidregitem *head;
    } xidregistry;

    unsigned long main_thread;

#define NEXITFUNCS 32
    void (*exitfuncs[NEXITFUNCS])(void);
    int nexitfuncs;

    struct _ceval_runtime_state ceval;
    struct _gilstate_runtime_state gilstate;

    PyPreConfig preconfig;

    // Audit values must be preserved when Py_Initialize()/Py_Finalize()
    // is called multiple times.
    Py_OpenCodeHookFunction open_code_hook;
    void *open_code_userdata;
    _Py_AuditHookEntry *audit_hook_head;

    struct _Py_unicode_runtime_ids unicode_ids;

    /* All the objects that are shared by the runtime's interpreters. */
    struct _Py_global_objects global_objects;

    /* The following fields are here to avoid allocation during init.
       The data is exposed through _PyRuntimeState pointer fields.
       These fields should not be accessed directly outside of init.

       All other _PyRuntimeState pointer fields are populated when
       needed and default to NULL.

       For now there are some exceptions to that rule, which require
       allocation during init.  These will be addressed on a case-by-case
       basis.  Most notably, we don't pre-allocated the several mutex
       (PyThread_type_lock) fields, because on Windows we only ever get
       a pointer type.
       */

    /* PyInterpreterState.interpreters.main */
    PyInterpreterState _main_interpreter;
} _PyRuntimeState;


/* other API */

PyAPI_DATA(_PyRuntimeState) _PyRuntime;

PyAPI_FUNC(PyStatus) _PyRuntimeState_Init(_PyRuntimeState *runtime);
PyAPI_FUNC(void) _PyRuntimeState_Fini(_PyRuntimeState *runtime);

#ifdef HAVE_FORK
extern PyStatus _PyRuntimeState_ReInitThreads(_PyRuntimeState *runtime);
#endif

/* Initialize _PyRuntimeState.
   Return NULL on success, or return an error message on failure. */
PyAPI_FUNC(PyStatus) _PyRuntime_Initialize(void);

PyAPI_FUNC(void) _PyRuntime_Finalize(void);


static inline PyThreadState*
_PyRuntimeState_GetFinalizing(_PyRuntimeState *runtime) {
    return (PyThreadState*)_Py_atomic_load_relaxed(&runtime->_finalizing);
}

static inline void
_PyRuntimeState_SetFinalizing(_PyRuntimeState *runtime, PyThreadState *tstate) {
    _Py_atomic_store_relaxed(&runtime->_finalizing, (uintptr_t)tstate);
}

#ifdef __cplusplus
}
#endif
#endif /* !Py_INTERNAL_RUNTIME_H */

Filemanager

Name Type Size Permission Actions
pycore_abstract.h File 611 B 0644
pycore_accu.h File 1.1 KB 0644
pycore_asdl.h File 2.96 KB 0644
pycore_ast.h File 28.63 KB 0644
pycore_ast_state.h File 6.4 KB 0644
pycore_atomic.h File 16.58 KB 0644
pycore_atomic_funcs.h File 2.38 KB 0644
pycore_bitutils.h File 5.92 KB 0644
pycore_blocks_output_buffer.h File 8.48 KB 0644
pycore_bytes_methods.h File 3.3 KB 0644
pycore_bytesobject.h File 1.39 KB 0644
pycore_call.h File 3.39 KB 0644
pycore_ceval.h File 4.31 KB 0644
pycore_code.h File 15.56 KB 0644
pycore_compile.h File 1.02 KB 0644
pycore_condvar.h File 2.77 KB 0644
pycore_context.h File 1.21 KB 0644
pycore_dict.h File 5.55 KB 0644
pycore_dtoa.h File 704 B 0644
pycore_emscripten_signal.h File 562 B 0644
pycore_exceptions.h File 842 B 0644
pycore_fileutils.h File 7.23 KB 0644
pycore_floatobject.h File 1.28 KB 0644
pycore_format.h File 480 B 0644
pycore_frame.h File 7.39 KB 0644
pycore_function.h File 413 B 0644
pycore_gc.h File 6.73 KB 0644
pycore_genobject.h File 1.14 KB 0644
pycore_getopt.h File 490 B 0644
pycore_gil.h File 1.53 KB 0644
pycore_global_objects.h File 1.4 KB 0644
pycore_global_strings.h File 12.68 KB 0644
pycore_hamt.h File 3.61 KB 0644
pycore_hashtable.h File 4.1 KB 0644
pycore_import.h File 743 B 0644
pycore_initconfig.h File 5.66 KB 0644
pycore_interp.h File 6.51 KB 0644
pycore_interpreteridobject.h File 562 B 0644
pycore_list.h File 1.32 KB 0644
pycore_long.h File 3.43 KB 0644
pycore_moduleobject.h File 1.02 KB 0644
pycore_namespace.h File 392 B 0644
pycore_object.h File 9.8 KB 0644
pycore_opcode.h File 18.54 KB 0644
pycore_parser.h File 626 B 0644
pycore_pathconfig.h File 606 B 0644
pycore_pyarena.h File 2.67 KB 0644
pycore_pyerrors.h File 2.44 KB 0644
pycore_pyhash.h File 206 B 0644
pycore_pylifecycle.h File 3.42 KB 0644
pycore_pymath.h File 9.21 KB 0644
pycore_pymem.h File 3.62 KB 0644
pycore_pystate.h File 4.15 KB 0644
pycore_runtime.h File 5.85 KB 0644
pycore_runtime_init.h File 47.94 KB 0644
pycore_signal.h File 937 B 0644
pycore_sliceobject.h File 336 B 0644
pycore_strhex.h File 937 B 0644
pycore_structseq.h File 580 B 0644
pycore_symtable.h File 5.51 KB 0644
pycore_sysmodule.h File 605 B 0644
pycore_traceback.h File 3.42 KB 0644
pycore_tuple.h File 2.04 KB 0644
pycore_typeobject.h File 1.13 KB 0644
pycore_ucnhash.h File 898 B 0644
pycore_unicodeobject.h File 1.68 KB 0644
pycore_unionobject.h File 678 B 0644
pycore_warnings.h File 740 B 0644