blob: ea4fd7dd8bfc72111d45e505c9f35ef179d76203 [file] [log] [blame]
Bram Moolenaaredf3f972016-08-29 22:49:24 +02001/* vi:set ts=8 sts=4 sw=4 noet:
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02002 *
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/*
21 * Roland Puntaier 2009/sept/16:
22 * Adaptations to support both python3.x and python2.x
23 */
24
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010025// uncomment this if used with the debug version of python
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 Moolenaarbd5e15f2010-07-17 21:19:38 +020031
32#include "vim.h"
33
34#include <limits.h>
35
Bram Moolenaar4f974752019-02-17 17:44:42 +010036#if defined(MSWIN) && defined(HAVE_FCNTL_H)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020037# undef HAVE_FCNTL_H
38#endif
39
40#ifdef _DEBUG
41# undef _DEBUG
42#endif
43
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020044#ifdef F_BLANK
45# undef F_BLANK
46#endif
47
Bram Moolenaar6aa2cd42016-02-16 15:06:59 +010048#ifdef HAVE_STRFTIME
49# undef HAVE_STRFTIME
50#endif
51#ifdef HAVE_STRING_H
52# undef HAVE_STRING_H
53#endif
54#ifdef HAVE_PUTENV
55# undef HAVE_PUTENV
56#endif
Bram Moolenaar6df6f472010-07-18 18:04:50 +020057#ifdef HAVE_STDARG_H
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010058# undef HAVE_STDARG_H // Python's config.h defines it as well.
Bram Moolenaar6df6f472010-07-18 18:04:50 +020059#endif
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010060#ifdef _POSIX_C_SOURCE // defined in feature.h
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020061# undef _POSIX_C_SOURCE
62#endif
Bram Moolenaar6df6f472010-07-18 18:04:50 +020063#ifdef _XOPEN_SOURCE
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010064# undef _XOPEN_SOURCE // pyconfig.h defines it as well.
Bram Moolenaar6df6f472010-07-18 18:04:50 +020065#endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020066
Bram Moolenaar0bdda372013-06-10 18:36:24 +020067#define PY_SSIZE_T_CLEAN
68
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020069#include <Python.h>
Bram Moolenaar0bdda372013-06-10 18:36:24 +020070
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010071#undef main // Defined in python.h - aargh
72#undef HAVE_FCNTL_H // Clash with os_win32.h
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020073
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010074// The "surrogateescape" error handler is new in Python 3.1
Bram Moolenaar3d64a312011-07-15 15:54:44 +020075#if PY_VERSION_HEX >= 0x030100f0
76# define CODEC_ERROR_HANDLER "surrogateescape"
77#else
78# define CODEC_ERROR_HANDLER NULL
79#endif
80
Bram Moolenaar2ab2e862019-12-04 21:24:53 +010081// Python 3 does not support CObjects, always use Capsules
Bram Moolenaar2afa3232012-06-29 16:28:28 +020082#define PY_USE_CAPSULE
83
Bram Moolenaar2e2f52a2020-12-21 16:03:02 +010084#define ERRORS_DECODE_ARG CODEC_ERROR_HANDLER
85#define ERRORS_ENCODE_ARG ERRORS_DECODE_ARG
86
Bram Moolenaar170bf1a2010-07-24 23:51:45 +020087#define PyInt Py_ssize_t
Bram Moolenaar32ac8cd2013-07-03 18:49:17 +020088#ifndef PyString_Check
89# define PyString_Check(obj) PyUnicode_Check(obj)
90#endif
Bram Moolenaare0324612013-07-09 17:30:55 +020091#define PyString_FromString(repr) \
Bram Moolenaar2e2f52a2020-12-21 16:03:02 +010092 PyUnicode_Decode(repr, STRLEN(repr), ENC_OPT, ERRORS_DECODE_ARG)
Bram Moolenaar1a3b5692013-05-30 12:40:39 +020093#define PyString_FromFormat PyUnicode_FromFormat
Bram Moolenaar32ac8cd2013-07-03 18:49:17 +020094#ifndef PyInt_Check
95# define PyInt_Check(obj) PyLong_Check(obj)
96#endif
Bram Moolenaar77045652012-09-21 13:46:06 +020097#define PyInt_FromLong(i) PyLong_FromLong(i)
98#define PyInt_AsLong(obj) PyLong_AsLong(obj)
Bram Moolenaar4d1da492013-04-24 13:39:15 +020099#define Py_ssize_t_fmt "n"
Bram Moolenaara9922d62013-05-30 13:01:18 +0200100#define Py_bytes_fmt "y"
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200101
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100102#define PyIntArgFunc ssizeargfunc
103#define PyIntObjArgProc ssizeobjargproc
104
Bram Moolenaar922a4662014-03-30 16:11:43 +0200105/*
106 * PySlice_GetIndicesEx(): first argument type changed from PySliceObject
107 * to PyObject in Python 3.2 or later.
108 */
109#if PY_VERSION_HEX >= 0x030200f0
110typedef PyObject PySliceObject_T;
111#else
112typedef PySliceObject PySliceObject_T;
113#endif
114
Bram Moolenaar0c1f3f42011-02-25 15:18:50 +0100115#if defined(DYNAMIC_PYTHON3) || defined(PROTO)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200116
Bram Moolenaar4f974752019-02-17 17:44:42 +0100117# ifndef MSWIN
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200118# include <dlfcn.h>
119# define FARPROC void*
120# define HINSTANCE void*
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100121# if defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200122# define load_dll(n) dlopen((n), RTLD_LAZY)
123# else
124# define load_dll(n) dlopen((n), RTLD_LAZY|RTLD_GLOBAL)
125# endif
126# define close_dll dlclose
127# define symbol_from_dll dlsym
128# else
Bram Moolenaarebbcb822010-10-23 14:02:54 +0200129# define load_dll vimLoadLib
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200130# define close_dll FreeLibrary
131# define symbol_from_dll GetProcAddress
132# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200133/*
134 * Wrapper defines
135 */
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200136# undef PyArg_Parse
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200137# define PyArg_Parse py3_PyArg_Parse
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200138# undef PyArg_ParseTuple
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200139# define PyArg_ParseTuple py3_PyArg_ParseTuple
Bram Moolenaar19e60942011-06-19 00:27:51 +0200140# define PyMem_Free py3_PyMem_Free
Bram Moolenaardb913952012-06-29 12:54:53 +0200141# define PyMem_Malloc py3_PyMem_Malloc
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200142# define PyDict_SetItemString py3_PyDict_SetItemString
143# define PyErr_BadArgument py3_PyErr_BadArgument
144# define PyErr_Clear py3_PyErr_Clear
Bram Moolenaarc476e522013-06-23 13:46:40 +0200145# define PyErr_Format py3_PyErr_Format
Bram Moolenaar4d369872013-02-20 16:09:43 +0100146# define PyErr_PrintEx py3_PyErr_PrintEx
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200147# define PyErr_NoMemory py3_PyErr_NoMemory
148# define PyErr_Occurred py3_PyErr_Occurred
149# define PyErr_SetNone py3_PyErr_SetNone
150# define PyErr_SetString py3_PyErr_SetString
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200151# define PyErr_SetObject py3_PyErr_SetObject
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200152# define PyErr_ExceptionMatches py3_PyErr_ExceptionMatches
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200153# define PyEval_InitThreads py3_PyEval_InitThreads
154# define PyEval_RestoreThread py3_PyEval_RestoreThread
155# define PyEval_SaveThread py3_PyEval_SaveThread
156# define PyGILState_Ensure py3_PyGILState_Ensure
157# define PyGILState_Release py3_PyGILState_Release
158# define PyLong_AsLong py3_PyLong_AsLong
159# define PyLong_FromLong py3_PyLong_FromLong
160# define PyList_GetItem py3_PyList_GetItem
161# define PyList_Append py3_PyList_Append
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200162# define PyList_Insert py3_PyList_Insert
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200163# define PyList_New py3_PyList_New
164# define PyList_SetItem py3_PyList_SetItem
165# define PyList_Size py3_PyList_Size
Bram Moolenaardb913952012-06-29 12:54:53 +0200166# define PySequence_Check py3_PySequence_Check
167# define PySequence_Size py3_PySequence_Size
168# define PySequence_GetItem py3_PySequence_GetItem
Bram Moolenaara9922d62013-05-30 13:01:18 +0200169# define PySequence_Fast py3_PySequence_Fast
Bram Moolenaardb913952012-06-29 12:54:53 +0200170# define PyTuple_Size py3_PyTuple_Size
171# define PyTuple_GetItem py3_PyTuple_GetItem
Bram Moolenaar3b48b112018-07-04 22:03:25 +0200172# if PY_VERSION_HEX >= 0x030601f0
173# define PySlice_AdjustIndices py3_PySlice_AdjustIndices
174# define PySlice_Unpack py3_PySlice_Unpack
175# endif
176# undef PySlice_GetIndicesEx
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200177# define PySlice_GetIndicesEx py3_PySlice_GetIndicesEx
178# define PyImport_ImportModule py3_PyImport_ImportModule
179# define PyObject_Init py3__PyObject_Init
180# define PyDict_New py3_PyDict_New
181# define PyDict_GetItemString py3_PyDict_GetItemString
Bram Moolenaardb913952012-06-29 12:54:53 +0200182# define PyDict_Next py3_PyDict_Next
183# define PyMapping_Check py3_PyMapping_Check
Bram Moolenaar32ac8cd2013-07-03 18:49:17 +0200184# ifndef PyMapping_Keys
185# define PyMapping_Keys py3_PyMapping_Keys
186# endif
Bram Moolenaardb913952012-06-29 12:54:53 +0200187# define PyIter_Next py3_PyIter_Next
188# define PyObject_GetIter py3_PyObject_GetIter
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200189# define PyObject_Repr py3_PyObject_Repr
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200190# define PyObject_GetItem py3_PyObject_GetItem
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200191# define PyObject_IsTrue py3_PyObject_IsTrue
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200192# define PyModule_GetDict py3_PyModule_GetDict
193#undef PyRun_SimpleString
194# define PyRun_SimpleString py3_PyRun_SimpleString
Bram Moolenaardb913952012-06-29 12:54:53 +0200195#undef PyRun_String
196# define PyRun_String py3_PyRun_String
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200197# define PyObject_GetAttrString py3_PyObject_GetAttrString
Bram Moolenaara9922d62013-05-30 13:01:18 +0200198# define PyObject_HasAttrString py3_PyObject_HasAttrString
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200199# define PyObject_SetAttrString py3_PyObject_SetAttrString
200# define PyObject_CallFunctionObjArgs py3_PyObject_CallFunctionObjArgs
Bram Moolenaar81c40c52013-06-12 14:41:04 +0200201# define _PyObject_CallFunction_SizeT py3__PyObject_CallFunction_SizeT
Bram Moolenaarf4258302013-06-02 18:20:17 +0200202# define PyObject_Call py3_PyObject_Call
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200203# define PyEval_GetLocals py3_PyEval_GetLocals
204# define PyEval_GetGlobals py3_PyEval_GetGlobals
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200205# define PySys_SetObject py3_PySys_SetObject
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200206# define PySys_GetObject py3_PySys_GetObject
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200207# define PySys_SetArgv py3_PySys_SetArgv
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200208# define PyType_Ready py3_PyType_Ready
Bram Moolenaaree1b9312020-07-16 22:15:53 +0200209# if PY_VERSION_HEX >= 0x030900b0
210# define PyType_GetFlags py3_PyType_GetFlags
211# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200212#undef Py_BuildValue
213# define Py_BuildValue py3_Py_BuildValue
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100214# define Py_SetPythonHome py3_Py_SetPythonHome
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200215# define Py_Initialize py3_Py_Initialize
216# define Py_Finalize py3_Py_Finalize
217# define Py_IsInitialized py3_Py_IsInitialized
218# define _Py_NoneStruct (*py3__Py_NoneStruct)
Bram Moolenaar66b79852012-09-21 14:00:35 +0200219# define _Py_FalseStruct (*py3__Py_FalseStruct)
220# define _Py_TrueStruct (*py3__Py_TrueStruct)
Bram Moolenaardb913952012-06-29 12:54:53 +0200221# define _PyObject_NextNotImplemented (*py3__PyObject_NextNotImplemented)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200222# define PyModule_AddObject py3_PyModule_AddObject
223# define PyImport_AppendInittab py3_PyImport_AppendInittab
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200224# define PyImport_AddModule py3_PyImport_AddModule
Bram Moolenaar7bc4f932012-10-14 03:22:56 +0200225# if PY_VERSION_HEX >= 0x030300f0
226# undef _PyUnicode_AsString
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200227# define _PyUnicode_AsString py3_PyUnicode_AsUTF8
Bram Moolenaar7bc4f932012-10-14 03:22:56 +0200228# else
229# define _PyUnicode_AsString py3__PyUnicode_AsString
230# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200231# undef PyUnicode_AsEncodedString
232# define PyUnicode_AsEncodedString py3_PyUnicode_AsEncodedString
233# undef PyBytes_AsString
234# define PyBytes_AsString py3_PyBytes_AsString
Bram Moolenaar32ac8cd2013-07-03 18:49:17 +0200235# ifndef PyBytes_AsStringAndSize
236# define PyBytes_AsStringAndSize py3_PyBytes_AsStringAndSize
237# endif
Bram Moolenaardb913952012-06-29 12:54:53 +0200238# undef PyBytes_FromString
239# define PyBytes_FromString py3_PyBytes_FromString
Bram Moolenaar6e5ea8d2019-01-12 22:47:31 +0100240# undef PyBytes_FromStringAndSize
241# define PyBytes_FromStringAndSize py3_PyBytes_FromStringAndSize
Bram Moolenaaree1b9312020-07-16 22:15:53 +0200242# if defined(Py_DEBUG) || PY_VERSION_HEX >= 0x030900b0
243# define _Py_Dealloc py3__Py_Dealloc
244# endif
Bram Moolenaardb913952012-06-29 12:54:53 +0200245# define PyFloat_FromDouble py3_PyFloat_FromDouble
246# define PyFloat_AsDouble py3_PyFloat_AsDouble
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200247# define PyObject_GenericGetAttr py3_PyObject_GenericGetAttr
Bram Moolenaar66b79852012-09-21 14:00:35 +0200248# define PyType_Type (*py3_PyType_Type)
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200249# define PyStdPrinter_Type (*py3_PyStdPrinter_Type)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200250# define PySlice_Type (*py3_PySlice_Type)
Bram Moolenaardb913952012-06-29 12:54:53 +0200251# define PyFloat_Type (*py3_PyFloat_Type)
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200252# define PyNumber_Check (*py3_PyNumber_Check)
253# define PyNumber_Long (*py3_PyNumber_Long)
Bram Moolenaar66b79852012-09-21 14:00:35 +0200254# define PyBool_Type (*py3_PyBool_Type)
Bram Moolenaar19e60942011-06-19 00:27:51 +0200255# define PyErr_NewException py3_PyErr_NewException
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200256# ifdef Py_DEBUG
257# define _Py_NegativeRefcount py3__Py_NegativeRefcount
258# define _Py_RefTotal (*py3__Py_RefTotal)
Bram Moolenaar0014a532013-05-29 21:33:39 +0200259# define PyModule_Create2TraceRefs py3_PyModule_Create2TraceRefs
260# else
261# define PyModule_Create2 py3_PyModule_Create2
262# endif
263# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200264# define _PyObject_DebugMalloc py3__PyObject_DebugMalloc
265# define _PyObject_DebugFree py3__PyObject_DebugFree
266# else
267# define PyObject_Malloc py3_PyObject_Malloc
268# define PyObject_Free py3_PyObject_Free
269# endif
Bram Moolenaar774267b2013-05-21 20:51:59 +0200270# define _PyObject_GC_New py3__PyObject_GC_New
271# define PyObject_GC_Del py3_PyObject_GC_Del
272# define PyObject_GC_UnTrack py3_PyObject_GC_UnTrack
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200273# define PyType_GenericAlloc py3_PyType_GenericAlloc
274# define PyType_GenericNew py3_PyType_GenericNew
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200275# undef PyUnicode_FromString
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200276# define PyUnicode_FromString py3_PyUnicode_FromString
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200277# ifndef PyUnicode_FromFormat
278# define PyUnicode_FromFormat py3_PyUnicode_FromFormat
279# else
280# define Py_UNICODE_USE_UCS_FUNCTIONS
281# ifdef Py_UNICODE_WIDE
282# define PyUnicodeUCS4_FromFormat py3_PyUnicodeUCS4_FromFormat
283# else
284# define PyUnicodeUCS2_FromFormat py3_PyUnicodeUCS2_FromFormat
285# endif
286# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200287# undef PyUnicode_Decode
288# define PyUnicode_Decode py3_PyUnicode_Decode
Bram Moolenaardb913952012-06-29 12:54:53 +0200289# define PyType_IsSubtype py3_PyType_IsSubtype
290# define PyCapsule_New py3_PyCapsule_New
291# define PyCapsule_GetPointer py3_PyCapsule_GetPointer
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200292
Bram Moolenaar0014a532013-05-29 21:33:39 +0200293# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200294# undef PyObject_NEW
295# define PyObject_NEW(type, typeobj) \
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200296( (type *) PyObject_Init( \
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200297 (PyObject *) _PyObject_DebugMalloc( _PyObject_SIZE(typeobj) ), (typeobj)) )
Bram Moolenaaree1b9312020-07-16 22:15:53 +0200298# elif PY_VERSION_HEX >= 0x030900b0
299# undef PyObject_NEW
300# define PyObject_NEW(type, typeobj) \
301 ((type *)py3__PyObject_New(typeobj))
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200302# endif
303
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200304/*
305 * Pointers for dynamic link
306 */
307static int (*py3_PySys_SetArgv)(int, wchar_t **);
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100308static void (*py3_Py_SetPythonHome)(wchar_t *home);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200309static void (*py3_Py_Initialize)(void);
310static PyObject* (*py3_PyList_New)(Py_ssize_t size);
311static PyGILState_STATE (*py3_PyGILState_Ensure)(void);
312static void (*py3_PyGILState_Release)(PyGILState_STATE);
313static int (*py3_PySys_SetObject)(char *, PyObject *);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200314static PyObject* (*py3_PySys_GetObject)(char *);
315static int (*py3_PyList_Append)(PyObject *, PyObject *);
316static int (*py3_PyList_Insert)(PyObject *, int, PyObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200317static Py_ssize_t (*py3_PyList_Size)(PyObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200318static int (*py3_PySequence_Check)(PyObject *);
319static Py_ssize_t (*py3_PySequence_Size)(PyObject *);
320static PyObject* (*py3_PySequence_GetItem)(PyObject *, Py_ssize_t);
Bram Moolenaara9922d62013-05-30 13:01:18 +0200321static PyObject* (*py3_PySequence_Fast)(PyObject *, const char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200322static Py_ssize_t (*py3_PyTuple_Size)(PyObject *);
323static PyObject* (*py3_PyTuple_GetItem)(PyObject *, Py_ssize_t);
324static int (*py3_PyMapping_Check)(PyObject *);
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200325static PyObject* (*py3_PyMapping_Keys)(PyObject *);
Bram Moolenaar3b48b112018-07-04 22:03:25 +0200326# if PY_VERSION_HEX >= 0x030601f0
327static int (*py3_PySlice_AdjustIndices)(Py_ssize_t length,
328 Py_ssize_t *start, Py_ssize_t *stop, Py_ssize_t step);
329static int (*py3_PySlice_Unpack)(PyObject *slice,
330 Py_ssize_t *start, Py_ssize_t *stop, Py_ssize_t *step);
331# endif
Bram Moolenaar922a4662014-03-30 16:11:43 +0200332static int (*py3_PySlice_GetIndicesEx)(PySliceObject_T *r, Py_ssize_t length,
Bram Moolenaar063a46b2014-01-14 16:36:51 +0100333 Py_ssize_t *start, Py_ssize_t *stop, Py_ssize_t *step,
334 Py_ssize_t *slicelen);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200335static PyObject* (*py3_PyErr_NoMemory)(void);
336static void (*py3_Py_Finalize)(void);
337static void (*py3_PyErr_SetString)(PyObject *, const char *);
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200338static void (*py3_PyErr_SetObject)(PyObject *, PyObject *);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200339static int (*py3_PyErr_ExceptionMatches)(PyObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200340static int (*py3_PyRun_SimpleString)(char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200341static PyObject* (*py3_PyRun_String)(char *, int, PyObject *, PyObject *);
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200342static PyObject* (*py3_PyObject_GetAttrString)(PyObject *, const char *);
Bram Moolenaara9922d62013-05-30 13:01:18 +0200343static int (*py3_PyObject_HasAttrString)(PyObject *, const char *);
Bram Moolenaar0b400082013-11-03 00:28:25 +0100344static int (*py3_PyObject_SetAttrString)(PyObject *, const char *, PyObject *);
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200345static PyObject* (*py3_PyObject_CallFunctionObjArgs)(PyObject *, ...);
Bram Moolenaar81c40c52013-06-12 14:41:04 +0200346static PyObject* (*py3__PyObject_CallFunction_SizeT)(PyObject *, char *, ...);
Bram Moolenaarf4258302013-06-02 18:20:17 +0200347static PyObject* (*py3_PyObject_Call)(PyObject *, PyObject *, PyObject *);
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200348static PyObject* (*py3_PyEval_GetGlobals)();
349static PyObject* (*py3_PyEval_GetLocals)();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200350static PyObject* (*py3_PyList_GetItem)(PyObject *, Py_ssize_t);
351static PyObject* (*py3_PyImport_ImportModule)(const char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200352static PyObject* (*py3_PyImport_AddModule)(const char *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200353static int (*py3_PyErr_BadArgument)(void);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200354static PyObject* (*py3_PyErr_Occurred)(void);
355static PyObject* (*py3_PyModule_GetDict)(PyObject *);
356static int (*py3_PyList_SetItem)(PyObject *, Py_ssize_t, PyObject *);
357static PyObject* (*py3_PyDict_GetItemString)(PyObject *, const char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200358static int (*py3_PyDict_Next)(PyObject *, Py_ssize_t *, PyObject **, PyObject **);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200359static PyObject* (*py3_PyLong_FromLong)(long);
360static PyObject* (*py3_PyDict_New)(void);
Bram Moolenaardb913952012-06-29 12:54:53 +0200361static PyObject* (*py3_PyIter_Next)(PyObject *);
362static PyObject* (*py3_PyObject_GetIter)(PyObject *);
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200363static PyObject* (*py3_PyObject_Repr)(PyObject *);
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200364static PyObject* (*py3_PyObject_GetItem)(PyObject *, PyObject *);
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200365static int (*py3_PyObject_IsTrue)(PyObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200366static PyObject* (*py3_Py_BuildValue)(char *, ...);
Bram Moolenaaree1b9312020-07-16 22:15:53 +0200367# if PY_VERSION_HEX >= 0x030900b0
368static int (*py3_PyType_GetFlags)(PyTypeObject *o);
369# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200370static int (*py3_PyType_Ready)(PyTypeObject *type);
371static int (*py3_PyDict_SetItemString)(PyObject *dp, char *key, PyObject *item);
372static PyObject* (*py3_PyUnicode_FromString)(const char *u);
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200373# ifndef Py_UNICODE_USE_UCS_FUNCTIONS
374static PyObject* (*py3_PyUnicode_FromFormat)(const char *u, ...);
375# else
376# ifdef Py_UNICODE_WIDE
377static PyObject* (*py3_PyUnicodeUCS4_FromFormat)(const char *u, ...);
378# else
379static PyObject* (*py3_PyUnicodeUCS2_FromFormat)(const char *u, ...);
380# endif
381# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200382static PyObject* (*py3_PyUnicode_Decode)(const char *u, Py_ssize_t size,
383 const char *encoding, const char *errors);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200384static long (*py3_PyLong_AsLong)(PyObject *);
385static void (*py3_PyErr_SetNone)(PyObject *);
386static void (*py3_PyEval_InitThreads)(void);
387static void(*py3_PyEval_RestoreThread)(PyThreadState *);
388static PyThreadState*(*py3_PyEval_SaveThread)(void);
389static int (*py3_PyArg_Parse)(PyObject *, char *, ...);
390static int (*py3_PyArg_ParseTuple)(PyObject *, char *, ...);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200391static int (*py3_PyMem_Free)(void *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200392static void* (*py3_PyMem_Malloc)(size_t);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200393static int (*py3_Py_IsInitialized)(void);
394static void (*py3_PyErr_Clear)(void);
Bram Moolenaarc476e522013-06-23 13:46:40 +0200395static PyObject* (*py3_PyErr_Format)(PyObject *, const char *, ...);
Bram Moolenaar4d369872013-02-20 16:09:43 +0100396static void (*py3_PyErr_PrintEx)(int);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200397static PyObject*(*py3__PyObject_Init)(PyObject *, PyTypeObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200398static iternextfunc py3__PyObject_NextNotImplemented;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200399static PyObject* py3__Py_NoneStruct;
Bram Moolenaar66b79852012-09-21 14:00:35 +0200400static PyObject* py3__Py_FalseStruct;
401static PyObject* py3__Py_TrueStruct;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200402static int (*py3_PyModule_AddObject)(PyObject *m, const char *name, PyObject *o);
403static int (*py3_PyImport_AppendInittab)(const char *name, PyObject* (*initfunc)(void));
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200404# if PY_VERSION_HEX >= 0x030300f0
405static char* (*py3_PyUnicode_AsUTF8)(PyObject *unicode);
406# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200407static char* (*py3__PyUnicode_AsString)(PyObject *unicode);
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200408# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200409static PyObject* (*py3_PyUnicode_AsEncodedString)(PyObject *unicode, const char* encoding, const char* errors);
410static char* (*py3_PyBytes_AsString)(PyObject *bytes);
Bram Moolenaar808c2bc2013-06-23 13:11:18 +0200411static int (*py3_PyBytes_AsStringAndSize)(PyObject *bytes, char **buffer, Py_ssize_t *length);
Bram Moolenaardb913952012-06-29 12:54:53 +0200412static PyObject* (*py3_PyBytes_FromString)(char *str);
Bram Moolenaar6e5ea8d2019-01-12 22:47:31 +0100413static PyObject* (*py3_PyBytes_FromStringAndSize)(char *str, Py_ssize_t length);
Bram Moolenaaree1b9312020-07-16 22:15:53 +0200414# if defined(Py_DEBUG) || PY_VERSION_HEX >= 0x030900b0
415static void (*py3__Py_Dealloc)(PyObject *obj);
416# endif
417# if PY_VERSION_HEX >= 0x030900b0
418static PyObject* (*py3__PyObject_New)(PyTypeObject *);
419# endif
Bram Moolenaardb913952012-06-29 12:54:53 +0200420static PyObject* (*py3_PyFloat_FromDouble)(double num);
421static double (*py3_PyFloat_AsDouble)(PyObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200422static PyObject* (*py3_PyObject_GenericGetAttr)(PyObject *obj, PyObject *name);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200423static PyObject* (*py3_PyType_GenericAlloc)(PyTypeObject *type, Py_ssize_t nitems);
424static PyObject* (*py3_PyType_GenericNew)(PyTypeObject *type, PyObject *args, PyObject *kwds);
Bram Moolenaar66b79852012-09-21 14:00:35 +0200425static PyTypeObject* py3_PyType_Type;
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200426static PyTypeObject* py3_PyStdPrinter_Type;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200427static PyTypeObject* py3_PySlice_Type;
Bram Moolenaardb913952012-06-29 12:54:53 +0200428static PyTypeObject* py3_PyFloat_Type;
Bram Moolenaar66b79852012-09-21 14:00:35 +0200429static PyTypeObject* py3_PyBool_Type;
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200430static int (*py3_PyNumber_Check)(PyObject *);
431static PyObject* (*py3_PyNumber_Long)(PyObject *);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200432static PyObject* (*py3_PyErr_NewException)(char *name, PyObject *base, PyObject *dict);
Bram Moolenaardb913952012-06-29 12:54:53 +0200433static PyObject* (*py3_PyCapsule_New)(void *, char *, PyCapsule_Destructor);
434static void* (*py3_PyCapsule_GetPointer)(PyObject *, char *);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200435# ifdef Py_DEBUG
Bram Moolenaar0014a532013-05-29 21:33:39 +0200436static void (*py3__Py_NegativeRefcount)(const char *fname, int lineno, PyObject *op);
437static Py_ssize_t* py3__Py_RefTotal;
Bram Moolenaar0014a532013-05-29 21:33:39 +0200438static PyObject* (*py3_PyModule_Create2TraceRefs)(struct PyModuleDef* module, int module_api_version);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200439# else
Bram Moolenaar0014a532013-05-29 21:33:39 +0200440static PyObject* (*py3_PyModule_Create2)(struct PyModuleDef* module, int module_api_version);
441# endif
442# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
443static void (*py3__PyObject_DebugFree)(void*);
444static void* (*py3__PyObject_DebugMalloc)(size_t);
445# else
446static void (*py3_PyObject_Free)(void*);
447static void* (*py3_PyObject_Malloc)(size_t);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200448# endif
Bram Moolenaar774267b2013-05-21 20:51:59 +0200449static PyObject*(*py3__PyObject_GC_New)(PyTypeObject *);
450static void(*py3_PyObject_GC_Del)(void *);
451static void(*py3_PyObject_GC_UnTrack)(void *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200452static int (*py3_PyType_IsSubtype)(PyTypeObject *, PyTypeObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200453
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100454static HINSTANCE hinstPy3 = 0; // Instance of python.dll
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200455
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100456// Imported exception objects
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200457static PyObject *p3imp_PyExc_AttributeError;
458static PyObject *p3imp_PyExc_IndexError;
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200459static PyObject *p3imp_PyExc_KeyError;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200460static PyObject *p3imp_PyExc_KeyboardInterrupt;
461static PyObject *p3imp_PyExc_TypeError;
462static PyObject *p3imp_PyExc_ValueError;
Bram Moolenaar41009372013-07-01 22:03:04 +0200463static PyObject *p3imp_PyExc_SystemExit;
Bram Moolenaar8661b172013-05-15 15:44:28 +0200464static PyObject *p3imp_PyExc_RuntimeError;
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200465static PyObject *p3imp_PyExc_ImportError;
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200466static PyObject *p3imp_PyExc_OverflowError;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200467
468# define PyExc_AttributeError p3imp_PyExc_AttributeError
469# define PyExc_IndexError p3imp_PyExc_IndexError
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200470# define PyExc_KeyError p3imp_PyExc_KeyError
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200471# define PyExc_KeyboardInterrupt p3imp_PyExc_KeyboardInterrupt
472# define PyExc_TypeError p3imp_PyExc_TypeError
473# define PyExc_ValueError p3imp_PyExc_ValueError
Bram Moolenaar41009372013-07-01 22:03:04 +0200474# define PyExc_SystemExit p3imp_PyExc_SystemExit
Bram Moolenaar8661b172013-05-15 15:44:28 +0200475# define PyExc_RuntimeError p3imp_PyExc_RuntimeError
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200476# define PyExc_ImportError p3imp_PyExc_ImportError
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200477# define PyExc_OverflowError p3imp_PyExc_OverflowError
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200478
479/*
480 * Table of name to function pointer of python.
481 */
482# define PYTHON_PROC FARPROC
483static struct
484{
485 char *name;
486 PYTHON_PROC *ptr;
487} py3_funcname_table[] =
488{
489 {"PySys_SetArgv", (PYTHON_PROC*)&py3_PySys_SetArgv},
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100490 {"Py_SetPythonHome", (PYTHON_PROC*)&py3_Py_SetPythonHome},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200491 {"Py_Initialize", (PYTHON_PROC*)&py3_Py_Initialize},
Bram Moolenaare8cdcef2012-09-12 20:21:43 +0200492 {"_PyArg_ParseTuple_SizeT", (PYTHON_PROC*)&py3_PyArg_ParseTuple},
493 {"_Py_BuildValue_SizeT", (PYTHON_PROC*)&py3_Py_BuildValue},
Bram Moolenaar19e60942011-06-19 00:27:51 +0200494 {"PyMem_Free", (PYTHON_PROC*)&py3_PyMem_Free},
Bram Moolenaardb913952012-06-29 12:54:53 +0200495 {"PyMem_Malloc", (PYTHON_PROC*)&py3_PyMem_Malloc},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200496 {"PyList_New", (PYTHON_PROC*)&py3_PyList_New},
497 {"PyGILState_Ensure", (PYTHON_PROC*)&py3_PyGILState_Ensure},
498 {"PyGILState_Release", (PYTHON_PROC*)&py3_PyGILState_Release},
499 {"PySys_SetObject", (PYTHON_PROC*)&py3_PySys_SetObject},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200500 {"PySys_GetObject", (PYTHON_PROC*)&py3_PySys_GetObject},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200501 {"PyList_Append", (PYTHON_PROC*)&py3_PyList_Append},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200502 {"PyList_Insert", (PYTHON_PROC*)&py3_PyList_Insert},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200503 {"PyList_Size", (PYTHON_PROC*)&py3_PyList_Size},
Bram Moolenaardb913952012-06-29 12:54:53 +0200504 {"PySequence_Check", (PYTHON_PROC*)&py3_PySequence_Check},
505 {"PySequence_Size", (PYTHON_PROC*)&py3_PySequence_Size},
506 {"PySequence_GetItem", (PYTHON_PROC*)&py3_PySequence_GetItem},
Bram Moolenaara9922d62013-05-30 13:01:18 +0200507 {"PySequence_Fast", (PYTHON_PROC*)&py3_PySequence_Fast},
Bram Moolenaardb913952012-06-29 12:54:53 +0200508 {"PyTuple_Size", (PYTHON_PROC*)&py3_PyTuple_Size},
509 {"PyTuple_GetItem", (PYTHON_PROC*)&py3_PyTuple_GetItem},
Bram Moolenaar3b48b112018-07-04 22:03:25 +0200510# if PY_VERSION_HEX >= 0x030601f0
511 {"PySlice_AdjustIndices", (PYTHON_PROC*)&py3_PySlice_AdjustIndices},
512 {"PySlice_Unpack", (PYTHON_PROC*)&py3_PySlice_Unpack},
513# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200514 {"PySlice_GetIndicesEx", (PYTHON_PROC*)&py3_PySlice_GetIndicesEx},
515 {"PyErr_NoMemory", (PYTHON_PROC*)&py3_PyErr_NoMemory},
516 {"Py_Finalize", (PYTHON_PROC*)&py3_Py_Finalize},
517 {"PyErr_SetString", (PYTHON_PROC*)&py3_PyErr_SetString},
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200518 {"PyErr_SetObject", (PYTHON_PROC*)&py3_PyErr_SetObject},
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200519 {"PyErr_ExceptionMatches", (PYTHON_PROC*)&py3_PyErr_ExceptionMatches},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200520 {"PyRun_SimpleString", (PYTHON_PROC*)&py3_PyRun_SimpleString},
Bram Moolenaardb913952012-06-29 12:54:53 +0200521 {"PyRun_String", (PYTHON_PROC*)&py3_PyRun_String},
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200522 {"PyObject_GetAttrString", (PYTHON_PROC*)&py3_PyObject_GetAttrString},
Bram Moolenaara9922d62013-05-30 13:01:18 +0200523 {"PyObject_HasAttrString", (PYTHON_PROC*)&py3_PyObject_HasAttrString},
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200524 {"PyObject_SetAttrString", (PYTHON_PROC*)&py3_PyObject_SetAttrString},
525 {"PyObject_CallFunctionObjArgs", (PYTHON_PROC*)&py3_PyObject_CallFunctionObjArgs},
Bram Moolenaar81c40c52013-06-12 14:41:04 +0200526 {"_PyObject_CallFunction_SizeT", (PYTHON_PROC*)&py3__PyObject_CallFunction_SizeT},
Bram Moolenaarf4258302013-06-02 18:20:17 +0200527 {"PyObject_Call", (PYTHON_PROC*)&py3_PyObject_Call},
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200528 {"PyEval_GetGlobals", (PYTHON_PROC*)&py3_PyEval_GetGlobals},
529 {"PyEval_GetLocals", (PYTHON_PROC*)&py3_PyEval_GetLocals},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200530 {"PyList_GetItem", (PYTHON_PROC*)&py3_PyList_GetItem},
531 {"PyImport_ImportModule", (PYTHON_PROC*)&py3_PyImport_ImportModule},
Bram Moolenaardb913952012-06-29 12:54:53 +0200532 {"PyImport_AddModule", (PYTHON_PROC*)&py3_PyImport_AddModule},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200533 {"PyErr_BadArgument", (PYTHON_PROC*)&py3_PyErr_BadArgument},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200534 {"PyErr_Occurred", (PYTHON_PROC*)&py3_PyErr_Occurred},
535 {"PyModule_GetDict", (PYTHON_PROC*)&py3_PyModule_GetDict},
536 {"PyList_SetItem", (PYTHON_PROC*)&py3_PyList_SetItem},
537 {"PyDict_GetItemString", (PYTHON_PROC*)&py3_PyDict_GetItemString},
Bram Moolenaardb913952012-06-29 12:54:53 +0200538 {"PyDict_Next", (PYTHON_PROC*)&py3_PyDict_Next},
539 {"PyMapping_Check", (PYTHON_PROC*)&py3_PyMapping_Check},
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200540 {"PyMapping_Keys", (PYTHON_PROC*)&py3_PyMapping_Keys},
Bram Moolenaardb913952012-06-29 12:54:53 +0200541 {"PyIter_Next", (PYTHON_PROC*)&py3_PyIter_Next},
542 {"PyObject_GetIter", (PYTHON_PROC*)&py3_PyObject_GetIter},
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200543 {"PyObject_Repr", (PYTHON_PROC*)&py3_PyObject_Repr},
Bram Moolenaarbcb40972013-05-30 13:22:13 +0200544 {"PyObject_GetItem", (PYTHON_PROC*)&py3_PyObject_GetItem},
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200545 {"PyObject_IsTrue", (PYTHON_PROC*)&py3_PyObject_IsTrue},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200546 {"PyLong_FromLong", (PYTHON_PROC*)&py3_PyLong_FromLong},
547 {"PyDict_New", (PYTHON_PROC*)&py3_PyDict_New},
Bram Moolenaaree1b9312020-07-16 22:15:53 +0200548# if PY_VERSION_HEX >= 0x030900b0
549 {"PyType_GetFlags", (PYTHON_PROC*)&py3_PyType_GetFlags},
550# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200551 {"PyType_Ready", (PYTHON_PROC*)&py3_PyType_Ready},
552 {"PyDict_SetItemString", (PYTHON_PROC*)&py3_PyDict_SetItemString},
553 {"PyLong_AsLong", (PYTHON_PROC*)&py3_PyLong_AsLong},
554 {"PyErr_SetNone", (PYTHON_PROC*)&py3_PyErr_SetNone},
555 {"PyEval_InitThreads", (PYTHON_PROC*)&py3_PyEval_InitThreads},
556 {"PyEval_RestoreThread", (PYTHON_PROC*)&py3_PyEval_RestoreThread},
557 {"PyEval_SaveThread", (PYTHON_PROC*)&py3_PyEval_SaveThread},
Bram Moolenaar5f87b232013-06-13 20:57:50 +0200558 {"_PyArg_Parse_SizeT", (PYTHON_PROC*)&py3_PyArg_Parse},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200559 {"Py_IsInitialized", (PYTHON_PROC*)&py3_Py_IsInitialized},
Bram Moolenaardb913952012-06-29 12:54:53 +0200560 {"_PyObject_NextNotImplemented", (PYTHON_PROC*)&py3__PyObject_NextNotImplemented},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200561 {"_Py_NoneStruct", (PYTHON_PROC*)&py3__Py_NoneStruct},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200562 {"_Py_FalseStruct", (PYTHON_PROC*)&py3__Py_FalseStruct},
563 {"_Py_TrueStruct", (PYTHON_PROC*)&py3__Py_TrueStruct},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200564 {"PyErr_Clear", (PYTHON_PROC*)&py3_PyErr_Clear},
Bram Moolenaarc476e522013-06-23 13:46:40 +0200565 {"PyErr_Format", (PYTHON_PROC*)&py3_PyErr_Format},
Bram Moolenaar4d369872013-02-20 16:09:43 +0100566 {"PyErr_PrintEx", (PYTHON_PROC*)&py3_PyErr_PrintEx},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200567 {"PyObject_Init", (PYTHON_PROC*)&py3__PyObject_Init},
568 {"PyModule_AddObject", (PYTHON_PROC*)&py3_PyModule_AddObject},
569 {"PyImport_AppendInittab", (PYTHON_PROC*)&py3_PyImport_AppendInittab},
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200570# if PY_VERSION_HEX >= 0x030300f0
571 {"PyUnicode_AsUTF8", (PYTHON_PROC*)&py3_PyUnicode_AsUTF8},
572# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200573 {"_PyUnicode_AsString", (PYTHON_PROC*)&py3__PyUnicode_AsString},
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200574# endif
Bram Moolenaar1a3b5692013-05-30 12:40:39 +0200575# ifndef Py_UNICODE_USE_UCS_FUNCTIONS
576 {"PyUnicode_FromFormat", (PYTHON_PROC*)&py3_PyUnicode_FromFormat},
577# else
578# ifdef Py_UNICODE_WIDE
579 {"PyUnicodeUCS4_FromFormat", (PYTHON_PROC*)&py3_PyUnicodeUCS4_FromFormat},
580# else
581 {"PyUnicodeUCS2_FromFormat", (PYTHON_PROC*)&py3_PyUnicodeUCS2_FromFormat},
582# endif
583# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200584 {"PyBytes_AsString", (PYTHON_PROC*)&py3_PyBytes_AsString},
Bram Moolenaarcdab9052012-09-05 19:03:56 +0200585 {"PyBytes_AsStringAndSize", (PYTHON_PROC*)&py3_PyBytes_AsStringAndSize},
Bram Moolenaardb913952012-06-29 12:54:53 +0200586 {"PyBytes_FromString", (PYTHON_PROC*)&py3_PyBytes_FromString},
Bram Moolenaar6e5ea8d2019-01-12 22:47:31 +0100587 {"PyBytes_FromStringAndSize", (PYTHON_PROC*)&py3_PyBytes_FromStringAndSize},
Bram Moolenaaree1b9312020-07-16 22:15:53 +0200588# if defined(Py_DEBUG) || PY_VERSION_HEX >= 0x030900b0
589 {"_Py_Dealloc", (PYTHON_PROC*)&py3__Py_Dealloc},
590# endif
591# if PY_VERSION_HEX >= 0x030900b0
592 {"_PyObject_New", (PYTHON_PROC*)&py3__PyObject_New},
593# endif
Bram Moolenaardb913952012-06-29 12:54:53 +0200594 {"PyFloat_FromDouble", (PYTHON_PROC*)&py3_PyFloat_FromDouble},
595 {"PyFloat_AsDouble", (PYTHON_PROC*)&py3_PyFloat_AsDouble},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200596 {"PyObject_GenericGetAttr", (PYTHON_PROC*)&py3_PyObject_GenericGetAttr},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200597 {"PyType_GenericAlloc", (PYTHON_PROC*)&py3_PyType_GenericAlloc},
598 {"PyType_GenericNew", (PYTHON_PROC*)&py3_PyType_GenericNew},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200599 {"PyType_Type", (PYTHON_PROC*)&py3_PyType_Type},
Bram Moolenaard4a8c982018-05-15 22:31:18 +0200600 {"PyStdPrinter_Type", (PYTHON_PROC*)&py3_PyStdPrinter_Type},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200601 {"PySlice_Type", (PYTHON_PROC*)&py3_PySlice_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200602 {"PyFloat_Type", (PYTHON_PROC*)&py3_PyFloat_Type},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200603 {"PyBool_Type", (PYTHON_PROC*)&py3_PyBool_Type},
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200604 {"PyNumber_Check", (PYTHON_PROC*)&py3_PyNumber_Check},
605 {"PyNumber_Long", (PYTHON_PROC*)&py3_PyNumber_Long},
Bram Moolenaar19e60942011-06-19 00:27:51 +0200606 {"PyErr_NewException", (PYTHON_PROC*)&py3_PyErr_NewException},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200607# ifdef Py_DEBUG
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200608 {"_Py_NegativeRefcount", (PYTHON_PROC*)&py3__Py_NegativeRefcount},
609 {"_Py_RefTotal", (PYTHON_PROC*)&py3__Py_RefTotal},
Bram Moolenaar0014a532013-05-29 21:33:39 +0200610 {"PyModule_Create2TraceRefs", (PYTHON_PROC*)&py3_PyModule_Create2TraceRefs},
611# else
612 {"PyModule_Create2", (PYTHON_PROC*)&py3_PyModule_Create2},
613# endif
614# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200615 {"_PyObject_DebugFree", (PYTHON_PROC*)&py3__PyObject_DebugFree},
616 {"_PyObject_DebugMalloc", (PYTHON_PROC*)&py3__PyObject_DebugMalloc},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200617# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200618 {"PyObject_Malloc", (PYTHON_PROC*)&py3_PyObject_Malloc},
619 {"PyObject_Free", (PYTHON_PROC*)&py3_PyObject_Free},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200620# endif
Bram Moolenaar774267b2013-05-21 20:51:59 +0200621 {"_PyObject_GC_New", (PYTHON_PROC*)&py3__PyObject_GC_New},
622 {"PyObject_GC_Del", (PYTHON_PROC*)&py3_PyObject_GC_Del},
623 {"PyObject_GC_UnTrack", (PYTHON_PROC*)&py3_PyObject_GC_UnTrack},
Bram Moolenaardb913952012-06-29 12:54:53 +0200624 {"PyType_IsSubtype", (PYTHON_PROC*)&py3_PyType_IsSubtype},
625 {"PyCapsule_New", (PYTHON_PROC*)&py3_PyCapsule_New},
626 {"PyCapsule_GetPointer", (PYTHON_PROC*)&py3_PyCapsule_GetPointer},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200627 {"", NULL},
628};
629
Bram Moolenaar13a1f3f2019-10-23 21:37:25 +0200630# if PY_VERSION_HEX >= 0x030800f0
631 static inline void
632py3__Py_DECREF(const char *filename UNUSED, int lineno UNUSED, PyObject *op)
633{
Bram Moolenaar13a1f3f2019-10-23 21:37:25 +0200634 if (--op->ob_refcnt != 0)
635 {
636# ifdef Py_REF_DEBUG
637 if (op->ob_refcnt < 0)
638 {
639 _Py_NegativeRefcount(filename, lineno, op);
640 }
641# endif
642 }
643 else
644 {
645 _Py_Dealloc(op);
646 }
647}
648
649# undef Py_DECREF
650# define Py_DECREF(op) py3__Py_DECREF(__FILE__, __LINE__, _PyObject_CAST(op))
651
652 static inline void
653py3__Py_XDECREF(PyObject *op)
654{
655 if (op != NULL)
656 {
657 Py_DECREF(op);
658 }
659}
660
661# undef Py_XDECREF
662# define Py_XDECREF(op) py3__Py_XDECREF(_PyObject_CAST(op))
663# endif
664
Bram Moolenaaree1b9312020-07-16 22:15:53 +0200665# if PY_VERSION_HEX >= 0x030900b0
666 static inline int
667py3_PyType_HasFeature(PyTypeObject *type, unsigned long feature)
668{
669 return ((PyType_GetFlags(type) & feature) != 0);
670}
671# define PyType_HasFeature(t,f) py3_PyType_HasFeature(t,f)
672# endif
673
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200674/*
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200675 * Load library and get all pointers.
676 * Parameter 'libname' provides name of DLL.
677 * Return OK or FAIL.
678 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200679 static int
680py3_runtime_link_init(char *libname, int verbose)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200681{
682 int i;
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200683 PYTHON_PROC *ucs_from_string = (PYTHON_PROC *)&py3_PyUnicode_FromString;
684 PYTHON_PROC *ucs_decode = (PYTHON_PROC *)&py3_PyUnicode_Decode;
685 PYTHON_PROC *ucs_as_encoded_string =
686 (PYTHON_PROC *)&py3_PyUnicode_AsEncodedString;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200687
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100688# if !(defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)) && defined(UNIX) && defined(FEAT_PYTHON)
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100689 // Can't have Python and Python3 loaded at the same time.
690 // It cause a crash, because RTLD_GLOBAL is needed for
691 // standard C extension libraries of one or both python versions.
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200692 if (python_loaded())
693 {
Bram Moolenaar9dc93ae2011-08-28 16:00:19 +0200694 if (verbose)
Bram Moolenaarf9e3e092019-01-13 23:38:42 +0100695 emsg(_("E837: This Vim cannot execute :py3 after using :python"));
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200696 return FAIL;
697 }
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200698# endif
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200699
700 if (hinstPy3 != 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200701 return OK;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200702 hinstPy3 = load_dll(libname);
703
704 if (!hinstPy3)
705 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200706 if (verbose)
Bram Moolenaarf9e3e092019-01-13 23:38:42 +0100707 semsg(_(e_loadlib), libname);
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200708 return FAIL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200709 }
710
711 for (i = 0; py3_funcname_table[i].ptr; ++i)
712 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200713 if ((*py3_funcname_table[i].ptr = symbol_from_dll(hinstPy3,
714 py3_funcname_table[i].name)) == NULL)
715 {
716 close_dll(hinstPy3);
717 hinstPy3 = 0;
718 if (verbose)
Bram Moolenaarf9e3e092019-01-13 23:38:42 +0100719 semsg(_(e_loadfunc), py3_funcname_table[i].name);
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200720 return FAIL;
721 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200722 }
723
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100724 // Load unicode functions separately as only the ucs2 or the ucs4 functions
725 // will be present in the library.
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200726# if PY_VERSION_HEX >= 0x030300f0
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200727 *ucs_from_string = symbol_from_dll(hinstPy3, "PyUnicode_FromString");
728 *ucs_decode = symbol_from_dll(hinstPy3, "PyUnicode_Decode");
729 *ucs_as_encoded_string = symbol_from_dll(hinstPy3,
Bram Moolenaar7bc4f932012-10-14 03:22:56 +0200730 "PyUnicode_AsEncodedString");
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200731# else
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200732 *ucs_from_string = symbol_from_dll(hinstPy3, "PyUnicodeUCS2_FromString");
733 *ucs_decode = symbol_from_dll(hinstPy3,
Bram Moolenaar19e60942011-06-19 00:27:51 +0200734 "PyUnicodeUCS2_Decode");
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200735 *ucs_as_encoded_string = symbol_from_dll(hinstPy3,
Bram Moolenaar19e60942011-06-19 00:27:51 +0200736 "PyUnicodeUCS2_AsEncodedString");
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200737 if (*ucs_from_string == NULL || *ucs_decode == NULL
738 || *ucs_as_encoded_string == NULL)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200739 {
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200740 *ucs_from_string = symbol_from_dll(hinstPy3,
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200741 "PyUnicodeUCS4_FromString");
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200742 *ucs_decode = symbol_from_dll(hinstPy3,
Bram Moolenaar19e60942011-06-19 00:27:51 +0200743 "PyUnicodeUCS4_Decode");
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200744 *ucs_as_encoded_string = symbol_from_dll(hinstPy3,
Bram Moolenaar19e60942011-06-19 00:27:51 +0200745 "PyUnicodeUCS4_AsEncodedString");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200746 }
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200747# endif
Bram Moolenaar7b24ce02018-03-29 18:15:26 +0200748 if (*ucs_from_string == NULL || *ucs_decode == NULL
749 || *ucs_as_encoded_string == NULL)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200750 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200751 close_dll(hinstPy3);
752 hinstPy3 = 0;
753 if (verbose)
Bram Moolenaarf9e3e092019-01-13 23:38:42 +0100754 semsg(_(e_loadfunc), "PyUnicode_UCSX_*");
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200755 return FAIL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200756 }
757
758 return OK;
759}
760
761/*
762 * If python is enabled (there is installed python on Windows system) return
763 * TRUE, else FALSE.
764 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200765 int
766python3_enabled(int verbose)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200767{
Bram Moolenaar25e4fcd2016-01-09 14:57:47 +0100768 return py3_runtime_link_init((char *)p_py3dll, verbose) == OK;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200769}
770
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100771/*
772 * Load the standard Python exceptions - don't import the symbols from the
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200773 * DLL, as this can cause errors (importing data symbols is not reliable).
774 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200775 static void
Bram Moolenaar68c2f632016-01-30 17:24:07 +0100776get_py3_exceptions(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200777{
778 PyObject *exmod = PyImport_ImportModule("builtins");
779 PyObject *exdict = PyModule_GetDict(exmod);
780 p3imp_PyExc_AttributeError = PyDict_GetItemString(exdict, "AttributeError");
781 p3imp_PyExc_IndexError = PyDict_GetItemString(exdict, "IndexError");
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200782 p3imp_PyExc_KeyError = PyDict_GetItemString(exdict, "KeyError");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200783 p3imp_PyExc_KeyboardInterrupt = PyDict_GetItemString(exdict, "KeyboardInterrupt");
784 p3imp_PyExc_TypeError = PyDict_GetItemString(exdict, "TypeError");
785 p3imp_PyExc_ValueError = PyDict_GetItemString(exdict, "ValueError");
Bram Moolenaar41009372013-07-01 22:03:04 +0200786 p3imp_PyExc_SystemExit = PyDict_GetItemString(exdict, "SystemExit");
Bram Moolenaar8661b172013-05-15 15:44:28 +0200787 p3imp_PyExc_RuntimeError = PyDict_GetItemString(exdict, "RuntimeError");
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200788 p3imp_PyExc_ImportError = PyDict_GetItemString(exdict, "ImportError");
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200789 p3imp_PyExc_OverflowError = PyDict_GetItemString(exdict, "OverflowError");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200790 Py_XINCREF(p3imp_PyExc_AttributeError);
791 Py_XINCREF(p3imp_PyExc_IndexError);
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200792 Py_XINCREF(p3imp_PyExc_KeyError);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200793 Py_XINCREF(p3imp_PyExc_KeyboardInterrupt);
794 Py_XINCREF(p3imp_PyExc_TypeError);
795 Py_XINCREF(p3imp_PyExc_ValueError);
Bram Moolenaar41009372013-07-01 22:03:04 +0200796 Py_XINCREF(p3imp_PyExc_SystemExit);
Bram Moolenaar8661b172013-05-15 15:44:28 +0200797 Py_XINCREF(p3imp_PyExc_RuntimeError);
Bram Moolenaarc09a6d62013-06-10 21:27:29 +0200798 Py_XINCREF(p3imp_PyExc_ImportError);
Bram Moolenaar141be8a2013-06-23 14:16:57 +0200799 Py_XINCREF(p3imp_PyExc_OverflowError);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200800 Py_XDECREF(exmod);
801}
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100802#endif // DYNAMIC_PYTHON3
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200803
Bram Moolenaardb913952012-06-29 12:54:53 +0200804static int py3initialised = 0;
Bram Moolenaardb913952012-06-29 12:54:53 +0200805#define PYINITIALISED py3initialised
Bram Moolenaarc4f83382017-07-07 14:50:44 +0200806static int python_end_called = FALSE;
Bram Moolenaardb913952012-06-29 12:54:53 +0200807
Bram Moolenaar774267b2013-05-21 20:51:59 +0200808#define DESTRUCTOR_FINISH(self) Py_TYPE(self)->tp_free((PyObject*)self)
Bram Moolenaardb913952012-06-29 12:54:53 +0200809
Bram Moolenaar971db462013-05-12 18:44:48 +0200810#define WIN_PYTHON_REF(win) win->w_python3_ref
811#define BUF_PYTHON_REF(buf) buf->b_python3_ref
Bram Moolenaar5e538ec2013-05-15 15:12:29 +0200812#define TAB_PYTHON_REF(tab) tab->tp_python3_ref
Bram Moolenaar971db462013-05-12 18:44:48 +0200813
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200814 static void
815call_PyObject_Free(void *p)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200816{
Bram Moolenaar0014a532013-05-29 21:33:39 +0200817#if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200818 _PyObject_DebugFree(p);
819#else
820 PyObject_Free(p);
821#endif
822}
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200823
824 static PyObject *
825call_PyType_GenericNew(PyTypeObject *type, PyObject *args, PyObject *kwds)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200826{
827 return PyType_GenericNew(type,args,kwds);
828}
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200829
830 static PyObject *
831call_PyType_GenericAlloc(PyTypeObject *type, Py_ssize_t nitems)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200832{
833 return PyType_GenericAlloc(type,nitems);
834}
835
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200836static PyObject *OutputGetattro(PyObject *, PyObject *);
837static int OutputSetattro(PyObject *, PyObject *, PyObject *);
838static PyObject *BufferGetattro(PyObject *, PyObject *);
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200839static int BufferSetattro(PyObject *, PyObject *, PyObject *);
Bram Moolenaar5e538ec2013-05-15 15:12:29 +0200840static PyObject *TabPageGetattro(PyObject *, PyObject *);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200841static PyObject *WindowGetattro(PyObject *, PyObject *);
842static int WindowSetattro(PyObject *, PyObject *, PyObject *);
843static PyObject *RangeGetattro(PyObject *, PyObject *);
844static PyObject *CurrentGetattro(PyObject *, PyObject *);
845static int CurrentSetattro(PyObject *, PyObject *, PyObject *);
846static PyObject *DictionaryGetattro(PyObject *, PyObject *);
847static int DictionarySetattro(PyObject *, PyObject *, PyObject *);
848static PyObject *ListGetattro(PyObject *, PyObject *);
849static int ListSetattro(PyObject *, PyObject *, PyObject *);
850static PyObject *FunctionGetattro(PyObject *, PyObject *);
851
852static struct PyModuleDef vimmodule;
853
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200854#define PY_CAN_RECURSE
855
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200856/*
857 * Include the code shared with if_python.c
858 */
859#include "if_py_both.h"
860
Bram Moolenaar828bff12019-03-19 22:11:41 +0100861// NOTE: Must always be used at the start of a block, since it declares "name".
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200862#define GET_ATTR_STRING(name, nameobj) \
863 char *name = ""; \
864 if (PyUnicode_Check(nameobj)) \
Bram Moolenaar828bff12019-03-19 22:11:41 +0100865 name = (char *)_PyUnicode_AsString(nameobj)
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200866
867#define PY3OBJ_DELETED(obj) (obj->ob_base.ob_refcnt<=0)
868
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100869///////////////////////////////////////////////////////
870// Internal function prototypes.
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200871
Bram Moolenaar7854e3a2012-11-28 15:33:14 +0100872static PyObject *Py3Init_vim(void);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200873
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100874///////////////////////////////////////////////////////
875// 1. Python interpreter main program.
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200876
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200877 void
Bram Moolenaar68c2f632016-01-30 17:24:07 +0100878python3_end(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200879{
880 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 Moolenaarbd5e15f2010-07-17 21:19:38 +0200883 if (recurse != 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200884 return;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200885
Bram Moolenaarc4f83382017-07-07 14:50:44 +0200886 python_end_called = TRUE;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200887 ++recurse;
888
889#ifdef DYNAMIC_PYTHON3
890 if (hinstPy3)
891#endif
892 if (Py_IsInitialized())
893 {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100894 // acquire lock before finalizing
Bram Moolenaar71700b82013-05-15 17:49:05 +0200895 PyGILState_Ensure();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200896
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200897 Py_Finalize();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200898 }
899
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200900 --recurse;
901}
902
Bram Moolenaar094454f2015-10-07 10:39:55 +0200903#if (defined(DYNAMIC_PYTHON3) && defined(DYNAMIC_PYTHON) && defined(FEAT_PYTHON) && defined(UNIX)) || defined(PROTO)
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200904 int
Bram Moolenaar68c2f632016-01-30 17:24:07 +0100905python3_loaded(void)
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200906{
907 return (hinstPy3 != 0);
908}
909#endif
910
Bram Moolenaar94073162018-01-31 21:49:05 +0100911static wchar_t *py_home_buf = NULL;
912
Bram Moolenaar56b8dc32020-08-06 21:47:11 +0200913#if defined(MSWIN) && (PY_VERSION_HEX >= 0x030500f0)
Bram Moolenaarc6ed2542020-10-10 23:26:28 +0200914/*
915 * Return TRUE if stdin is readable from Python 3.
916 */
917 static BOOL
918is_stdin_readable(void)
919{
920 DWORD mode, eventnum;
921 struct _stat st;
922 int fd = fileno(stdin);
923 HANDLE hstdin = (HANDLE)_get_osfhandle(fd);
924
925 // Check if stdin is connected to the console.
926 if (GetConsoleMode(hstdin, &mode))
927 // Check if it is opened as input.
928 return GetNumberOfConsoleInputEvents(hstdin, &eventnum);
929
930 return _fstat(fd, &st) == 0;
931}
932
933// Python 3.5 or later will abort inside Py_Initialize() when stdin has
934// been closed (i.e. executed by "vim -"). Reconnect stdin to CONIN$.
Bram Moolenaar56b8dc32020-08-06 21:47:11 +0200935// Note that the python DLL is linked to its own stdio DLL which can be
936// differ from Vim's stdio.
937 static void
938reset_stdin(void)
939{
940 FILE *(*py__acrt_iob_func)(unsigned) = NULL;
941 FILE *(*pyfreopen)(const char *, const char *, FILE *) = NULL;
942 HINSTANCE hinst;
943
944# ifdef DYNAMIC_PYTHON3
945 hinst = hinstPy3;
946# else
947 hinst = GetModuleHandle(PYTHON3_DLL);
948# endif
Bram Moolenaarc6ed2542020-10-10 23:26:28 +0200949 if (hinst == NULL || is_stdin_readable())
Bram Moolenaar56b8dc32020-08-06 21:47:11 +0200950 return;
951
952 // Get "freopen" and "stdin" which are used in the python DLL.
953 // "stdin" is defined as "__acrt_iob_func(0)" in VC++ 2015 or later.
954 py__acrt_iob_func = get_dll_import_func(hinst, "__acrt_iob_func");
955 if (py__acrt_iob_func)
956 {
957 HINSTANCE hpystdiodll = find_imported_module_by_funcname(hinst,
Bram Moolenaar253b16a2020-10-06 19:59:06 +0200958 "__acrt_iob_func");
Bram Moolenaar56b8dc32020-08-06 21:47:11 +0200959 if (hpystdiodll)
Bram Moolenaar253b16a2020-10-06 19:59:06 +0200960 pyfreopen = (void *)GetProcAddress(hpystdiodll, "freopen");
Bram Moolenaar56b8dc32020-08-06 21:47:11 +0200961 }
962
Bram Moolenaarc6ed2542020-10-10 23:26:28 +0200963 // Reconnect stdin to CONIN$.
Bram Moolenaar253b16a2020-10-06 19:59:06 +0200964 if (pyfreopen != NULL)
Bram Moolenaarc6ed2542020-10-10 23:26:28 +0200965 pyfreopen("CONIN$", "r", py__acrt_iob_func(0));
Bram Moolenaar56b8dc32020-08-06 21:47:11 +0200966 else
Bram Moolenaarc6ed2542020-10-10 23:26:28 +0200967 freopen("CONIN$", "r", stdin);
Bram Moolenaar56b8dc32020-08-06 21:47:11 +0200968}
969#else
970# define reset_stdin()
971#endif
972
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200973 static int
974Python3_Init(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200975{
976 if (!py3initialised)
977 {
978#ifdef DYNAMIC_PYTHON3
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200979 if (!python3_enabled(TRUE))
980 {
Bram Moolenaarf9e3e092019-01-13 23:38:42 +0100981 emsg(_("E263: Sorry, this command is disabled, the Python library could not be loaded."));
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200982 goto fail;
983 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200984#endif
985
986 init_structs();
987
Bram Moolenaar94073162018-01-31 21:49:05 +0100988 if (*p_py3home != NUL)
989 {
990 size_t len = mbstowcs(NULL, (char *)p_py3home, 0) + 1;
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100991
Bram Moolenaar2ab2e862019-12-04 21:24:53 +0100992 // The string must not change later, make a copy in static memory.
Bram Moolenaarc799fe22019-05-28 23:08:19 +0200993 py_home_buf = ALLOC_MULT(wchar_t, len);
Bram Moolenaar94073162018-01-31 21:49:05 +0100994 if (py_home_buf != NULL && mbstowcs(
995 py_home_buf, (char *)p_py3home, len) != (size_t)-1)
996 Py_SetPythonHome(py_home_buf);
997 }
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100998#ifdef PYTHON3_HOME
Bram Moolenaar94073162018-01-31 21:49:05 +0100999 else if (mch_getenv((char_u *)"PYTHONHOME") == NULL)
Bram Moolenaar10005652015-12-31 21:03:23 +01001000 Py_SetPythonHome(PYTHON3_HOME);
Bram Moolenaar644d37b2010-11-16 19:26:02 +01001001#endif
1002
Bram Moolenaar7bc4f932012-10-14 03:22:56 +02001003 PyImport_AppendInittab("vim", Py3Init_vim);
1004
Bram Moolenaar56b8dc32020-08-06 21:47:11 +02001005 reset_stdin();
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001006 Py_Initialize();
Bram Moolenaard0573012017-10-28 21:11:06 +02001007
Bram Moolenaarefc0d942020-10-11 18:05:02 +02001008#if PY_VERSION_HEX < 0x03090000
1009 // Initialise threads. This is deprecated since Python 3.9.
Bram Moolenaar456f2bb2011-06-12 21:37:13 +02001010 PyEval_InitThreads();
Bram Moolenaarefc0d942020-10-11 18:05:02 +02001011#endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001012#ifdef DYNAMIC_PYTHON3
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001013 get_py3_exceptions();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001014#endif
1015
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001016 if (PythonIO_Init_io())
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001017 goto fail;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001018
Bram Moolenaardb913952012-06-29 12:54:53 +02001019 globals = PyModule_GetDict(PyImport_AddModule("__main__"));
1020
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001021 // Remove the element from sys.path that was added because of our
1022 // argv[0] value in Py3Init_vim(). Previously we used an empty
1023 // string, but depending on the OS we then get an empty entry or
1024 // the current directory in sys.path.
1025 // Only after vim has been imported, the element does exist in
1026 // sys.path.
Bram Moolenaar19e60942011-06-19 00:27:51 +02001027 PyRun_SimpleString("import vim; import sys; sys.path = list(filter(lambda x: not x.endswith('must>not&exist'), sys.path))");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001028
Bram Moolenaarefc0d942020-10-11 18:05:02 +02001029 // Without the call to PyEval_SaveThread, thread specific state (such
1030 // as the system trace hook), will be lost between invocations of
1031 // Python code.
1032 // GIL may have been created and acquired in PyEval_InitThreads() and
1033 // thread state is created in Py_Initialize(); there
1034 // _PyGILState_NoteThreadState() also sets gilcounter to 1 (python must
1035 // have threads enabled!), so the following does both: unlock GIL and
1036 // save thread state in TLS without deleting thread state
Bram Moolenaar76d711c2013-02-13 14:17:08 +01001037 PyEval_SaveThread();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001038
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001039 py3initialised = 1;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001040 }
1041
1042 return 0;
1043
1044fail:
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001045 // We call PythonIO_Flush() here to print any Python errors.
1046 // This is OK, as it is possible to call this function even
1047 // if PythonIO_Init_io() has not completed successfully (it will
1048 // not do anything in this case).
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001049 PythonIO_Flush();
1050 return -1;
1051}
1052
1053/*
1054 * External interface
1055 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001056 static void
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001057DoPyCommand(const char *cmd, rangeinitializer init_range, runner run, void *arg)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001058{
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001059#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001060 char *saved_locale;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001061#endif
Bram Moolenaar19e60942011-06-19 00:27:51 +02001062 PyObject *cmdstr;
1063 PyObject *cmdbytes;
Bram Moolenaar71700b82013-05-15 17:49:05 +02001064 PyGILState_STATE pygilstate;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001065
Bram Moolenaarc4f83382017-07-07 14:50:44 +02001066 if (python_end_called)
1067 goto theend;
1068
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001069 if (Python3_Init())
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001070 goto theend;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001071
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001072 init_range(arg);
1073
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001074 Python_Release_Vim(); // leave Vim
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001075
1076#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001077 // Python only works properly when the LC_NUMERIC locale is "C".
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001078 saved_locale = setlocale(LC_NUMERIC, NULL);
1079 if (saved_locale == NULL || STRCMP(saved_locale, "C") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001080 saved_locale = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001081 else
1082 {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001083 // Need to make a copy, value may change when setting new locale.
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001084 saved_locale = (char *)vim_strsave((char_u *)saved_locale);
1085 (void)setlocale(LC_NUMERIC, "C");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001086 }
1087#endif
1088
1089 pygilstate = PyGILState_Ensure();
1090
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001091 // PyRun_SimpleString expects a UTF-8 string. Wrong encoding may cause
1092 // SyntaxError (unicode error).
Bram Moolenaar3d64a312011-07-15 15:54:44 +02001093 cmdstr = PyUnicode_Decode(cmd, strlen(cmd),
Bram Moolenaar2e2f52a2020-12-21 16:03:02 +01001094 (char *)ENC_OPT, ERRORS_DECODE_ARG);
1095 cmdbytes = PyUnicode_AsEncodedString(cmdstr, "utf-8", ERRORS_ENCODE_ARG);
Bram Moolenaar19e60942011-06-19 00:27:51 +02001096 Py_XDECREF(cmdstr);
Bram Moolenaardb913952012-06-29 12:54:53 +02001097
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001098 run(PyBytes_AsString(cmdbytes), arg, &pygilstate);
Bram Moolenaar19e60942011-06-19 00:27:51 +02001099 Py_XDECREF(cmdbytes);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001100
1101 PyGILState_Release(pygilstate);
1102
1103#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
1104 if (saved_locale != NULL)
1105 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001106 (void)setlocale(LC_NUMERIC, saved_locale);
1107 vim_free(saved_locale);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001108 }
1109#endif
1110
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001111 Python_Lock_Vim(); // enter Vim
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001112 PythonIO_Flush();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001113
1114theend:
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001115 return; // keeps lint happy
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001116}
1117
1118/*
Bram Moolenaar368373e2010-07-19 20:46:22 +02001119 * ":py3"
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001120 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001121 void
1122ex_py3(exarg_T *eap)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001123{
1124 char_u *script;
1125
1126 script = script_get(eap, eap->arg);
1127 if (!eap->skip)
1128 {
Bram Moolenaar14816ad2019-02-18 22:04:56 +01001129 if (p_pyx == 0)
1130 p_pyx = 3;
1131
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001132 DoPyCommand(script == NULL ? (char *) eap->arg : (char *) script,
1133 (rangeinitializer) init_range_cmd,
1134 (runner) run_cmd,
1135 (void *) eap);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001136 }
1137 vim_free(script);
1138}
1139
1140#define BUFFER_SIZE 2048
1141
1142/*
Bram Moolenaar6df6f472010-07-18 18:04:50 +02001143 * ":py3file"
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001144 */
1145 void
1146ex_py3file(exarg_T *eap)
1147{
1148 static char buffer[BUFFER_SIZE];
1149 const char *file;
1150 char *p;
1151 int i;
1152
Bram Moolenaarf42dd3c2017-01-28 16:06:38 +01001153 if (p_pyx == 0)
1154 p_pyx = 3;
1155
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001156 // Have to do it like this. PyRun_SimpleFile requires you to pass a
1157 // stdio file pointer, but Vim and the Python DLL are compiled with
1158 // different options under Windows, meaning that stdio pointers aren't
1159 // compatible between the two. Yuk.
1160 //
1161 // construct: exec(compile(open('a_filename', 'rb').read(), 'a_filename', 'exec'))
1162 //
1163 // Using bytes so that Python can detect the source encoding as it normally
1164 // does. The doc does not say "compile" accept bytes, though.
1165 //
1166 // We need to escape any backslashes or single quotes in the file name, so that
1167 // Python won't mangle the file name.
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001168
1169 strcpy(buffer, "exec(compile(open('");
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001170 p = buffer + 19; // size of "exec(compile(open('"
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001171
1172 for (i=0; i<2; ++i)
1173 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001174 file = (char *)eap->arg;
1175 while (*file && p < buffer + (BUFFER_SIZE - 3))
1176 {
1177 if (*file == '\\' || *file == '\'')
1178 *p++ = '\\';
1179 *p++ = *file++;
1180 }
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001181 // If we didn't finish the file name, we hit a buffer overflow
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001182 if (*file != '\0')
1183 return;
1184 if (i==0)
1185 {
Bram Moolenaar19e60942011-06-19 00:27:51 +02001186 strcpy(p,"','rb').read(),'");
1187 p += 16;
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001188 }
1189 else
1190 {
1191 strcpy(p,"','exec'))");
1192 p += 10;
1193 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001194 }
1195
1196
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001197 // Execute the file
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001198 DoPyCommand(buffer,
1199 (rangeinitializer) init_range_cmd,
1200 (runner) run_cmd,
1201 (void *) eap);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001202}
1203
Bram Moolenaar54e8f002013-05-15 19:44:39 +02001204 void
1205ex_py3do(exarg_T *eap)
Bram Moolenaar3dab2802013-05-15 18:28:13 +02001206{
Bram Moolenaarf42dd3c2017-01-28 16:06:38 +01001207 if (p_pyx == 0)
1208 p_pyx = 3;
1209
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001210 DoPyCommand((char *)eap->arg,
1211 (rangeinitializer)init_range_cmd,
1212 (runner)run_do,
1213 (void *)eap);
Bram Moolenaar3dab2802013-05-15 18:28:13 +02001214}
1215
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001216///////////////////////////////////////////////////////
1217// 2. Python output stream: writes output via [e]msg().
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001218
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001219// Implementation functions
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001220
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001221 static PyObject *
1222OutputGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001223{
Bram Moolenaar77045652012-09-21 13:46:06 +02001224 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001225
1226 if (strcmp(name, "softspace") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001227 return PyLong_FromLong(((OutputObject *)(self))->softspace);
Bram Moolenaar6d4431e2016-04-21 20:00:56 +02001228 else if (strcmp(name, "errors") == 0)
1229 return PyString_FromString("strict");
1230 else if (strcmp(name, "encoding") == 0)
1231 return PyString_FromString(ENC_OPT);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001232
1233 return PyObject_GenericGetAttr(self, nameobj);
1234}
1235
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001236 static int
1237OutputSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001238{
Bram Moolenaar77045652012-09-21 13:46:06 +02001239 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001240
Bram Moolenaard6e39182013-05-21 18:30:34 +02001241 return OutputSetattr((OutputObject *)(self), name, val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001242}
1243
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001244///////////////////////////////////////////////////////
1245// 3. Implementation of the Vim module for Python
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001246
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001247// Window type - Implementation functions
1248// --------------------------------------
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001249
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001250#define WindowType_Check(obj) ((obj)->ob_base.ob_type == &WindowType)
1251
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001252// Buffer type - Implementation functions
1253// --------------------------------------
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001254
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001255#define BufferType_Check(obj) ((obj)->ob_base.ob_type == &BufferType)
1256
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001257static PyObject* BufferSubscript(PyObject *self, PyObject *idx);
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001258static int BufferAsSubscript(PyObject *self, PyObject *idx, PyObject *val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001259
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001260// Line range type - Implementation functions
1261// --------------------------------------
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001262
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001263#define RangeType_Check(obj) ((obj)->ob_base.ob_type == &RangeType)
1264
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001265static PyObject* RangeSubscript(PyObject *self, PyObject *idx);
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001266static int RangeAsItem(PyObject *, Py_ssize_t, PyObject *);
1267static int RangeAsSubscript(PyObject *self, PyObject *idx, PyObject *val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001268
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001269// Current objects type - Implementation functions
1270// -----------------------------------------------
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001271
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001272static PySequenceMethods BufferAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001273 (lenfunc) BufferLength, // sq_length, len(x)
1274 (binaryfunc) 0, // sq_concat, x+y
1275 (ssizeargfunc) 0, // sq_repeat, x*n
1276 (ssizeargfunc) BufferItem, // sq_item, x[i]
1277 0, // was_sq_slice, x[i:j]
1278 0, // sq_ass_item, x[i]=v
1279 0, // sq_ass_slice, x[i:j]=v
1280 0, // sq_contains
1281 0, // sq_inplace_concat
1282 0, // sq_inplace_repeat
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001283};
1284
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001285static PyMappingMethods BufferAsMapping = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001286 /* mp_length */ (lenfunc)BufferLength,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001287 /* mp_subscript */ (binaryfunc)BufferSubscript,
Bram Moolenaar19e60942011-06-19 00:27:51 +02001288 /* mp_ass_subscript */ (objobjargproc)BufferAsSubscript,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001289};
1290
1291
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001292// Buffer object
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001293
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001294 static PyObject *
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001295BufferGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001296{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001297 PyObject *r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001298
Bram Moolenaar77045652012-09-21 13:46:06 +02001299 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001300
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001301 if ((r = BufferAttrValid((BufferObject *)(self), name)))
1302 return r;
1303
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001304 if (CheckBuffer((BufferObject *)(self)))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001305 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001306
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001307 r = BufferAttr((BufferObject *)(self), name);
1308 if (r || PyErr_Occurred())
1309 return r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001310 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001311 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001312}
1313
Bram Moolenaare9ba5162013-05-29 22:02:22 +02001314 static int
1315BufferSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
1316{
1317 GET_ATTR_STRING(name, nameobj);
1318
1319 return BufferSetattr((BufferObject *)(self), name, val);
1320}
1321
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001322//////////////////
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001323
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001324 static PyObject *
1325BufferSubscript(PyObject *self, PyObject* idx)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001326{
Bram Moolenaardb913952012-06-29 12:54:53 +02001327 if (PyLong_Check(idx))
1328 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001329 long _idx = PyLong_AsLong(idx);
Bram Moolenaard6e39182013-05-21 18:30:34 +02001330 return BufferItem((BufferObject *)(self), _idx);
Bram Moolenaardb913952012-06-29 12:54:53 +02001331 } else if (PySlice_Check(idx))
1332 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001333 Py_ssize_t start, stop, step, slicelen;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001334
Bram Moolenaar8f1723d2013-05-12 20:36:14 +02001335 if (CheckBuffer((BufferObject *) self))
1336 return NULL;
1337
Bram Moolenaar922a4662014-03-30 16:11:43 +02001338 if (PySlice_GetIndicesEx((PySliceObject_T *)idx,
Bram Moolenaarbd80f352013-05-12 21:16:23 +02001339 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count,
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001340 &start, &stop,
Bram Moolenaardb913952012-06-29 12:54:53 +02001341 &step, &slicelen) < 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001342 return NULL;
Bram Moolenaard6e39182013-05-21 18:30:34 +02001343 return BufferSlice((BufferObject *)(self), start, stop);
Bram Moolenaardb913952012-06-29 12:54:53 +02001344 }
1345 else
1346 {
Bram Moolenaarc476e522013-06-23 13:46:40 +02001347 RAISE_INVALID_INDEX_TYPE(idx);
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001348 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001349 }
1350}
1351
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001352 static int
Bram Moolenaar19e60942011-06-19 00:27:51 +02001353BufferAsSubscript(PyObject *self, PyObject* idx, PyObject* val)
1354{
Bram Moolenaardb913952012-06-29 12:54:53 +02001355 if (PyLong_Check(idx))
1356 {
Bram Moolenaar19e60942011-06-19 00:27:51 +02001357 long n = PyLong_AsLong(idx);
Bram Moolenaarab589462020-07-06 21:03:06 +02001358
1359 if (CheckBuffer((BufferObject *) self))
1360 return -1;
1361
Bram Moolenaar19e60942011-06-19 00:27:51 +02001362 return RBAsItem((BufferObject *)(self), n, val, 1,
1363 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count,
1364 NULL);
Bram Moolenaardb913952012-06-29 12:54:53 +02001365 } else if (PySlice_Check(idx))
1366 {
Bram Moolenaar19e60942011-06-19 00:27:51 +02001367 Py_ssize_t start, stop, step, slicelen;
1368
Bram Moolenaar8f1723d2013-05-12 20:36:14 +02001369 if (CheckBuffer((BufferObject *) self))
1370 return -1;
1371
Bram Moolenaar922a4662014-03-30 16:11:43 +02001372 if (PySlice_GetIndicesEx((PySliceObject_T *)idx,
Bram Moolenaarbd80f352013-05-12 21:16:23 +02001373 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count,
Bram Moolenaar19e60942011-06-19 00:27:51 +02001374 &start, &stop,
Bram Moolenaardb913952012-06-29 12:54:53 +02001375 &step, &slicelen) < 0)
Bram Moolenaar19e60942011-06-19 00:27:51 +02001376 return -1;
Bram Moolenaar19e60942011-06-19 00:27:51 +02001377 return RBAsSlice((BufferObject *)(self), start, stop, val, 1,
1378 (PyInt)((BufferObject *)(self))->buf->b_ml.ml_line_count,
1379 NULL);
Bram Moolenaardb913952012-06-29 12:54:53 +02001380 }
1381 else
1382 {
Bram Moolenaarc476e522013-06-23 13:46:40 +02001383 RAISE_INVALID_INDEX_TYPE(idx);
Bram Moolenaar19e60942011-06-19 00:27:51 +02001384 return -1;
1385 }
1386}
1387
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001388static PySequenceMethods RangeAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001389 (lenfunc) RangeLength, // sq_length, len(x)
1390 (binaryfunc) 0, // RangeConcat, sq_concat, x+y
1391 (ssizeargfunc) 0, // RangeRepeat, sq_repeat, x*n
1392 (ssizeargfunc) RangeItem, // sq_item, x[i]
1393 0, // was_sq_slice, x[i:j]
1394 (ssizeobjargproc) RangeAsItem, // sq_as_item, x[i]=v
1395 0, // sq_ass_slice, x[i:j]=v
1396 0, // sq_contains
1397 0, // sq_inplace_concat
1398 0, // sq_inplace_repeat
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001399};
1400
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001401static PyMappingMethods RangeAsMapping = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001402 /* mp_length */ (lenfunc)RangeLength,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001403 /* mp_subscript */ (binaryfunc)RangeSubscript,
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001404 /* mp_ass_subscript */ (objobjargproc)RangeAsSubscript,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001405};
1406
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001407// Line range object - Implementation
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001408
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001409 static PyObject *
1410RangeGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001411{
Bram Moolenaar77045652012-09-21 13:46:06 +02001412 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001413
1414 if (strcmp(name, "start") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001415 return Py_BuildValue("n", ((RangeObject *)(self))->start - 1);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001416 else if (strcmp(name, "end") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001417 return Py_BuildValue("n", ((RangeObject *)(self))->end - 1);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001418 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001419 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001420}
1421
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001422////////////////
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001423
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001424 static int
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001425RangeAsItem(PyObject *self, Py_ssize_t n, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001426{
1427 return RBAsItem(((RangeObject *)(self))->buf, n, val,
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001428 ((RangeObject *)(self))->start,
1429 ((RangeObject *)(self))->end,
1430 &((RangeObject *)(self))->end);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001431}
1432
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001433 static Py_ssize_t
1434RangeAsSlice(PyObject *self, Py_ssize_t lo, Py_ssize_t hi, PyObject *val)
1435{
1436 return RBAsSlice(((RangeObject *)(self))->buf, lo, hi, val,
1437 ((RangeObject *)(self))->start,
1438 ((RangeObject *)(self))->end,
1439 &((RangeObject *)(self))->end);
1440}
1441
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001442 static PyObject *
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001443RangeSubscript(PyObject *self, PyObject* idx)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001444{
Bram Moolenaardb913952012-06-29 12:54:53 +02001445 if (PyLong_Check(idx))
1446 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001447 long _idx = PyLong_AsLong(idx);
Bram Moolenaard6e39182013-05-21 18:30:34 +02001448 return RangeItem((RangeObject *)(self), _idx);
Bram Moolenaardb913952012-06-29 12:54:53 +02001449 } else if (PySlice_Check(idx))
1450 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001451 Py_ssize_t start, stop, step, slicelen;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001452
Bram Moolenaar922a4662014-03-30 16:11:43 +02001453 if (PySlice_GetIndicesEx((PySliceObject_T *)idx,
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001454 ((RangeObject *)(self))->end-((RangeObject *)(self))->start+1,
1455 &start, &stop,
Bram Moolenaardb913952012-06-29 12:54:53 +02001456 &step, &slicelen) < 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001457 return NULL;
Bram Moolenaard6e39182013-05-21 18:30:34 +02001458 return RangeSlice((RangeObject *)(self), start, stop);
Bram Moolenaardb913952012-06-29 12:54:53 +02001459 }
1460 else
1461 {
Bram Moolenaarc476e522013-06-23 13:46:40 +02001462 RAISE_INVALID_INDEX_TYPE(idx);
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001463 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001464 }
1465}
1466
Bram Moolenaar4ce5fe42020-10-21 21:01:59 +02001467 static int
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001468RangeAsSubscript(PyObject *self, PyObject *idx, PyObject *val)
1469{
Bram Moolenaardb913952012-06-29 12:54:53 +02001470 if (PyLong_Check(idx))
1471 {
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001472 long n = PyLong_AsLong(idx);
1473 return RangeAsItem(self, n, val);
Bram Moolenaarabab0b02019-03-30 18:47:01 +01001474 }
1475 else if (PySlice_Check(idx))
Bram Moolenaardb913952012-06-29 12:54:53 +02001476 {
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001477 Py_ssize_t start, stop, step, slicelen;
1478
Bram Moolenaar922a4662014-03-30 16:11:43 +02001479 if (PySlice_GetIndicesEx((PySliceObject_T *)idx,
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001480 ((RangeObject *)(self))->end-((RangeObject *)(self))->start+1,
1481 &start, &stop,
Bram Moolenaardb913952012-06-29 12:54:53 +02001482 &step, &slicelen) < 0)
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001483 return -1;
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001484 return RangeAsSlice(self, start, stop, val);
Bram Moolenaardb913952012-06-29 12:54:53 +02001485 }
1486 else
1487 {
Bram Moolenaarc476e522013-06-23 13:46:40 +02001488 RAISE_INVALID_INDEX_TYPE(idx);
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001489 return -1;
1490 }
1491}
1492
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001493// TabPage object - Implementation
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001494
1495 static PyObject *
1496TabPageGetattro(PyObject *self, PyObject *nameobj)
1497{
1498 PyObject *r;
1499
1500 GET_ATTR_STRING(name, nameobj);
1501
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001502 if ((r = TabPageAttrValid((TabPageObject *)(self), name)))
1503 return r;
1504
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001505 if (CheckTabPage((TabPageObject *)(self)))
1506 return NULL;
1507
1508 r = TabPageAttr((TabPageObject *)(self), name);
1509 if (r || PyErr_Occurred())
1510 return r;
1511 else
1512 return PyObject_GenericGetAttr(self, nameobj);
1513}
1514
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001515// Window object - Implementation
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001516
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001517 static PyObject *
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001518WindowGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001519{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001520 PyObject *r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001521
Bram Moolenaar77045652012-09-21 13:46:06 +02001522 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001523
Bram Moolenaar9e822c02013-05-29 22:15:30 +02001524 if ((r = WindowAttrValid((WindowObject *)(self), name)))
1525 return r;
1526
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001527 if (CheckWindow((WindowObject *)(self)))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001528 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001529
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001530 r = WindowAttr((WindowObject *)(self), name);
1531 if (r || PyErr_Occurred())
1532 return r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001533 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001534 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001535}
1536
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001537 static int
1538WindowSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001539{
Bram Moolenaar77045652012-09-21 13:46:06 +02001540 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001541
Bram Moolenaard6e39182013-05-21 18:30:34 +02001542 return WindowSetattr((WindowObject *)(self), name, val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001543}
1544
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001545// Tab page list object - Definitions
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001546
1547static PySequenceMethods TabListAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001548 (lenfunc) TabListLength, // sq_length, len(x)
1549 (binaryfunc) 0, // sq_concat, x+y
1550 (ssizeargfunc) 0, // sq_repeat, x*n
1551 (ssizeargfunc) TabListItem, // sq_item, x[i]
1552 0, // sq_slice, x[i:j]
1553 (ssizeobjargproc)0, // sq_as_item, x[i]=v
1554 0, // sq_ass_slice, x[i:j]=v
1555 0, // sq_contains
1556 0, // sq_inplace_concat
1557 0, // sq_inplace_repeat
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001558};
1559
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001560// Window list object - Definitions
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001561
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001562static PySequenceMethods WinListAsSeq = {
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001563 (lenfunc) WinListLength, // sq_length, len(x)
1564 (binaryfunc) 0, // sq_concat, x+y
1565 (ssizeargfunc) 0, // sq_repeat, x*n
1566 (ssizeargfunc) WinListItem, // sq_item, x[i]
1567 0, // sq_slice, x[i:j]
1568 (ssizeobjargproc)0, // sq_as_item, x[i]=v
1569 0, // sq_ass_slice, x[i:j]=v
1570 0, // sq_contains
1571 0, // sq_inplace_concat
1572 0, // sq_inplace_repeat
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001573};
1574
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001575/*
1576 * Current items object - Implementation
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001577 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001578 static PyObject *
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001579CurrentGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001580{
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001581 PyObject *r;
Bram Moolenaar77045652012-09-21 13:46:06 +02001582 GET_ATTR_STRING(name, nameobj);
Bram Moolenaardd8aca62013-05-29 22:36:10 +02001583 if (!(r = CurrentGetattr(self, name)))
1584 return PyObject_GenericGetAttr(self, nameobj);
1585 return r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001586}
1587
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001588 static int
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001589CurrentSetattro(PyObject *self, PyObject *nameobj, PyObject *value)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001590{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001591 GET_ATTR_STRING(name, nameobj);
1592 return CurrentSetattr(self, name, value);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001593}
1594
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001595// Dictionary object - Definitions
Bram Moolenaardb913952012-06-29 12:54:53 +02001596
Bram Moolenaar66b79852012-09-21 14:00:35 +02001597 static PyObject *
1598DictionaryGetattro(PyObject *self, PyObject *nameobj)
1599{
1600 DictionaryObject *this = ((DictionaryObject *) (self));
1601
1602 GET_ATTR_STRING(name, nameobj);
1603
1604 if (strcmp(name, "locked") == 0)
1605 return PyLong_FromLong(this->dict->dv_lock);
1606 else if (strcmp(name, "scope") == 0)
1607 return PyLong_FromLong(this->dict->dv_scope);
1608
1609 return PyObject_GenericGetAttr(self, nameobj);
1610}
1611
1612 static int
1613DictionarySetattro(PyObject *self, PyObject *nameobj, PyObject *val)
1614{
1615 GET_ATTR_STRING(name, nameobj);
Bram Moolenaard6e39182013-05-21 18:30:34 +02001616 return DictionarySetattr((DictionaryObject *)(self), name, val);
Bram Moolenaardb913952012-06-29 12:54:53 +02001617}
1618
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001619// List object - Definitions
Bram Moolenaardb913952012-06-29 12:54:53 +02001620
Bram Moolenaar66b79852012-09-21 14:00:35 +02001621 static PyObject *
1622ListGetattro(PyObject *self, PyObject *nameobj)
1623{
1624 GET_ATTR_STRING(name, nameobj);
1625
1626 if (strcmp(name, "locked") == 0)
1627 return PyLong_FromLong(((ListObject *) (self))->list->lv_lock);
1628
1629 return PyObject_GenericGetAttr(self, nameobj);
1630}
1631
1632 static int
1633ListSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
1634{
1635 GET_ATTR_STRING(name, nameobj);
Bram Moolenaard6e39182013-05-21 18:30:34 +02001636 return ListSetattr((ListObject *)(self), name, val);
Bram Moolenaardb913952012-06-29 12:54:53 +02001637}
1638
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001639// Function object - Definitions
Bram Moolenaardb913952012-06-29 12:54:53 +02001640
Bram Moolenaardb913952012-06-29 12:54:53 +02001641 static PyObject *
1642FunctionGetattro(PyObject *self, PyObject *nameobj)
1643{
Bram Moolenaar8110a092016-04-14 15:56:09 +02001644 PyObject *r;
Bram Moolenaardb913952012-06-29 12:54:53 +02001645 FunctionObject *this = (FunctionObject *)(self);
Bram Moolenaar77045652012-09-21 13:46:06 +02001646
1647 GET_ATTR_STRING(name, nameobj);
Bram Moolenaardb913952012-06-29 12:54:53 +02001648
Bram Moolenaar8110a092016-04-14 15:56:09 +02001649 r = FunctionAttr(this, name);
1650 if (r || PyErr_Occurred())
1651 return r;
1652 else
1653 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaardb913952012-06-29 12:54:53 +02001654}
1655
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001656// External interface
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001657
1658 void
1659python3_buffer_free(buf_T *buf)
1660{
Bram Moolenaar971db462013-05-12 18:44:48 +02001661 if (BUF_PYTHON_REF(buf) != NULL)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001662 {
Bram Moolenaar971db462013-05-12 18:44:48 +02001663 BufferObject *bp = BUF_PYTHON_REF(buf);
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001664 bp->buf = INVALID_BUFFER_VALUE;
Bram Moolenaar971db462013-05-12 18:44:48 +02001665 BUF_PYTHON_REF(buf) = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001666 }
1667}
1668
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001669 void
1670python3_window_free(win_T *win)
1671{
Bram Moolenaar971db462013-05-12 18:44:48 +02001672 if (WIN_PYTHON_REF(win) != NULL)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001673 {
Bram Moolenaar971db462013-05-12 18:44:48 +02001674 WindowObject *wp = WIN_PYTHON_REF(win);
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001675 wp->win = INVALID_WINDOW_VALUE;
Bram Moolenaar971db462013-05-12 18:44:48 +02001676 WIN_PYTHON_REF(win) = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001677 }
1678}
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001679
1680 void
1681python3_tabpage_free(tabpage_T *tab)
1682{
1683 if (TAB_PYTHON_REF(tab) != NULL)
1684 {
1685 TabPageObject *tp = TAB_PYTHON_REF(tab);
1686 tp->tab = INVALID_TABPAGE_VALUE;
1687 TAB_PYTHON_REF(tab) = NULL;
1688 }
1689}
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001690
Bram Moolenaar7854e3a2012-11-28 15:33:14 +01001691 static PyObject *
1692Py3Init_vim(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001693{
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001694 // The special value is removed from sys.path in Python3_Init().
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001695 static wchar_t *(argv[2]) = {L"/must>not&exist/foo", NULL};
1696
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001697 if (init_types())
1698 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001699
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001700 // Set sys.argv[] to avoid a crash in warn().
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001701 PySys_SetArgv(1, argv);
1702
Bram Moolenaarc09a6d62013-06-10 21:27:29 +02001703 if ((vim_module = PyModule_Create(&vimmodule)) == NULL)
Bram Moolenaar19e60942011-06-19 00:27:51 +02001704 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001705
Bram Moolenaardee2e312013-06-23 16:35:47 +02001706 if (populate_module(vim_module))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001707 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001708
Bram Moolenaarc09a6d62013-06-10 21:27:29 +02001709 if (init_sys_path())
1710 return NULL;
1711
1712 return vim_module;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001713}
1714
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001715//////////////////////////////////////////////////////////////////////////
1716// 4. Utility functions for handling the interface between Vim and Python.
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001717
Bram Moolenaar2ab2e862019-12-04 21:24:53 +01001718/*
1719 * Convert a Vim line into a Python string.
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001720 * All internal newlines are replaced by null characters.
1721 *
1722 * On errors, the Python exception data is set, and NULL is returned.
1723 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001724 static PyObject *
1725LineToString(const char *str)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001726{
1727 PyObject *result;
1728 Py_ssize_t len = strlen(str);
Bram Moolenaard672dde2020-02-26 13:43:51 +01001729 char *tmp, *p;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001730
Bram Moolenaarc799fe22019-05-28 23:08:19 +02001731 tmp = alloc(len + 1);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001732 p = tmp;
1733 if (p == NULL)
1734 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001735 PyErr_NoMemory();
1736 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001737 }
1738
1739 while (*str)
1740 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001741 if (*str == '\n')
1742 *p = '\0';
1743 else
1744 *p = *str;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001745
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001746 ++p;
1747 ++str;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001748 }
1749 *p = '\0';
1750
Bram Moolenaar2e2f52a2020-12-21 16:03:02 +01001751 result = PyUnicode_Decode(tmp, len, (char *)ENC_OPT, ERRORS_DECODE_ARG);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001752
1753 vim_free(tmp);
1754 return result;
1755}
1756
Bram Moolenaardb913952012-06-29 12:54:53 +02001757 void
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001758do_py3eval(char_u *str, typval_T *rettv)
Bram Moolenaardb913952012-06-29 12:54:53 +02001759{
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001760 DoPyCommand((char *) str,
1761 (rangeinitializer) init_range_eval,
1762 (runner) run_eval,
1763 (void *) rettv);
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001764 if (rettv->v_type == VAR_UNKNOWN)
Bram Moolenaardb913952012-06-29 12:54:53 +02001765 {
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001766 rettv->v_type = VAR_NUMBER;
1767 rettv->vval.v_number = 0;
Bram Moolenaardb913952012-06-29 12:54:53 +02001768 }
1769}
1770
Bram Moolenaar2459a5e2015-02-03 12:55:18 +01001771 int
Bram Moolenaar8e9a24a2019-03-19 22:22:55 +01001772set_ref_in_python3(int copyID)
Bram Moolenaardb913952012-06-29 12:54:53 +02001773{
Bram Moolenaarb641df42015-02-03 13:16:04 +01001774 return set_ref_in_py(copyID);
Bram Moolenaardb913952012-06-29 12:54:53 +02001775}