blob: 012a3e776948bfcbf56ff04b02f8b437b0d68c64 [file] [log] [blame]
Bram Moolenaardb913952012-06-29 12:54:53 +02001/* vi:set ts=8 sts=4 sw=4 noet:
Bram Moolenaar071d4272004-06-13 20:20:40 +00002 *
3 * VIM - Vi IMproved by Bram Moolenaar
4 *
5 * Do ":help uganda" in Vim to read copying and usage conditions.
6 * Do ":help credits" in Vim to see a list of people who contributed.
7 * See README.txt for an overview of the Vim source code.
8 */
9/*
10 * Python extensions by Paul Moore.
11 * Changes for Unix by David Leonard.
12 *
13 * This consists of four parts:
14 * 1. Python interpreter main program
15 * 2. Python output stream: writes output via [e]msg().
16 * 3. Implementation of the Vim module for Python
17 * 4. Utility functions for handling the interface between Vim and Python.
18 */
19
20#include "vim.h"
21
Bram Moolenaar071d4272004-06-13 20:20:40 +000022#include <limits.h>
23
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010024// uncomment this if used with the debug version of python.
25// Checked on 2.7.4.
26// #define Py_DEBUG
27// Note: most of time you can add -DPy_DEBUG to CFLAGS in place of uncommenting
28// uncomment this if used with the debug version of python, but without its
29// allocator
30// #define Py_DEBUG_NO_PYMALLOC
Bram Moolenaar0014a532013-05-29 21:33:39 +020031
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010032// Python.h defines _POSIX_THREADS itself (if needed)
Bram Moolenaar071d4272004-06-13 20:20:40 +000033#ifdef _POSIX_THREADS
34# undef _POSIX_THREADS
35#endif
36
Bram Moolenaar4f974752019-02-17 17:44:42 +010037#if defined(MSWIN) && defined(HAVE_FCNTL_H)
Bram Moolenaar071d4272004-06-13 20:20:40 +000038# undef HAVE_FCNTL_H
39#endif
40
41#ifdef _DEBUG
42# undef _DEBUG
43#endif
44
Bram Moolenaar6aa2cd42016-02-16 15:06:59 +010045#ifdef HAVE_STRFTIME
46# undef HAVE_STRFTIME
47#endif
48#ifdef HAVE_STRING_H
49# undef HAVE_STRING_H
50#endif
51#ifdef HAVE_PUTENV
52# undef HAVE_PUTENV
53#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +000054#ifdef HAVE_STDARG_H
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010055# undef HAVE_STDARG_H // Python's config.h defines it as well.
Bram Moolenaar071d4272004-06-13 20:20:40 +000056#endif
Bram Moolenaarbe2c9ae2009-11-11 14:06:59 +000057#ifdef _POSIX_C_SOURCE
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010058# undef _POSIX_C_SOURCE // pyconfig.h defines it as well.
Bram Moolenaarbe2c9ae2009-11-11 14:06:59 +000059#endif
60#ifdef _XOPEN_SOURCE
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010061# undef _XOPEN_SOURCE // pyconfig.h defines it as well.
Bram Moolenaarbe2c9ae2009-11-11 14:06:59 +000062#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +000063
Bram Moolenaar0bdda372013-06-10 18:36:24 +020064#define PY_SSIZE_T_CLEAN
65
Bram Moolenaar071d4272004-06-13 20:20:40 +000066#include <Python.h>
Bram Moolenaar0bdda372013-06-10 18:36:24 +020067
68#if !defined(PY_VERSION_HEX) || PY_VERSION_HEX < 0x02050000
69# undef PY_SSIZE_T_CLEAN
70#endif
71
Bram Moolenaar2e2f52a2020-12-21 16:03:02 +010072// these are NULL for Python 2
73#define ERRORS_DECODE_ARG NULL
74#define ERRORS_ENCODE_ARG ERRORS_DECODE_ARG
75
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010076#undef main // Defined in python.h - aargh
77#undef HAVE_FCNTL_H // Clash with os_win32.h
Bram Moolenaar071d4272004-06-13 20:20:40 +000078
Bram Moolenaar65951252019-02-01 22:10:16 +010079// Perhaps leave this out for Python 2.6, which supports bytes?
Bram Moolenaar808c2bc2013-06-23 13:11:18 +020080#define PyBytes_FromString PyString_FromString
Bram Moolenaar792f0e32018-02-27 17:27:13 +010081#define PyBytes_Check PyString_Check
Bram Moolenaar808c2bc2013-06-23 13:11:18 +020082#define PyBytes_AsStringAndSize PyString_AsStringAndSize
Bram Moolenaar65951252019-02-01 22:10:16 +010083#define PyBytes_FromStringAndSize PyString_FromStringAndSize
Bram Moolenaar19e60942011-06-19 00:27:51 +020084
Bram Moolenaar071d4272004-06-13 20:20:40 +000085#if !defined(FEAT_PYTHON) && defined(PROTO)
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010086// Use this to be able to generate prototypes without python being used.
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +000087# define PyObject Py_ssize_t
88# define PyThreadState Py_ssize_t
89# define PyTypeObject Py_ssize_t
90struct PyMethodDef { Py_ssize_t a; };
91# define PySequenceMethods Py_ssize_t
Bram Moolenaar071d4272004-06-13 20:20:40 +000092#endif
93
Bram Moolenaar2afa3232012-06-29 16:28:28 +020094#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
95# define PY_USE_CAPSULE
96#endif
97
Bram Moolenaar2c45e942008-06-04 11:35:26 +000098#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02050000
99# define PyInt Py_ssize_t
100# define PyInquiry lenfunc
101# define PyIntArgFunc ssizeargfunc
102# define PyIntIntArgFunc ssizessizeargfunc
103# define PyIntObjArgProc ssizeobjargproc
104# define PyIntIntObjArgProc ssizessizeobjargproc
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +0000105# define Py_ssize_t_fmt "n"
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000106#else
107# define PyInt int
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200108# define lenfunc inquiry
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000109# define PyInquiry inquiry
110# define PyIntArgFunc intargfunc
111# define PyIntIntArgFunc intintargfunc
112# define PyIntObjArgProc intobjargproc
113# define PyIntIntObjArgProc intintobjargproc
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +0000114# define Py_ssize_t_fmt "i"
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000115#endif
Bram Moolenaara9922d62013-05-30 13:01:18 +0200116#define Py_bytes_fmt "s"
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000117
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100118// Parser flags
Bram Moolenaar071d4272004-06-13 20:20:40 +0000119#define single_input 256
120#define file_input 257
121#define eval_input 258
122
123#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x020300F0
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100124 // Python 2.3: can invoke ":python" recursively.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000125# define PY_CAN_RECURSE
126#endif
127
Bram Moolenaar65951252019-02-01 22:10:16 +0100128#if defined(DYNAMIC_PYTHON) || defined(PROTO)
129# ifndef DYNAMIC_PYTHON
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100130# define HINSTANCE long_u // for generating prototypes
Bram Moolenaar65951252019-02-01 22:10:16 +0100131# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000132
Ken Takatac97b3fe2023-10-11 21:27:06 +0200133# ifdef MSWIN
134# define load_dll vimLoadLib
135# define close_dll FreeLibrary
136# define symbol_from_dll GetProcAddress
137# define load_dll_error GetWin32Error
138# else
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200139# include <dlfcn.h>
140# define FARPROC void*
141# define HINSTANCE void*
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100142# if defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200143# define load_dll(n) dlopen((n), RTLD_LAZY)
144# else
145# define load_dll(n) dlopen((n), RTLD_LAZY|RTLD_GLOBAL)
146# endif
147# define close_dll dlclose
148# define symbol_from_dll dlsym
Martin Tournoij1a3e5742021-07-24 13:57:29 +0200149# define load_dll_error dlerror
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200150# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200151
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100152// This makes if_python.c compile without warnings against Python 2.5
153// on Win32 and Win64.
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200154# undef PyRun_SimpleString
Bram Moolenaardb913952012-06-29 12:54:53 +0200155# undef PyRun_String
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200156# undef PyArg_Parse
157# undef PyArg_ParseTuple
158# undef Py_BuildValue
159# undef Py_InitModule4
160# undef Py_InitModule4_64
Bram Moolenaardb913952012-06-29 12:54:53 +0200161# undef PyObject_CallMethod
Bram Moolenaar9f3685a2013-06-12 14:20:36 +0200162# undef PyObject_CallFunction
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +0000163
Bram Moolenaar071d4272004-06-13 20:20:40 +0000164/*
165 * Wrapper defines
166 */
167# define PyArg_Parse dll_PyArg_Parse
168# define PyArg_ParseTuple dll_PyArg_ParseTuple
Bram Moolenaar19e60942011-06-19 00:27:51 +0200169# define PyMem_Free dll_PyMem_Free
Bram Moolenaardb913952012-06-29 12:54:53 +0200170# define PyMem_Malloc dll_PyMem_Malloc
Bram Moolenaar071d4272004-06-13 20:20:40 +0000171# define PyDict_SetItemString dll_PyDict_SetItemString
172# define PyErr_BadArgument dll_PyErr_BadArgument
Bram Moolenaard5f729c2013-05-15 16:04:40 +0200173# define PyErr_NewException dll_PyErr_NewException
Bram Moolenaar071d4272004-06-13 20:20:40 +0000174# define PyErr_Clear dll_PyErr_Clear
Bram Moolenaarc476e522013-06-23 13:46:40 +0200175# define PyErr_Format dll_PyErr_Format
Bram Moolenaar4d369872013-02-20 16:09:43 +0100176# define PyErr_PrintEx dll_PyErr_PrintEx
Bram Moolenaar071d4272004-06-13 20:20:40 +0000177# define PyErr_NoMemory dll_PyErr_NoMemory
178# define PyErr_Occurred dll_PyErr_Occurred
179# define PyErr_SetNone dll_PyErr_SetNone
180# define PyErr_SetString dll_PyErr_SetString
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200181# define PyErr_SetObject dll_PyErr_SetObject
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200182# define PyErr_ExceptionMatches dll_PyErr_ExceptionMatches
Bram Moolenaar071d4272004-06-13 20:20:40 +0000183# define PyEval_InitThreads dll_PyEval_InitThreads
184# define PyEval_RestoreThread dll_PyEval_RestoreThread
185# define PyEval_SaveThread dll_PyEval_SaveThread
186# ifdef PY_CAN_RECURSE
187# define PyGILState_Ensure dll_PyGILState_Ensure
188# define PyGILState_Release dll_PyGILState_Release
189# endif
190# define PyInt_AsLong dll_PyInt_AsLong
191# define PyInt_FromLong dll_PyInt_FromLong
Bram Moolenaardb913952012-06-29 12:54:53 +0200192# define PyLong_AsLong dll_PyLong_AsLong
193# define PyLong_FromLong dll_PyLong_FromLong
Bram Moolenaar66b79852012-09-21 14:00:35 +0200194# define PyBool_Type (*dll_PyBool_Type)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000195# define PyInt_Type (*dll_PyInt_Type)
Bram Moolenaardb913952012-06-29 12:54:53 +0200196# define PyLong_Type (*dll_PyLong_Type)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000197# define PyList_GetItem dll_PyList_GetItem
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000198# define PyList_Append dll_PyList_Append
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200199# define PyList_Insert dll_PyList_Insert
Bram Moolenaar071d4272004-06-13 20:20:40 +0000200# define PyList_New dll_PyList_New
201# define PyList_SetItem dll_PyList_SetItem
202# define PyList_Size dll_PyList_Size
203# define PyList_Type (*dll_PyList_Type)
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100204# define PyTuple_GetItem dll_PyTuple_GetItem
Yee Cheng Chine06b2ae2025-03-27 20:13:33 +0100205# define PyTuple_SetItem dll_PyTuple_SetItem
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100206# define PyTuple_New dll_PyTuple_New
207# define PyTuple_Size dll_PyTuple_Size
208# define PyTuple_Type (*dll_PyTuple_Type)
Bram Moolenaardb913952012-06-29 12:54:53 +0200209# define PySequence_Check dll_PySequence_Check
210# define PySequence_Size dll_PySequence_Size
211# define PySequence_GetItem dll_PySequence_GetItem
Bram Moolenaara9922d62013-05-30 13:01:18 +0200212# define PySequence_Fast dll_PySequence_Fast
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100213# define PySlice_GetIndicesEx dll_PySlice_GetIndicesEx
Bram Moolenaar071d4272004-06-13 20:20:40 +0000214# define PyImport_ImportModule dll_PyImport_ImportModule
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000215# define PyDict_New dll_PyDict_New
Bram Moolenaar071d4272004-06-13 20:20:40 +0000216# define PyDict_GetItemString dll_PyDict_GetItemString
Bram Moolenaardb913952012-06-29 12:54:53 +0200217# define PyDict_Next dll_PyDict_Next
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200218# define PyDict_Type (*dll_PyDict_Type)
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200219# ifdef PyMapping_Keys
220# define PY_NO_MAPPING_KEYS
Bram Moolenaardb913952012-06-29 12:54:53 +0200221# else
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200222# define PyMapping_Keys dll_PyMapping_Keys
Bram Moolenaardb913952012-06-29 12:54:53 +0200223# endif
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200224# define PyObject_GetItem dll_PyObject_GetItem
Bram Moolenaardb913952012-06-29 12:54:53 +0200225# define PyObject_CallMethod dll_PyObject_CallMethod
226# define PyMapping_Check dll_PyMapping_Check
227# define PyIter_Next dll_PyIter_Next
Bram Moolenaar071d4272004-06-13 20:20:40 +0000228# define PyModule_GetDict dll_PyModule_GetDict
Bram Moolenaarf9c9b322013-06-10 20:47:36 +0200229# define PyModule_AddObject dll_PyModule_AddObject
Bram Moolenaar071d4272004-06-13 20:20:40 +0000230# define PyRun_SimpleString dll_PyRun_SimpleString
Bram Moolenaardb913952012-06-29 12:54:53 +0200231# define PyRun_String dll_PyRun_String
Bram Moolenaard620aa92013-05-17 16:40:06 +0200232# define PyObject_GetAttrString dll_PyObject_GetAttrString
Bram Moolenaara9922d62013-05-30 13:01:18 +0200233# define PyObject_HasAttrString dll_PyObject_HasAttrString
Bram Moolenaard620aa92013-05-17 16:40:06 +0200234# define PyObject_SetAttrString dll_PyObject_SetAttrString
235# define PyObject_CallFunctionObjArgs dll_PyObject_CallFunctionObjArgs
Bram Moolenaar9f3685a2013-06-12 14:20:36 +0200236# define PyObject_CallFunction dll_PyObject_CallFunction
Bram Moolenaarf4258302013-06-02 18:20:17 +0200237# define PyObject_Call dll_PyObject_Call
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200238# define PyObject_Repr dll_PyObject_Repr
Bram Moolenaar071d4272004-06-13 20:20:40 +0000239# define PyString_AsString dll_PyString_AsString
Bram Moolenaarcdab9052012-09-05 19:03:56 +0200240# define PyString_AsStringAndSize dll_PyString_AsStringAndSize
Bram Moolenaar071d4272004-06-13 20:20:40 +0000241# define PyString_FromString dll_PyString_FromString
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200242# define PyString_FromFormat dll_PyString_FromFormat
Bram Moolenaar071d4272004-06-13 20:20:40 +0000243# define PyString_FromStringAndSize dll_PyString_FromStringAndSize
244# define PyString_Size dll_PyString_Size
245# define PyString_Type (*dll_PyString_Type)
Bram Moolenaardb913952012-06-29 12:54:53 +0200246# define PyUnicode_Type (*dll_PyUnicode_Type)
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200247# undef PyUnicode_AsEncodedString
248# define PyUnicode_AsEncodedString py_PyUnicode_AsEncodedString
Bram Moolenaardb913952012-06-29 12:54:53 +0200249# define PyFloat_AsDouble dll_PyFloat_AsDouble
250# define PyFloat_FromDouble dll_PyFloat_FromDouble
251# define PyFloat_Type (*dll_PyFloat_Type)
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200252# define PyNumber_Check dll_PyNumber_Check
253# define PyNumber_Long dll_PyNumber_Long
Bram Moolenaardb913952012-06-29 12:54:53 +0200254# define PyImport_AddModule (*dll_PyImport_AddModule)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000255# define PySys_SetObject dll_PySys_SetObject
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200256# define PySys_GetObject dll_PySys_GetObject
Bram Moolenaar071d4272004-06-13 20:20:40 +0000257# define PySys_SetArgv dll_PySys_SetArgv
258# define PyType_Type (*dll_PyType_Type)
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200259# define PyFile_Type (*dll_PyFile_Type)
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100260# define PySlice_Type (*dll_PySlice_Type)
Bram Moolenaar30fec7b2011-03-26 18:32:05 +0100261# define PyType_Ready (*dll_PyType_Ready)
Bram Moolenaara9922d62013-05-30 13:01:18 +0200262# define PyType_GenericAlloc dll_PyType_GenericAlloc
Bram Moolenaar071d4272004-06-13 20:20:40 +0000263# define Py_BuildValue dll_Py_BuildValue
264# define Py_FindMethod dll_Py_FindMethod
265# define Py_InitModule4 dll_Py_InitModule4
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100266# define Py_SetPythonHome dll_Py_SetPythonHome
Bram Moolenaar071d4272004-06-13 20:20:40 +0000267# define Py_Initialize dll_Py_Initialize
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000268# define Py_Finalize dll_Py_Finalize
269# define Py_IsInitialized dll_Py_IsInitialized
Bram Moolenaar071d4272004-06-13 20:20:40 +0000270# define _PyObject_New dll__PyObject_New
Bram Moolenaar774267b2013-05-21 20:51:59 +0200271# define _PyObject_GC_New dll__PyObject_GC_New
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200272# ifdef PyObject_GC_Del
273# define Py_underscore_GC
274# define _PyObject_GC_Del dll__PyObject_GC_Del
275# define _PyObject_GC_UnTrack dll__PyObject_GC_UnTrack
276# else
277# define PyObject_GC_Del dll_PyObject_GC_Del
278# define PyObject_GC_UnTrack dll_PyObject_GC_UnTrack
279# endif
Bram Moolenaare7211222012-06-30 13:21:08 +0200280# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
281# define _PyObject_NextNotImplemented (*dll__PyObject_NextNotImplemented)
282# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000283# define _Py_NoneStruct (*dll__Py_NoneStruct)
Bram Moolenaar66b79852012-09-21 14:00:35 +0200284# define _Py_ZeroStruct (*dll__Py_ZeroStruct)
285# define _Py_TrueStruct (*dll__Py_TrueStruct)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000286# define PyObject_Init dll__PyObject_Init
Bram Moolenaardb913952012-06-29 12:54:53 +0200287# define PyObject_GetIter dll_PyObject_GetIter
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200288# define PyObject_IsTrue dll_PyObject_IsTrue
Bram Moolenaar071d4272004-06-13 20:20:40 +0000289# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02020000
290# define PyType_IsSubtype dll_PyType_IsSubtype
Bram Moolenaar0014a532013-05-29 21:33:39 +0200291# ifdef Py_DEBUG
292# define _Py_NegativeRefcount dll__Py_NegativeRefcount
293# define _Py_RefTotal (*dll__Py_RefTotal)
294# define _Py_Dealloc dll__Py_Dealloc
295# endif
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200296# endif
297# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02030000
Bram Moolenaar0014a532013-05-29 21:33:39 +0200298# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
299# define _PyObject_DebugMalloc dll__PyObject_DebugMalloc
300# define _PyObject_DebugFree dll__PyObject_DebugFree
301# else
302# define PyObject_Malloc dll_PyObject_Malloc
303# define PyObject_Free dll_PyObject_Free
304# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000305# endif
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200306# ifdef PY_USE_CAPSULE
307# define PyCapsule_New dll_PyCapsule_New
308# define PyCapsule_GetPointer dll_PyCapsule_GetPointer
309# else
310# define PyCObject_FromVoidPtr dll_PyCObject_FromVoidPtr
311# define PyCObject_AsVoidPtr dll_PyCObject_AsVoidPtr
312# endif
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200313# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
314# define Py_NoSiteFlag (*dll_Py_NoSiteFlag)
315# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000316
317/*
318 * Pointers for dynamic link
319 */
320static int(*dll_PyArg_Parse)(PyObject *, char *, ...);
321static int(*dll_PyArg_ParseTuple)(PyObject *, char *, ...);
Yee Cheng Chind606fcc2023-09-20 19:59:47 +0200322static void(*dll_PyMem_Free)(void *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200323static void* (*dll_PyMem_Malloc)(size_t);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000324static int(*dll_PyDict_SetItemString)(PyObject *dp, char *key, PyObject *item);
325static int(*dll_PyErr_BadArgument)(void);
Bram Moolenaard5f729c2013-05-15 16:04:40 +0200326static PyObject *(*dll_PyErr_NewException)(char *, PyObject *, PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000327static void(*dll_PyErr_Clear)(void);
Bram Moolenaarc476e522013-06-23 13:46:40 +0200328static PyObject*(*dll_PyErr_Format)(PyObject *, const char *, ...);
Bram Moolenaar4d369872013-02-20 16:09:43 +0100329static void(*dll_PyErr_PrintEx)(int);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000330static PyObject*(*dll_PyErr_NoMemory)(void);
331static PyObject*(*dll_PyErr_Occurred)(void);
332static void(*dll_PyErr_SetNone)(PyObject *);
333static void(*dll_PyErr_SetString)(PyObject *, const char *);
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200334static void(*dll_PyErr_SetObject)(PyObject *, PyObject *);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200335static int(*dll_PyErr_ExceptionMatches)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000336static void(*dll_PyEval_InitThreads)(void);
337static void(*dll_PyEval_RestoreThread)(PyThreadState *);
338static PyThreadState*(*dll_PyEval_SaveThread)(void);
339# ifdef PY_CAN_RECURSE
340static PyGILState_STATE (*dll_PyGILState_Ensure)(void);
341static void (*dll_PyGILState_Release)(PyGILState_STATE);
Bram Moolenaardb913952012-06-29 12:54:53 +0200342# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000343static long(*dll_PyInt_AsLong)(PyObject *);
344static PyObject*(*dll_PyInt_FromLong)(long);
Bram Moolenaardb913952012-06-29 12:54:53 +0200345static long(*dll_PyLong_AsLong)(PyObject *);
346static PyObject*(*dll_PyLong_FromLong)(long);
Bram Moolenaar66b79852012-09-21 14:00:35 +0200347static PyTypeObject* dll_PyBool_Type;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000348static PyTypeObject* dll_PyInt_Type;
Bram Moolenaardb913952012-06-29 12:54:53 +0200349static PyTypeObject* dll_PyLong_Type;
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000350static PyObject*(*dll_PyList_GetItem)(PyObject *, PyInt);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200351static int(*dll_PyList_Append)(PyObject *, PyObject *);
Bram Moolenaard5e376e2013-06-24 20:32:57 +0200352static int(*dll_PyList_Insert)(PyObject *, PyInt, PyObject *);
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000353static PyObject*(*dll_PyList_New)(PyInt size);
354static int(*dll_PyList_SetItem)(PyObject *, PyInt, PyObject *);
355static PyInt(*dll_PyList_Size)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000356static PyTypeObject* dll_PyList_Type;
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100357static PyObject*(*dll_PyTuple_GetItem)(PyObject *, PyInt);
358static int(*dll_PyTuple_SetItem)(PyObject *, PyInt, PyObject *);
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100359static PyObject*(*dll_PyTuple_New)(PyInt size);
360static PyInt(*dll_PyTuple_Size)(PyObject *);
361static PyTypeObject* dll_PyTuple_Type;
Bram Moolenaardb913952012-06-29 12:54:53 +0200362static int (*dll_PySequence_Check)(PyObject *);
363static PyInt(*dll_PySequence_Size)(PyObject *);
364static PyObject*(*dll_PySequence_GetItem)(PyObject *, PyInt);
Bram Moolenaara9922d62013-05-30 13:01:18 +0200365static PyObject*(*dll_PySequence_Fast)(PyObject *, const char *);
Bram Moolenaar5395e7a2014-01-14 19:35:56 +0100366static int (*dll_PySlice_GetIndicesEx)(PySliceObject *r, PyInt length,
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100367 PyInt *start, PyInt *stop, PyInt *step,
368 PyInt *slicelen);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000369static PyObject*(*dll_PyImport_ImportModule)(const char *);
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000370static PyObject*(*dll_PyDict_New)(void);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000371static PyObject*(*dll_PyDict_GetItemString)(PyObject *, const char *);
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200372static int (*dll_PyDict_Next)(PyObject *, PyInt *, PyObject **, PyObject **);
373static PyTypeObject* dll_PyDict_Type;
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200374# ifndef PY_NO_MAPPING_KEYS
375static PyObject* (*dll_PyMapping_Keys)(PyObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200376# endif
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200377static PyObject* (*dll_PyObject_GetItem)(PyObject *, PyObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200378static PyObject* (*dll_PyObject_CallMethod)(PyObject *, char *, PyObject *);
379static int (*dll_PyMapping_Check)(PyObject *);
380static PyObject* (*dll_PyIter_Next)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000381static PyObject*(*dll_PyModule_GetDict)(PyObject *);
Bram Moolenaarf9c9b322013-06-10 20:47:36 +0200382static int(*dll_PyModule_AddObject)(PyObject *, const char *, PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000383static int(*dll_PyRun_SimpleString)(char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200384static PyObject *(*dll_PyRun_String)(char *, int, PyObject *, PyObject *);
Bram Moolenaard620aa92013-05-17 16:40:06 +0200385static PyObject* (*dll_PyObject_GetAttrString)(PyObject *, const char *);
Bram Moolenaara9922d62013-05-30 13:01:18 +0200386static int (*dll_PyObject_HasAttrString)(PyObject *, const char *);
Bram Moolenaar0b400082013-11-03 00:28:25 +0100387static int (*dll_PyObject_SetAttrString)(PyObject *, const char *, PyObject *);
Bram Moolenaard620aa92013-05-17 16:40:06 +0200388static PyObject* (*dll_PyObject_CallFunctionObjArgs)(PyObject *, ...);
Bram Moolenaar9f3685a2013-06-12 14:20:36 +0200389static PyObject* (*dll_PyObject_CallFunction)(PyObject *, char *, ...);
Bram Moolenaarf4258302013-06-02 18:20:17 +0200390static PyObject* (*dll_PyObject_Call)(PyObject *, PyObject *, PyObject *);
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200391static PyObject* (*dll_PyObject_Repr)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000392static char*(*dll_PyString_AsString)(PyObject *);
Bram Moolenaard5e376e2013-06-24 20:32:57 +0200393static int(*dll_PyString_AsStringAndSize)(PyObject *, char **, PyInt *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000394static PyObject*(*dll_PyString_FromString)(const char *);
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200395static PyObject*(*dll_PyString_FromFormat)(const char *, ...);
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000396static PyObject*(*dll_PyString_FromStringAndSize)(const char *, PyInt);
397static PyInt(*dll_PyString_Size)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000398static PyTypeObject* dll_PyString_Type;
Bram Moolenaardb913952012-06-29 12:54:53 +0200399static PyTypeObject* dll_PyUnicode_Type;
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200400static PyObject *(*py_PyUnicode_AsEncodedString)(PyObject *, char *, char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200401static double(*dll_PyFloat_AsDouble)(PyObject *);
402static PyObject*(*dll_PyFloat_FromDouble)(double);
403static PyTypeObject* dll_PyFloat_Type;
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200404static int(*dll_PyNumber_Check)(PyObject *);
405static PyObject*(*dll_PyNumber_Long)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000406static int(*dll_PySys_SetObject)(char *, PyObject *);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200407static PyObject *(*dll_PySys_GetObject)(char *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000408static int(*dll_PySys_SetArgv)(int, char **);
409static PyTypeObject* dll_PyType_Type;
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200410static PyTypeObject* dll_PyFile_Type;
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100411static PyTypeObject* dll_PySlice_Type;
Bram Moolenaar30fec7b2011-03-26 18:32:05 +0100412static int (*dll_PyType_Ready)(PyTypeObject *type);
Bram Moolenaara9922d62013-05-30 13:01:18 +0200413static PyObject* (*dll_PyType_GenericAlloc)(PyTypeObject *type, PyInt nitems);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000414static PyObject*(*dll_Py_BuildValue)(char *, ...);
415static PyObject*(*dll_Py_FindMethod)(struct PyMethodDef[], PyObject *, char *);
416static PyObject*(*dll_Py_InitModule4)(char *, struct PyMethodDef *, char *, PyObject *, int);
Bram Moolenaardb913952012-06-29 12:54:53 +0200417static PyObject*(*dll_PyImport_AddModule)(char *);
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100418static void(*dll_Py_SetPythonHome)(char *home);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000419static void(*dll_Py_Initialize)(void);
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000420static void(*dll_Py_Finalize)(void);
421static int(*dll_Py_IsInitialized)(void);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000422static PyObject*(*dll__PyObject_New)(PyTypeObject *, PyObject *);
Bram Moolenaar774267b2013-05-21 20:51:59 +0200423static PyObject*(*dll__PyObject_GC_New)(PyTypeObject *);
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200424# ifdef Py_underscore_GC
425static void(*dll__PyObject_GC_Del)(void *);
426static void(*dll__PyObject_GC_UnTrack)(void *);
427# else
Bram Moolenaar774267b2013-05-21 20:51:59 +0200428static void(*dll_PyObject_GC_Del)(void *);
429static void(*dll_PyObject_GC_UnTrack)(void *);
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200430# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000431static PyObject*(*dll__PyObject_Init)(PyObject *, PyTypeObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200432static PyObject* (*dll_PyObject_GetIter)(PyObject *);
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200433static int (*dll_PyObject_IsTrue)(PyObject *);
Bram Moolenaare7211222012-06-30 13:21:08 +0200434# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
Bram Moolenaardb913952012-06-29 12:54:53 +0200435static iternextfunc dll__PyObject_NextNotImplemented;
Bram Moolenaare7211222012-06-30 13:21:08 +0200436# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000437static PyObject* dll__Py_NoneStruct;
Bram Moolenaar66b79852012-09-21 14:00:35 +0200438static PyObject* _Py_ZeroStruct;
439static PyObject* dll__Py_TrueStruct;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000440# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02020000
441static int (*dll_PyType_IsSubtype)(PyTypeObject *, PyTypeObject *);
Bram Moolenaar0014a532013-05-29 21:33:39 +0200442# ifdef Py_DEBUG
443static void (*dll__Py_NegativeRefcount)(const char *fname, int lineno, PyObject *op);
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200444static PyInt* dll__Py_RefTotal;
Bram Moolenaar0014a532013-05-29 21:33:39 +0200445static void (*dll__Py_Dealloc)(PyObject *obj);
446# endif
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200447# endif
448# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02030000
Bram Moolenaar0014a532013-05-29 21:33:39 +0200449# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
450static void (*dll__PyObject_DebugFree)(void*);
451static void* (*dll__PyObject_DebugMalloc)(size_t);
452# else
Bram Moolenaar071d4272004-06-13 20:20:40 +0000453static void* (*dll_PyObject_Malloc)(size_t);
454static void (*dll_PyObject_Free)(void*);
Bram Moolenaar0014a532013-05-29 21:33:39 +0200455# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000456# endif
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200457# ifdef PY_USE_CAPSULE
Bram Moolenaardb913952012-06-29 12:54:53 +0200458static PyObject* (*dll_PyCapsule_New)(void *, char *, PyCapsule_Destructor);
459static void* (*dll_PyCapsule_GetPointer)(PyObject *, char *);
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200460# else
Bram Moolenaar221d6872012-06-30 13:34:34 +0200461static PyObject* (*dll_PyCObject_FromVoidPtr)(void *cobj, void (*destr)(void *));
462static void* (*dll_PyCObject_AsVoidPtr)(PyObject *);
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200463# endif
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200464# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
465static int* dll_Py_NoSiteFlag;
466# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000467
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100468static HINSTANCE hinstPython = 0; // Instance of python.dll
Bram Moolenaar071d4272004-06-13 20:20:40 +0000469
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100470// Imported exception objects
Bram Moolenaar071d4272004-06-13 20:20:40 +0000471static PyObject *imp_PyExc_AttributeError;
472static PyObject *imp_PyExc_IndexError;
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200473static PyObject *imp_PyExc_KeyError;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000474static PyObject *imp_PyExc_KeyboardInterrupt;
475static PyObject *imp_PyExc_TypeError;
476static PyObject *imp_PyExc_ValueError;
Bram Moolenaar41009372013-07-01 22:03:04 +0200477static PyObject *imp_PyExc_SystemExit;
Bram Moolenaar8661b172013-05-15 15:44:28 +0200478static PyObject *imp_PyExc_RuntimeError;
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200479static PyObject *imp_PyExc_ImportError;
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200480static PyObject *imp_PyExc_OverflowError;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000481
482# define PyExc_AttributeError imp_PyExc_AttributeError
483# define PyExc_IndexError imp_PyExc_IndexError
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200484# define PyExc_KeyError imp_PyExc_KeyError
Bram Moolenaar071d4272004-06-13 20:20:40 +0000485# define PyExc_KeyboardInterrupt imp_PyExc_KeyboardInterrupt
486# define PyExc_TypeError imp_PyExc_TypeError
487# define PyExc_ValueError imp_PyExc_ValueError
Bram Moolenaar41009372013-07-01 22:03:04 +0200488# define PyExc_SystemExit imp_PyExc_SystemExit
Bram Moolenaar8661b172013-05-15 15:44:28 +0200489# define PyExc_RuntimeError imp_PyExc_RuntimeError
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200490# define PyExc_ImportError imp_PyExc_ImportError
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200491# define PyExc_OverflowError imp_PyExc_OverflowError
Bram Moolenaar071d4272004-06-13 20:20:40 +0000492
493/*
494 * Table of name to function pointer of python.
495 */
496# define PYTHON_PROC FARPROC
497static struct
498{
499 char *name;
500 PYTHON_PROC *ptr;
501} python_funcname_table[] =
502{
Ken Takatac97b3fe2023-10-11 21:27:06 +0200503# ifdef PY_SSIZE_T_CLEAN
Bram Moolenaare8cdcef2012-09-12 20:21:43 +0200504 {"_PyArg_Parse_SizeT", (PYTHON_PROC*)&dll_PyArg_Parse},
505 {"_PyArg_ParseTuple_SizeT", (PYTHON_PROC*)&dll_PyArg_ParseTuple},
506 {"_Py_BuildValue_SizeT", (PYTHON_PROC*)&dll_Py_BuildValue},
Ken Takatac97b3fe2023-10-11 21:27:06 +0200507# else
508 {"PyArg_Parse", (PYTHON_PROC*)&dll_PyArg_Parse},
509 {"PyArg_ParseTuple", (PYTHON_PROC*)&dll_PyArg_ParseTuple},
510 {"Py_BuildValue", (PYTHON_PROC*)&dll_Py_BuildValue},
Bram Moolenaar65951252019-02-01 22:10:16 +0100511# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200512 {"PyMem_Free", (PYTHON_PROC*)&dll_PyMem_Free},
Bram Moolenaardb913952012-06-29 12:54:53 +0200513 {"PyMem_Malloc", (PYTHON_PROC*)&dll_PyMem_Malloc},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000514 {"PyDict_SetItemString", (PYTHON_PROC*)&dll_PyDict_SetItemString},
515 {"PyErr_BadArgument", (PYTHON_PROC*)&dll_PyErr_BadArgument},
Bram Moolenaard5f729c2013-05-15 16:04:40 +0200516 {"PyErr_NewException", (PYTHON_PROC*)&dll_PyErr_NewException},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000517 {"PyErr_Clear", (PYTHON_PROC*)&dll_PyErr_Clear},
Bram Moolenaarc476e522013-06-23 13:46:40 +0200518 {"PyErr_Format", (PYTHON_PROC*)&dll_PyErr_Format},
Bram Moolenaar4d369872013-02-20 16:09:43 +0100519 {"PyErr_PrintEx", (PYTHON_PROC*)&dll_PyErr_PrintEx},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000520 {"PyErr_NoMemory", (PYTHON_PROC*)&dll_PyErr_NoMemory},
521 {"PyErr_Occurred", (PYTHON_PROC*)&dll_PyErr_Occurred},
522 {"PyErr_SetNone", (PYTHON_PROC*)&dll_PyErr_SetNone},
523 {"PyErr_SetString", (PYTHON_PROC*)&dll_PyErr_SetString},
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200524 {"PyErr_SetObject", (PYTHON_PROC*)&dll_PyErr_SetObject},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200525 {"PyErr_ExceptionMatches", (PYTHON_PROC*)&dll_PyErr_ExceptionMatches},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000526 {"PyEval_InitThreads", (PYTHON_PROC*)&dll_PyEval_InitThreads},
527 {"PyEval_RestoreThread", (PYTHON_PROC*)&dll_PyEval_RestoreThread},
528 {"PyEval_SaveThread", (PYTHON_PROC*)&dll_PyEval_SaveThread},
529# ifdef PY_CAN_RECURSE
530 {"PyGILState_Ensure", (PYTHON_PROC*)&dll_PyGILState_Ensure},
531 {"PyGILState_Release", (PYTHON_PROC*)&dll_PyGILState_Release},
532# endif
533 {"PyInt_AsLong", (PYTHON_PROC*)&dll_PyInt_AsLong},
534 {"PyInt_FromLong", (PYTHON_PROC*)&dll_PyInt_FromLong},
Bram Moolenaardb913952012-06-29 12:54:53 +0200535 {"PyLong_AsLong", (PYTHON_PROC*)&dll_PyLong_AsLong},
536 {"PyLong_FromLong", (PYTHON_PROC*)&dll_PyLong_FromLong},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200537 {"PyBool_Type", (PYTHON_PROC*)&dll_PyBool_Type},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000538 {"PyInt_Type", (PYTHON_PROC*)&dll_PyInt_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200539 {"PyLong_Type", (PYTHON_PROC*)&dll_PyLong_Type},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000540 {"PyList_GetItem", (PYTHON_PROC*)&dll_PyList_GetItem},
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000541 {"PyList_Append", (PYTHON_PROC*)&dll_PyList_Append},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200542 {"PyList_Insert", (PYTHON_PROC*)&dll_PyList_Insert},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000543 {"PyList_New", (PYTHON_PROC*)&dll_PyList_New},
544 {"PyList_SetItem", (PYTHON_PROC*)&dll_PyList_SetItem},
545 {"PyList_Size", (PYTHON_PROC*)&dll_PyList_Size},
546 {"PyList_Type", (PYTHON_PROC*)&dll_PyList_Type},
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100547 {"PyTuple_GetItem", (PYTHON_PROC*)&dll_PyTuple_GetItem},
548 {"PyTuple_SetItem", (PYTHON_PROC*)&dll_PyTuple_SetItem},
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100549 {"PyTuple_New", (PYTHON_PROC*)&dll_PyTuple_New},
550 {"PyTuple_Size", (PYTHON_PROC*)&dll_PyTuple_Size},
551 {"PyTuple_Type", (PYTHON_PROC*)&dll_PyTuple_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200552 {"PySequence_Size", (PYTHON_PROC*)&dll_PySequence_Size},
553 {"PySequence_Check", (PYTHON_PROC*)&dll_PySequence_Check},
Bram Moolenaara9922d62013-05-30 13:01:18 +0200554 {"PySequence_GetItem", (PYTHON_PROC*)&dll_PySequence_GetItem},
555 {"PySequence_Fast", (PYTHON_PROC*)&dll_PySequence_Fast},
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100556 {"PySlice_GetIndicesEx", (PYTHON_PROC*)&dll_PySlice_GetIndicesEx},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000557 {"PyImport_ImportModule", (PYTHON_PROC*)&dll_PyImport_ImportModule},
558 {"PyDict_GetItemString", (PYTHON_PROC*)&dll_PyDict_GetItemString},
Bram Moolenaardb913952012-06-29 12:54:53 +0200559 {"PyDict_Next", (PYTHON_PROC*)&dll_PyDict_Next},
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000560 {"PyDict_New", (PYTHON_PROC*)&dll_PyDict_New},
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200561 {"PyDict_Type", (PYTHON_PROC*)&dll_PyDict_Type},
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200562# ifndef PY_NO_MAPPING_KEYS
563 {"PyMapping_Keys", (PYTHON_PROC*)&dll_PyMapping_Keys},
Bram Moolenaardb913952012-06-29 12:54:53 +0200564# endif
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200565 {"PyObject_GetItem", (PYTHON_PROC*)&dll_PyObject_GetItem},
Bram Moolenaardb913952012-06-29 12:54:53 +0200566 {"PyObject_CallMethod", (PYTHON_PROC*)&dll_PyObject_CallMethod},
567 {"PyMapping_Check", (PYTHON_PROC*)&dll_PyMapping_Check},
568 {"PyIter_Next", (PYTHON_PROC*)&dll_PyIter_Next},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000569 {"PyModule_GetDict", (PYTHON_PROC*)&dll_PyModule_GetDict},
Bram Moolenaarf9c9b322013-06-10 20:47:36 +0200570 {"PyModule_AddObject", (PYTHON_PROC*)&dll_PyModule_AddObject},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000571 {"PyRun_SimpleString", (PYTHON_PROC*)&dll_PyRun_SimpleString},
Bram Moolenaardb913952012-06-29 12:54:53 +0200572 {"PyRun_String", (PYTHON_PROC*)&dll_PyRun_String},
Bram Moolenaard620aa92013-05-17 16:40:06 +0200573 {"PyObject_GetAttrString", (PYTHON_PROC*)&dll_PyObject_GetAttrString},
Bram Moolenaara9922d62013-05-30 13:01:18 +0200574 {"PyObject_HasAttrString", (PYTHON_PROC*)&dll_PyObject_HasAttrString},
Bram Moolenaard620aa92013-05-17 16:40:06 +0200575 {"PyObject_SetAttrString", (PYTHON_PROC*)&dll_PyObject_SetAttrString},
576 {"PyObject_CallFunctionObjArgs", (PYTHON_PROC*)&dll_PyObject_CallFunctionObjArgs},
Bram Moolenaar9f3685a2013-06-12 14:20:36 +0200577 {"PyObject_CallFunction", (PYTHON_PROC*)&dll_PyObject_CallFunction},
Bram Moolenaarf4258302013-06-02 18:20:17 +0200578 {"PyObject_Call", (PYTHON_PROC*)&dll_PyObject_Call},
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200579 {"PyObject_Repr", (PYTHON_PROC*)&dll_PyObject_Repr},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000580 {"PyString_AsString", (PYTHON_PROC*)&dll_PyString_AsString},
Bram Moolenaarcdab9052012-09-05 19:03:56 +0200581 {"PyString_AsStringAndSize", (PYTHON_PROC*)&dll_PyString_AsStringAndSize},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000582 {"PyString_FromString", (PYTHON_PROC*)&dll_PyString_FromString},
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200583 {"PyString_FromFormat", (PYTHON_PROC*)&dll_PyString_FromFormat},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000584 {"PyString_FromStringAndSize", (PYTHON_PROC*)&dll_PyString_FromStringAndSize},
585 {"PyString_Size", (PYTHON_PROC*)&dll_PyString_Size},
586 {"PyString_Type", (PYTHON_PROC*)&dll_PyString_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200587 {"PyUnicode_Type", (PYTHON_PROC*)&dll_PyUnicode_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200588 {"PyFloat_Type", (PYTHON_PROC*)&dll_PyFloat_Type},
589 {"PyFloat_AsDouble", (PYTHON_PROC*)&dll_PyFloat_AsDouble},
590 {"PyFloat_FromDouble", (PYTHON_PROC*)&dll_PyFloat_FromDouble},
591 {"PyImport_AddModule", (PYTHON_PROC*)&dll_PyImport_AddModule},
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200592 {"PyNumber_Check", (PYTHON_PROC*)&dll_PyNumber_Check},
593 {"PyNumber_Long", (PYTHON_PROC*)&dll_PyNumber_Long},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000594 {"PySys_SetObject", (PYTHON_PROC*)&dll_PySys_SetObject},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200595 {"PySys_GetObject", (PYTHON_PROC*)&dll_PySys_GetObject},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000596 {"PySys_SetArgv", (PYTHON_PROC*)&dll_PySys_SetArgv},
597 {"PyType_Type", (PYTHON_PROC*)&dll_PyType_Type},
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200598 {"PyFile_Type", (PYTHON_PROC*)&dll_PyFile_Type},
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100599 {"PySlice_Type", (PYTHON_PROC*)&dll_PySlice_Type},
Bram Moolenaar30fec7b2011-03-26 18:32:05 +0100600 {"PyType_Ready", (PYTHON_PROC*)&dll_PyType_Ready},
Bram Moolenaara9922d62013-05-30 13:01:18 +0200601 {"PyType_GenericAlloc", (PYTHON_PROC*)&dll_PyType_GenericAlloc},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000602 {"Py_FindMethod", (PYTHON_PROC*)&dll_Py_FindMethod},
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100603 {"Py_SetPythonHome", (PYTHON_PROC*)&dll_Py_SetPythonHome},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000604 {"Py_Initialize", (PYTHON_PROC*)&dll_Py_Initialize},
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000605 {"Py_Finalize", (PYTHON_PROC*)&dll_Py_Finalize},
606 {"Py_IsInitialized", (PYTHON_PROC*)&dll_Py_IsInitialized},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000607 {"_PyObject_New", (PYTHON_PROC*)&dll__PyObject_New},
Bram Moolenaar774267b2013-05-21 20:51:59 +0200608 {"_PyObject_GC_New", (PYTHON_PROC*)&dll__PyObject_GC_New},
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200609# ifdef Py_underscore_GC
610 {"_PyObject_GC_Del", (PYTHON_PROC*)&dll__PyObject_GC_Del},
611 {"_PyObject_GC_UnTrack", (PYTHON_PROC*)&dll__PyObject_GC_UnTrack},
612# else
Bram Moolenaar774267b2013-05-21 20:51:59 +0200613 {"PyObject_GC_Del", (PYTHON_PROC*)&dll_PyObject_GC_Del},
614 {"PyObject_GC_UnTrack", (PYTHON_PROC*)&dll_PyObject_GC_UnTrack},
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200615# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000616 {"PyObject_Init", (PYTHON_PROC*)&dll__PyObject_Init},
Bram Moolenaardb913952012-06-29 12:54:53 +0200617 {"PyObject_GetIter", (PYTHON_PROC*)&dll_PyObject_GetIter},
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200618 {"PyObject_IsTrue", (PYTHON_PROC*)&dll_PyObject_IsTrue},
Bram Moolenaare7211222012-06-30 13:21:08 +0200619# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
Bram Moolenaardb913952012-06-29 12:54:53 +0200620 {"_PyObject_NextNotImplemented", (PYTHON_PROC*)&dll__PyObject_NextNotImplemented},
Bram Moolenaare7211222012-06-30 13:21:08 +0200621# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000622 {"_Py_NoneStruct", (PYTHON_PROC*)&dll__Py_NoneStruct},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200623 {"_Py_ZeroStruct", (PYTHON_PROC*)&dll__Py_ZeroStruct},
624 {"_Py_TrueStruct", (PYTHON_PROC*)&dll__Py_TrueStruct},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000625# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02020000
Bram Moolenaar0014a532013-05-29 21:33:39 +0200626# ifdef Py_DEBUG
627 {"_Py_NegativeRefcount", (PYTHON_PROC*)&dll__Py_NegativeRefcount},
628 {"_Py_RefTotal", (PYTHON_PROC*)&dll__Py_RefTotal},
629 {"_Py_Dealloc", (PYTHON_PROC*)&dll__Py_Dealloc},
630# endif
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200631 {"PyType_IsSubtype", (PYTHON_PROC*)&dll_PyType_IsSubtype},
632# endif
633# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02030000
Bram Moolenaar0014a532013-05-29 21:33:39 +0200634# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
635 {"_PyObject_DebugFree", (PYTHON_PROC*)&dll__PyObject_DebugFree},
636 {"_PyObject_DebugMalloc", (PYTHON_PROC*)&dll__PyObject_DebugMalloc},
637# else
Bram Moolenaar071d4272004-06-13 20:20:40 +0000638 {"PyObject_Malloc", (PYTHON_PROC*)&dll_PyObject_Malloc},
639 {"PyObject_Free", (PYTHON_PROC*)&dll_PyObject_Free},
Bram Moolenaar0014a532013-05-29 21:33:39 +0200640# endif
641# endif
642# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02050000 \
Bram Moolenaara2aa31a2014-02-23 22:52:40 +0100643 && SIZEOF_SIZE_T != VIM_SIZEOF_INT
Bram Moolenaar0014a532013-05-29 21:33:39 +0200644# ifdef Py_DEBUG
645 {"Py_InitModule4TraceRefs_64", (PYTHON_PROC*)&dll_Py_InitModule4},
646# else
647 {"Py_InitModule4_64", (PYTHON_PROC*)&dll_Py_InitModule4},
648# endif
649# else
650# ifdef Py_DEBUG
651 {"Py_InitModule4TraceRefs", (PYTHON_PROC*)&dll_Py_InitModule4},
652# else
653 {"Py_InitModule4", (PYTHON_PROC*)&dll_Py_InitModule4},
654# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000655# endif
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200656# ifdef PY_USE_CAPSULE
Bram Moolenaardb913952012-06-29 12:54:53 +0200657 {"PyCapsule_New", (PYTHON_PROC*)&dll_PyCapsule_New},
658 {"PyCapsule_GetPointer", (PYTHON_PROC*)&dll_PyCapsule_GetPointer},
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200659# else
660 {"PyCObject_FromVoidPtr", (PYTHON_PROC*)&dll_PyCObject_FromVoidPtr},
661 {"PyCObject_AsVoidPtr", (PYTHON_PROC*)&dll_PyCObject_AsVoidPtr},
662# endif
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200663# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
664 {"Py_NoSiteFlag", (PYTHON_PROC*)&dll_Py_NoSiteFlag},
665# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000666 {"", NULL},
667};
668
669/*
Bram Moolenaar071d4272004-06-13 20:20:40 +0000670 * Load library and get all pointers.
671 * Parameter 'libname' provides name of DLL.
672 * Return OK or FAIL.
673 */
674 static int
675python_runtime_link_init(char *libname, int verbose)
676{
677 int i;
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200678 PYTHON_PROC *ucs_as_encoded_string =
679 (PYTHON_PROC*)&py_PyUnicode_AsEncodedString;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000680
Bram Moolenaar65951252019-02-01 22:10:16 +0100681# if !(defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)) && defined(UNIX) && defined(FEAT_PYTHON3)
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100682 // Can't have Python and Python3 loaded at the same time.
Dominique Pelleaf4a61a2021-12-27 17:21:41 +0000683 // It causes a crash, because RTLD_GLOBAL is needed for
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100684 // standard C extension libraries of one or both python versions.
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200685 if (python3_loaded())
686 {
Bram Moolenaar9dc93ae2011-08-28 16:00:19 +0200687 if (verbose)
Bram Moolenaar9d00e4a2022-01-05 17:49:15 +0000688 emsg(_(e_this_vim_cannot_execute_python_after_using_py3));
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200689 return FAIL;
690 }
Bram Moolenaar65951252019-02-01 22:10:16 +0100691# endif
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200692
Bram Moolenaar071d4272004-06-13 20:20:40 +0000693 if (hinstPython)
694 return OK;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200695 hinstPython = load_dll(libname);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000696 if (!hinstPython)
697 {
698 if (verbose)
Bram Moolenaar460ae5d2022-01-01 14:19:49 +0000699 semsg(_(e_could_not_load_library_str_str), libname, load_dll_error());
Bram Moolenaar071d4272004-06-13 20:20:40 +0000700 return FAIL;
701 }
702
703 for (i = 0; python_funcname_table[i].ptr; ++i)
704 {
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200705 if ((*python_funcname_table[i].ptr = symbol_from_dll(hinstPython,
Bram Moolenaar071d4272004-06-13 20:20:40 +0000706 python_funcname_table[i].name)) == NULL)
707 {
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200708 close_dll(hinstPython);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000709 hinstPython = 0;
710 if (verbose)
Bram Moolenaar460ae5d2022-01-01 14:19:49 +0000711 semsg(_(e_could_not_load_library_function_str), python_funcname_table[i].name);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000712 return FAIL;
713 }
714 }
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200715
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100716 // Load unicode functions separately as only the ucs2 or the ucs4 functions
717 // will be present in the library.
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200718 *ucs_as_encoded_string = symbol_from_dll(hinstPython,
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200719 "PyUnicodeUCS2_AsEncodedString");
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200720 if (*ucs_as_encoded_string == NULL)
721 *ucs_as_encoded_string = symbol_from_dll(hinstPython,
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200722 "PyUnicodeUCS4_AsEncodedString");
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200723 if (*ucs_as_encoded_string == NULL)
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200724 {
725 close_dll(hinstPython);
726 hinstPython = 0;
727 if (verbose)
Bram Moolenaar460ae5d2022-01-01 14:19:49 +0000728 semsg(_(e_could_not_load_library_function_str), "PyUnicode_UCSX_*");
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200729 return FAIL;
730 }
731
Bram Moolenaar071d4272004-06-13 20:20:40 +0000732 return OK;
733}
734
735/*
736 * If python is enabled (there is installed python on Windows system) return
737 * TRUE, else FALSE.
738 */
739 int
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +0000740python_enabled(int verbose)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000741{
Bram Moolenaar25e4fcd2016-01-09 14:57:47 +0100742 return python_runtime_link_init((char *)p_pydll, verbose) == OK;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000743}
744
Bram Moolenaarca8a4df2010-07-31 19:54:14 +0200745/*
746 * Load the standard Python exceptions - don't import the symbols from the
Bram Moolenaar071d4272004-06-13 20:20:40 +0000747 * DLL, as this can cause errors (importing data symbols is not reliable).
748 */
Bram Moolenaar071d4272004-06-13 20:20:40 +0000749 static void
Bram Moolenaarca8a4df2010-07-31 19:54:14 +0200750get_exceptions(void)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000751{
752 PyObject *exmod = PyImport_ImportModule("exceptions");
753 PyObject *exdict = PyModule_GetDict(exmod);
754 imp_PyExc_AttributeError = PyDict_GetItemString(exdict, "AttributeError");
755 imp_PyExc_IndexError = PyDict_GetItemString(exdict, "IndexError");
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200756 imp_PyExc_KeyError = PyDict_GetItemString(exdict, "KeyError");
Bram Moolenaar071d4272004-06-13 20:20:40 +0000757 imp_PyExc_KeyboardInterrupt = PyDict_GetItemString(exdict, "KeyboardInterrupt");
758 imp_PyExc_TypeError = PyDict_GetItemString(exdict, "TypeError");
759 imp_PyExc_ValueError = PyDict_GetItemString(exdict, "ValueError");
Bram Moolenaar41009372013-07-01 22:03:04 +0200760 imp_PyExc_SystemExit = PyDict_GetItemString(exdict, "SystemExit");
Bram Moolenaar8661b172013-05-15 15:44:28 +0200761 imp_PyExc_RuntimeError = PyDict_GetItemString(exdict, "RuntimeError");
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200762 imp_PyExc_ImportError = PyDict_GetItemString(exdict, "ImportError");
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200763 imp_PyExc_OverflowError = PyDict_GetItemString(exdict, "OverflowError");
Bram Moolenaar071d4272004-06-13 20:20:40 +0000764 Py_XINCREF(imp_PyExc_AttributeError);
765 Py_XINCREF(imp_PyExc_IndexError);
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200766 Py_XINCREF(imp_PyExc_KeyError);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000767 Py_XINCREF(imp_PyExc_KeyboardInterrupt);
768 Py_XINCREF(imp_PyExc_TypeError);
769 Py_XINCREF(imp_PyExc_ValueError);
Bram Moolenaar41009372013-07-01 22:03:04 +0200770 Py_XINCREF(imp_PyExc_SystemExit);
Bram Moolenaar8661b172013-05-15 15:44:28 +0200771 Py_XINCREF(imp_PyExc_RuntimeError);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200772 Py_XINCREF(imp_PyExc_ImportError);
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200773 Py_XINCREF(imp_PyExc_OverflowError);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000774 Py_XDECREF(exmod);
775}
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100776#endif // DYNAMIC_PYTHON
Bram Moolenaar071d4272004-06-13 20:20:40 +0000777
Bram Moolenaardb913952012-06-29 12:54:53 +0200778static int initialised = 0;
779#define PYINITIALISED initialised
Bram Moolenaarc4f83382017-07-07 14:50:44 +0200780static int python_end_called = FALSE;
Bram Moolenaardb913952012-06-29 12:54:53 +0200781
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200782#define DESTRUCTOR_FINISH(self) self->ob_type->tp_free((PyObject*)self);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200783
Bram Moolenaar971db462013-05-12 18:44:48 +0200784#define WIN_PYTHON_REF(win) win->w_python_ref
785#define BUF_PYTHON_REF(buf) buf->b_python_ref
Bram Moolenaar5e538ec2013-05-15 15:12:29 +0200786#define TAB_PYTHON_REF(tab) tab->tp_python_ref
Bram Moolenaar971db462013-05-12 18:44:48 +0200787
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200788static PyObject *OutputGetattr(PyObject *, char *);
789static PyObject *BufferGetattr(PyObject *, char *);
790static PyObject *WindowGetattr(PyObject *, char *);
Bram Moolenaar5e538ec2013-05-15 15:12:29 +0200791static PyObject *TabPageGetattr(PyObject *, char *);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200792static PyObject *RangeGetattr(PyObject *, char *);
793static PyObject *DictionaryGetattr(PyObject *, char*);
794static PyObject *ListGetattr(PyObject *, char *);
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100795static PyObject *TupleGetattr(PyObject *, char *);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200796static PyObject *FunctionGetattr(PyObject *, char *);
797
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200798#ifndef Py_VISIT
799# define Py_VISIT(obj) visit(obj, arg)
800#endif
801#ifndef Py_CLEAR
802# define Py_CLEAR(obj) \
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200803 { \
804 Py_XDECREF(obj); \
805 obj = NULL; \
806 }
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200807#endif
808
Bram Moolenaarfdde8802013-05-30 15:38:24 +0200809#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
810 static void *
811py_memsave(void *p, size_t len)
812{
813 void *r;
814
815 if (!(r = PyMem_Malloc(len)))
816 return NULL;
817 mch_memmove(r, p, len);
818 return r;
819}
820
821# define PY_STRSAVE(s) ((char_u *) py_memsave(s, STRLEN(s) + 1))
822#endif
823
Bram Moolenaar922a4662014-03-30 16:11:43 +0200824typedef PySliceObject PySliceObject_T;
825
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200826/*
827 * Include the code shared with if_python3.c
828 */
829#include "if_py_both.h"
830
831
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100832///////////////////////////////////////////////////////
833// Internal function prototypes.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000834
Bram Moolenaar071d4272004-06-13 20:20:40 +0000835static int PythonMod_Init(void);
836
Bram Moolenaar071d4272004-06-13 20:20:40 +0000837
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100838///////////////////////////////////////////////////////
839// 1. Python interpreter main program.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000840
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100841#if PYTHON_API_VERSION < 1007 // Python 1.4
Bram Moolenaar071d4272004-06-13 20:20:40 +0000842typedef PyObject PyThreadState;
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000843#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000844
Bram Moolenaar71700b82013-05-15 17:49:05 +0200845#ifndef PY_CAN_RECURSE
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000846static PyThreadState *saved_python_thread = NULL;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000847
848/*
849 * Suspend a thread of the Python interpreter, other threads are allowed to
850 * run.
851 */
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000852 static void
853Python_SaveThread(void)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000854{
855 saved_python_thread = PyEval_SaveThread();
856}
857
858/*
859 * Restore a thread of the Python interpreter, waits for other threads to
860 * block.
861 */
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000862 static void
863Python_RestoreThread(void)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000864{
865 PyEval_RestoreThread(saved_python_thread);
866 saved_python_thread = NULL;
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000867}
Bram Moolenaar71700b82013-05-15 17:49:05 +0200868#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000869
Bram Moolenaar071d4272004-06-13 20:20:40 +0000870 void
Bram Moolenaar68c2f632016-01-30 17:24:07 +0100871python_end(void)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000872{
Bram Moolenaara5792f52005-11-23 21:25:05 +0000873 static int recurse = 0;
874
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100875 // If a crash occurs while doing this, don't try again.
Bram Moolenaara5792f52005-11-23 21:25:05 +0000876 if (recurse != 0)
877 return;
878
Bram Moolenaarc4f83382017-07-07 14:50:44 +0200879 python_end_called = TRUE;
Bram Moolenaara5792f52005-11-23 21:25:05 +0000880 ++recurse;
881
Bram Moolenaar071d4272004-06-13 20:20:40 +0000882#ifdef DYNAMIC_PYTHON
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000883 if (hinstPython && Py_IsInitialized())
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000884 {
Bram Moolenaar71700b82013-05-15 17:49:05 +0200885# ifdef PY_CAN_RECURSE
886 PyGILState_Ensure();
887# else
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100888 Python_RestoreThread(); // enter python
Bram Moolenaar71700b82013-05-15 17:49:05 +0200889# endif
Bram Moolenaarc9b4b052006-04-30 18:54:39 +0000890 Py_Finalize();
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000891 }
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000892#else
893 if (Py_IsInitialized())
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000894 {
Bram Moolenaar71700b82013-05-15 17:49:05 +0200895# ifdef PY_CAN_RECURSE
896 PyGILState_Ensure();
897# else
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100898 Python_RestoreThread(); // enter python
Bram Moolenaar71700b82013-05-15 17:49:05 +0200899# endif
Bram Moolenaarc9b4b052006-04-30 18:54:39 +0000900 Py_Finalize();
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000901 }
Bram Moolenaar071d4272004-06-13 20:20:40 +0000902#endif
Bram Moolenaara5792f52005-11-23 21:25:05 +0000903
904 --recurse;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000905}
906
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200907#if (defined(DYNAMIC_PYTHON) && defined(FEAT_PYTHON3)) || defined(PROTO)
908 int
Bram Moolenaar68c2f632016-01-30 17:24:07 +0100909python_loaded(void)
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200910{
911 return (hinstPython != 0);
912}
913#endif
914
Bram Moolenaar94073162018-01-31 21:49:05 +0100915static char *py_home_buf = NULL;
916
Bram Moolenaar071d4272004-06-13 20:20:40 +0000917 static int
918Python_Init(void)
919{
920 if (!initialised)
921 {
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200922#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
923 PyObject *site;
924#endif
925
Bram Moolenaar071d4272004-06-13 20:20:40 +0000926#ifdef DYNAMIC_PYTHON
927 if (!python_enabled(TRUE))
928 {
Bram Moolenaar9a846fb2022-01-01 21:59:18 +0000929 emsg(_(e_sorry_this_command_is_disabled_python_library_could_not_be_found));
Bram Moolenaar071d4272004-06-13 20:20:40 +0000930 goto fail;
931 }
932#endif
933
Bram Moolenaar94073162018-01-31 21:49:05 +0100934 if (*p_pyhome != NUL)
935 {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100936 // The string must not change later, make a copy in static memory.
Bram Moolenaar94073162018-01-31 21:49:05 +0100937 py_home_buf = (char *)vim_strsave(p_pyhome);
938 if (py_home_buf != NULL)
939 Py_SetPythonHome(py_home_buf);
940 }
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100941#ifdef PYTHON_HOME
Bram Moolenaar94073162018-01-31 21:49:05 +0100942 else if (mch_getenv((char_u *)"PYTHONHOME") == NULL)
Bram Moolenaar10005652015-12-31 21:03:23 +0100943 Py_SetPythonHome(PYTHON_HOME);
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100944#endif
945
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200946 init_structs();
947
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200948#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100949 // Disable implicit 'import site', because it may cause Vim to exit
950 // when it can't be found.
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200951 Py_NoSiteFlag++;
952#endif
953
Bram Moolenaar071d4272004-06-13 20:20:40 +0000954 Py_Initialize();
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200955
956#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100957 // 'import site' explicitly.
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200958 site = PyImport_ImportModule("site");
959 if (site == NULL)
960 {
Damien Lejayb84ab022025-07-01 21:57:59 +0200961 emsg(_(e_sorry_this_command_is_disabled_python_site_module_could_not_be_loaded));
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200962 goto fail;
963 }
964 Py_DECREF(site);
965#endif
966
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100967 // Initialise threads, and below save the state using
968 // PyEval_SaveThread. Without the call to PyEval_SaveThread, thread
969 // specific state (such as the system trace hook), will be lost
970 // between invocations of Python code.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000971 PyEval_InitThreads();
Bram Moolenaar071d4272004-06-13 20:20:40 +0000972#ifdef DYNAMIC_PYTHON
973 get_exceptions();
974#endif
975
Bram Moolenaar1dc28782013-05-21 19:11:01 +0200976 if (PythonIO_Init_io())
Bram Moolenaar071d4272004-06-13 20:20:40 +0000977 goto fail;
978
979 if (PythonMod_Init())
980 goto fail;
981
Bram Moolenaardb913952012-06-29 12:54:53 +0200982 globals = PyModule_GetDict(PyImport_AddModule("__main__"));
983
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100984 // Remove the element from sys.path that was added because of our
985 // argv[0] value in PythonMod_Init(). Previously we used an empty
986 // string, but depending on the OS we then get an empty entry or
987 // the current directory in sys.path.
Bram Moolenaar9774ecc2008-11-20 10:04:53 +0000988 PyRun_SimpleString("import sys; sys.path = filter(lambda x: x != '/must>not&exist', sys.path)");
989
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100990 // lock is created and acquired in PyEval_InitThreads() and thread
991 // state is created in Py_Initialize()
992 // there _PyGILState_NoteThreadState() also sets gilcounter to 1
993 // (python must have threads enabled!)
994 // so the following does both: unlock GIL and save thread state in TLS
995 // without deleting thread state
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200996#ifndef PY_CAN_RECURSE
997 saved_python_thread =
998#endif
999 PyEval_SaveThread();
Bram Moolenaar071d4272004-06-13 20:20:40 +00001000
1001 initialised = 1;
1002 }
1003
1004 return 0;
1005
1006fail:
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001007 // We call PythonIO_Flush() here to print any Python errors.
1008 // This is OK, as it is possible to call this function even
1009 // if PythonIO_Init_io() has not completed successfully (it will
1010 // not do anything in this case).
Bram Moolenaar071d4272004-06-13 20:20:40 +00001011 PythonIO_Flush();
1012 return -1;
1013}
1014
1015/*
1016 * External interface
1017 */
1018 static void
Ben Jacksonea19e782024-11-06 21:50:05 +01001019DoPyCommand(const char *cmd, dict_T* locals, rangeinitializer init_range, runner run, void *arg)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001020{
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +00001021#ifndef PY_CAN_RECURSE
Bram Moolenaar071d4272004-06-13 20:20:40 +00001022 static int recursive = 0;
1023#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001024#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
1025 char *saved_locale;
1026#endif
Bram Moolenaar71700b82013-05-15 17:49:05 +02001027#ifdef PY_CAN_RECURSE
1028 PyGILState_STATE pygilstate;
1029#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001030
1031#ifndef PY_CAN_RECURSE
1032 if (recursive)
1033 {
Bram Moolenaara6f79292022-01-04 21:30:47 +00001034 emsg(_(e_cannot_invoke_python_recursively));
Bram Moolenaar071d4272004-06-13 20:20:40 +00001035 return;
1036 }
1037 ++recursive;
1038#endif
Bram Moolenaarc4f83382017-07-07 14:50:44 +02001039 if (python_end_called)
1040 return;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001041
Bram Moolenaar071d4272004-06-13 20:20:40 +00001042 if (Python_Init())
1043 goto theend;
1044
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001045 init_range(arg);
1046
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001047 Python_Release_Vim(); // leave Vim
Bram Moolenaar071d4272004-06-13 20:20:40 +00001048
1049#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001050 // Python only works properly when the LC_NUMERIC locale is "C".
Bram Moolenaar071d4272004-06-13 20:20:40 +00001051 saved_locale = setlocale(LC_NUMERIC, NULL);
1052 if (saved_locale == NULL || STRCMP(saved_locale, "C") == 0)
1053 saved_locale = NULL;
1054 else
1055 {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001056 // Need to make a copy, value may change when setting new locale.
Bram Moolenaare9ba5162013-05-29 22:02:22 +02001057 saved_locale = (char *) PY_STRSAVE(saved_locale);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001058 (void)setlocale(LC_NUMERIC, "C");
1059 }
1060#endif
1061
Bram Moolenaar71700b82013-05-15 17:49:05 +02001062#ifdef PY_CAN_RECURSE
1063 pygilstate = PyGILState_Ensure();
1064#else
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001065 Python_RestoreThread(); // enter python
Bram Moolenaar71700b82013-05-15 17:49:05 +02001066#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001067
Ben Jacksonea19e782024-11-06 21:50:05 +01001068 run((char *) cmd, locals, arg
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +02001069#ifdef PY_CAN_RECURSE
1070 , &pygilstate
1071#endif
1072 );
Bram Moolenaar071d4272004-06-13 20:20:40 +00001073
Bram Moolenaar71700b82013-05-15 17:49:05 +02001074#ifdef PY_CAN_RECURSE
1075 PyGILState_Release(pygilstate);
1076#else
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001077 Python_SaveThread(); // leave python
Bram Moolenaar71700b82013-05-15 17:49:05 +02001078#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001079
1080#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
1081 if (saved_locale != NULL)
1082 {
1083 (void)setlocale(LC_NUMERIC, saved_locale);
Bram Moolenaare9ba5162013-05-29 22:02:22 +02001084 PyMem_Free(saved_locale);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001085 }
1086#endif
1087
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001088 Python_Lock_Vim(); // enter vim
Bram Moolenaar071d4272004-06-13 20:20:40 +00001089 PythonIO_Flush();
Bram Moolenaar071d4272004-06-13 20:20:40 +00001090
1091theend:
1092#ifndef PY_CAN_RECURSE
1093 --recursive;
1094#endif
Bram Moolenaardb913952012-06-29 12:54:53 +02001095 return;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001096}
1097
1098/*
1099 * ":python"
1100 */
1101 void
1102ex_python(exarg_T *eap)
1103{
1104 char_u *script;
1105
1106 script = script_get(eap, eap->arg);
1107 if (!eap->skip)
1108 {
Bram Moolenaar14816ad2019-02-18 22:04:56 +01001109 if (p_pyx == 0)
1110 p_pyx = 2;
1111
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001112 DoPyCommand(script == NULL ? (char *) eap->arg : (char *) script,
Ben Jacksonea19e782024-11-06 21:50:05 +01001113 NULL,
Yee Cheng Chin2ce070c2023-09-19 20:30:22 +02001114 init_range_cmd,
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001115 (runner) run_cmd,
1116 (void *) eap);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001117 }
1118 vim_free(script);
1119}
1120
1121#define BUFFER_SIZE 1024
1122
1123/*
1124 * ":pyfile"
1125 */
1126 void
1127ex_pyfile(exarg_T *eap)
1128{
1129 static char buffer[BUFFER_SIZE];
1130 const char *file = (char *)eap->arg;
1131 char *p;
1132
Bram Moolenaarf42dd3c2017-01-28 16:06:38 +01001133 if (p_pyx == 0)
1134 p_pyx = 2;
1135
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001136 // Have to do it like this. PyRun_SimpleFile requires you to pass a
1137 // stdio file pointer, but Vim and the Python DLL are compiled with
1138 // different options under Windows, meaning that stdio pointers aren't
1139 // compatible between the two. Yuk.
1140 //
1141 // Put the string "execfile('file')" into buffer. But, we need to
1142 // escape any backslashes or single quotes in the file name, so that
1143 // Python won't mangle the file name.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001144 strcpy(buffer, "execfile('");
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001145 p = buffer + 10; // size of "execfile('"
Bram Moolenaar071d4272004-06-13 20:20:40 +00001146
1147 while (*file && p < buffer + (BUFFER_SIZE - 3))
1148 {
1149 if (*file == '\\' || *file == '\'')
1150 *p++ = '\\';
1151 *p++ = *file++;
1152 }
1153
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001154 // If we didn't finish the file name, we hit a buffer overflow
Bram Moolenaar071d4272004-06-13 20:20:40 +00001155 if (*file != '\0')
1156 return;
1157
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001158 // Put in the terminating "')" and a null
Bram Moolenaar071d4272004-06-13 20:20:40 +00001159 *p++ = '\'';
1160 *p++ = ')';
1161 *p++ = '\0';
1162
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001163 // Execute the file
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001164 DoPyCommand(buffer,
Ben Jacksonea19e782024-11-06 21:50:05 +01001165 NULL,
Yee Cheng Chin2ce070c2023-09-19 20:30:22 +02001166 init_range_cmd,
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001167 (runner) run_cmd,
1168 (void *) eap);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001169}
1170
Bram Moolenaard620aa92013-05-17 16:40:06 +02001171 void
1172ex_pydo(exarg_T *eap)
1173{
Bram Moolenaarf42dd3c2017-01-28 16:06:38 +01001174 if (p_pyx == 0)
1175 p_pyx = 2;
1176
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001177 DoPyCommand((char *)eap->arg,
Ben Jacksonea19e782024-11-06 21:50:05 +01001178 NULL,
Yee Cheng Chin2ce070c2023-09-19 20:30:22 +02001179 init_range_cmd,
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001180 (runner)run_do,
1181 (void *)eap);
Bram Moolenaard620aa92013-05-17 16:40:06 +02001182}
1183
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001184///////////////////////////////////////////////////////
1185// 2. Python output stream: writes output via [e]msg().
Bram Moolenaar071d4272004-06-13 20:20:40 +00001186
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001187// Implementation functions
Bram Moolenaar071d4272004-06-13 20:20:40 +00001188
Bram Moolenaar071d4272004-06-13 20:20:40 +00001189 static PyObject *
1190OutputGetattr(PyObject *self, char *name)
1191{
1192 if (strcmp(name, "softspace") == 0)
1193 return PyInt_FromLong(((OutputObject *)(self))->softspace);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001194 else if (strcmp(name, "__members__") == 0)
1195 return ObjectDir(NULL, OutputAttrs);
Bram Moolenaar6d4431e2016-04-21 20:00:56 +02001196 else if (strcmp(name, "errors") == 0)
1197 return PyString_FromString("strict");
1198 else if (strcmp(name, "encoding") == 0)
1199 return PyString_FromString(ENC_OPT);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001200 return Py_FindMethod(OutputMethods, self, name);
1201}
1202
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001203///////////////////////////////////////////////////////
1204// 3. Implementation of the Vim module for Python
Bram Moolenaar071d4272004-06-13 20:20:40 +00001205
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001206// Window type - Implementation functions
1207// --------------------------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +00001208
Bram Moolenaar071d4272004-06-13 20:20:40 +00001209#define WindowType_Check(obj) ((obj)->ob_type == &WindowType)
1210
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001211// Buffer type - Implementation functions
1212// --------------------------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +00001213
Bram Moolenaar071d4272004-06-13 20:20:40 +00001214#define BufferType_Check(obj) ((obj)->ob_type == &BufferType)
1215
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001216static int BufferAssItem(PyObject *, PyInt, PyObject *);
1217static int BufferAssSlice(PyObject *, PyInt, PyInt, PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001218
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001219// Line range type - Implementation functions
1220// --------------------------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +00001221
Bram Moolenaar071d4272004-06-13 20:20:40 +00001222#define RangeType_Check(obj) ((obj)->ob_type == &RangeType)
1223
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001224static int RangeAssItem(PyObject *, PyInt, PyObject *);
1225static int RangeAssSlice(PyObject *, PyInt, PyInt, PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001226
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001227// Current objects type - Implementation functions
1228// -----------------------------------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +00001229
Bram Moolenaar071d4272004-06-13 20:20:40 +00001230static PySequenceMethods BufferAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001231 (PyInquiry) BufferLength, // sq_length, len(x)
1232 (binaryfunc) 0, // BufferConcat, sq_concat, x+y
1233 (PyIntArgFunc) 0, // BufferRepeat, sq_repeat, x*n
1234 (PyIntArgFunc) BufferItem, // sq_item, x[i]
1235 (PyIntIntArgFunc) BufferSlice, // sq_slice, x[i:j]
1236 (PyIntObjArgProc) BufferAssItem, // sq_ass_item, x[i]=v
1237 (PyIntIntObjArgProc) BufferAssSlice, // sq_ass_slice, x[i:j]=v
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001238 (objobjproc) 0,
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001239 (binaryfunc) 0,
Bram Moolenaar071d4272004-06-13 20:20:40 +00001240 0,
Bram Moolenaar071d4272004-06-13 20:20:40 +00001241};
1242
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001243// Buffer object - Implementation
Bram Moolenaar071d4272004-06-13 20:20:40 +00001244
1245 static PyObject *
Bram Moolenaar071d4272004-06-13 20:20:40 +00001246BufferGetattr(PyObject *self, char *name)
1247{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001248 PyObject *r;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001249
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001250 if ((r = BufferAttrValid((BufferObject *)(self), name)))
1251 return r;
1252
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001253 if (CheckBuffer((BufferObject *)(self)))
Bram Moolenaar071d4272004-06-13 20:20:40 +00001254 return NULL;
1255
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001256 r = BufferAttr((BufferObject *)(self), name);
1257 if (r || PyErr_Occurred())
1258 return r;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001259 else
1260 return Py_FindMethod(BufferMethods, self, name);
1261}
1262
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001263//////////////////
Bram Moolenaar071d4272004-06-13 20:20:40 +00001264
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001265 static int
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001266BufferAssItem(PyObject *self, PyInt n, PyObject *val)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001267{
Bram Moolenaar8f1723d2013-05-12 20:36:14 +02001268 return RBAsItem((BufferObject *)(self), n, val, 1, -1, NULL);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001269}
1270
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001271 static int
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001272BufferAssSlice(PyObject *self, PyInt lo, PyInt hi, PyObject *val)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001273{
Bram Moolenaar8f1723d2013-05-12 20:36:14 +02001274 return RBAsSlice((BufferObject *)(self), lo, hi, val, 1, -1, NULL);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001275}
1276
Bram Moolenaar071d4272004-06-13 20:20:40 +00001277static PySequenceMethods RangeAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001278 (PyInquiry) RangeLength, // sq_length, len(x)
1279 (binaryfunc) 0, /* RangeConcat, */ // sq_concat, x+y
1280 (PyIntArgFunc) 0, /* RangeRepeat, */ // sq_repeat, x*n
1281 (PyIntArgFunc) RangeItem, // sq_item, x[i]
1282 (PyIntIntArgFunc) RangeSlice, // sq_slice, x[i:j]
1283 (PyIntObjArgProc) RangeAssItem, // sq_ass_item, x[i]=v
1284 (PyIntIntObjArgProc) RangeAssSlice, // sq_ass_slice, x[i:j]=v
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001285 (objobjproc) 0,
1286#if PY_MAJOR_VERSION >= 2
1287 (binaryfunc) 0,
1288 0,
1289#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001290};
1291
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001292// Line range object - Implementation
Bram Moolenaar071d4272004-06-13 20:20:40 +00001293
Bram Moolenaar071d4272004-06-13 20:20:40 +00001294 static PyObject *
1295RangeGetattr(PyObject *self, char *name)
1296{
1297 if (strcmp(name, "start") == 0)
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +00001298 return Py_BuildValue(Py_ssize_t_fmt, ((RangeObject *)(self))->start - 1);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001299 else if (strcmp(name, "end") == 0)
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +00001300 return Py_BuildValue(Py_ssize_t_fmt, ((RangeObject *)(self))->end - 1);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001301 else if (strcmp(name, "__members__") == 0)
1302 return ObjectDir(NULL, RangeAttrs);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001303 else
1304 return Py_FindMethod(RangeMethods, self, name);
1305}
1306
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001307////////////////
Bram Moolenaar071d4272004-06-13 20:20:40 +00001308
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001309 static int
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001310RangeAssItem(PyObject *self, PyInt n, PyObject *val)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001311{
Bram Moolenaarca8a4df2010-07-31 19:54:14 +02001312 return RBAsItem(((RangeObject *)(self))->buf, n, val,
Bram Moolenaar071d4272004-06-13 20:20:40 +00001313 ((RangeObject *)(self))->start,
1314 ((RangeObject *)(self))->end,
1315 &((RangeObject *)(self))->end);
1316}
1317
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001318 static int
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001319RangeAssSlice(PyObject *self, PyInt lo, PyInt hi, PyObject *val)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001320{
Bram Moolenaar19e60942011-06-19 00:27:51 +02001321 return RBAsSlice(((RangeObject *)(self))->buf, lo, hi, val,
Bram Moolenaar071d4272004-06-13 20:20:40 +00001322 ((RangeObject *)(self))->start,
1323 ((RangeObject *)(self))->end,
1324 &((RangeObject *)(self))->end);
1325}
1326
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001327// TabPage object - Implementation
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001328
1329 static PyObject *
1330TabPageGetattr(PyObject *self, char *name)
1331{
1332 PyObject *r;
1333
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001334 if ((r = TabPageAttrValid((TabPageObject *)(self), name)))
1335 return r;
1336
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001337 if (CheckTabPage((TabPageObject *)(self)))
1338 return NULL;
1339
1340 r = TabPageAttr((TabPageObject *)(self), name);
1341 if (r || PyErr_Occurred())
1342 return r;
1343 else
1344 return Py_FindMethod(TabPageMethods, self, name);
1345}
1346
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001347// Window object - Implementation
Bram Moolenaar071d4272004-06-13 20:20:40 +00001348
1349 static PyObject *
Bram Moolenaar071d4272004-06-13 20:20:40 +00001350WindowGetattr(PyObject *self, char *name)
1351{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001352 PyObject *r;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001353
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001354 if ((r = WindowAttrValid((WindowObject *)(self), name)))
1355 return r;
1356
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001357 if (CheckWindow((WindowObject *)(self)))
Bram Moolenaar071d4272004-06-13 20:20:40 +00001358 return NULL;
1359
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001360 r = WindowAttr((WindowObject *)(self), name);
1361 if (r || PyErr_Occurred())
1362 return r;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001363 else
1364 return Py_FindMethod(WindowMethods, self, name);
1365}
1366
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001367// Tab page list object - Definitions
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001368
1369static PySequenceMethods TabListAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001370 (PyInquiry) TabListLength, // sq_length, len(x)
1371 (binaryfunc) 0, // sq_concat, x+y
1372 (PyIntArgFunc) 0, // sq_repeat, x*n
1373 (PyIntArgFunc) TabListItem, // sq_item, x[i]
1374 (PyIntIntArgFunc) 0, // sq_slice, x[i:j]
1375 (PyIntObjArgProc) 0, // sq_ass_item, x[i]=v
1376 (PyIntIntObjArgProc) 0, // sq_ass_slice, x[i:j]=v
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001377 (objobjproc) 0,
1378#if PY_MAJOR_VERSION >= 2
1379 (binaryfunc) 0,
1380 0,
1381#endif
1382};
1383
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001384// Window list object - Definitions
Bram Moolenaar071d4272004-06-13 20:20:40 +00001385
Bram Moolenaar071d4272004-06-13 20:20:40 +00001386static PySequenceMethods WinListAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001387 (PyInquiry) WinListLength, // sq_length, len(x)
1388 (binaryfunc) 0, // sq_concat, x+y
1389 (PyIntArgFunc) 0, // sq_repeat, x*n
1390 (PyIntArgFunc) WinListItem, // sq_item, x[i]
1391 (PyIntIntArgFunc) 0, // sq_slice, x[i:j]
1392 (PyIntObjArgProc) 0, // sq_ass_item, x[i]=v
1393 (PyIntIntObjArgProc) 0, // sq_ass_slice, x[i:j]=v
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001394 (objobjproc) 0,
1395#if PY_MAJOR_VERSION >= 2
1396 (binaryfunc) 0,
1397 0,
1398#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001399};
1400
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001401// External interface
Bram Moolenaar071d4272004-06-13 20:20:40 +00001402
1403 void
1404python_buffer_free(buf_T *buf)
1405{
Yegappan Lakshmanan0233bdf2023-01-12 12:33:30 +00001406 BufferObject *bp = BUF_PYTHON_REF(buf);
1407 if (bp == NULL)
1408 return;
1409 bp->buf = INVALID_BUFFER_VALUE;
1410 BUF_PYTHON_REF(buf) = NULL;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001411}
1412
Bram Moolenaar071d4272004-06-13 20:20:40 +00001413 void
1414python_window_free(win_T *win)
1415{
Yegappan Lakshmanan0233bdf2023-01-12 12:33:30 +00001416 WindowObject *wp = WIN_PYTHON_REF(win);
1417 if (wp == NULL)
1418 return;
1419 wp->win = INVALID_WINDOW_VALUE;
1420 WIN_PYTHON_REF(win) = NULL;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001421}
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001422
1423 void
1424python_tabpage_free(tabpage_T *tab)
1425{
Yegappan Lakshmanan0233bdf2023-01-12 12:33:30 +00001426 TabPageObject *tp = TAB_PYTHON_REF(tab);
1427 if (tp == NULL)
1428 return;
1429 tp->tab = INVALID_TABPAGE_VALUE;
1430 TAB_PYTHON_REF(tab) = NULL;
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001431}
Bram Moolenaar071d4272004-06-13 20:20:40 +00001432
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001433 static int
Bram Moolenaar071d4272004-06-13 20:20:40 +00001434PythonMod_Init(void)
1435{
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001436 // The special value is removed from sys.path in Python_Init().
Bram Moolenaar9f3685a2013-06-12 14:20:36 +02001437 static char *(argv[2]) = {"/must>not&exist/foo", NULL};
Bram Moolenaar071d4272004-06-13 20:20:40 +00001438
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001439 if (init_types())
1440 return -1;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001441
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001442 // Set sys.argv[] to avoid a crash in warn().
Bram Moolenaar071d4272004-06-13 20:20:40 +00001443 PySys_SetArgv(1, argv);
1444
Bram Moolenaarc09a6d62013-06-10 21:27:29 +02001445 vim_module = Py_InitModule4("vim", VimMethods, (char *)NULL,
1446 (PyObject *)NULL, PYTHON_API_VERSION);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001447
Bram Moolenaardee2e312013-06-23 16:35:47 +02001448 if (populate_module(vim_module))
Bram Moolenaarc09a6d62013-06-10 21:27:29 +02001449 return -1;
1450
1451 if (init_sys_path())
1452 return -1;
1453
1454 return 0;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001455}
1456
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001457//////////////////////////////////////////////////////////////////////////
1458// 4. Utility functions for handling the interface between Vim and Python.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001459
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001460// Convert a Vim line into a Python string.
1461// All internal newlines are replaced by null characters.
1462//
1463// On errors, the Python exception data is set, and NULL is returned.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001464 static PyObject *
1465LineToString(const char *str)
1466{
1467 PyObject *result;
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001468 PyInt len = strlen(str);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001469 char *p;
1470
Dominique Pelleaf4a61a2021-12-27 17:21:41 +00001471 // Allocate a Python string object, with uninitialised contents. We
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001472 // must do it this way, so that we can modify the string in place
1473 // later. See the Python source, Objects/stringobject.c for details.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001474 result = PyString_FromStringAndSize(NULL, len);
1475 if (result == NULL)
1476 return NULL;
1477
1478 p = PyString_AsString(result);
1479
1480 while (*str)
1481 {
1482 if (*str == '\n')
1483 *p = '\0';
1484 else
1485 *p = *str;
1486
1487 ++p;
1488 ++str;
1489 }
1490
1491 return result;
1492}
1493
Bram Moolenaardb913952012-06-29 12:54:53 +02001494 static PyObject *
1495DictionaryGetattr(PyObject *self, char *name)
1496{
Bram Moolenaar66b79852012-09-21 14:00:35 +02001497 DictionaryObject *this = ((DictionaryObject *) (self));
1498
1499 if (strcmp(name, "locked") == 0)
1500 return PyInt_FromLong(this->dict->dv_lock);
1501 else if (strcmp(name, "scope") == 0)
1502 return PyInt_FromLong(this->dict->dv_scope);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001503 else if (strcmp(name, "__members__") == 0)
1504 return ObjectDir(NULL, DictionaryAttrs);
Bram Moolenaar66b79852012-09-21 14:00:35 +02001505
Bram Moolenaardb913952012-06-29 12:54:53 +02001506 return Py_FindMethod(DictionaryMethods, self, name);
1507}
1508
Bram Moolenaardb913952012-06-29 12:54:53 +02001509 static PyObject *
1510ListGetattr(PyObject *self, char *name)
1511{
Bram Moolenaar66b79852012-09-21 14:00:35 +02001512 if (strcmp(name, "locked") == 0)
1513 return PyInt_FromLong(((ListObject *)(self))->list->lv_lock);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001514 else if (strcmp(name, "__members__") == 0)
1515 return ObjectDir(NULL, ListAttrs);
Bram Moolenaar66b79852012-09-21 14:00:35 +02001516
Bram Moolenaardb913952012-06-29 12:54:53 +02001517 return Py_FindMethod(ListMethods, self, name);
1518}
1519
Bram Moolenaardb913952012-06-29 12:54:53 +02001520 static PyObject *
Yegappan Lakshmanan038be272025-03-26 18:46:21 +01001521TupleGetattr(PyObject *self, char *name)
1522{
1523 if (strcmp(name, "locked") == 0)
1524 return PyInt_FromLong(((TupleObject *)(self))->tuple->tv_lock);
1525 else if (strcmp(name, "__members__") == 0)
1526 return ObjectDir(NULL, TupleAttrs);
1527
1528 return Py_FindMethod(TupleMethods, self, name);
1529}
1530
1531 static PyObject *
Bram Moolenaardb913952012-06-29 12:54:53 +02001532FunctionGetattr(PyObject *self, char *name)
1533{
Bram Moolenaar8110a092016-04-14 15:56:09 +02001534 PyObject *r;
Bram Moolenaardb913952012-06-29 12:54:53 +02001535
Bram Moolenaar8110a092016-04-14 15:56:09 +02001536 r = FunctionAttr((FunctionObject *)(self), name);
1537
1538 if (r || PyErr_Occurred())
1539 return r;
Bram Moolenaardb913952012-06-29 12:54:53 +02001540 else
1541 return Py_FindMethod(FunctionMethods, self, name);
1542}
1543
1544 void
Ben Jacksonea19e782024-11-06 21:50:05 +01001545do_pyeval(char_u *str, dict_T *locals, typval_T *rettv)
Bram Moolenaardb913952012-06-29 12:54:53 +02001546{
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001547 DoPyCommand((char *) str,
Ben Jacksonea19e782024-11-06 21:50:05 +01001548 locals,
Yee Cheng Chin2ce070c2023-09-19 20:30:22 +02001549 init_range_eval,
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001550 (runner) run_eval,
1551 (void *) rettv);
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001552 if (rettv->v_type == VAR_UNKNOWN)
Bram Moolenaardb913952012-06-29 12:54:53 +02001553 {
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001554 rettv->v_type = VAR_NUMBER;
1555 rettv->vval.v_number = 0;
Bram Moolenaardb913952012-06-29 12:54:53 +02001556 }
1557}
Bram Moolenaar071d4272004-06-13 20:20:40 +00001558
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001559// Don't generate a prototype for the next function, it generates an error on
1560// newer Python versions.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001561#if PYTHON_API_VERSION < 1007 /* Python 1.4 */ && !defined(PROTO)
1562
1563 char *
1564Py_GetProgramName(void)
1565{
1566 return "vim";
1567}
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001568#endif // Python 1.4
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001569
Bram Moolenaar2459a5e2015-02-03 12:55:18 +01001570 int
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001571set_ref_in_python(int copyID)
Bram Moolenaardb913952012-06-29 12:54:53 +02001572{
Bram Moolenaar2459a5e2015-02-03 12:55:18 +01001573 return set_ref_in_py(copyID);
Bram Moolenaardb913952012-06-29 12:54:53 +02001574}