blob: 594d7e5bd7b60236cd98b4d363828dcd90d051af [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
205# define PyTuple_New dll_PyTuple_New
206# define PyTuple_Size dll_PyTuple_Size
207# define PyTuple_Type (*dll_PyTuple_Type)
Bram Moolenaardb913952012-06-29 12:54:53 +0200208# define PySequence_Check dll_PySequence_Check
209# define PySequence_Size dll_PySequence_Size
210# define PySequence_GetItem dll_PySequence_GetItem
Bram Moolenaara9922d62013-05-30 13:01:18 +0200211# define PySequence_Fast dll_PySequence_Fast
Bram Moolenaardb913952012-06-29 12:54:53 +0200212# define PyTuple_Size dll_PyTuple_Size
213# define PyTuple_GetItem dll_PyTuple_GetItem
214# define PyTuple_Type (*dll_PyTuple_Type)
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100215# define PySlice_GetIndicesEx dll_PySlice_GetIndicesEx
Bram Moolenaar071d4272004-06-13 20:20:40 +0000216# define PyImport_ImportModule dll_PyImport_ImportModule
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000217# define PyDict_New dll_PyDict_New
Bram Moolenaar071d4272004-06-13 20:20:40 +0000218# define PyDict_GetItemString dll_PyDict_GetItemString
Bram Moolenaardb913952012-06-29 12:54:53 +0200219# define PyDict_Next dll_PyDict_Next
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200220# define PyDict_Type (*dll_PyDict_Type)
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200221# ifdef PyMapping_Keys
222# define PY_NO_MAPPING_KEYS
Bram Moolenaardb913952012-06-29 12:54:53 +0200223# else
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200224# define PyMapping_Keys dll_PyMapping_Keys
Bram Moolenaardb913952012-06-29 12:54:53 +0200225# endif
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200226# define PyObject_GetItem dll_PyObject_GetItem
Bram Moolenaardb913952012-06-29 12:54:53 +0200227# define PyObject_CallMethod dll_PyObject_CallMethod
228# define PyMapping_Check dll_PyMapping_Check
229# define PyIter_Next dll_PyIter_Next
Bram Moolenaar071d4272004-06-13 20:20:40 +0000230# define PyModule_GetDict dll_PyModule_GetDict
Bram Moolenaarf9c9b322013-06-10 20:47:36 +0200231# define PyModule_AddObject dll_PyModule_AddObject
Bram Moolenaar071d4272004-06-13 20:20:40 +0000232# define PyRun_SimpleString dll_PyRun_SimpleString
Bram Moolenaardb913952012-06-29 12:54:53 +0200233# define PyRun_String dll_PyRun_String
Bram Moolenaard620aa92013-05-17 16:40:06 +0200234# define PyObject_GetAttrString dll_PyObject_GetAttrString
Bram Moolenaara9922d62013-05-30 13:01:18 +0200235# define PyObject_HasAttrString dll_PyObject_HasAttrString
Bram Moolenaard620aa92013-05-17 16:40:06 +0200236# define PyObject_SetAttrString dll_PyObject_SetAttrString
237# define PyObject_CallFunctionObjArgs dll_PyObject_CallFunctionObjArgs
Bram Moolenaar9f3685a2013-06-12 14:20:36 +0200238# define PyObject_CallFunction dll_PyObject_CallFunction
Bram Moolenaarf4258302013-06-02 18:20:17 +0200239# define PyObject_Call dll_PyObject_Call
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200240# define PyObject_Repr dll_PyObject_Repr
Bram Moolenaar071d4272004-06-13 20:20:40 +0000241# define PyString_AsString dll_PyString_AsString
Bram Moolenaarcdab9052012-09-05 19:03:56 +0200242# define PyString_AsStringAndSize dll_PyString_AsStringAndSize
Bram Moolenaar071d4272004-06-13 20:20:40 +0000243# define PyString_FromString dll_PyString_FromString
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200244# define PyString_FromFormat dll_PyString_FromFormat
Bram Moolenaar071d4272004-06-13 20:20:40 +0000245# define PyString_FromStringAndSize dll_PyString_FromStringAndSize
246# define PyString_Size dll_PyString_Size
247# define PyString_Type (*dll_PyString_Type)
Bram Moolenaardb913952012-06-29 12:54:53 +0200248# define PyUnicode_Type (*dll_PyUnicode_Type)
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200249# undef PyUnicode_AsEncodedString
250# define PyUnicode_AsEncodedString py_PyUnicode_AsEncodedString
Bram Moolenaardb913952012-06-29 12:54:53 +0200251# define PyFloat_AsDouble dll_PyFloat_AsDouble
252# define PyFloat_FromDouble dll_PyFloat_FromDouble
253# define PyFloat_Type (*dll_PyFloat_Type)
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200254# define PyNumber_Check dll_PyNumber_Check
255# define PyNumber_Long dll_PyNumber_Long
Bram Moolenaardb913952012-06-29 12:54:53 +0200256# define PyImport_AddModule (*dll_PyImport_AddModule)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000257# define PySys_SetObject dll_PySys_SetObject
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200258# define PySys_GetObject dll_PySys_GetObject
Bram Moolenaar071d4272004-06-13 20:20:40 +0000259# define PySys_SetArgv dll_PySys_SetArgv
260# define PyType_Type (*dll_PyType_Type)
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200261# define PyFile_Type (*dll_PyFile_Type)
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100262# define PySlice_Type (*dll_PySlice_Type)
Bram Moolenaar30fec7b2011-03-26 18:32:05 +0100263# define PyType_Ready (*dll_PyType_Ready)
Bram Moolenaara9922d62013-05-30 13:01:18 +0200264# define PyType_GenericAlloc dll_PyType_GenericAlloc
Bram Moolenaar071d4272004-06-13 20:20:40 +0000265# define Py_BuildValue dll_Py_BuildValue
266# define Py_FindMethod dll_Py_FindMethod
267# define Py_InitModule4 dll_Py_InitModule4
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100268# define Py_SetPythonHome dll_Py_SetPythonHome
Bram Moolenaar071d4272004-06-13 20:20:40 +0000269# define Py_Initialize dll_Py_Initialize
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000270# define Py_Finalize dll_Py_Finalize
271# define Py_IsInitialized dll_Py_IsInitialized
Bram Moolenaar071d4272004-06-13 20:20:40 +0000272# define _PyObject_New dll__PyObject_New
Bram Moolenaar774267b2013-05-21 20:51:59 +0200273# define _PyObject_GC_New dll__PyObject_GC_New
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200274# ifdef PyObject_GC_Del
275# define Py_underscore_GC
276# define _PyObject_GC_Del dll__PyObject_GC_Del
277# define _PyObject_GC_UnTrack dll__PyObject_GC_UnTrack
278# else
279# define PyObject_GC_Del dll_PyObject_GC_Del
280# define PyObject_GC_UnTrack dll_PyObject_GC_UnTrack
281# endif
Bram Moolenaare7211222012-06-30 13:21:08 +0200282# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
283# define _PyObject_NextNotImplemented (*dll__PyObject_NextNotImplemented)
284# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000285# define _Py_NoneStruct (*dll__Py_NoneStruct)
Bram Moolenaar66b79852012-09-21 14:00:35 +0200286# define _Py_ZeroStruct (*dll__Py_ZeroStruct)
287# define _Py_TrueStruct (*dll__Py_TrueStruct)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000288# define PyObject_Init dll__PyObject_Init
Bram Moolenaardb913952012-06-29 12:54:53 +0200289# define PyObject_GetIter dll_PyObject_GetIter
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200290# define PyObject_IsTrue dll_PyObject_IsTrue
Bram Moolenaar071d4272004-06-13 20:20:40 +0000291# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02020000
292# define PyType_IsSubtype dll_PyType_IsSubtype
Bram Moolenaar0014a532013-05-29 21:33:39 +0200293# ifdef Py_DEBUG
294# define _Py_NegativeRefcount dll__Py_NegativeRefcount
295# define _Py_RefTotal (*dll__Py_RefTotal)
296# define _Py_Dealloc dll__Py_Dealloc
297# endif
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200298# endif
299# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02030000
Bram Moolenaar0014a532013-05-29 21:33:39 +0200300# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
301# define _PyObject_DebugMalloc dll__PyObject_DebugMalloc
302# define _PyObject_DebugFree dll__PyObject_DebugFree
303# else
304# define PyObject_Malloc dll_PyObject_Malloc
305# define PyObject_Free dll_PyObject_Free
306# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000307# endif
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200308# ifdef PY_USE_CAPSULE
309# define PyCapsule_New dll_PyCapsule_New
310# define PyCapsule_GetPointer dll_PyCapsule_GetPointer
311# else
312# define PyCObject_FromVoidPtr dll_PyCObject_FromVoidPtr
313# define PyCObject_AsVoidPtr dll_PyCObject_AsVoidPtr
314# endif
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200315# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
316# define Py_NoSiteFlag (*dll_Py_NoSiteFlag)
317# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000318
319/*
320 * Pointers for dynamic link
321 */
322static int(*dll_PyArg_Parse)(PyObject *, char *, ...);
323static int(*dll_PyArg_ParseTuple)(PyObject *, char *, ...);
Yee Cheng Chind606fcc2023-09-20 19:59:47 +0200324static void(*dll_PyMem_Free)(void *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200325static void* (*dll_PyMem_Malloc)(size_t);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000326static int(*dll_PyDict_SetItemString)(PyObject *dp, char *key, PyObject *item);
327static int(*dll_PyErr_BadArgument)(void);
Bram Moolenaard5f729c2013-05-15 16:04:40 +0200328static PyObject *(*dll_PyErr_NewException)(char *, PyObject *, PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000329static void(*dll_PyErr_Clear)(void);
Bram Moolenaarc476e522013-06-23 13:46:40 +0200330static PyObject*(*dll_PyErr_Format)(PyObject *, const char *, ...);
Bram Moolenaar4d369872013-02-20 16:09:43 +0100331static void(*dll_PyErr_PrintEx)(int);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000332static PyObject*(*dll_PyErr_NoMemory)(void);
333static PyObject*(*dll_PyErr_Occurred)(void);
334static void(*dll_PyErr_SetNone)(PyObject *);
335static void(*dll_PyErr_SetString)(PyObject *, const char *);
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200336static void(*dll_PyErr_SetObject)(PyObject *, PyObject *);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200337static int(*dll_PyErr_ExceptionMatches)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000338static void(*dll_PyEval_InitThreads)(void);
339static void(*dll_PyEval_RestoreThread)(PyThreadState *);
340static PyThreadState*(*dll_PyEval_SaveThread)(void);
341# ifdef PY_CAN_RECURSE
342static PyGILState_STATE (*dll_PyGILState_Ensure)(void);
343static void (*dll_PyGILState_Release)(PyGILState_STATE);
Bram Moolenaardb913952012-06-29 12:54:53 +0200344# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000345static long(*dll_PyInt_AsLong)(PyObject *);
346static PyObject*(*dll_PyInt_FromLong)(long);
Bram Moolenaardb913952012-06-29 12:54:53 +0200347static long(*dll_PyLong_AsLong)(PyObject *);
348static PyObject*(*dll_PyLong_FromLong)(long);
Bram Moolenaar66b79852012-09-21 14:00:35 +0200349static PyTypeObject* dll_PyBool_Type;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000350static PyTypeObject* dll_PyInt_Type;
Bram Moolenaardb913952012-06-29 12:54:53 +0200351static PyTypeObject* dll_PyLong_Type;
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000352static PyObject*(*dll_PyList_GetItem)(PyObject *, PyInt);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200353static int(*dll_PyList_Append)(PyObject *, PyObject *);
Bram Moolenaard5e376e2013-06-24 20:32:57 +0200354static int(*dll_PyList_Insert)(PyObject *, PyInt, PyObject *);
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000355static PyObject*(*dll_PyList_New)(PyInt size);
356static int(*dll_PyList_SetItem)(PyObject *, PyInt, PyObject *);
357static PyInt(*dll_PyList_Size)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000358static PyTypeObject* dll_PyList_Type;
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100359static PyObject*(*dll_PyTuple_GetItem)(PyObject *, PyInt);
360static int(*dll_PyTuple_SetItem)(PyObject *, PyInt, PyObject *);
361static int(*dll_PyTuple_SET_ITEM)(PyObject *, PyInt, PyObject *);
362static PyObject*(*dll_PyTuple_New)(PyInt size);
363static PyInt(*dll_PyTuple_Size)(PyObject *);
364static PyTypeObject* dll_PyTuple_Type;
Bram Moolenaardb913952012-06-29 12:54:53 +0200365static int (*dll_PySequence_Check)(PyObject *);
366static PyInt(*dll_PySequence_Size)(PyObject *);
367static PyObject*(*dll_PySequence_GetItem)(PyObject *, PyInt);
Bram Moolenaara9922d62013-05-30 13:01:18 +0200368static PyObject*(*dll_PySequence_Fast)(PyObject *, const char *);
Bram Moolenaar5395e7a2014-01-14 19:35:56 +0100369static int (*dll_PySlice_GetIndicesEx)(PySliceObject *r, PyInt length,
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100370 PyInt *start, PyInt *stop, PyInt *step,
371 PyInt *slicelen);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000372static PyObject*(*dll_PyImport_ImportModule)(const char *);
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000373static PyObject*(*dll_PyDict_New)(void);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000374static PyObject*(*dll_PyDict_GetItemString)(PyObject *, const char *);
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200375static int (*dll_PyDict_Next)(PyObject *, PyInt *, PyObject **, PyObject **);
376static PyTypeObject* dll_PyDict_Type;
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200377# ifndef PY_NO_MAPPING_KEYS
378static PyObject* (*dll_PyMapping_Keys)(PyObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200379# endif
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200380static PyObject* (*dll_PyObject_GetItem)(PyObject *, PyObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200381static PyObject* (*dll_PyObject_CallMethod)(PyObject *, char *, PyObject *);
382static int (*dll_PyMapping_Check)(PyObject *);
383static PyObject* (*dll_PyIter_Next)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000384static PyObject*(*dll_PyModule_GetDict)(PyObject *);
Bram Moolenaarf9c9b322013-06-10 20:47:36 +0200385static int(*dll_PyModule_AddObject)(PyObject *, const char *, PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000386static int(*dll_PyRun_SimpleString)(char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200387static PyObject *(*dll_PyRun_String)(char *, int, PyObject *, PyObject *);
Bram Moolenaard620aa92013-05-17 16:40:06 +0200388static PyObject* (*dll_PyObject_GetAttrString)(PyObject *, const char *);
Bram Moolenaara9922d62013-05-30 13:01:18 +0200389static int (*dll_PyObject_HasAttrString)(PyObject *, const char *);
Bram Moolenaar0b400082013-11-03 00:28:25 +0100390static int (*dll_PyObject_SetAttrString)(PyObject *, const char *, PyObject *);
Bram Moolenaard620aa92013-05-17 16:40:06 +0200391static PyObject* (*dll_PyObject_CallFunctionObjArgs)(PyObject *, ...);
Bram Moolenaar9f3685a2013-06-12 14:20:36 +0200392static PyObject* (*dll_PyObject_CallFunction)(PyObject *, char *, ...);
Bram Moolenaarf4258302013-06-02 18:20:17 +0200393static PyObject* (*dll_PyObject_Call)(PyObject *, PyObject *, PyObject *);
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200394static PyObject* (*dll_PyObject_Repr)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000395static char*(*dll_PyString_AsString)(PyObject *);
Bram Moolenaard5e376e2013-06-24 20:32:57 +0200396static int(*dll_PyString_AsStringAndSize)(PyObject *, char **, PyInt *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000397static PyObject*(*dll_PyString_FromString)(const char *);
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200398static PyObject*(*dll_PyString_FromFormat)(const char *, ...);
Bram Moolenaar2c45e942008-06-04 11:35:26 +0000399static PyObject*(*dll_PyString_FromStringAndSize)(const char *, PyInt);
400static PyInt(*dll_PyString_Size)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000401static PyTypeObject* dll_PyString_Type;
Bram Moolenaardb913952012-06-29 12:54:53 +0200402static PyTypeObject* dll_PyUnicode_Type;
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200403static PyObject *(*py_PyUnicode_AsEncodedString)(PyObject *, char *, char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200404static double(*dll_PyFloat_AsDouble)(PyObject *);
405static PyObject*(*dll_PyFloat_FromDouble)(double);
406static PyTypeObject* dll_PyFloat_Type;
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200407static int(*dll_PyNumber_Check)(PyObject *);
408static PyObject*(*dll_PyNumber_Long)(PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000409static int(*dll_PySys_SetObject)(char *, PyObject *);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200410static PyObject *(*dll_PySys_GetObject)(char *);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000411static int(*dll_PySys_SetArgv)(int, char **);
412static PyTypeObject* dll_PyType_Type;
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200413static PyTypeObject* dll_PyFile_Type;
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100414static PyTypeObject* dll_PySlice_Type;
Bram Moolenaar30fec7b2011-03-26 18:32:05 +0100415static int (*dll_PyType_Ready)(PyTypeObject *type);
Bram Moolenaara9922d62013-05-30 13:01:18 +0200416static PyObject* (*dll_PyType_GenericAlloc)(PyTypeObject *type, PyInt nitems);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000417static PyObject*(*dll_Py_BuildValue)(char *, ...);
418static PyObject*(*dll_Py_FindMethod)(struct PyMethodDef[], PyObject *, char *);
419static PyObject*(*dll_Py_InitModule4)(char *, struct PyMethodDef *, char *, PyObject *, int);
Bram Moolenaardb913952012-06-29 12:54:53 +0200420static PyObject*(*dll_PyImport_AddModule)(char *);
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100421static void(*dll_Py_SetPythonHome)(char *home);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000422static void(*dll_Py_Initialize)(void);
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000423static void(*dll_Py_Finalize)(void);
424static int(*dll_Py_IsInitialized)(void);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000425static PyObject*(*dll__PyObject_New)(PyTypeObject *, PyObject *);
Bram Moolenaar774267b2013-05-21 20:51:59 +0200426static PyObject*(*dll__PyObject_GC_New)(PyTypeObject *);
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200427# ifdef Py_underscore_GC
428static void(*dll__PyObject_GC_Del)(void *);
429static void(*dll__PyObject_GC_UnTrack)(void *);
430# else
Bram Moolenaar774267b2013-05-21 20:51:59 +0200431static void(*dll_PyObject_GC_Del)(void *);
432static void(*dll_PyObject_GC_UnTrack)(void *);
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200433# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000434static PyObject*(*dll__PyObject_Init)(PyObject *, PyTypeObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200435static PyObject* (*dll_PyObject_GetIter)(PyObject *);
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200436static int (*dll_PyObject_IsTrue)(PyObject *);
Bram Moolenaare7211222012-06-30 13:21:08 +0200437# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
Bram Moolenaardb913952012-06-29 12:54:53 +0200438static iternextfunc dll__PyObject_NextNotImplemented;
Bram Moolenaare7211222012-06-30 13:21:08 +0200439# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000440static PyObject* dll__Py_NoneStruct;
Bram Moolenaar66b79852012-09-21 14:00:35 +0200441static PyObject* _Py_ZeroStruct;
442static PyObject* dll__Py_TrueStruct;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000443# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02020000
444static int (*dll_PyType_IsSubtype)(PyTypeObject *, PyTypeObject *);
Bram Moolenaar0014a532013-05-29 21:33:39 +0200445# ifdef Py_DEBUG
446static void (*dll__Py_NegativeRefcount)(const char *fname, int lineno, PyObject *op);
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200447static PyInt* dll__Py_RefTotal;
Bram Moolenaar0014a532013-05-29 21:33:39 +0200448static void (*dll__Py_Dealloc)(PyObject *obj);
449# endif
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200450# endif
451# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02030000
Bram Moolenaar0014a532013-05-29 21:33:39 +0200452# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
453static void (*dll__PyObject_DebugFree)(void*);
454static void* (*dll__PyObject_DebugMalloc)(size_t);
455# else
Bram Moolenaar071d4272004-06-13 20:20:40 +0000456static void* (*dll_PyObject_Malloc)(size_t);
457static void (*dll_PyObject_Free)(void*);
Bram Moolenaar0014a532013-05-29 21:33:39 +0200458# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000459# endif
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200460# ifdef PY_USE_CAPSULE
Bram Moolenaardb913952012-06-29 12:54:53 +0200461static PyObject* (*dll_PyCapsule_New)(void *, char *, PyCapsule_Destructor);
462static void* (*dll_PyCapsule_GetPointer)(PyObject *, char *);
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200463# else
Bram Moolenaar221d6872012-06-30 13:34:34 +0200464static PyObject* (*dll_PyCObject_FromVoidPtr)(void *cobj, void (*destr)(void *));
465static void* (*dll_PyCObject_AsVoidPtr)(PyObject *);
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200466# endif
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200467# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
468static int* dll_Py_NoSiteFlag;
469# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000470
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100471static HINSTANCE hinstPython = 0; // Instance of python.dll
Bram Moolenaar071d4272004-06-13 20:20:40 +0000472
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100473// Imported exception objects
Bram Moolenaar071d4272004-06-13 20:20:40 +0000474static PyObject *imp_PyExc_AttributeError;
475static PyObject *imp_PyExc_IndexError;
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200476static PyObject *imp_PyExc_KeyError;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000477static PyObject *imp_PyExc_KeyboardInterrupt;
478static PyObject *imp_PyExc_TypeError;
479static PyObject *imp_PyExc_ValueError;
Bram Moolenaar41009372013-07-01 22:03:04 +0200480static PyObject *imp_PyExc_SystemExit;
Bram Moolenaar8661b172013-05-15 15:44:28 +0200481static PyObject *imp_PyExc_RuntimeError;
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200482static PyObject *imp_PyExc_ImportError;
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200483static PyObject *imp_PyExc_OverflowError;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000484
485# define PyExc_AttributeError imp_PyExc_AttributeError
486# define PyExc_IndexError imp_PyExc_IndexError
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200487# define PyExc_KeyError imp_PyExc_KeyError
Bram Moolenaar071d4272004-06-13 20:20:40 +0000488# define PyExc_KeyboardInterrupt imp_PyExc_KeyboardInterrupt
489# define PyExc_TypeError imp_PyExc_TypeError
490# define PyExc_ValueError imp_PyExc_ValueError
Bram Moolenaar41009372013-07-01 22:03:04 +0200491# define PyExc_SystemExit imp_PyExc_SystemExit
Bram Moolenaar8661b172013-05-15 15:44:28 +0200492# define PyExc_RuntimeError imp_PyExc_RuntimeError
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200493# define PyExc_ImportError imp_PyExc_ImportError
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200494# define PyExc_OverflowError imp_PyExc_OverflowError
Bram Moolenaar071d4272004-06-13 20:20:40 +0000495
496/*
497 * Table of name to function pointer of python.
498 */
499# define PYTHON_PROC FARPROC
500static struct
501{
502 char *name;
503 PYTHON_PROC *ptr;
504} python_funcname_table[] =
505{
Ken Takatac97b3fe2023-10-11 21:27:06 +0200506# ifdef PY_SSIZE_T_CLEAN
Bram Moolenaare8cdcef2012-09-12 20:21:43 +0200507 {"_PyArg_Parse_SizeT", (PYTHON_PROC*)&dll_PyArg_Parse},
508 {"_PyArg_ParseTuple_SizeT", (PYTHON_PROC*)&dll_PyArg_ParseTuple},
509 {"_Py_BuildValue_SizeT", (PYTHON_PROC*)&dll_Py_BuildValue},
Ken Takatac97b3fe2023-10-11 21:27:06 +0200510# else
511 {"PyArg_Parse", (PYTHON_PROC*)&dll_PyArg_Parse},
512 {"PyArg_ParseTuple", (PYTHON_PROC*)&dll_PyArg_ParseTuple},
513 {"Py_BuildValue", (PYTHON_PROC*)&dll_Py_BuildValue},
Bram Moolenaar65951252019-02-01 22:10:16 +0100514# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200515 {"PyMem_Free", (PYTHON_PROC*)&dll_PyMem_Free},
Bram Moolenaardb913952012-06-29 12:54:53 +0200516 {"PyMem_Malloc", (PYTHON_PROC*)&dll_PyMem_Malloc},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000517 {"PyDict_SetItemString", (PYTHON_PROC*)&dll_PyDict_SetItemString},
518 {"PyErr_BadArgument", (PYTHON_PROC*)&dll_PyErr_BadArgument},
Bram Moolenaard5f729c2013-05-15 16:04:40 +0200519 {"PyErr_NewException", (PYTHON_PROC*)&dll_PyErr_NewException},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000520 {"PyErr_Clear", (PYTHON_PROC*)&dll_PyErr_Clear},
Bram Moolenaarc476e522013-06-23 13:46:40 +0200521 {"PyErr_Format", (PYTHON_PROC*)&dll_PyErr_Format},
Bram Moolenaar4d369872013-02-20 16:09:43 +0100522 {"PyErr_PrintEx", (PYTHON_PROC*)&dll_PyErr_PrintEx},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000523 {"PyErr_NoMemory", (PYTHON_PROC*)&dll_PyErr_NoMemory},
524 {"PyErr_Occurred", (PYTHON_PROC*)&dll_PyErr_Occurred},
525 {"PyErr_SetNone", (PYTHON_PROC*)&dll_PyErr_SetNone},
526 {"PyErr_SetString", (PYTHON_PROC*)&dll_PyErr_SetString},
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200527 {"PyErr_SetObject", (PYTHON_PROC*)&dll_PyErr_SetObject},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200528 {"PyErr_ExceptionMatches", (PYTHON_PROC*)&dll_PyErr_ExceptionMatches},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000529 {"PyEval_InitThreads", (PYTHON_PROC*)&dll_PyEval_InitThreads},
530 {"PyEval_RestoreThread", (PYTHON_PROC*)&dll_PyEval_RestoreThread},
531 {"PyEval_SaveThread", (PYTHON_PROC*)&dll_PyEval_SaveThread},
532# ifdef PY_CAN_RECURSE
533 {"PyGILState_Ensure", (PYTHON_PROC*)&dll_PyGILState_Ensure},
534 {"PyGILState_Release", (PYTHON_PROC*)&dll_PyGILState_Release},
535# endif
536 {"PyInt_AsLong", (PYTHON_PROC*)&dll_PyInt_AsLong},
537 {"PyInt_FromLong", (PYTHON_PROC*)&dll_PyInt_FromLong},
Bram Moolenaardb913952012-06-29 12:54:53 +0200538 {"PyLong_AsLong", (PYTHON_PROC*)&dll_PyLong_AsLong},
539 {"PyLong_FromLong", (PYTHON_PROC*)&dll_PyLong_FromLong},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200540 {"PyBool_Type", (PYTHON_PROC*)&dll_PyBool_Type},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000541 {"PyInt_Type", (PYTHON_PROC*)&dll_PyInt_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200542 {"PyLong_Type", (PYTHON_PROC*)&dll_PyLong_Type},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000543 {"PyList_GetItem", (PYTHON_PROC*)&dll_PyList_GetItem},
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000544 {"PyList_Append", (PYTHON_PROC*)&dll_PyList_Append},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200545 {"PyList_Insert", (PYTHON_PROC*)&dll_PyList_Insert},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000546 {"PyList_New", (PYTHON_PROC*)&dll_PyList_New},
547 {"PyList_SetItem", (PYTHON_PROC*)&dll_PyList_SetItem},
548 {"PyList_Size", (PYTHON_PROC*)&dll_PyList_Size},
549 {"PyList_Type", (PYTHON_PROC*)&dll_PyList_Type},
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100550 {"PyTuple_GetItem", (PYTHON_PROC*)&dll_PyTuple_GetItem},
551 {"PyTuple_SetItem", (PYTHON_PROC*)&dll_PyTuple_SetItem},
552 {"PyTuple_SET_ITEM", (PYTHON_PROC*)&dll_PyTuple_SET_ITEM},
553 {"PyTuple_New", (PYTHON_PROC*)&dll_PyTuple_New},
554 {"PyTuple_Size", (PYTHON_PROC*)&dll_PyTuple_Size},
555 {"PyTuple_Type", (PYTHON_PROC*)&dll_PyTuple_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200556 {"PySequence_Size", (PYTHON_PROC*)&dll_PySequence_Size},
557 {"PySequence_Check", (PYTHON_PROC*)&dll_PySequence_Check},
Bram Moolenaara9922d62013-05-30 13:01:18 +0200558 {"PySequence_GetItem", (PYTHON_PROC*)&dll_PySequence_GetItem},
559 {"PySequence_Fast", (PYTHON_PROC*)&dll_PySequence_Fast},
Bram Moolenaardb913952012-06-29 12:54:53 +0200560 {"PyTuple_GetItem", (PYTHON_PROC*)&dll_PyTuple_GetItem},
561 {"PyTuple_Size", (PYTHON_PROC*)&dll_PyTuple_Size},
562 {"PyTuple_Type", (PYTHON_PROC*)&dll_PyTuple_Type},
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100563 {"PySlice_GetIndicesEx", (PYTHON_PROC*)&dll_PySlice_GetIndicesEx},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000564 {"PyImport_ImportModule", (PYTHON_PROC*)&dll_PyImport_ImportModule},
565 {"PyDict_GetItemString", (PYTHON_PROC*)&dll_PyDict_GetItemString},
Bram Moolenaardb913952012-06-29 12:54:53 +0200566 {"PyDict_Next", (PYTHON_PROC*)&dll_PyDict_Next},
Bram Moolenaar0ac93792006-01-21 22:16:51 +0000567 {"PyDict_New", (PYTHON_PROC*)&dll_PyDict_New},
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200568 {"PyDict_Type", (PYTHON_PROC*)&dll_PyDict_Type},
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200569# ifndef PY_NO_MAPPING_KEYS
570 {"PyMapping_Keys", (PYTHON_PROC*)&dll_PyMapping_Keys},
Bram Moolenaardb913952012-06-29 12:54:53 +0200571# endif
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200572 {"PyObject_GetItem", (PYTHON_PROC*)&dll_PyObject_GetItem},
Bram Moolenaardb913952012-06-29 12:54:53 +0200573 {"PyObject_CallMethod", (PYTHON_PROC*)&dll_PyObject_CallMethod},
574 {"PyMapping_Check", (PYTHON_PROC*)&dll_PyMapping_Check},
575 {"PyIter_Next", (PYTHON_PROC*)&dll_PyIter_Next},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000576 {"PyModule_GetDict", (PYTHON_PROC*)&dll_PyModule_GetDict},
Bram Moolenaarf9c9b322013-06-10 20:47:36 +0200577 {"PyModule_AddObject", (PYTHON_PROC*)&dll_PyModule_AddObject},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000578 {"PyRun_SimpleString", (PYTHON_PROC*)&dll_PyRun_SimpleString},
Bram Moolenaardb913952012-06-29 12:54:53 +0200579 {"PyRun_String", (PYTHON_PROC*)&dll_PyRun_String},
Bram Moolenaard620aa92013-05-17 16:40:06 +0200580 {"PyObject_GetAttrString", (PYTHON_PROC*)&dll_PyObject_GetAttrString},
Bram Moolenaara9922d62013-05-30 13:01:18 +0200581 {"PyObject_HasAttrString", (PYTHON_PROC*)&dll_PyObject_HasAttrString},
Bram Moolenaard620aa92013-05-17 16:40:06 +0200582 {"PyObject_SetAttrString", (PYTHON_PROC*)&dll_PyObject_SetAttrString},
583 {"PyObject_CallFunctionObjArgs", (PYTHON_PROC*)&dll_PyObject_CallFunctionObjArgs},
Bram Moolenaar9f3685a2013-06-12 14:20:36 +0200584 {"PyObject_CallFunction", (PYTHON_PROC*)&dll_PyObject_CallFunction},
Bram Moolenaarf4258302013-06-02 18:20:17 +0200585 {"PyObject_Call", (PYTHON_PROC*)&dll_PyObject_Call},
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200586 {"PyObject_Repr", (PYTHON_PROC*)&dll_PyObject_Repr},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000587 {"PyString_AsString", (PYTHON_PROC*)&dll_PyString_AsString},
Bram Moolenaarcdab9052012-09-05 19:03:56 +0200588 {"PyString_AsStringAndSize", (PYTHON_PROC*)&dll_PyString_AsStringAndSize},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000589 {"PyString_FromString", (PYTHON_PROC*)&dll_PyString_FromString},
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200590 {"PyString_FromFormat", (PYTHON_PROC*)&dll_PyString_FromFormat},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000591 {"PyString_FromStringAndSize", (PYTHON_PROC*)&dll_PyString_FromStringAndSize},
592 {"PyString_Size", (PYTHON_PROC*)&dll_PyString_Size},
593 {"PyString_Type", (PYTHON_PROC*)&dll_PyString_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200594 {"PyUnicode_Type", (PYTHON_PROC*)&dll_PyUnicode_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200595 {"PyFloat_Type", (PYTHON_PROC*)&dll_PyFloat_Type},
596 {"PyFloat_AsDouble", (PYTHON_PROC*)&dll_PyFloat_AsDouble},
597 {"PyFloat_FromDouble", (PYTHON_PROC*)&dll_PyFloat_FromDouble},
598 {"PyImport_AddModule", (PYTHON_PROC*)&dll_PyImport_AddModule},
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200599 {"PyNumber_Check", (PYTHON_PROC*)&dll_PyNumber_Check},
600 {"PyNumber_Long", (PYTHON_PROC*)&dll_PyNumber_Long},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000601 {"PySys_SetObject", (PYTHON_PROC*)&dll_PySys_SetObject},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200602 {"PySys_GetObject", (PYTHON_PROC*)&dll_PySys_GetObject},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000603 {"PySys_SetArgv", (PYTHON_PROC*)&dll_PySys_SetArgv},
604 {"PyType_Type", (PYTHON_PROC*)&dll_PyType_Type},
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200605 {"PyFile_Type", (PYTHON_PROC*)&dll_PyFile_Type},
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100606 {"PySlice_Type", (PYTHON_PROC*)&dll_PySlice_Type},
Bram Moolenaar30fec7b2011-03-26 18:32:05 +0100607 {"PyType_Ready", (PYTHON_PROC*)&dll_PyType_Ready},
Bram Moolenaara9922d62013-05-30 13:01:18 +0200608 {"PyType_GenericAlloc", (PYTHON_PROC*)&dll_PyType_GenericAlloc},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000609 {"Py_FindMethod", (PYTHON_PROC*)&dll_Py_FindMethod},
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100610 {"Py_SetPythonHome", (PYTHON_PROC*)&dll_Py_SetPythonHome},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000611 {"Py_Initialize", (PYTHON_PROC*)&dll_Py_Initialize},
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000612 {"Py_Finalize", (PYTHON_PROC*)&dll_Py_Finalize},
613 {"Py_IsInitialized", (PYTHON_PROC*)&dll_Py_IsInitialized},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000614 {"_PyObject_New", (PYTHON_PROC*)&dll__PyObject_New},
Bram Moolenaar774267b2013-05-21 20:51:59 +0200615 {"_PyObject_GC_New", (PYTHON_PROC*)&dll__PyObject_GC_New},
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200616# ifdef Py_underscore_GC
617 {"_PyObject_GC_Del", (PYTHON_PROC*)&dll__PyObject_GC_Del},
618 {"_PyObject_GC_UnTrack", (PYTHON_PROC*)&dll__PyObject_GC_UnTrack},
619# else
Bram Moolenaar774267b2013-05-21 20:51:59 +0200620 {"PyObject_GC_Del", (PYTHON_PROC*)&dll_PyObject_GC_Del},
621 {"PyObject_GC_UnTrack", (PYTHON_PROC*)&dll_PyObject_GC_UnTrack},
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200622# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000623 {"PyObject_Init", (PYTHON_PROC*)&dll__PyObject_Init},
Bram Moolenaardb913952012-06-29 12:54:53 +0200624 {"PyObject_GetIter", (PYTHON_PROC*)&dll_PyObject_GetIter},
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200625 {"PyObject_IsTrue", (PYTHON_PROC*)&dll_PyObject_IsTrue},
Bram Moolenaare7211222012-06-30 13:21:08 +0200626# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
Bram Moolenaardb913952012-06-29 12:54:53 +0200627 {"_PyObject_NextNotImplemented", (PYTHON_PROC*)&dll__PyObject_NextNotImplemented},
Bram Moolenaare7211222012-06-30 13:21:08 +0200628# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000629 {"_Py_NoneStruct", (PYTHON_PROC*)&dll__Py_NoneStruct},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200630 {"_Py_ZeroStruct", (PYTHON_PROC*)&dll__Py_ZeroStruct},
631 {"_Py_TrueStruct", (PYTHON_PROC*)&dll__Py_TrueStruct},
Bram Moolenaar071d4272004-06-13 20:20:40 +0000632# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02020000
Bram Moolenaar0014a532013-05-29 21:33:39 +0200633# ifdef Py_DEBUG
634 {"_Py_NegativeRefcount", (PYTHON_PROC*)&dll__Py_NegativeRefcount},
635 {"_Py_RefTotal", (PYTHON_PROC*)&dll__Py_RefTotal},
636 {"_Py_Dealloc", (PYTHON_PROC*)&dll__Py_Dealloc},
637# endif
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200638 {"PyType_IsSubtype", (PYTHON_PROC*)&dll_PyType_IsSubtype},
639# endif
640# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02030000
Bram Moolenaar0014a532013-05-29 21:33:39 +0200641# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
642 {"_PyObject_DebugFree", (PYTHON_PROC*)&dll__PyObject_DebugFree},
643 {"_PyObject_DebugMalloc", (PYTHON_PROC*)&dll__PyObject_DebugMalloc},
644# else
Bram Moolenaar071d4272004-06-13 20:20:40 +0000645 {"PyObject_Malloc", (PYTHON_PROC*)&dll_PyObject_Malloc},
646 {"PyObject_Free", (PYTHON_PROC*)&dll_PyObject_Free},
Bram Moolenaar0014a532013-05-29 21:33:39 +0200647# endif
648# endif
649# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02050000 \
Bram Moolenaara2aa31a2014-02-23 22:52:40 +0100650 && SIZEOF_SIZE_T != VIM_SIZEOF_INT
Bram Moolenaar0014a532013-05-29 21:33:39 +0200651# ifdef Py_DEBUG
652 {"Py_InitModule4TraceRefs_64", (PYTHON_PROC*)&dll_Py_InitModule4},
653# else
654 {"Py_InitModule4_64", (PYTHON_PROC*)&dll_Py_InitModule4},
655# endif
656# else
657# ifdef Py_DEBUG
658 {"Py_InitModule4TraceRefs", (PYTHON_PROC*)&dll_Py_InitModule4},
659# else
660 {"Py_InitModule4", (PYTHON_PROC*)&dll_Py_InitModule4},
661# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000662# endif
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200663# ifdef PY_USE_CAPSULE
Bram Moolenaardb913952012-06-29 12:54:53 +0200664 {"PyCapsule_New", (PYTHON_PROC*)&dll_PyCapsule_New},
665 {"PyCapsule_GetPointer", (PYTHON_PROC*)&dll_PyCapsule_GetPointer},
Bram Moolenaar2afa3232012-06-29 16:28:28 +0200666# else
667 {"PyCObject_FromVoidPtr", (PYTHON_PROC*)&dll_PyCObject_FromVoidPtr},
668 {"PyCObject_AsVoidPtr", (PYTHON_PROC*)&dll_PyCObject_AsVoidPtr},
669# endif
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200670# if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
671 {"Py_NoSiteFlag", (PYTHON_PROC*)&dll_Py_NoSiteFlag},
672# endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000673 {"", NULL},
674};
675
676/*
Bram Moolenaar071d4272004-06-13 20:20:40 +0000677 * Load library and get all pointers.
678 * Parameter 'libname' provides name of DLL.
679 * Return OK or FAIL.
680 */
681 static int
682python_runtime_link_init(char *libname, int verbose)
683{
684 int i;
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200685 PYTHON_PROC *ucs_as_encoded_string =
686 (PYTHON_PROC*)&py_PyUnicode_AsEncodedString;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000687
Bram Moolenaar65951252019-02-01 22:10:16 +0100688# if !(defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)) && defined(UNIX) && defined(FEAT_PYTHON3)
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100689 // Can't have Python and Python3 loaded at the same time.
Dominique Pelleaf4a61a2021-12-27 17:21:41 +0000690 // It causes a crash, because RTLD_GLOBAL is needed for
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100691 // standard C extension libraries of one or both python versions.
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200692 if (python3_loaded())
693 {
Bram Moolenaar9dc93ae2011-08-28 16:00:19 +0200694 if (verbose)
Bram Moolenaar9d00e4a2022-01-05 17:49:15 +0000695 emsg(_(e_this_vim_cannot_execute_python_after_using_py3));
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200696 return FAIL;
697 }
Bram Moolenaar65951252019-02-01 22:10:16 +0100698# endif
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200699
Bram Moolenaar071d4272004-06-13 20:20:40 +0000700 if (hinstPython)
701 return OK;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200702 hinstPython = load_dll(libname);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000703 if (!hinstPython)
704 {
705 if (verbose)
Bram Moolenaar460ae5d2022-01-01 14:19:49 +0000706 semsg(_(e_could_not_load_library_str_str), libname, load_dll_error());
Bram Moolenaar071d4272004-06-13 20:20:40 +0000707 return FAIL;
708 }
709
710 for (i = 0; python_funcname_table[i].ptr; ++i)
711 {
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200712 if ((*python_funcname_table[i].ptr = symbol_from_dll(hinstPython,
Bram Moolenaar071d4272004-06-13 20:20:40 +0000713 python_funcname_table[i].name)) == NULL)
714 {
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200715 close_dll(hinstPython);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000716 hinstPython = 0;
717 if (verbose)
Bram Moolenaar460ae5d2022-01-01 14:19:49 +0000718 semsg(_(e_could_not_load_library_function_str), python_funcname_table[i].name);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000719 return FAIL;
720 }
721 }
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200722
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100723 // Load unicode functions separately as only the ucs2 or the ucs4 functions
724 // will be present in the library.
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200725 *ucs_as_encoded_string = symbol_from_dll(hinstPython,
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200726 "PyUnicodeUCS2_AsEncodedString");
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200727 if (*ucs_as_encoded_string == NULL)
728 *ucs_as_encoded_string = symbol_from_dll(hinstPython,
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200729 "PyUnicodeUCS4_AsEncodedString");
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200730 if (*ucs_as_encoded_string == NULL)
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200731 {
732 close_dll(hinstPython);
733 hinstPython = 0;
734 if (verbose)
Bram Moolenaar460ae5d2022-01-01 14:19:49 +0000735 semsg(_(e_could_not_load_library_function_str), "PyUnicode_UCSX_*");
Bram Moolenaarcc3e85f2012-06-29 19:14:52 +0200736 return FAIL;
737 }
738
Bram Moolenaar071d4272004-06-13 20:20:40 +0000739 return OK;
740}
741
742/*
743 * If python is enabled (there is installed python on Windows system) return
744 * TRUE, else FALSE.
745 */
746 int
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +0000747python_enabled(int verbose)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000748{
Bram Moolenaar25e4fcd2016-01-09 14:57:47 +0100749 return python_runtime_link_init((char *)p_pydll, verbose) == OK;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000750}
751
Bram Moolenaarca8a4df2010-07-31 19:54:14 +0200752/*
753 * Load the standard Python exceptions - don't import the symbols from the
Bram Moolenaar071d4272004-06-13 20:20:40 +0000754 * DLL, as this can cause errors (importing data symbols is not reliable).
755 */
Bram Moolenaar071d4272004-06-13 20:20:40 +0000756 static void
Bram Moolenaarca8a4df2010-07-31 19:54:14 +0200757get_exceptions(void)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000758{
759 PyObject *exmod = PyImport_ImportModule("exceptions");
760 PyObject *exdict = PyModule_GetDict(exmod);
761 imp_PyExc_AttributeError = PyDict_GetItemString(exdict, "AttributeError");
762 imp_PyExc_IndexError = PyDict_GetItemString(exdict, "IndexError");
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200763 imp_PyExc_KeyError = PyDict_GetItemString(exdict, "KeyError");
Bram Moolenaar071d4272004-06-13 20:20:40 +0000764 imp_PyExc_KeyboardInterrupt = PyDict_GetItemString(exdict, "KeyboardInterrupt");
765 imp_PyExc_TypeError = PyDict_GetItemString(exdict, "TypeError");
766 imp_PyExc_ValueError = PyDict_GetItemString(exdict, "ValueError");
Bram Moolenaar41009372013-07-01 22:03:04 +0200767 imp_PyExc_SystemExit = PyDict_GetItemString(exdict, "SystemExit");
Bram Moolenaar8661b172013-05-15 15:44:28 +0200768 imp_PyExc_RuntimeError = PyDict_GetItemString(exdict, "RuntimeError");
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200769 imp_PyExc_ImportError = PyDict_GetItemString(exdict, "ImportError");
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200770 imp_PyExc_OverflowError = PyDict_GetItemString(exdict, "OverflowError");
Bram Moolenaar071d4272004-06-13 20:20:40 +0000771 Py_XINCREF(imp_PyExc_AttributeError);
772 Py_XINCREF(imp_PyExc_IndexError);
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200773 Py_XINCREF(imp_PyExc_KeyError);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000774 Py_XINCREF(imp_PyExc_KeyboardInterrupt);
775 Py_XINCREF(imp_PyExc_TypeError);
776 Py_XINCREF(imp_PyExc_ValueError);
Bram Moolenaar41009372013-07-01 22:03:04 +0200777 Py_XINCREF(imp_PyExc_SystemExit);
Bram Moolenaar8661b172013-05-15 15:44:28 +0200778 Py_XINCREF(imp_PyExc_RuntimeError);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200779 Py_XINCREF(imp_PyExc_ImportError);
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200780 Py_XINCREF(imp_PyExc_OverflowError);
Bram Moolenaar071d4272004-06-13 20:20:40 +0000781 Py_XDECREF(exmod);
782}
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100783#endif // DYNAMIC_PYTHON
Bram Moolenaar071d4272004-06-13 20:20:40 +0000784
Bram Moolenaardb913952012-06-29 12:54:53 +0200785static int initialised = 0;
786#define PYINITIALISED initialised
Bram Moolenaarc4f83382017-07-07 14:50:44 +0200787static int python_end_called = FALSE;
Bram Moolenaardb913952012-06-29 12:54:53 +0200788
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200789#define DESTRUCTOR_FINISH(self) self->ob_type->tp_free((PyObject*)self);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200790
Bram Moolenaar971db462013-05-12 18:44:48 +0200791#define WIN_PYTHON_REF(win) win->w_python_ref
792#define BUF_PYTHON_REF(buf) buf->b_python_ref
Bram Moolenaar5e538ec2013-05-15 15:12:29 +0200793#define TAB_PYTHON_REF(tab) tab->tp_python_ref
Bram Moolenaar971db462013-05-12 18:44:48 +0200794
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200795static PyObject *OutputGetattr(PyObject *, char *);
796static PyObject *BufferGetattr(PyObject *, char *);
797static PyObject *WindowGetattr(PyObject *, char *);
Bram Moolenaar5e538ec2013-05-15 15:12:29 +0200798static PyObject *TabPageGetattr(PyObject *, char *);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200799static PyObject *RangeGetattr(PyObject *, char *);
800static PyObject *DictionaryGetattr(PyObject *, char*);
801static PyObject *ListGetattr(PyObject *, char *);
Yegappan Lakshmanan038be272025-03-26 18:46:21 +0100802static PyObject *TupleGetattr(PyObject *, char *);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200803static PyObject *FunctionGetattr(PyObject *, char *);
804
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200805#ifndef Py_VISIT
806# define Py_VISIT(obj) visit(obj, arg)
807#endif
808#ifndef Py_CLEAR
809# define Py_CLEAR(obj) \
Bram Moolenaar3e734ea2013-05-29 22:05:55 +0200810 { \
811 Py_XDECREF(obj); \
812 obj = NULL; \
813 }
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200814#endif
815
Bram Moolenaarfdde8802013-05-30 15:38:24 +0200816#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
817 static void *
818py_memsave(void *p, size_t len)
819{
820 void *r;
821
822 if (!(r = PyMem_Malloc(len)))
823 return NULL;
824 mch_memmove(r, p, len);
825 return r;
826}
827
828# define PY_STRSAVE(s) ((char_u *) py_memsave(s, STRLEN(s) + 1))
829#endif
830
Bram Moolenaar922a4662014-03-30 16:11:43 +0200831typedef PySliceObject PySliceObject_T;
832
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200833/*
834 * Include the code shared with if_python3.c
835 */
836#include "if_py_both.h"
837
838
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100839///////////////////////////////////////////////////////
840// Internal function prototypes.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000841
Bram Moolenaar071d4272004-06-13 20:20:40 +0000842static int PythonMod_Init(void);
843
Bram Moolenaar071d4272004-06-13 20:20:40 +0000844
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100845///////////////////////////////////////////////////////
846// 1. Python interpreter main program.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000847
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100848#if PYTHON_API_VERSION < 1007 // Python 1.4
Bram Moolenaar071d4272004-06-13 20:20:40 +0000849typedef PyObject PyThreadState;
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000850#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000851
Bram Moolenaar71700b82013-05-15 17:49:05 +0200852#ifndef PY_CAN_RECURSE
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000853static PyThreadState *saved_python_thread = NULL;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000854
855/*
856 * Suspend a thread of the Python interpreter, other threads are allowed to
857 * run.
858 */
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000859 static void
860Python_SaveThread(void)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000861{
862 saved_python_thread = PyEval_SaveThread();
863}
864
865/*
866 * Restore a thread of the Python interpreter, waits for other threads to
867 * block.
868 */
Bram Moolenaar293ee4d2004-12-09 21:34:53 +0000869 static void
870Python_RestoreThread(void)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000871{
872 PyEval_RestoreThread(saved_python_thread);
873 saved_python_thread = NULL;
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000874}
Bram Moolenaar71700b82013-05-15 17:49:05 +0200875#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +0000876
Bram Moolenaar071d4272004-06-13 20:20:40 +0000877 void
Bram Moolenaar68c2f632016-01-30 17:24:07 +0100878python_end(void)
Bram Moolenaar071d4272004-06-13 20:20:40 +0000879{
Bram Moolenaara5792f52005-11-23 21:25:05 +0000880 static int recurse = 0;
881
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100882 // If a crash occurs while doing this, don't try again.
Bram Moolenaara5792f52005-11-23 21:25:05 +0000883 if (recurse != 0)
884 return;
885
Bram Moolenaarc4f83382017-07-07 14:50:44 +0200886 python_end_called = TRUE;
Bram Moolenaara5792f52005-11-23 21:25:05 +0000887 ++recurse;
888
Bram Moolenaar071d4272004-06-13 20:20:40 +0000889#ifdef DYNAMIC_PYTHON
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000890 if (hinstPython && Py_IsInitialized())
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000891 {
Bram Moolenaar71700b82013-05-15 17:49:05 +0200892# ifdef PY_CAN_RECURSE
893 PyGILState_Ensure();
894# else
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100895 Python_RestoreThread(); // enter python
Bram Moolenaar71700b82013-05-15 17:49:05 +0200896# endif
Bram Moolenaarc9b4b052006-04-30 18:54:39 +0000897 Py_Finalize();
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000898 }
Bram Moolenaar0e21a3f2005-04-17 20:28:32 +0000899#else
900 if (Py_IsInitialized())
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000901 {
Bram Moolenaar71700b82013-05-15 17:49:05 +0200902# ifdef PY_CAN_RECURSE
903 PyGILState_Ensure();
904# else
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100905 Python_RestoreThread(); // enter python
Bram Moolenaar71700b82013-05-15 17:49:05 +0200906# endif
Bram Moolenaarc9b4b052006-04-30 18:54:39 +0000907 Py_Finalize();
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +0000908 }
Bram Moolenaar071d4272004-06-13 20:20:40 +0000909#endif
Bram Moolenaara5792f52005-11-23 21:25:05 +0000910
911 --recurse;
Bram Moolenaar071d4272004-06-13 20:20:40 +0000912}
913
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200914#if (defined(DYNAMIC_PYTHON) && defined(FEAT_PYTHON3)) || defined(PROTO)
915 int
Bram Moolenaar68c2f632016-01-30 17:24:07 +0100916python_loaded(void)
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200917{
918 return (hinstPython != 0);
919}
920#endif
921
Bram Moolenaar94073162018-01-31 21:49:05 +0100922static char *py_home_buf = NULL;
923
Bram Moolenaar071d4272004-06-13 20:20:40 +0000924 static int
925Python_Init(void)
926{
927 if (!initialised)
928 {
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200929#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
930 PyObject *site;
931#endif
932
Bram Moolenaar071d4272004-06-13 20:20:40 +0000933#ifdef DYNAMIC_PYTHON
934 if (!python_enabled(TRUE))
935 {
Bram Moolenaar9a846fb2022-01-01 21:59:18 +0000936 emsg(_(e_sorry_this_command_is_disabled_python_library_could_not_be_found));
Bram Moolenaar071d4272004-06-13 20:20:40 +0000937 goto fail;
938 }
939#endif
940
Bram Moolenaar94073162018-01-31 21:49:05 +0100941 if (*p_pyhome != NUL)
942 {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100943 // The string must not change later, make a copy in static memory.
Bram Moolenaar94073162018-01-31 21:49:05 +0100944 py_home_buf = (char *)vim_strsave(p_pyhome);
945 if (py_home_buf != NULL)
946 Py_SetPythonHome(py_home_buf);
947 }
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100948#ifdef PYTHON_HOME
Bram Moolenaar94073162018-01-31 21:49:05 +0100949 else if (mch_getenv((char_u *)"PYTHONHOME") == NULL)
Bram Moolenaar10005652015-12-31 21:03:23 +0100950 Py_SetPythonHome(PYTHON_HOME);
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100951#endif
952
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200953 init_structs();
954
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200955#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100956 // Disable implicit 'import site', because it may cause Vim to exit
957 // when it can't be found.
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200958 Py_NoSiteFlag++;
959#endif
960
Bram Moolenaar071d4272004-06-13 20:20:40 +0000961 Py_Initialize();
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200962
963#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02070000
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100964 // 'import site' explicitly.
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200965 site = PyImport_ImportModule("site");
966 if (site == NULL)
967 {
Bram Moolenaard82a47d2022-01-05 20:24:39 +0000968 emsg(_(e_sorry_this_command_is_disabled_python_side_module_could_not_be_loaded));
Bram Moolenaar12a28d42014-07-23 16:57:00 +0200969 goto fail;
970 }
971 Py_DECREF(site);
972#endif
973
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100974 // Initialise threads, and below save the state using
975 // PyEval_SaveThread. Without the call to PyEval_SaveThread, thread
976 // specific state (such as the system trace hook), will be lost
977 // between invocations of Python code.
Bram Moolenaar071d4272004-06-13 20:20:40 +0000978 PyEval_InitThreads();
Bram Moolenaar071d4272004-06-13 20:20:40 +0000979#ifdef DYNAMIC_PYTHON
980 get_exceptions();
981#endif
982
Bram Moolenaar1dc28782013-05-21 19:11:01 +0200983 if (PythonIO_Init_io())
Bram Moolenaar071d4272004-06-13 20:20:40 +0000984 goto fail;
985
986 if (PythonMod_Init())
987 goto fail;
988
Bram Moolenaardb913952012-06-29 12:54:53 +0200989 globals = PyModule_GetDict(PyImport_AddModule("__main__"));
990
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100991 // Remove the element from sys.path that was added because of our
992 // argv[0] value in PythonMod_Init(). Previously we used an empty
993 // string, but depending on the OS we then get an empty entry or
994 // the current directory in sys.path.
Bram Moolenaar9774ecc2008-11-20 10:04:53 +0000995 PyRun_SimpleString("import sys; sys.path = filter(lambda x: x != '/must>not&exist', sys.path)");
996
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100997 // lock is created and acquired in PyEval_InitThreads() and thread
998 // state is created in Py_Initialize()
999 // there _PyGILState_NoteThreadState() also sets gilcounter to 1
1000 // (python must have threads enabled!)
1001 // so the following does both: unlock GIL and save thread state in TLS
1002 // without deleting thread state
Bram Moolenaar03db85b2013-05-15 14:51:35 +02001003#ifndef PY_CAN_RECURSE
1004 saved_python_thread =
1005#endif
1006 PyEval_SaveThread();
Bram Moolenaar071d4272004-06-13 20:20:40 +00001007
1008 initialised = 1;
1009 }
1010
1011 return 0;
1012
1013fail:
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001014 // We call PythonIO_Flush() here to print any Python errors.
1015 // This is OK, as it is possible to call this function even
1016 // if PythonIO_Init_io() has not completed successfully (it will
1017 // not do anything in this case).
Bram Moolenaar071d4272004-06-13 20:20:40 +00001018 PythonIO_Flush();
1019 return -1;
1020}
1021
1022/*
1023 * External interface
1024 */
1025 static void
Ben Jacksonea19e782024-11-06 21:50:05 +01001026DoPyCommand(const char *cmd, dict_T* locals, rangeinitializer init_range, runner run, void *arg)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001027{
Bram Moolenaar9ba0eb82005-06-13 22:28:56 +00001028#ifndef PY_CAN_RECURSE
Bram Moolenaar071d4272004-06-13 20:20:40 +00001029 static int recursive = 0;
1030#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001031#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
1032 char *saved_locale;
1033#endif
Bram Moolenaar71700b82013-05-15 17:49:05 +02001034#ifdef PY_CAN_RECURSE
1035 PyGILState_STATE pygilstate;
1036#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001037
1038#ifndef PY_CAN_RECURSE
1039 if (recursive)
1040 {
Bram Moolenaara6f79292022-01-04 21:30:47 +00001041 emsg(_(e_cannot_invoke_python_recursively));
Bram Moolenaar071d4272004-06-13 20:20:40 +00001042 return;
1043 }
1044 ++recursive;
1045#endif
Bram Moolenaarc4f83382017-07-07 14:50:44 +02001046 if (python_end_called)
1047 return;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001048
Bram Moolenaar071d4272004-06-13 20:20:40 +00001049 if (Python_Init())
1050 goto theend;
1051
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001052 init_range(arg);
1053
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001054 Python_Release_Vim(); // leave Vim
Bram Moolenaar071d4272004-06-13 20:20:40 +00001055
1056#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001057 // Python only works properly when the LC_NUMERIC locale is "C".
Bram Moolenaar071d4272004-06-13 20:20:40 +00001058 saved_locale = setlocale(LC_NUMERIC, NULL);
1059 if (saved_locale == NULL || STRCMP(saved_locale, "C") == 0)
1060 saved_locale = NULL;
1061 else
1062 {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001063 // Need to make a copy, value may change when setting new locale.
Bram Moolenaare9ba5162013-05-29 22:02:22 +02001064 saved_locale = (char *) PY_STRSAVE(saved_locale);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001065 (void)setlocale(LC_NUMERIC, "C");
1066 }
1067#endif
1068
Bram Moolenaar71700b82013-05-15 17:49:05 +02001069#ifdef PY_CAN_RECURSE
1070 pygilstate = PyGILState_Ensure();
1071#else
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001072 Python_RestoreThread(); // enter python
Bram Moolenaar71700b82013-05-15 17:49:05 +02001073#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001074
Ben Jacksonea19e782024-11-06 21:50:05 +01001075 run((char *) cmd, locals, arg
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +02001076#ifdef PY_CAN_RECURSE
1077 , &pygilstate
1078#endif
1079 );
Bram Moolenaar071d4272004-06-13 20:20:40 +00001080
Bram Moolenaar71700b82013-05-15 17:49:05 +02001081#ifdef PY_CAN_RECURSE
1082 PyGILState_Release(pygilstate);
1083#else
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001084 Python_SaveThread(); // leave python
Bram Moolenaar71700b82013-05-15 17:49:05 +02001085#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001086
1087#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
1088 if (saved_locale != NULL)
1089 {
1090 (void)setlocale(LC_NUMERIC, saved_locale);
Bram Moolenaare9ba5162013-05-29 22:02:22 +02001091 PyMem_Free(saved_locale);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001092 }
1093#endif
1094
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001095 Python_Lock_Vim(); // enter vim
Bram Moolenaar071d4272004-06-13 20:20:40 +00001096 PythonIO_Flush();
Bram Moolenaar071d4272004-06-13 20:20:40 +00001097
1098theend:
1099#ifndef PY_CAN_RECURSE
1100 --recursive;
1101#endif
Bram Moolenaardb913952012-06-29 12:54:53 +02001102 return;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001103}
1104
1105/*
1106 * ":python"
1107 */
1108 void
1109ex_python(exarg_T *eap)
1110{
1111 char_u *script;
1112
1113 script = script_get(eap, eap->arg);
1114 if (!eap->skip)
1115 {
Bram Moolenaar14816ad2019-02-18 22:04:56 +01001116 if (p_pyx == 0)
1117 p_pyx = 2;
1118
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001119 DoPyCommand(script == NULL ? (char *) eap->arg : (char *) script,
Ben Jacksonea19e782024-11-06 21:50:05 +01001120 NULL,
Yee Cheng Chin2ce070c2023-09-19 20:30:22 +02001121 init_range_cmd,
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001122 (runner) run_cmd,
1123 (void *) eap);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001124 }
1125 vim_free(script);
1126}
1127
1128#define BUFFER_SIZE 1024
1129
1130/*
1131 * ":pyfile"
1132 */
1133 void
1134ex_pyfile(exarg_T *eap)
1135{
1136 static char buffer[BUFFER_SIZE];
1137 const char *file = (char *)eap->arg;
1138 char *p;
1139
Bram Moolenaarf42dd3c2017-01-28 16:06:38 +01001140 if (p_pyx == 0)
1141 p_pyx = 2;
1142
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001143 // Have to do it like this. PyRun_SimpleFile requires you to pass a
1144 // stdio file pointer, but Vim and the Python DLL are compiled with
1145 // different options under Windows, meaning that stdio pointers aren't
1146 // compatible between the two. Yuk.
1147 //
1148 // Put the string "execfile('file')" into buffer. But, we need to
1149 // escape any backslashes or single quotes in the file name, so that
1150 // Python won't mangle the file name.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001151 strcpy(buffer, "execfile('");
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001152 p = buffer + 10; // size of "execfile('"
Bram Moolenaar071d4272004-06-13 20:20:40 +00001153
1154 while (*file && p < buffer + (BUFFER_SIZE - 3))
1155 {
1156 if (*file == '\\' || *file == '\'')
1157 *p++ = '\\';
1158 *p++ = *file++;
1159 }
1160
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001161 // If we didn't finish the file name, we hit a buffer overflow
Bram Moolenaar071d4272004-06-13 20:20:40 +00001162 if (*file != '\0')
1163 return;
1164
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001165 // Put in the terminating "')" and a null
Bram Moolenaar071d4272004-06-13 20:20:40 +00001166 *p++ = '\'';
1167 *p++ = ')';
1168 *p++ = '\0';
1169
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001170 // Execute the file
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001171 DoPyCommand(buffer,
Ben Jacksonea19e782024-11-06 21:50:05 +01001172 NULL,
Yee Cheng Chin2ce070c2023-09-19 20:30:22 +02001173 init_range_cmd,
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001174 (runner) run_cmd,
1175 (void *) eap);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001176}
1177
Bram Moolenaard620aa92013-05-17 16:40:06 +02001178 void
1179ex_pydo(exarg_T *eap)
1180{
Bram Moolenaarf42dd3c2017-01-28 16:06:38 +01001181 if (p_pyx == 0)
1182 p_pyx = 2;
1183
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001184 DoPyCommand((char *)eap->arg,
Ben Jacksonea19e782024-11-06 21:50:05 +01001185 NULL,
Yee Cheng Chin2ce070c2023-09-19 20:30:22 +02001186 init_range_cmd,
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001187 (runner)run_do,
1188 (void *)eap);
Bram Moolenaard620aa92013-05-17 16:40:06 +02001189}
1190
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001191///////////////////////////////////////////////////////
1192// 2. Python output stream: writes output via [e]msg().
Bram Moolenaar071d4272004-06-13 20:20:40 +00001193
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001194// Implementation functions
Bram Moolenaar071d4272004-06-13 20:20:40 +00001195
Bram Moolenaar071d4272004-06-13 20:20:40 +00001196 static PyObject *
1197OutputGetattr(PyObject *self, char *name)
1198{
1199 if (strcmp(name, "softspace") == 0)
1200 return PyInt_FromLong(((OutputObject *)(self))->softspace);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001201 else if (strcmp(name, "__members__") == 0)
1202 return ObjectDir(NULL, OutputAttrs);
Bram Moolenaar6d4431e2016-04-21 20:00:56 +02001203 else if (strcmp(name, "errors") == 0)
1204 return PyString_FromString("strict");
1205 else if (strcmp(name, "encoding") == 0)
1206 return PyString_FromString(ENC_OPT);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001207 return Py_FindMethod(OutputMethods, self, name);
1208}
1209
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001210///////////////////////////////////////////////////////
1211// 3. Implementation of the Vim module for Python
Bram Moolenaar071d4272004-06-13 20:20:40 +00001212
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001213// Window type - Implementation functions
1214// --------------------------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +00001215
Bram Moolenaar071d4272004-06-13 20:20:40 +00001216#define WindowType_Check(obj) ((obj)->ob_type == &WindowType)
1217
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001218// Buffer type - Implementation functions
1219// --------------------------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +00001220
Bram Moolenaar071d4272004-06-13 20:20:40 +00001221#define BufferType_Check(obj) ((obj)->ob_type == &BufferType)
1222
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001223static int BufferAssItem(PyObject *, PyInt, PyObject *);
1224static int BufferAssSlice(PyObject *, PyInt, PyInt, PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001225
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001226// Line range type - Implementation functions
1227// --------------------------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +00001228
Bram Moolenaar071d4272004-06-13 20:20:40 +00001229#define RangeType_Check(obj) ((obj)->ob_type == &RangeType)
1230
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001231static int RangeAssItem(PyObject *, PyInt, PyObject *);
1232static int RangeAssSlice(PyObject *, PyInt, PyInt, PyObject *);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001233
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001234// Current objects type - Implementation functions
1235// -----------------------------------------------
Bram Moolenaar071d4272004-06-13 20:20:40 +00001236
Bram Moolenaar071d4272004-06-13 20:20:40 +00001237static PySequenceMethods BufferAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001238 (PyInquiry) BufferLength, // sq_length, len(x)
1239 (binaryfunc) 0, // BufferConcat, sq_concat, x+y
1240 (PyIntArgFunc) 0, // BufferRepeat, sq_repeat, x*n
1241 (PyIntArgFunc) BufferItem, // sq_item, x[i]
1242 (PyIntIntArgFunc) BufferSlice, // sq_slice, x[i:j]
1243 (PyIntObjArgProc) BufferAssItem, // sq_ass_item, x[i]=v
1244 (PyIntIntObjArgProc) BufferAssSlice, // sq_ass_slice, x[i:j]=v
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001245 (objobjproc) 0,
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001246 (binaryfunc) 0,
Bram Moolenaar071d4272004-06-13 20:20:40 +00001247 0,
Bram Moolenaar071d4272004-06-13 20:20:40 +00001248};
1249
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001250// Buffer object - Implementation
Bram Moolenaar071d4272004-06-13 20:20:40 +00001251
1252 static PyObject *
Bram Moolenaar071d4272004-06-13 20:20:40 +00001253BufferGetattr(PyObject *self, char *name)
1254{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001255 PyObject *r;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001256
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001257 if ((r = BufferAttrValid((BufferObject *)(self), name)))
1258 return r;
1259
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001260 if (CheckBuffer((BufferObject *)(self)))
Bram Moolenaar071d4272004-06-13 20:20:40 +00001261 return NULL;
1262
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001263 r = BufferAttr((BufferObject *)(self), name);
1264 if (r || PyErr_Occurred())
1265 return r;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001266 else
1267 return Py_FindMethod(BufferMethods, self, name);
1268}
1269
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001270//////////////////
Bram Moolenaar071d4272004-06-13 20:20:40 +00001271
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001272 static int
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001273BufferAssItem(PyObject *self, PyInt n, PyObject *val)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001274{
Bram Moolenaar8f1723d2013-05-12 20:36:14 +02001275 return RBAsItem((BufferObject *)(self), n, val, 1, -1, NULL);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001276}
1277
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001278 static int
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001279BufferAssSlice(PyObject *self, PyInt lo, PyInt hi, PyObject *val)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001280{
Bram Moolenaar8f1723d2013-05-12 20:36:14 +02001281 return RBAsSlice((BufferObject *)(self), lo, hi, val, 1, -1, NULL);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001282}
1283
Bram Moolenaar071d4272004-06-13 20:20:40 +00001284static PySequenceMethods RangeAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001285 (PyInquiry) RangeLength, // sq_length, len(x)
1286 (binaryfunc) 0, /* RangeConcat, */ // sq_concat, x+y
1287 (PyIntArgFunc) 0, /* RangeRepeat, */ // sq_repeat, x*n
1288 (PyIntArgFunc) RangeItem, // sq_item, x[i]
1289 (PyIntIntArgFunc) RangeSlice, // sq_slice, x[i:j]
1290 (PyIntObjArgProc) RangeAssItem, // sq_ass_item, x[i]=v
1291 (PyIntIntObjArgProc) RangeAssSlice, // sq_ass_slice, x[i:j]=v
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001292 (objobjproc) 0,
1293#if PY_MAJOR_VERSION >= 2
1294 (binaryfunc) 0,
1295 0,
1296#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001297};
1298
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001299// Line range object - Implementation
Bram Moolenaar071d4272004-06-13 20:20:40 +00001300
Bram Moolenaar071d4272004-06-13 20:20:40 +00001301 static PyObject *
1302RangeGetattr(PyObject *self, char *name)
1303{
1304 if (strcmp(name, "start") == 0)
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +00001305 return Py_BuildValue(Py_ssize_t_fmt, ((RangeObject *)(self))->start - 1);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001306 else if (strcmp(name, "end") == 0)
Bram Moolenaare7cb9cf2008-06-20 14:32:41 +00001307 return Py_BuildValue(Py_ssize_t_fmt, ((RangeObject *)(self))->end - 1);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001308 else if (strcmp(name, "__members__") == 0)
1309 return ObjectDir(NULL, RangeAttrs);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001310 else
1311 return Py_FindMethod(RangeMethods, self, name);
1312}
1313
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001314////////////////
Bram Moolenaar071d4272004-06-13 20:20:40 +00001315
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001316 static int
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001317RangeAssItem(PyObject *self, PyInt n, PyObject *val)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001318{
Bram Moolenaarca8a4df2010-07-31 19:54:14 +02001319 return RBAsItem(((RangeObject *)(self))->buf, n, val,
Bram Moolenaar071d4272004-06-13 20:20:40 +00001320 ((RangeObject *)(self))->start,
1321 ((RangeObject *)(self))->end,
1322 &((RangeObject *)(self))->end);
1323}
1324
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001325 static int
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001326RangeAssSlice(PyObject *self, PyInt lo, PyInt hi, PyObject *val)
Bram Moolenaar071d4272004-06-13 20:20:40 +00001327{
Bram Moolenaar19e60942011-06-19 00:27:51 +02001328 return RBAsSlice(((RangeObject *)(self))->buf, lo, hi, val,
Bram Moolenaar071d4272004-06-13 20:20:40 +00001329 ((RangeObject *)(self))->start,
1330 ((RangeObject *)(self))->end,
1331 &((RangeObject *)(self))->end);
1332}
1333
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001334// TabPage object - Implementation
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001335
1336 static PyObject *
1337TabPageGetattr(PyObject *self, char *name)
1338{
1339 PyObject *r;
1340
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001341 if ((r = TabPageAttrValid((TabPageObject *)(self), name)))
1342 return r;
1343
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001344 if (CheckTabPage((TabPageObject *)(self)))
1345 return NULL;
1346
1347 r = TabPageAttr((TabPageObject *)(self), name);
1348 if (r || PyErr_Occurred())
1349 return r;
1350 else
1351 return Py_FindMethod(TabPageMethods, self, name);
1352}
1353
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001354// Window object - Implementation
Bram Moolenaar071d4272004-06-13 20:20:40 +00001355
1356 static PyObject *
Bram Moolenaar071d4272004-06-13 20:20:40 +00001357WindowGetattr(PyObject *self, char *name)
1358{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001359 PyObject *r;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001360
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001361 if ((r = WindowAttrValid((WindowObject *)(self), name)))
1362 return r;
1363
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001364 if (CheckWindow((WindowObject *)(self)))
Bram Moolenaar071d4272004-06-13 20:20:40 +00001365 return NULL;
1366
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001367 r = WindowAttr((WindowObject *)(self), name);
1368 if (r || PyErr_Occurred())
1369 return r;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001370 else
1371 return Py_FindMethod(WindowMethods, self, name);
1372}
1373
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001374// Tab page list object - Definitions
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001375
1376static PySequenceMethods TabListAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001377 (PyInquiry) TabListLength, // sq_length, len(x)
1378 (binaryfunc) 0, // sq_concat, x+y
1379 (PyIntArgFunc) 0, // sq_repeat, x*n
1380 (PyIntArgFunc) TabListItem, // sq_item, x[i]
1381 (PyIntIntArgFunc) 0, // sq_slice, x[i:j]
1382 (PyIntObjArgProc) 0, // sq_ass_item, x[i]=v
1383 (PyIntIntObjArgProc) 0, // sq_ass_slice, x[i:j]=v
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001384 (objobjproc) 0,
1385#if PY_MAJOR_VERSION >= 2
1386 (binaryfunc) 0,
1387 0,
1388#endif
1389};
1390
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001391// Window list object - Definitions
Bram Moolenaar071d4272004-06-13 20:20:40 +00001392
Bram Moolenaar071d4272004-06-13 20:20:40 +00001393static PySequenceMethods WinListAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001394 (PyInquiry) WinListLength, // sq_length, len(x)
1395 (binaryfunc) 0, // sq_concat, x+y
1396 (PyIntArgFunc) 0, // sq_repeat, x*n
1397 (PyIntArgFunc) WinListItem, // sq_item, x[i]
1398 (PyIntIntArgFunc) 0, // sq_slice, x[i:j]
1399 (PyIntObjArgProc) 0, // sq_ass_item, x[i]=v
1400 (PyIntIntObjArgProc) 0, // sq_ass_slice, x[i:j]=v
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001401 (objobjproc) 0,
1402#if PY_MAJOR_VERSION >= 2
1403 (binaryfunc) 0,
1404 0,
1405#endif
Bram Moolenaar071d4272004-06-13 20:20:40 +00001406};
1407
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001408// External interface
Bram Moolenaar071d4272004-06-13 20:20:40 +00001409
1410 void
1411python_buffer_free(buf_T *buf)
1412{
Yegappan Lakshmanan0233bdf2023-01-12 12:33:30 +00001413 BufferObject *bp = BUF_PYTHON_REF(buf);
1414 if (bp == NULL)
1415 return;
1416 bp->buf = INVALID_BUFFER_VALUE;
1417 BUF_PYTHON_REF(buf) = NULL;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001418}
1419
Bram Moolenaar071d4272004-06-13 20:20:40 +00001420 void
1421python_window_free(win_T *win)
1422{
Yegappan Lakshmanan0233bdf2023-01-12 12:33:30 +00001423 WindowObject *wp = WIN_PYTHON_REF(win);
1424 if (wp == NULL)
1425 return;
1426 wp->win = INVALID_WINDOW_VALUE;
1427 WIN_PYTHON_REF(win) = NULL;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001428}
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001429
1430 void
1431python_tabpage_free(tabpage_T *tab)
1432{
Yegappan Lakshmanan0233bdf2023-01-12 12:33:30 +00001433 TabPageObject *tp = TAB_PYTHON_REF(tab);
1434 if (tp == NULL)
1435 return;
1436 tp->tab = INVALID_TABPAGE_VALUE;
1437 TAB_PYTHON_REF(tab) = NULL;
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001438}
Bram Moolenaar071d4272004-06-13 20:20:40 +00001439
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001440 static int
Bram Moolenaar071d4272004-06-13 20:20:40 +00001441PythonMod_Init(void)
1442{
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001443 // The special value is removed from sys.path in Python_Init().
Bram Moolenaar9f3685a2013-06-12 14:20:36 +02001444 static char *(argv[2]) = {"/must>not&exist/foo", NULL};
Bram Moolenaar071d4272004-06-13 20:20:40 +00001445
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001446 if (init_types())
1447 return -1;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001448
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001449 // Set sys.argv[] to avoid a crash in warn().
Bram Moolenaar071d4272004-06-13 20:20:40 +00001450 PySys_SetArgv(1, argv);
1451
Bram Moolenaarc09a6d62013-06-10 21:27:29 +02001452 vim_module = Py_InitModule4("vim", VimMethods, (char *)NULL,
1453 (PyObject *)NULL, PYTHON_API_VERSION);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001454
Bram Moolenaardee2e312013-06-23 16:35:47 +02001455 if (populate_module(vim_module))
Bram Moolenaarc09a6d62013-06-10 21:27:29 +02001456 return -1;
1457
1458 if (init_sys_path())
1459 return -1;
1460
1461 return 0;
Bram Moolenaar071d4272004-06-13 20:20:40 +00001462}
1463
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001464//////////////////////////////////////////////////////////////////////////
1465// 4. Utility functions for handling the interface between Vim and Python.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001466
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001467// Convert a Vim line into a Python string.
1468// All internal newlines are replaced by null characters.
1469//
1470// On errors, the Python exception data is set, and NULL is returned.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001471 static PyObject *
1472LineToString(const char *str)
1473{
1474 PyObject *result;
Bram Moolenaar2c45e942008-06-04 11:35:26 +00001475 PyInt len = strlen(str);
Bram Moolenaar071d4272004-06-13 20:20:40 +00001476 char *p;
1477
Dominique Pelleaf4a61a2021-12-27 17:21:41 +00001478 // Allocate a Python string object, with uninitialised contents. We
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001479 // must do it this way, so that we can modify the string in place
1480 // later. See the Python source, Objects/stringobject.c for details.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001481 result = PyString_FromStringAndSize(NULL, len);
1482 if (result == NULL)
1483 return NULL;
1484
1485 p = PyString_AsString(result);
1486
1487 while (*str)
1488 {
1489 if (*str == '\n')
1490 *p = '\0';
1491 else
1492 *p = *str;
1493
1494 ++p;
1495 ++str;
1496 }
1497
1498 return result;
1499}
1500
Bram Moolenaardb913952012-06-29 12:54:53 +02001501 static PyObject *
1502DictionaryGetattr(PyObject *self, char *name)
1503{
Bram Moolenaar66b79852012-09-21 14:00:35 +02001504 DictionaryObject *this = ((DictionaryObject *) (self));
1505
1506 if (strcmp(name, "locked") == 0)
1507 return PyInt_FromLong(this->dict->dv_lock);
1508 else if (strcmp(name, "scope") == 0)
1509 return PyInt_FromLong(this->dict->dv_scope);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001510 else if (strcmp(name, "__members__") == 0)
1511 return ObjectDir(NULL, DictionaryAttrs);
Bram Moolenaar66b79852012-09-21 14:00:35 +02001512
Bram Moolenaardb913952012-06-29 12:54:53 +02001513 return Py_FindMethod(DictionaryMethods, self, name);
1514}
1515
Bram Moolenaardb913952012-06-29 12:54:53 +02001516 static PyObject *
1517ListGetattr(PyObject *self, char *name)
1518{
Bram Moolenaar66b79852012-09-21 14:00:35 +02001519 if (strcmp(name, "locked") == 0)
1520 return PyInt_FromLong(((ListObject *)(self))->list->lv_lock);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001521 else if (strcmp(name, "__members__") == 0)
1522 return ObjectDir(NULL, ListAttrs);
Bram Moolenaar66b79852012-09-21 14:00:35 +02001523
Bram Moolenaardb913952012-06-29 12:54:53 +02001524 return Py_FindMethod(ListMethods, self, name);
1525}
1526
Bram Moolenaardb913952012-06-29 12:54:53 +02001527 static PyObject *
Yegappan Lakshmanan038be272025-03-26 18:46:21 +01001528TupleGetattr(PyObject *self, char *name)
1529{
1530 if (strcmp(name, "locked") == 0)
1531 return PyInt_FromLong(((TupleObject *)(self))->tuple->tv_lock);
1532 else if (strcmp(name, "__members__") == 0)
1533 return ObjectDir(NULL, TupleAttrs);
1534
1535 return Py_FindMethod(TupleMethods, self, name);
1536}
1537
1538 static PyObject *
Bram Moolenaardb913952012-06-29 12:54:53 +02001539FunctionGetattr(PyObject *self, char *name)
1540{
Bram Moolenaar8110a092016-04-14 15:56:09 +02001541 PyObject *r;
Bram Moolenaardb913952012-06-29 12:54:53 +02001542
Bram Moolenaar8110a092016-04-14 15:56:09 +02001543 r = FunctionAttr((FunctionObject *)(self), name);
1544
1545 if (r || PyErr_Occurred())
1546 return r;
Bram Moolenaardb913952012-06-29 12:54:53 +02001547 else
1548 return Py_FindMethod(FunctionMethods, self, name);
1549}
1550
1551 void
Ben Jacksonea19e782024-11-06 21:50:05 +01001552do_pyeval(char_u *str, dict_T *locals, typval_T *rettv)
Bram Moolenaardb913952012-06-29 12:54:53 +02001553{
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001554 DoPyCommand((char *) str,
Ben Jacksonea19e782024-11-06 21:50:05 +01001555 locals,
Yee Cheng Chin2ce070c2023-09-19 20:30:22 +02001556 init_range_eval,
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001557 (runner) run_eval,
1558 (void *) rettv);
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001559 if (rettv->v_type == VAR_UNKNOWN)
Bram Moolenaardb913952012-06-29 12:54:53 +02001560 {
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001561 rettv->v_type = VAR_NUMBER;
1562 rettv->vval.v_number = 0;
Bram Moolenaardb913952012-06-29 12:54:53 +02001563 }
1564}
Bram Moolenaar071d4272004-06-13 20:20:40 +00001565
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001566// Don't generate a prototype for the next function, it generates an error on
1567// newer Python versions.
Bram Moolenaar071d4272004-06-13 20:20:40 +00001568#if PYTHON_API_VERSION < 1007 /* Python 1.4 */ && !defined(PROTO)
1569
1570 char *
1571Py_GetProgramName(void)
1572{
1573 return "vim";
1574}
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001575#endif // Python 1.4
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001576
Bram Moolenaar2459a5e2015-02-03 12:55:18 +01001577 int
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001578set_ref_in_python(int copyID)
Bram Moolenaardb913952012-06-29 12:54:53 +02001579{
Bram Moolenaar2459a5e2015-02-03 12:55:18 +01001580 return set_ref_in_py(copyID);
Bram Moolenaardb913952012-06-29 12:54:53 +02001581}