mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 03:44:55 +00:00 
			
		
		
		
	This change is strictly renames and moving code around. It helps in the following ways: * ensures type-related init functions focus strictly on one of the three aspects (state, objects, types) * passes in PyInterpreterState * to all those functions, simplifying work on moving types/objects/state to the interpreter * consistent naming conventions help make what's going on more clear * keeping API related to a type in the corresponding header file makes it more obvious where to look for it https://bugs.python.org/issue46008
		
			
				
	
	
		
			200 lines
		
	
	
	
		
			5.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			200 lines
		
	
	
	
		
			5.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef Py_INTERNAL_INTERP_H
 | 
						|
#define Py_INTERNAL_INTERP_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_ast_state.h"     // struct ast_state
 | 
						|
#include "pycore_bytesobject.h"   // struct _Py_bytes_state
 | 
						|
#include "pycore_context.h"       // struct _Py_context_state
 | 
						|
#include "pycore_dict.h"          // struct _Py_dict_state
 | 
						|
#include "pycore_exceptions.h"    // struct _Py_exc_state
 | 
						|
#include "pycore_floatobject.h"   // struct _Py_float_state
 | 
						|
#include "pycore_genobject.h"     // struct _Py_async_gen_state
 | 
						|
#include "pycore_gil.h"           // struct _gil_runtime_state
 | 
						|
#include "pycore_gc.h"            // struct _gc_runtime_state
 | 
						|
#include "pycore_list.h"          // struct _Py_list_state
 | 
						|
#include "pycore_tuple.h"         // struct _Py_tuple_state
 | 
						|
#include "pycore_typeobject.h"    // struct type_cache
 | 
						|
#include "pycore_unicodeobject.h" // struct _Py_unicode_state
 | 
						|
#include "pycore_warnings.h"      // struct _warnings_runtime_state
 | 
						|
 | 
						|
struct _pending_calls {
 | 
						|
    PyThread_type_lock lock;
 | 
						|
    /* Request for running pending calls. */
 | 
						|
    _Py_atomic_int calls_to_do;
 | 
						|
    /* Request for looking at the `async_exc` field of the current
 | 
						|
       thread state.
 | 
						|
       Guarded by the GIL. */
 | 
						|
    int async_exc;
 | 
						|
#define NPENDINGCALLS 32
 | 
						|
    struct {
 | 
						|
        int (*func)(void *);
 | 
						|
        void *arg;
 | 
						|
    } calls[NPENDINGCALLS];
 | 
						|
    int first;
 | 
						|
    int last;
 | 
						|
};
 | 
						|
 | 
						|
struct _ceval_state {
 | 
						|
    int recursion_limit;
 | 
						|
    /* This single variable consolidates all requests to break out of
 | 
						|
       the fast path in the eval loop. */
 | 
						|
    _Py_atomic_int eval_breaker;
 | 
						|
    /* Request for dropping the GIL */
 | 
						|
    _Py_atomic_int gil_drop_request;
 | 
						|
    struct _pending_calls pending;
 | 
						|
#ifdef EXPERIMENTAL_ISOLATED_SUBINTERPRETERS
 | 
						|
    struct _gil_runtime_state gil;
 | 
						|
#endif
 | 
						|
};
 | 
						|
 | 
						|
 | 
						|
// atexit state
 | 
						|
typedef struct {
 | 
						|
    PyObject *func;
 | 
						|
    PyObject *args;
 | 
						|
    PyObject *kwargs;
 | 
						|
} atexit_callback;
 | 
						|
 | 
						|
struct atexit_state {
 | 
						|
    atexit_callback **callbacks;
 | 
						|
    int ncallbacks;
 | 
						|
    int callback_len;
 | 
						|
};
 | 
						|
 | 
						|
 | 
						|
/* interpreter state */
 | 
						|
 | 
						|
// The PyInterpreterState typedef is in Include/pystate.h.
 | 
						|
struct _is {
 | 
						|
 | 
						|
    struct _is *next;
 | 
						|
 | 
						|
    struct pythreads {
 | 
						|
        uint64_t next_unique_id;
 | 
						|
        struct _ts *head;
 | 
						|
        /* Used in Modules/_threadmodule.c. */
 | 
						|
        long count;
 | 
						|
        /* Support for runtime thread stack size tuning.
 | 
						|
           A value of 0 means using the platform's default stack size
 | 
						|
           or the size specified by the THREAD_STACK_SIZE macro. */
 | 
						|
        /* Used in Python/thread.c. */
 | 
						|
        size_t stacksize;
 | 
						|
    } threads;
 | 
						|
 | 
						|
    /* Reference to the _PyRuntime global variable. This field exists
 | 
						|
       to not have to pass runtime in addition to tstate to a function.
 | 
						|
       Get runtime from tstate: tstate->interp->runtime. */
 | 
						|
    struct pyruntimestate *runtime;
 | 
						|
 | 
						|
    int64_t id;
 | 
						|
    int64_t id_refcount;
 | 
						|
    int requires_idref;
 | 
						|
    PyThread_type_lock id_mutex;
 | 
						|
 | 
						|
    /* 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;
 | 
						|
    int finalizing;
 | 
						|
 | 
						|
    struct _ceval_state ceval;
 | 
						|
    struct _gc_runtime_state gc;
 | 
						|
 | 
						|
    // sys.modules dictionary
 | 
						|
    PyObject *modules;
 | 
						|
    PyObject *modules_by_index;
 | 
						|
    // Dictionary of the sys module
 | 
						|
    PyObject *sysdict;
 | 
						|
    // Dictionary of the builtins module
 | 
						|
    PyObject *builtins;
 | 
						|
    // importlib module
 | 
						|
    PyObject *importlib;
 | 
						|
    // override for config->use_frozen_modules (for tests)
 | 
						|
    // (-1: "off", 1: "on", 0: no override)
 | 
						|
    int override_frozen_modules;
 | 
						|
 | 
						|
    PyObject *codec_search_path;
 | 
						|
    PyObject *codec_search_cache;
 | 
						|
    PyObject *codec_error_registry;
 | 
						|
    int codecs_initialized;
 | 
						|
 | 
						|
    PyConfig config;
 | 
						|
#ifdef HAVE_DLOPEN
 | 
						|
    int dlopenflags;
 | 
						|
#endif
 | 
						|
 | 
						|
    PyObject *dict;  /* Stores per-interpreter state */
 | 
						|
 | 
						|
    PyObject *builtins_copy;
 | 
						|
    PyObject *import_func;
 | 
						|
    // Initialized to _PyEval_EvalFrameDefault().
 | 
						|
    _PyFrameEvalFunction eval_frame;
 | 
						|
 | 
						|
    Py_ssize_t co_extra_user_count;
 | 
						|
    freefunc co_extra_freefuncs[MAX_CO_EXTRA_USERS];
 | 
						|
 | 
						|
#ifdef HAVE_FORK
 | 
						|
    PyObject *before_forkers;
 | 
						|
    PyObject *after_forkers_parent;
 | 
						|
    PyObject *after_forkers_child;
 | 
						|
#endif
 | 
						|
 | 
						|
    struct _warnings_runtime_state warnings;
 | 
						|
    struct atexit_state atexit;
 | 
						|
 | 
						|
    PyObject *audit_hooks;
 | 
						|
 | 
						|
    struct _Py_bytes_state bytes;
 | 
						|
    struct _Py_unicode_state unicode;
 | 
						|
    struct _Py_float_state float_state;
 | 
						|
    /* Using a cache is very effective since typically only a single slice is
 | 
						|
       created and then deleted again. */
 | 
						|
    PySliceObject *slice_cache;
 | 
						|
 | 
						|
    struct _Py_tuple_state tuple;
 | 
						|
    struct _Py_list_state list;
 | 
						|
    struct _Py_dict_state dict_state;
 | 
						|
    struct _Py_async_gen_state async_gen;
 | 
						|
    struct _Py_context_state context;
 | 
						|
    struct _Py_exc_state exc_state;
 | 
						|
 | 
						|
    struct ast_state ast;
 | 
						|
    struct type_cache type_cache;
 | 
						|
};
 | 
						|
 | 
						|
extern void _PyInterpreterState_ClearModules(PyInterpreterState *interp);
 | 
						|
extern void _PyInterpreterState_Clear(PyThreadState *tstate);
 | 
						|
 | 
						|
 | 
						|
/* cross-interpreter data registry */
 | 
						|
 | 
						|
/* For now we use a global registry of shareable classes.  An
 | 
						|
   alternative would be to add a tp_* slot for a class's
 | 
						|
   crossinterpdatafunc. It would be simpler and more efficient. */
 | 
						|
 | 
						|
struct _xidregitem;
 | 
						|
 | 
						|
struct _xidregitem {
 | 
						|
    PyTypeObject *cls;
 | 
						|
    crossinterpdatafunc getdata;
 | 
						|
    struct _xidregitem *next;
 | 
						|
};
 | 
						|
 | 
						|
PyAPI_FUNC(struct _is*) _PyInterpreterState_LookUpID(int64_t);
 | 
						|
 | 
						|
PyAPI_FUNC(int) _PyInterpreterState_IDInitref(struct _is *);
 | 
						|
PyAPI_FUNC(int) _PyInterpreterState_IDIncref(struct _is *);
 | 
						|
PyAPI_FUNC(void) _PyInterpreterState_IDDecref(struct _is *);
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 | 
						|
#endif /* !Py_INTERNAL_INTERP_H */
 |