blob: b7323c2a969796765654d195fd32f5402e9b0b76 [file] [log] [blame]
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001/* vi:set ts=8 sts=4 sw=4:
2 *
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 Moolenaar0c1f3f42011-02-25 15:18:50 +010025/* uncomment this if used with the debug version of python */
26/* #define Py_DEBUG */
Bram Moolenaar0014a532013-05-29 21:33:39 +020027/* Note: most of time you can add -DPy_DEBUG to CFLAGS in place of uncommenting
28 */
29/* uncomment this if used with the debug version of python, but without its
30 * allocator */
31/* #define Py_DEBUG_NO_PYMALLOC */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020032
33#include "vim.h"
34
35#include <limits.h>
36
37/* Python.h defines _POSIX_THREADS itself (if needed) */
38#ifdef _POSIX_THREADS
39# undef _POSIX_THREADS
40#endif
41
Bram Moolenaard68554d2010-07-25 13:43:20 +020042#if defined(_WIN32) && defined(HAVE_FCNTL_H)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020043# undef HAVE_FCNTL_H
44#endif
45
46#ifdef _DEBUG
47# undef _DEBUG
48#endif
49
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020050#ifdef F_BLANK
51# undef F_BLANK
52#endif
53
Bram Moolenaar6df6f472010-07-18 18:04:50 +020054#ifdef HAVE_STDARG_H
55# undef HAVE_STDARG_H /* Python's config.h defines it as well. */
56#endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020057#ifdef _POSIX_C_SOURCE /* defined in feature.h */
58# undef _POSIX_C_SOURCE
59#endif
Bram Moolenaar6df6f472010-07-18 18:04:50 +020060#ifdef _XOPEN_SOURCE
61# undef _XOPEN_SOURCE /* pyconfig.h defines it as well. */
62#endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020063
64#include <Python.h>
65#if defined(MACOS) && !defined(MACOS_X_UNIX)
66# include "macglue.h"
67# include <CodeFragments.h>
68#endif
69#undef main /* Defined in python.h - aargh */
70#undef HAVE_FCNTL_H /* Clash with os_win32.h */
71
Bram Moolenaare8cdcef2012-09-12 20:21:43 +020072#if defined(PY_VERSION_HEX) && PY_VERSION_HEX >= 0x02050000
73# define PY_SSIZE_T_CLEAN
74#endif
75
Bram Moolenaar3d64a312011-07-15 15:54:44 +020076/* The "surrogateescape" error handler is new in Python 3.1 */
77#if PY_VERSION_HEX >= 0x030100f0
78# define CODEC_ERROR_HANDLER "surrogateescape"
79#else
80# define CODEC_ERROR_HANDLER NULL
81#endif
82
Bram Moolenaar2afa3232012-06-29 16:28:28 +020083/* Python 3 does not support CObjects, always use Capsules */
84#define PY_USE_CAPSULE
85
Bram Moolenaar170bf1a2010-07-24 23:51:45 +020086#define PyInt Py_ssize_t
Bram Moolenaarca8a4df2010-07-31 19:54:14 +020087#define PyString_Check(obj) PyUnicode_Check(obj)
Bram Moolenaardb913952012-06-29 12:54:53 +020088#define PyString_AsBytes(obj) PyUnicode_AsEncodedString(obj, (char *)ENC_OPT, CODEC_ERROR_HANDLER)
Bram Moolenaar19e60942011-06-19 00:27:51 +020089#define PyString_FreeBytes(obj) Py_XDECREF(bytes)
90#define PyString_AsString(obj) PyBytes_AsString(obj)
91#define PyString_Size(obj) PyBytes_GET_SIZE(bytes)
Bram Moolenaarca8a4df2010-07-31 19:54:14 +020092#define PyString_FromString(repr) PyUnicode_FromString(repr)
Bram Moolenaarafa6b9a2012-09-05 19:09:11 +020093#define PyString_AsStringAndSize(obj, buffer, len) PyBytes_AsStringAndSize(obj, buffer, len)
Bram Moolenaar77045652012-09-21 13:46:06 +020094#define PyInt_Check(obj) PyLong_Check(obj)
95#define PyInt_FromLong(i) PyLong_FromLong(i)
96#define PyInt_AsLong(obj) PyLong_AsLong(obj)
Bram Moolenaar4d1da492013-04-24 13:39:15 +020097#define Py_ssize_t_fmt "n"
Bram Moolenaar170bf1a2010-07-24 23:51:45 +020098
Bram Moolenaar0c1f3f42011-02-25 15:18:50 +010099#if defined(DYNAMIC_PYTHON3) || defined(PROTO)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200100
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200101# ifndef WIN3264
102# include <dlfcn.h>
103# define FARPROC void*
104# define HINSTANCE void*
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100105# if defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200106# define load_dll(n) dlopen((n), RTLD_LAZY)
107# else
108# define load_dll(n) dlopen((n), RTLD_LAZY|RTLD_GLOBAL)
109# endif
110# define close_dll dlclose
111# define symbol_from_dll dlsym
112# else
Bram Moolenaarebbcb822010-10-23 14:02:54 +0200113# define load_dll vimLoadLib
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200114# define close_dll FreeLibrary
115# define symbol_from_dll GetProcAddress
116# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200117/*
118 * Wrapper defines
119 */
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200120# undef PyArg_Parse
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200121# define PyArg_Parse py3_PyArg_Parse
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200122# undef PyArg_ParseTuple
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200123# define PyArg_ParseTuple py3_PyArg_ParseTuple
Bram Moolenaar19e60942011-06-19 00:27:51 +0200124# define PyMem_Free py3_PyMem_Free
Bram Moolenaardb913952012-06-29 12:54:53 +0200125# define PyMem_Malloc py3_PyMem_Malloc
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200126# define PyDict_SetItemString py3_PyDict_SetItemString
127# define PyErr_BadArgument py3_PyErr_BadArgument
128# define PyErr_Clear py3_PyErr_Clear
Bram Moolenaar4d369872013-02-20 16:09:43 +0100129# define PyErr_PrintEx py3_PyErr_PrintEx
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200130# define PyErr_NoMemory py3_PyErr_NoMemory
131# define PyErr_Occurred py3_PyErr_Occurred
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200132# define PyErr_PrintEx py3_PyErr_PrintEx
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200133# define PyErr_SetNone py3_PyErr_SetNone
134# define PyErr_SetString py3_PyErr_SetString
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200135# define PyErr_SetObject py3_PyErr_SetObject
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200136# define PyEval_InitThreads py3_PyEval_InitThreads
137# define PyEval_RestoreThread py3_PyEval_RestoreThread
138# define PyEval_SaveThread py3_PyEval_SaveThread
139# define PyGILState_Ensure py3_PyGILState_Ensure
140# define PyGILState_Release py3_PyGILState_Release
141# define PyLong_AsLong py3_PyLong_AsLong
142# define PyLong_FromLong py3_PyLong_FromLong
143# define PyList_GetItem py3_PyList_GetItem
144# define PyList_Append py3_PyList_Append
145# define PyList_New py3_PyList_New
146# define PyList_SetItem py3_PyList_SetItem
147# define PyList_Size py3_PyList_Size
Bram Moolenaardb913952012-06-29 12:54:53 +0200148# define PySequence_Check py3_PySequence_Check
149# define PySequence_Size py3_PySequence_Size
150# define PySequence_GetItem py3_PySequence_GetItem
151# define PyTuple_Size py3_PyTuple_Size
152# define PyTuple_GetItem py3_PyTuple_GetItem
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200153# define PySlice_GetIndicesEx py3_PySlice_GetIndicesEx
154# define PyImport_ImportModule py3_PyImport_ImportModule
155# define PyObject_Init py3__PyObject_Init
156# define PyDict_New py3_PyDict_New
157# define PyDict_GetItemString py3_PyDict_GetItemString
Bram Moolenaardb913952012-06-29 12:54:53 +0200158# define PyDict_Next py3_PyDict_Next
159# define PyMapping_Check py3_PyMapping_Check
160# define PyMapping_Items py3_PyMapping_Items
161# define PyIter_Next py3_PyIter_Next
162# define PyObject_GetIter py3_PyObject_GetIter
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200163# define PyObject_IsTrue py3_PyObject_IsTrue
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200164# define PyModule_GetDict py3_PyModule_GetDict
165#undef PyRun_SimpleString
166# define PyRun_SimpleString py3_PyRun_SimpleString
Bram Moolenaardb913952012-06-29 12:54:53 +0200167#undef PyRun_String
168# define PyRun_String py3_PyRun_String
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200169# define PyObject_GetAttrString py3_PyObject_GetAttrString
170# define PyObject_SetAttrString py3_PyObject_SetAttrString
171# define PyObject_CallFunctionObjArgs py3_PyObject_CallFunctionObjArgs
172# define PyEval_GetLocals py3_PyEval_GetLocals
173# define PyEval_GetGlobals py3_PyEval_GetGlobals
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200174# define PySys_SetObject py3_PySys_SetObject
175# define PySys_SetArgv py3_PySys_SetArgv
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200176# define PyType_Ready py3_PyType_Ready
177#undef Py_BuildValue
178# define Py_BuildValue py3_Py_BuildValue
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100179# define Py_SetPythonHome py3_Py_SetPythonHome
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200180# define Py_Initialize py3_Py_Initialize
181# define Py_Finalize py3_Py_Finalize
182# define Py_IsInitialized py3_Py_IsInitialized
183# define _Py_NoneStruct (*py3__Py_NoneStruct)
Bram Moolenaar66b79852012-09-21 14:00:35 +0200184# define _Py_FalseStruct (*py3__Py_FalseStruct)
185# define _Py_TrueStruct (*py3__Py_TrueStruct)
Bram Moolenaardb913952012-06-29 12:54:53 +0200186# define _PyObject_NextNotImplemented (*py3__PyObject_NextNotImplemented)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200187# define PyModule_AddObject py3_PyModule_AddObject
188# define PyImport_AppendInittab py3_PyImport_AppendInittab
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200189# define PyImport_AddModule py3_PyImport_AddModule
Bram Moolenaar7bc4f932012-10-14 03:22:56 +0200190# if PY_VERSION_HEX >= 0x030300f0
191# undef _PyUnicode_AsString
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200192# define _PyUnicode_AsString py3_PyUnicode_AsUTF8
Bram Moolenaar7bc4f932012-10-14 03:22:56 +0200193# else
194# define _PyUnicode_AsString py3__PyUnicode_AsString
195# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200196# undef PyUnicode_AsEncodedString
197# define PyUnicode_AsEncodedString py3_PyUnicode_AsEncodedString
198# undef PyBytes_AsString
199# define PyBytes_AsString py3_PyBytes_AsString
Bram Moolenaarcdab9052012-09-05 19:03:56 +0200200# define PyBytes_AsStringAndSize py3_PyBytes_AsStringAndSize
Bram Moolenaardb913952012-06-29 12:54:53 +0200201# undef PyBytes_FromString
202# define PyBytes_FromString py3_PyBytes_FromString
203# define PyFloat_FromDouble py3_PyFloat_FromDouble
204# define PyFloat_AsDouble py3_PyFloat_AsDouble
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200205# define PyObject_GenericGetAttr py3_PyObject_GenericGetAttr
Bram Moolenaar66b79852012-09-21 14:00:35 +0200206# define PyType_Type (*py3_PyType_Type)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200207# define PySlice_Type (*py3_PySlice_Type)
Bram Moolenaardb913952012-06-29 12:54:53 +0200208# define PyFloat_Type (*py3_PyFloat_Type)
Bram Moolenaar66b79852012-09-21 14:00:35 +0200209# define PyBool_Type (*py3_PyBool_Type)
Bram Moolenaar19e60942011-06-19 00:27:51 +0200210# define PyErr_NewException py3_PyErr_NewException
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200211# ifdef Py_DEBUG
212# define _Py_NegativeRefcount py3__Py_NegativeRefcount
213# define _Py_RefTotal (*py3__Py_RefTotal)
214# define _Py_Dealloc py3__Py_Dealloc
Bram Moolenaar0014a532013-05-29 21:33:39 +0200215# define PyModule_Create2TraceRefs py3_PyModule_Create2TraceRefs
216# else
217# define PyModule_Create2 py3_PyModule_Create2
218# endif
219# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200220# define _PyObject_DebugMalloc py3__PyObject_DebugMalloc
221# define _PyObject_DebugFree py3__PyObject_DebugFree
222# else
223# define PyObject_Malloc py3_PyObject_Malloc
224# define PyObject_Free py3_PyObject_Free
225# endif
Bram Moolenaar774267b2013-05-21 20:51:59 +0200226# define _PyObject_GC_New py3__PyObject_GC_New
227# define PyObject_GC_Del py3_PyObject_GC_Del
228# define PyObject_GC_UnTrack py3_PyObject_GC_UnTrack
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200229# define PyType_GenericAlloc py3_PyType_GenericAlloc
230# define PyType_GenericNew py3_PyType_GenericNew
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200231# undef PyUnicode_FromString
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200232# define PyUnicode_FromString py3_PyUnicode_FromString
Bram Moolenaar19e60942011-06-19 00:27:51 +0200233# undef PyUnicode_Decode
234# define PyUnicode_Decode py3_PyUnicode_Decode
Bram Moolenaardb913952012-06-29 12:54:53 +0200235# define PyType_IsSubtype py3_PyType_IsSubtype
236# define PyCapsule_New py3_PyCapsule_New
237# define PyCapsule_GetPointer py3_PyCapsule_GetPointer
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200238
Bram Moolenaar0014a532013-05-29 21:33:39 +0200239# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200240# undef PyObject_NEW
241# define PyObject_NEW(type, typeobj) \
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200242( (type *) PyObject_Init( \
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200243 (PyObject *) _PyObject_DebugMalloc( _PyObject_SIZE(typeobj) ), (typeobj)) )
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200244# endif
245
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200246/*
247 * Pointers for dynamic link
248 */
249static int (*py3_PySys_SetArgv)(int, wchar_t **);
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100250static void (*py3_Py_SetPythonHome)(wchar_t *home);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200251static void (*py3_Py_Initialize)(void);
252static PyObject* (*py3_PyList_New)(Py_ssize_t size);
253static PyGILState_STATE (*py3_PyGILState_Ensure)(void);
254static void (*py3_PyGILState_Release)(PyGILState_STATE);
255static int (*py3_PySys_SetObject)(char *, PyObject *);
256static PyObject* (*py3_PyList_Append)(PyObject *, PyObject *);
257static Py_ssize_t (*py3_PyList_Size)(PyObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200258static int (*py3_PySequence_Check)(PyObject *);
259static Py_ssize_t (*py3_PySequence_Size)(PyObject *);
260static PyObject* (*py3_PySequence_GetItem)(PyObject *, Py_ssize_t);
261static Py_ssize_t (*py3_PyTuple_Size)(PyObject *);
262static PyObject* (*py3_PyTuple_GetItem)(PyObject *, Py_ssize_t);
263static int (*py3_PyMapping_Check)(PyObject *);
264static PyObject* (*py3_PyMapping_Items)(PyObject *);
Bram Moolenaar314ed4b2011-09-14 18:59:39 +0200265static int (*py3_PySlice_GetIndicesEx)(PyObject *r, Py_ssize_t length,
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200266 Py_ssize_t *start, Py_ssize_t *stop, Py_ssize_t *step, Py_ssize_t *slicelength);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200267static PyObject* (*py3_PyErr_NoMemory)(void);
268static void (*py3_Py_Finalize)(void);
269static void (*py3_PyErr_SetString)(PyObject *, const char *);
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200270static void (*py3_PyErr_SetObject)(PyObject *, PyObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200271static int (*py3_PyRun_SimpleString)(char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200272static PyObject* (*py3_PyRun_String)(char *, int, PyObject *, PyObject *);
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200273static PyObject* (*py3_PyObject_GetAttrString)(PyObject *, const char *);
274static PyObject* (*py3_PyObject_SetAttrString)(PyObject *, const char *, PyObject *);
275static PyObject* (*py3_PyObject_CallFunctionObjArgs)(PyObject *, ...);
276static PyObject* (*py3_PyEval_GetGlobals)();
277static PyObject* (*py3_PyEval_GetLocals)();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200278static PyObject* (*py3_PyList_GetItem)(PyObject *, Py_ssize_t);
279static PyObject* (*py3_PyImport_ImportModule)(const char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200280static PyObject* (*py3_PyImport_AddModule)(const char *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200281static int (*py3_PyErr_BadArgument)(void);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200282static PyObject* (*py3_PyErr_Occurred)(void);
283static PyObject* (*py3_PyModule_GetDict)(PyObject *);
284static int (*py3_PyList_SetItem)(PyObject *, Py_ssize_t, PyObject *);
285static PyObject* (*py3_PyDict_GetItemString)(PyObject *, const char *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200286static int (*py3_PyDict_Next)(PyObject *, Py_ssize_t *, PyObject **, PyObject **);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200287static PyObject* (*py3_PyLong_FromLong)(long);
288static PyObject* (*py3_PyDict_New)(void);
Bram Moolenaardb913952012-06-29 12:54:53 +0200289static PyObject* (*py3_PyIter_Next)(PyObject *);
290static PyObject* (*py3_PyObject_GetIter)(PyObject *);
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200291static int (*py3_PyObject_IsTrue)(PyObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200292static PyObject* (*py3_Py_BuildValue)(char *, ...);
293static int (*py3_PyType_Ready)(PyTypeObject *type);
294static int (*py3_PyDict_SetItemString)(PyObject *dp, char *key, PyObject *item);
295static PyObject* (*py3_PyUnicode_FromString)(const char *u);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200296static PyObject* (*py3_PyUnicode_Decode)(const char *u, Py_ssize_t size,
297 const char *encoding, const char *errors);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200298static long (*py3_PyLong_AsLong)(PyObject *);
299static void (*py3_PyErr_SetNone)(PyObject *);
300static void (*py3_PyEval_InitThreads)(void);
301static void(*py3_PyEval_RestoreThread)(PyThreadState *);
302static PyThreadState*(*py3_PyEval_SaveThread)(void);
303static int (*py3_PyArg_Parse)(PyObject *, char *, ...);
304static int (*py3_PyArg_ParseTuple)(PyObject *, char *, ...);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200305static int (*py3_PyMem_Free)(void *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200306static void* (*py3_PyMem_Malloc)(size_t);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200307static int (*py3_Py_IsInitialized)(void);
308static void (*py3_PyErr_Clear)(void);
Bram Moolenaar4d369872013-02-20 16:09:43 +0100309static void (*py3_PyErr_PrintEx)(int);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200310static PyObject*(*py3__PyObject_Init)(PyObject *, PyTypeObject *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200311static iternextfunc py3__PyObject_NextNotImplemented;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200312static PyObject* py3__Py_NoneStruct;
Bram Moolenaar66b79852012-09-21 14:00:35 +0200313static PyObject* py3__Py_FalseStruct;
314static PyObject* py3__Py_TrueStruct;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200315static int (*py3_PyModule_AddObject)(PyObject *m, const char *name, PyObject *o);
316static int (*py3_PyImport_AppendInittab)(const char *name, PyObject* (*initfunc)(void));
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200317# if PY_VERSION_HEX >= 0x030300f0
318static char* (*py3_PyUnicode_AsUTF8)(PyObject *unicode);
319# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200320static char* (*py3__PyUnicode_AsString)(PyObject *unicode);
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200321# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200322static PyObject* (*py3_PyUnicode_AsEncodedString)(PyObject *unicode, const char* encoding, const char* errors);
323static char* (*py3_PyBytes_AsString)(PyObject *bytes);
Bram Moolenaarcdab9052012-09-05 19:03:56 +0200324static int (*py3_PyBytes_AsStringAndSize)(PyObject *bytes, char **buffer, int *length);
Bram Moolenaardb913952012-06-29 12:54:53 +0200325static PyObject* (*py3_PyBytes_FromString)(char *str);
326static PyObject* (*py3_PyFloat_FromDouble)(double num);
327static double (*py3_PyFloat_AsDouble)(PyObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200328static PyObject* (*py3_PyObject_GenericGetAttr)(PyObject *obj, PyObject *name);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200329static PyObject* (*py3_PyType_GenericAlloc)(PyTypeObject *type, Py_ssize_t nitems);
330static PyObject* (*py3_PyType_GenericNew)(PyTypeObject *type, PyObject *args, PyObject *kwds);
Bram Moolenaar66b79852012-09-21 14:00:35 +0200331static PyTypeObject* py3_PyType_Type;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200332static PyTypeObject* py3_PySlice_Type;
Bram Moolenaardb913952012-06-29 12:54:53 +0200333static PyTypeObject* py3_PyFloat_Type;
Bram Moolenaar66b79852012-09-21 14:00:35 +0200334static PyTypeObject* py3_PyBool_Type;
Bram Moolenaar19e60942011-06-19 00:27:51 +0200335static PyObject* (*py3_PyErr_NewException)(char *name, PyObject *base, PyObject *dict);
Bram Moolenaardb913952012-06-29 12:54:53 +0200336static PyObject* (*py3_PyCapsule_New)(void *, char *, PyCapsule_Destructor);
337static void* (*py3_PyCapsule_GetPointer)(PyObject *, char *);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200338# ifdef Py_DEBUG
Bram Moolenaar0014a532013-05-29 21:33:39 +0200339static void (*py3__Py_NegativeRefcount)(const char *fname, int lineno, PyObject *op);
340static Py_ssize_t* py3__Py_RefTotal;
341static void (*py3__Py_Dealloc)(PyObject *obj);
342static PyObject* (*py3_PyModule_Create2TraceRefs)(struct PyModuleDef* module, int module_api_version);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200343# else
Bram Moolenaar0014a532013-05-29 21:33:39 +0200344static PyObject* (*py3_PyModule_Create2)(struct PyModuleDef* module, int module_api_version);
345# endif
346# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
347static void (*py3__PyObject_DebugFree)(void*);
348static void* (*py3__PyObject_DebugMalloc)(size_t);
349# else
350static void (*py3_PyObject_Free)(void*);
351static void* (*py3_PyObject_Malloc)(size_t);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200352# endif
Bram Moolenaar774267b2013-05-21 20:51:59 +0200353static PyObject*(*py3__PyObject_GC_New)(PyTypeObject *);
354static void(*py3_PyObject_GC_Del)(void *);
355static void(*py3_PyObject_GC_UnTrack)(void *);
Bram Moolenaardb913952012-06-29 12:54:53 +0200356static int (*py3_PyType_IsSubtype)(PyTypeObject *, PyTypeObject *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200357
358static HINSTANCE hinstPy3 = 0; /* Instance of python.dll */
359
360/* Imported exception objects */
361static PyObject *p3imp_PyExc_AttributeError;
362static PyObject *p3imp_PyExc_IndexError;
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200363static PyObject *p3imp_PyExc_KeyError;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200364static PyObject *p3imp_PyExc_KeyboardInterrupt;
365static PyObject *p3imp_PyExc_TypeError;
366static PyObject *p3imp_PyExc_ValueError;
Bram Moolenaar8661b172013-05-15 15:44:28 +0200367static PyObject *p3imp_PyExc_RuntimeError;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200368
369# define PyExc_AttributeError p3imp_PyExc_AttributeError
370# define PyExc_IndexError p3imp_PyExc_IndexError
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200371# define PyExc_KeyError p3imp_PyExc_KeyError
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200372# define PyExc_KeyboardInterrupt p3imp_PyExc_KeyboardInterrupt
373# define PyExc_TypeError p3imp_PyExc_TypeError
374# define PyExc_ValueError p3imp_PyExc_ValueError
Bram Moolenaar8661b172013-05-15 15:44:28 +0200375# define PyExc_RuntimeError p3imp_PyExc_RuntimeError
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200376
377/*
378 * Table of name to function pointer of python.
379 */
380# define PYTHON_PROC FARPROC
381static struct
382{
383 char *name;
384 PYTHON_PROC *ptr;
385} py3_funcname_table[] =
386{
387 {"PySys_SetArgv", (PYTHON_PROC*)&py3_PySys_SetArgv},
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100388 {"Py_SetPythonHome", (PYTHON_PROC*)&py3_Py_SetPythonHome},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200389 {"Py_Initialize", (PYTHON_PROC*)&py3_Py_Initialize},
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200390# ifndef PY_SSIZE_T_CLEAN
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200391 {"PyArg_ParseTuple", (PYTHON_PROC*)&py3_PyArg_ParseTuple},
Bram Moolenaare8cdcef2012-09-12 20:21:43 +0200392 {"Py_BuildValue", (PYTHON_PROC*)&py3_Py_BuildValue},
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200393# else
Bram Moolenaare8cdcef2012-09-12 20:21:43 +0200394 {"_PyArg_ParseTuple_SizeT", (PYTHON_PROC*)&py3_PyArg_ParseTuple},
395 {"_Py_BuildValue_SizeT", (PYTHON_PROC*)&py3_Py_BuildValue},
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200396# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200397 {"PyMem_Free", (PYTHON_PROC*)&py3_PyMem_Free},
Bram Moolenaardb913952012-06-29 12:54:53 +0200398 {"PyMem_Malloc", (PYTHON_PROC*)&py3_PyMem_Malloc},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200399 {"PyList_New", (PYTHON_PROC*)&py3_PyList_New},
400 {"PyGILState_Ensure", (PYTHON_PROC*)&py3_PyGILState_Ensure},
401 {"PyGILState_Release", (PYTHON_PROC*)&py3_PyGILState_Release},
402 {"PySys_SetObject", (PYTHON_PROC*)&py3_PySys_SetObject},
403 {"PyList_Append", (PYTHON_PROC*)&py3_PyList_Append},
404 {"PyList_Size", (PYTHON_PROC*)&py3_PyList_Size},
Bram Moolenaardb913952012-06-29 12:54:53 +0200405 {"PySequence_Check", (PYTHON_PROC*)&py3_PySequence_Check},
406 {"PySequence_Size", (PYTHON_PROC*)&py3_PySequence_Size},
407 {"PySequence_GetItem", (PYTHON_PROC*)&py3_PySequence_GetItem},
408 {"PyTuple_Size", (PYTHON_PROC*)&py3_PyTuple_Size},
409 {"PyTuple_GetItem", (PYTHON_PROC*)&py3_PyTuple_GetItem},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200410 {"PySlice_GetIndicesEx", (PYTHON_PROC*)&py3_PySlice_GetIndicesEx},
411 {"PyErr_NoMemory", (PYTHON_PROC*)&py3_PyErr_NoMemory},
412 {"Py_Finalize", (PYTHON_PROC*)&py3_Py_Finalize},
413 {"PyErr_SetString", (PYTHON_PROC*)&py3_PyErr_SetString},
Bram Moolenaar4d188da2013-05-15 15:35:09 +0200414 {"PyErr_SetObject", (PYTHON_PROC*)&py3_PyErr_SetObject},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200415 {"PyRun_SimpleString", (PYTHON_PROC*)&py3_PyRun_SimpleString},
Bram Moolenaardb913952012-06-29 12:54:53 +0200416 {"PyRun_String", (PYTHON_PROC*)&py3_PyRun_String},
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200417 {"PyObject_GetAttrString", (PYTHON_PROC*)&py3_PyObject_GetAttrString},
418 {"PyObject_SetAttrString", (PYTHON_PROC*)&py3_PyObject_SetAttrString},
419 {"PyObject_CallFunctionObjArgs", (PYTHON_PROC*)&py3_PyObject_CallFunctionObjArgs},
420 {"PyEval_GetGlobals", (PYTHON_PROC*)&py3_PyEval_GetGlobals},
421 {"PyEval_GetLocals", (PYTHON_PROC*)&py3_PyEval_GetLocals},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200422 {"PyList_GetItem", (PYTHON_PROC*)&py3_PyList_GetItem},
423 {"PyImport_ImportModule", (PYTHON_PROC*)&py3_PyImport_ImportModule},
Bram Moolenaardb913952012-06-29 12:54:53 +0200424 {"PyImport_AddModule", (PYTHON_PROC*)&py3_PyImport_AddModule},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200425 {"PyErr_BadArgument", (PYTHON_PROC*)&py3_PyErr_BadArgument},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200426 {"PyErr_Occurred", (PYTHON_PROC*)&py3_PyErr_Occurred},
427 {"PyModule_GetDict", (PYTHON_PROC*)&py3_PyModule_GetDict},
428 {"PyList_SetItem", (PYTHON_PROC*)&py3_PyList_SetItem},
429 {"PyDict_GetItemString", (PYTHON_PROC*)&py3_PyDict_GetItemString},
Bram Moolenaardb913952012-06-29 12:54:53 +0200430 {"PyDict_Next", (PYTHON_PROC*)&py3_PyDict_Next},
431 {"PyMapping_Check", (PYTHON_PROC*)&py3_PyMapping_Check},
432 {"PyMapping_Items", (PYTHON_PROC*)&py3_PyMapping_Items},
433 {"PyIter_Next", (PYTHON_PROC*)&py3_PyIter_Next},
434 {"PyObject_GetIter", (PYTHON_PROC*)&py3_PyObject_GetIter},
Bram Moolenaar03db85b2013-05-15 14:51:35 +0200435 {"PyObject_IsTrue", (PYTHON_PROC*)&py3_PyObject_IsTrue},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200436 {"PyLong_FromLong", (PYTHON_PROC*)&py3_PyLong_FromLong},
437 {"PyDict_New", (PYTHON_PROC*)&py3_PyDict_New},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200438 {"PyType_Ready", (PYTHON_PROC*)&py3_PyType_Ready},
439 {"PyDict_SetItemString", (PYTHON_PROC*)&py3_PyDict_SetItemString},
440 {"PyLong_AsLong", (PYTHON_PROC*)&py3_PyLong_AsLong},
441 {"PyErr_SetNone", (PYTHON_PROC*)&py3_PyErr_SetNone},
442 {"PyEval_InitThreads", (PYTHON_PROC*)&py3_PyEval_InitThreads},
443 {"PyEval_RestoreThread", (PYTHON_PROC*)&py3_PyEval_RestoreThread},
444 {"PyEval_SaveThread", (PYTHON_PROC*)&py3_PyEval_SaveThread},
445 {"PyArg_Parse", (PYTHON_PROC*)&py3_PyArg_Parse},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200446 {"Py_IsInitialized", (PYTHON_PROC*)&py3_Py_IsInitialized},
Bram Moolenaardb913952012-06-29 12:54:53 +0200447 {"_PyObject_NextNotImplemented", (PYTHON_PROC*)&py3__PyObject_NextNotImplemented},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200448 {"_Py_NoneStruct", (PYTHON_PROC*)&py3__Py_NoneStruct},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200449 {"_Py_FalseStruct", (PYTHON_PROC*)&py3__Py_FalseStruct},
450 {"_Py_TrueStruct", (PYTHON_PROC*)&py3__Py_TrueStruct},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200451 {"PyErr_Clear", (PYTHON_PROC*)&py3_PyErr_Clear},
Bram Moolenaar4d369872013-02-20 16:09:43 +0100452 {"PyErr_PrintEx", (PYTHON_PROC*)&py3_PyErr_PrintEx},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200453 {"PyObject_Init", (PYTHON_PROC*)&py3__PyObject_Init},
454 {"PyModule_AddObject", (PYTHON_PROC*)&py3_PyModule_AddObject},
455 {"PyImport_AppendInittab", (PYTHON_PROC*)&py3_PyImport_AppendInittab},
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200456# if PY_VERSION_HEX >= 0x030300f0
457 {"PyUnicode_AsUTF8", (PYTHON_PROC*)&py3_PyUnicode_AsUTF8},
458# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200459 {"_PyUnicode_AsString", (PYTHON_PROC*)&py3__PyUnicode_AsString},
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200460# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200461 {"PyBytes_AsString", (PYTHON_PROC*)&py3_PyBytes_AsString},
Bram Moolenaarcdab9052012-09-05 19:03:56 +0200462 {"PyBytes_AsStringAndSize", (PYTHON_PROC*)&py3_PyBytes_AsStringAndSize},
Bram Moolenaardb913952012-06-29 12:54:53 +0200463 {"PyBytes_FromString", (PYTHON_PROC*)&py3_PyBytes_FromString},
464 {"PyFloat_FromDouble", (PYTHON_PROC*)&py3_PyFloat_FromDouble},
465 {"PyFloat_AsDouble", (PYTHON_PROC*)&py3_PyFloat_AsDouble},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200466 {"PyObject_GenericGetAttr", (PYTHON_PROC*)&py3_PyObject_GenericGetAttr},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200467 {"PyType_GenericAlloc", (PYTHON_PROC*)&py3_PyType_GenericAlloc},
468 {"PyType_GenericNew", (PYTHON_PROC*)&py3_PyType_GenericNew},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200469 {"PyType_Type", (PYTHON_PROC*)&py3_PyType_Type},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200470 {"PySlice_Type", (PYTHON_PROC*)&py3_PySlice_Type},
Bram Moolenaardb913952012-06-29 12:54:53 +0200471 {"PyFloat_Type", (PYTHON_PROC*)&py3_PyFloat_Type},
Bram Moolenaar66b79852012-09-21 14:00:35 +0200472 {"PyBool_Type", (PYTHON_PROC*)&py3_PyBool_Type},
Bram Moolenaar19e60942011-06-19 00:27:51 +0200473 {"PyErr_NewException", (PYTHON_PROC*)&py3_PyErr_NewException},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200474# ifdef Py_DEBUG
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200475 {"_Py_NegativeRefcount", (PYTHON_PROC*)&py3__Py_NegativeRefcount},
476 {"_Py_RefTotal", (PYTHON_PROC*)&py3__Py_RefTotal},
477 {"_Py_Dealloc", (PYTHON_PROC*)&py3__Py_Dealloc},
Bram Moolenaar0014a532013-05-29 21:33:39 +0200478 {"PyModule_Create2TraceRefs", (PYTHON_PROC*)&py3_PyModule_Create2TraceRefs},
479# else
480 {"PyModule_Create2", (PYTHON_PROC*)&py3_PyModule_Create2},
481# endif
482# if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200483 {"_PyObject_DebugFree", (PYTHON_PROC*)&py3__PyObject_DebugFree},
484 {"_PyObject_DebugMalloc", (PYTHON_PROC*)&py3__PyObject_DebugMalloc},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200485# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200486 {"PyObject_Malloc", (PYTHON_PROC*)&py3_PyObject_Malloc},
487 {"PyObject_Free", (PYTHON_PROC*)&py3_PyObject_Free},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200488# endif
Bram Moolenaar774267b2013-05-21 20:51:59 +0200489 {"_PyObject_GC_New", (PYTHON_PROC*)&py3__PyObject_GC_New},
490 {"PyObject_GC_Del", (PYTHON_PROC*)&py3_PyObject_GC_Del},
491 {"PyObject_GC_UnTrack", (PYTHON_PROC*)&py3_PyObject_GC_UnTrack},
Bram Moolenaardb913952012-06-29 12:54:53 +0200492 {"PyType_IsSubtype", (PYTHON_PROC*)&py3_PyType_IsSubtype},
493 {"PyCapsule_New", (PYTHON_PROC*)&py3_PyCapsule_New},
494 {"PyCapsule_GetPointer", (PYTHON_PROC*)&py3_PyCapsule_GetPointer},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200495 {"", NULL},
496};
497
498/*
499 * Free python.dll
500 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200501 static void
502end_dynamic_python3(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200503{
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200504 if (hinstPy3 != 0)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200505 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200506 close_dll(hinstPy3);
507 hinstPy3 = 0;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200508 }
509}
510
511/*
512 * Load library and get all pointers.
513 * Parameter 'libname' provides name of DLL.
514 * Return OK or FAIL.
515 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200516 static int
517py3_runtime_link_init(char *libname, int verbose)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200518{
519 int i;
Bram Moolenaar19e60942011-06-19 00:27:51 +0200520 void *ucs_from_string, *ucs_decode, *ucs_as_encoded_string;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200521
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100522# if !(defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)) && defined(UNIX) && defined(FEAT_PYTHON)
Bram Moolenaarb744b2f2010-08-13 16:22:57 +0200523 /* Can't have Python and Python3 loaded at the same time.
524 * It cause a crash, because RTLD_GLOBAL is needed for
525 * standard C extension libraries of one or both python versions. */
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200526 if (python_loaded())
527 {
Bram Moolenaar9dc93ae2011-08-28 16:00:19 +0200528 if (verbose)
529 EMSG(_("E837: This Vim cannot execute :py3 after using :python"));
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200530 return FAIL;
531 }
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200532# endif
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200533
534 if (hinstPy3 != 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200535 return OK;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200536 hinstPy3 = load_dll(libname);
537
538 if (!hinstPy3)
539 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200540 if (verbose)
541 EMSG2(_(e_loadlib), libname);
542 return FAIL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200543 }
544
545 for (i = 0; py3_funcname_table[i].ptr; ++i)
546 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200547 if ((*py3_funcname_table[i].ptr = symbol_from_dll(hinstPy3,
548 py3_funcname_table[i].name)) == NULL)
549 {
550 close_dll(hinstPy3);
551 hinstPy3 = 0;
552 if (verbose)
553 EMSG2(_(e_loadfunc), py3_funcname_table[i].name);
554 return FAIL;
555 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200556 }
557
Bram Moolenaar69154f22010-07-18 21:42:34 +0200558 /* Load unicode functions separately as only the ucs2 or the ucs4 functions
559 * will be present in the library. */
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200560# if PY_VERSION_HEX >= 0x030300f0
Bram Moolenaar7bc4f932012-10-14 03:22:56 +0200561 ucs_from_string = symbol_from_dll(hinstPy3, "PyUnicode_FromString");
562 ucs_decode = symbol_from_dll(hinstPy3, "PyUnicode_Decode");
563 ucs_as_encoded_string = symbol_from_dll(hinstPy3,
564 "PyUnicode_AsEncodedString");
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200565# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200566 ucs_from_string = symbol_from_dll(hinstPy3, "PyUnicodeUCS2_FromString");
Bram Moolenaar19e60942011-06-19 00:27:51 +0200567 ucs_decode = symbol_from_dll(hinstPy3,
568 "PyUnicodeUCS2_Decode");
569 ucs_as_encoded_string = symbol_from_dll(hinstPy3,
570 "PyUnicodeUCS2_AsEncodedString");
571 if (!ucs_from_string || !ucs_decode || !ucs_as_encoded_string)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200572 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200573 ucs_from_string = symbol_from_dll(hinstPy3,
574 "PyUnicodeUCS4_FromString");
Bram Moolenaar19e60942011-06-19 00:27:51 +0200575 ucs_decode = symbol_from_dll(hinstPy3,
576 "PyUnicodeUCS4_Decode");
577 ucs_as_encoded_string = symbol_from_dll(hinstPy3,
578 "PyUnicodeUCS4_AsEncodedString");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200579 }
Bram Moolenaar9c9cbf12012-10-23 05:17:37 +0200580# endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200581 if (ucs_from_string && ucs_decode && ucs_as_encoded_string)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200582 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200583 py3_PyUnicode_FromString = ucs_from_string;
Bram Moolenaar19e60942011-06-19 00:27:51 +0200584 py3_PyUnicode_Decode = ucs_decode;
585 py3_PyUnicode_AsEncodedString = ucs_as_encoded_string;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200586 }
587 else
588 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200589 close_dll(hinstPy3);
590 hinstPy3 = 0;
591 if (verbose)
592 EMSG2(_(e_loadfunc), "PyUnicode_UCSX_*");
593 return FAIL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200594 }
595
596 return OK;
597}
598
599/*
600 * If python is enabled (there is installed python on Windows system) return
601 * TRUE, else FALSE.
602 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200603 int
604python3_enabled(int verbose)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200605{
606 return py3_runtime_link_init(DYNAMIC_PYTHON3_DLL, verbose) == OK;
607}
608
609/* Load the standard Python exceptions - don't import the symbols from the
610 * DLL, as this can cause errors (importing data symbols is not reliable).
611 */
612static void get_py3_exceptions __ARGS((void));
613
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200614 static void
615get_py3_exceptions()
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200616{
617 PyObject *exmod = PyImport_ImportModule("builtins");
618 PyObject *exdict = PyModule_GetDict(exmod);
619 p3imp_PyExc_AttributeError = PyDict_GetItemString(exdict, "AttributeError");
620 p3imp_PyExc_IndexError = PyDict_GetItemString(exdict, "IndexError");
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200621 p3imp_PyExc_KeyError = PyDict_GetItemString(exdict, "KeyError");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200622 p3imp_PyExc_KeyboardInterrupt = PyDict_GetItemString(exdict, "KeyboardInterrupt");
623 p3imp_PyExc_TypeError = PyDict_GetItemString(exdict, "TypeError");
624 p3imp_PyExc_ValueError = PyDict_GetItemString(exdict, "ValueError");
Bram Moolenaar8661b172013-05-15 15:44:28 +0200625 p3imp_PyExc_RuntimeError = PyDict_GetItemString(exdict, "RuntimeError");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200626 Py_XINCREF(p3imp_PyExc_AttributeError);
627 Py_XINCREF(p3imp_PyExc_IndexError);
Bram Moolenaaraf6abb92013-04-24 13:04:26 +0200628 Py_XINCREF(p3imp_PyExc_KeyError);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200629 Py_XINCREF(p3imp_PyExc_KeyboardInterrupt);
630 Py_XINCREF(p3imp_PyExc_TypeError);
631 Py_XINCREF(p3imp_PyExc_ValueError);
Bram Moolenaar8661b172013-05-15 15:44:28 +0200632 Py_XINCREF(p3imp_PyExc_RuntimeError);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200633 Py_XDECREF(exmod);
634}
635#endif /* DYNAMIC_PYTHON3 */
636
Bram Moolenaardb913952012-06-29 12:54:53 +0200637static int py3initialised = 0;
638
639#define PYINITIALISED py3initialised
640
Bram Moolenaar774267b2013-05-21 20:51:59 +0200641#define DESTRUCTOR_FINISH(self) Py_TYPE(self)->tp_free((PyObject*)self)
Bram Moolenaardb913952012-06-29 12:54:53 +0200642
Bram Moolenaar971db462013-05-12 18:44:48 +0200643#define WIN_PYTHON_REF(win) win->w_python3_ref
644#define BUF_PYTHON_REF(buf) buf->b_python3_ref
Bram Moolenaar5e538ec2013-05-15 15:12:29 +0200645#define TAB_PYTHON_REF(tab) tab->tp_python3_ref
Bram Moolenaar971db462013-05-12 18:44:48 +0200646
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200647 static void
648call_PyObject_Free(void *p)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200649{
Bram Moolenaar0014a532013-05-29 21:33:39 +0200650#if defined(Py_DEBUG) && !defined(Py_DEBUG_NO_PYMALLOC)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200651 _PyObject_DebugFree(p);
652#else
653 PyObject_Free(p);
654#endif
655}
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200656
657 static PyObject *
658call_PyType_GenericNew(PyTypeObject *type, PyObject *args, PyObject *kwds)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200659{
660 return PyType_GenericNew(type,args,kwds);
661}
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200662
663 static PyObject *
664call_PyType_GenericAlloc(PyTypeObject *type, Py_ssize_t nitems)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200665{
666 return PyType_GenericAlloc(type,nitems);
667}
668
Bram Moolenaar182dc4f2013-05-21 19:01:55 +0200669static PyObject *BufferDir(PyObject *);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200670static PyObject *OutputGetattro(PyObject *, PyObject *);
671static int OutputSetattro(PyObject *, PyObject *, PyObject *);
672static PyObject *BufferGetattro(PyObject *, PyObject *);
Bram Moolenaare9ba5162013-05-29 22:02:22 +0200673static int BufferSetattro(PyObject *, PyObject *, PyObject *);
Bram Moolenaar5e538ec2013-05-15 15:12:29 +0200674static PyObject *TabPageGetattro(PyObject *, PyObject *);
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200675static PyObject *WindowGetattro(PyObject *, PyObject *);
676static int WindowSetattro(PyObject *, PyObject *, PyObject *);
677static PyObject *RangeGetattro(PyObject *, PyObject *);
678static PyObject *CurrentGetattro(PyObject *, PyObject *);
679static int CurrentSetattro(PyObject *, PyObject *, PyObject *);
680static PyObject *DictionaryGetattro(PyObject *, PyObject *);
681static int DictionarySetattro(PyObject *, PyObject *, PyObject *);
682static PyObject *ListGetattro(PyObject *, PyObject *);
683static int ListSetattro(PyObject *, PyObject *, PyObject *);
684static PyObject *FunctionGetattro(PyObject *, PyObject *);
685
686static struct PyModuleDef vimmodule;
687
Bram Moolenaar2a0f3d32013-05-21 22:23:56 +0200688#define PY_CAN_RECURSE
689
Bram Moolenaar4d1da492013-04-24 13:39:15 +0200690/*
691 * Include the code shared with if_python.c
692 */
693#include "if_py_both.h"
694
695#define GET_ATTR_STRING(name, nameobj) \
696 char *name = ""; \
697 if (PyUnicode_Check(nameobj)) \
698 name = _PyUnicode_AsString(nameobj)
699
700#define PY3OBJ_DELETED(obj) (obj->ob_base.ob_refcnt<=0)
701
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200702/******************************************************
703 * Internal function prototypes.
704 */
705
Bram Moolenaar7854e3a2012-11-28 15:33:14 +0100706static PyObject *Py3Init_vim(void);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200707
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200708/******************************************************
709 * 1. Python interpreter main program.
710 */
711
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200712 void
713python3_end()
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200714{
715 static int recurse = 0;
716
717 /* If a crash occurs while doing this, don't try again. */
718 if (recurse != 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200719 return;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200720
721 ++recurse;
722
723#ifdef DYNAMIC_PYTHON3
724 if (hinstPy3)
725#endif
726 if (Py_IsInitialized())
727 {
728 // acquire lock before finalizing
Bram Moolenaar71700b82013-05-15 17:49:05 +0200729 PyGILState_Ensure();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200730
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200731 Py_Finalize();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200732 }
733
734#ifdef DYNAMIC_PYTHON3
735 end_dynamic_python3();
736#endif
737
738 --recurse;
739}
740
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200741#if (defined(DYNAMIC_PYTHON) && defined(FEAT_PYTHON)) || defined(PROTO)
742 int
743python3_loaded()
744{
745 return (hinstPy3 != 0);
746}
747#endif
748
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200749 static int
750Python3_Init(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200751{
752 if (!py3initialised)
753 {
754#ifdef DYNAMIC_PYTHON3
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200755 if (!python3_enabled(TRUE))
756 {
757 EMSG(_("E263: Sorry, this command is disabled, the Python library could not be loaded."));
758 goto fail;
759 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200760#endif
761
762 init_structs();
763
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100764
765#ifdef PYTHON3_HOME
766 Py_SetPythonHome(PYTHON3_HOME);
767#endif
768
Bram Moolenaar7bc4f932012-10-14 03:22:56 +0200769 PyImport_AppendInittab("vim", Py3Init_vim);
770
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200771#if !defined(MACOS) || defined(MACOS_X_UNIX)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200772 Py_Initialize();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200773#else
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200774 PyMac_Initialize();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200775#endif
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100776 /* Initialise threads, and below save the state using
777 * PyEval_SaveThread. Without the call to PyEval_SaveThread, thread
778 * specific state (such as the system trace hook), will be lost
779 * between invocations of Python code. */
Bram Moolenaar456f2bb2011-06-12 21:37:13 +0200780 PyEval_InitThreads();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200781#ifdef DYNAMIC_PYTHON3
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200782 get_py3_exceptions();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200783#endif
784
Bram Moolenaar1dc28782013-05-21 19:11:01 +0200785 if (PythonIO_Init_io())
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200786 goto fail;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200787
Bram Moolenaardb913952012-06-29 12:54:53 +0200788 globals = PyModule_GetDict(PyImport_AddModule("__main__"));
789
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200790 /* Remove the element from sys.path that was added because of our
791 * argv[0] value in Py3Init_vim(). Previously we used an empty
Bram Moolenaar84a05ac2013-05-06 04:24:17 +0200792 * string, but depending on the OS we then get an empty entry or
Bram Moolenaar19e60942011-06-19 00:27:51 +0200793 * the current directory in sys.path.
794 * Only after vim has been imported, the element does exist in
795 * sys.path.
796 */
797 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 +0200798
Bram Moolenaar76d711c2013-02-13 14:17:08 +0100799 /* lock is created and acquired in PyEval_InitThreads() and thread
800 * state is created in Py_Initialize()
801 * there _PyGILState_NoteThreadState() also sets gilcounter to 1
802 * (python must have threads enabled!)
803 * so the following does both: unlock GIL and save thread state in TLS
804 * without deleting thread state
805 */
806 PyEval_SaveThread();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200807
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200808 py3initialised = 1;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200809 }
810
811 return 0;
812
813fail:
814 /* We call PythonIO_Flush() here to print any Python errors.
815 * This is OK, as it is possible to call this function even
Bram Moolenaar1dc28782013-05-21 19:11:01 +0200816 * if PythonIO_Init_io() has not completed successfully (it will
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200817 * not do anything in this case).
818 */
819 PythonIO_Flush();
820 return -1;
821}
822
823/*
824 * External interface
825 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200826 static void
Bram Moolenaarb52f4c02013-05-21 18:19:38 +0200827DoPyCommand(const char *cmd, rangeinitializer init_range, runner run, void *arg)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200828{
829#if defined(MACOS) && !defined(MACOS_X_UNIX)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200830 GrafPtr oldPort;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200831#endif
832#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200833 char *saved_locale;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200834#endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200835 PyObject *cmdstr;
836 PyObject *cmdbytes;
Bram Moolenaar71700b82013-05-15 17:49:05 +0200837 PyGILState_STATE pygilstate;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200838
839#if defined(MACOS) && !defined(MACOS_X_UNIX)
840 GetPort(&oldPort);
841 /* Check if the Python library is available */
842 if ((Ptr)PyMac_Initialize == (Ptr)kUnresolvedCFragSymbolAddress)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200843 goto theend;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200844#endif
845 if (Python3_Init())
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200846 goto theend;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200847
Bram Moolenaarb52f4c02013-05-21 18:19:38 +0200848 init_range(arg);
849
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200850 Python_Release_Vim(); /* leave vim */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200851
852#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
853 /* Python only works properly when the LC_NUMERIC locale is "C". */
854 saved_locale = setlocale(LC_NUMERIC, NULL);
855 if (saved_locale == NULL || STRCMP(saved_locale, "C") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200856 saved_locale = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200857 else
858 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200859 /* Need to make a copy, value may change when setting new locale. */
860 saved_locale = (char *)vim_strsave((char_u *)saved_locale);
861 (void)setlocale(LC_NUMERIC, "C");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200862 }
863#endif
864
865 pygilstate = PyGILState_Ensure();
866
Bram Moolenaar19e60942011-06-19 00:27:51 +0200867 /* PyRun_SimpleString expects a UTF-8 string. Wrong encoding may cause
868 * SyntaxError (unicode error). */
Bram Moolenaar3d64a312011-07-15 15:54:44 +0200869 cmdstr = PyUnicode_Decode(cmd, strlen(cmd),
870 (char *)ENC_OPT, CODEC_ERROR_HANDLER);
871 cmdbytes = PyUnicode_AsEncodedString(cmdstr, "utf-8", CODEC_ERROR_HANDLER);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200872 Py_XDECREF(cmdstr);
Bram Moolenaardb913952012-06-29 12:54:53 +0200873
Bram Moolenaarb52f4c02013-05-21 18:19:38 +0200874 run(PyBytes_AsString(cmdbytes), arg, &pygilstate);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200875 Py_XDECREF(cmdbytes);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200876
877 PyGILState_Release(pygilstate);
878
879#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
880 if (saved_locale != NULL)
881 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200882 (void)setlocale(LC_NUMERIC, saved_locale);
883 vim_free(saved_locale);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200884 }
885#endif
886
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200887 Python_Lock_Vim(); /* enter vim */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200888 PythonIO_Flush();
889#if defined(MACOS) && !defined(MACOS_X_UNIX)
890 SetPort(oldPort);
891#endif
892
893theend:
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200894 return; /* keeps lint happy */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200895}
896
897/*
Bram Moolenaar368373e2010-07-19 20:46:22 +0200898 * ":py3"
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200899 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200900 void
901ex_py3(exarg_T *eap)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200902{
903 char_u *script;
904
905 script = script_get(eap, eap->arg);
906 if (!eap->skip)
907 {
Bram Moolenaarb52f4c02013-05-21 18:19:38 +0200908 DoPyCommand(script == NULL ? (char *) eap->arg : (char *) script,
909 (rangeinitializer) init_range_cmd,
910 (runner) run_cmd,
911 (void *) eap);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200912 }
913 vim_free(script);
914}
915
916#define BUFFER_SIZE 2048
917
918/*
Bram Moolenaar6df6f472010-07-18 18:04:50 +0200919 * ":py3file"
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200920 */
921 void
922ex_py3file(exarg_T *eap)
923{
924 static char buffer[BUFFER_SIZE];
925 const char *file;
926 char *p;
927 int i;
928
929 /* Have to do it like this. PyRun_SimpleFile requires you to pass a
930 * stdio file pointer, but Vim and the Python DLL are compiled with
931 * different options under Windows, meaning that stdio pointers aren't
932 * compatible between the two. Yuk.
933 *
Bram Moolenaar19e60942011-06-19 00:27:51 +0200934 * construct: exec(compile(open('a_filename', 'rb').read(), 'a_filename', 'exec'))
935 *
936 * Using bytes so that Python can detect the source encoding as it normally
937 * does. The doc does not say "compile" accept bytes, though.
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200938 *
939 * We need to escape any backslashes or single quotes in the file name, so that
940 * Python won't mangle the file name.
941 */
942
943 strcpy(buffer, "exec(compile(open('");
944 p = buffer + 19; /* size of "exec(compile(open('" */
945
946 for (i=0; i<2; ++i)
947 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200948 file = (char *)eap->arg;
949 while (*file && p < buffer + (BUFFER_SIZE - 3))
950 {
951 if (*file == '\\' || *file == '\'')
952 *p++ = '\\';
953 *p++ = *file++;
954 }
955 /* If we didn't finish the file name, we hit a buffer overflow */
956 if (*file != '\0')
957 return;
958 if (i==0)
959 {
Bram Moolenaar19e60942011-06-19 00:27:51 +0200960 strcpy(p,"','rb').read(),'");
961 p += 16;
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200962 }
963 else
964 {
965 strcpy(p,"','exec'))");
966 p += 10;
967 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200968 }
969
970
971 /* Execute the file */
Bram Moolenaarb52f4c02013-05-21 18:19:38 +0200972 DoPyCommand(buffer,
973 (rangeinitializer) init_range_cmd,
974 (runner) run_cmd,
975 (void *) eap);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200976}
977
Bram Moolenaar54e8f002013-05-15 19:44:39 +0200978 void
979ex_py3do(exarg_T *eap)
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200980{
Bram Moolenaarb52f4c02013-05-21 18:19:38 +0200981 DoPyCommand((char *)eap->arg,
982 (rangeinitializer)init_range_cmd,
983 (runner)run_do,
984 (void *)eap);
Bram Moolenaar3dab2802013-05-15 18:28:13 +0200985}
986
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200987/******************************************************
988 * 2. Python output stream: writes output via [e]msg().
989 */
990
991/* Implementation functions
992 */
993
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200994 static PyObject *
995OutputGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200996{
Bram Moolenaar77045652012-09-21 13:46:06 +0200997 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200998
999 if (strcmp(name, "softspace") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001000 return PyLong_FromLong(((OutputObject *)(self))->softspace);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001001
1002 return PyObject_GenericGetAttr(self, nameobj);
1003}
1004
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001005 static int
1006OutputSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001007{
Bram Moolenaar77045652012-09-21 13:46:06 +02001008 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001009
Bram Moolenaard6e39182013-05-21 18:30:34 +02001010 return OutputSetattr((OutputObject *)(self), name, val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001011}
1012
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001013/******************************************************
1014 * 3. Implementation of the Vim module for Python
1015 */
1016
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001017/* Window type - Implementation functions
1018 * --------------------------------------
1019 */
1020
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001021#define WindowType_Check(obj) ((obj)->ob_base.ob_type == &WindowType)
1022
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001023/* Buffer type - Implementation functions
1024 * --------------------------------------
1025 */
1026
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001027#define BufferType_Check(obj) ((obj)->ob_base.ob_type == &BufferType)
1028
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001029static PyObject* BufferSubscript(PyObject *self, PyObject *idx);
1030static Py_ssize_t BufferAsSubscript(PyObject *self, PyObject *idx, PyObject *val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001031
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001032/* Line range type - Implementation functions
1033 * --------------------------------------
1034 */
1035
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001036#define RangeType_Check(obj) ((obj)->ob_base.ob_type == &RangeType)
1037
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001038static PyObject* RangeSubscript(PyObject *self, PyObject *idx);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001039static Py_ssize_t RangeAsItem(PyObject *, Py_ssize_t, PyObject *);
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001040static Py_ssize_t RangeAsSubscript(PyObject *self, PyObject *idx, PyObject *val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001041
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001042/* Current objects type - Implementation functions
1043 * -----------------------------------------------
1044 */
1045
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001046static PySequenceMethods BufferAsSeq = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001047 (lenfunc) BufferLength, /* sq_length, len(x) */
1048 (binaryfunc) 0, /* sq_concat, x+y */
1049 (ssizeargfunc) 0, /* sq_repeat, x*n */
1050 (ssizeargfunc) BufferItem, /* sq_item, x[i] */
1051 0, /* was_sq_slice, x[i:j] */
Bram Moolenaar19e60942011-06-19 00:27:51 +02001052 0, /* sq_ass_item, x[i]=v */
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001053 0, /* sq_ass_slice, x[i:j]=v */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001054 0, /* sq_contains */
1055 0, /* sq_inplace_concat */
1056 0, /* sq_inplace_repeat */
1057};
1058
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001059static PyMappingMethods BufferAsMapping = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001060 /* mp_length */ (lenfunc)BufferLength,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001061 /* mp_subscript */ (binaryfunc)BufferSubscript,
Bram Moolenaar19e60942011-06-19 00:27:51 +02001062 /* mp_ass_subscript */ (objobjargproc)BufferAsSubscript,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001063};
1064
1065
Bram Moolenaar971db462013-05-12 18:44:48 +02001066/* Buffer object
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001067 */
1068
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001069 static PyObject *
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001070BufferGetattro(PyObject *self, PyObject*nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001071{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001072 PyObject *r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001073
Bram Moolenaar77045652012-09-21 13:46:06 +02001074 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001075
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001076 if (CheckBuffer((BufferObject *)(self)))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001077 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001078
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001079 r = BufferAttr((BufferObject *)(self), name);
1080 if (r || PyErr_Occurred())
1081 return r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001082 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001083 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001084}
1085
Bram Moolenaare9ba5162013-05-29 22:02:22 +02001086 static int
1087BufferSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
1088{
1089 GET_ATTR_STRING(name, nameobj);
1090
1091 return BufferSetattr((BufferObject *)(self), name, val);
1092}
1093
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001094 static PyObject *
Bram Moolenaar182dc4f2013-05-21 19:01:55 +02001095BufferDir(PyObject *self UNUSED)
Bram Moolenaar7f85d292012-02-04 20:17:26 +01001096{
1097 return Py_BuildValue("[sssss]", "name", "number",
1098 "append", "mark", "range");
1099}
1100
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001101/******************/
1102
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001103 static PyObject *
1104BufferSubscript(PyObject *self, PyObject* idx)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001105{
Bram Moolenaardb913952012-06-29 12:54:53 +02001106 if (PyLong_Check(idx))
1107 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001108 long _idx = PyLong_AsLong(idx);
Bram Moolenaard6e39182013-05-21 18:30:34 +02001109 return BufferItem((BufferObject *)(self), _idx);
Bram Moolenaardb913952012-06-29 12:54:53 +02001110 } else if (PySlice_Check(idx))
1111 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001112 Py_ssize_t start, stop, step, slicelen;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001113
Bram Moolenaar8f1723d2013-05-12 20:36:14 +02001114 if (CheckBuffer((BufferObject *) self))
1115 return NULL;
1116
Bram Moolenaar9e8edf62011-09-14 15:41:58 +02001117 if (PySlice_GetIndicesEx((PyObject *)idx,
Bram Moolenaarbd80f352013-05-12 21:16:23 +02001118 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count,
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001119 &start, &stop,
Bram Moolenaardb913952012-06-29 12:54:53 +02001120 &step, &slicelen) < 0)
1121 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001122 return NULL;
1123 }
Bram Moolenaard6e39182013-05-21 18:30:34 +02001124 return BufferSlice((BufferObject *)(self), start, stop);
Bram Moolenaardb913952012-06-29 12:54:53 +02001125 }
1126 else
1127 {
Bram Moolenaar8661b172013-05-15 15:44:28 +02001128 PyErr_SetString(PyExc_TypeError, _("index must be int or slice"));
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001129 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001130 }
1131}
1132
Bram Moolenaar19e60942011-06-19 00:27:51 +02001133 static Py_ssize_t
1134BufferAsSubscript(PyObject *self, PyObject* idx, PyObject* val)
1135{
Bram Moolenaardb913952012-06-29 12:54:53 +02001136 if (PyLong_Check(idx))
1137 {
Bram Moolenaar19e60942011-06-19 00:27:51 +02001138 long n = PyLong_AsLong(idx);
1139 return RBAsItem((BufferObject *)(self), n, val, 1,
1140 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count,
1141 NULL);
Bram Moolenaardb913952012-06-29 12:54:53 +02001142 } else if (PySlice_Check(idx))
1143 {
Bram Moolenaar19e60942011-06-19 00:27:51 +02001144 Py_ssize_t start, stop, step, slicelen;
1145
Bram Moolenaar8f1723d2013-05-12 20:36:14 +02001146 if (CheckBuffer((BufferObject *) self))
1147 return -1;
1148
Bram Moolenaar9e8edf62011-09-14 15:41:58 +02001149 if (PySlice_GetIndicesEx((PyObject *)idx,
Bram Moolenaarbd80f352013-05-12 21:16:23 +02001150 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count,
Bram Moolenaar19e60942011-06-19 00:27:51 +02001151 &start, &stop,
Bram Moolenaardb913952012-06-29 12:54:53 +02001152 &step, &slicelen) < 0)
1153 {
Bram Moolenaar19e60942011-06-19 00:27:51 +02001154 return -1;
1155 }
1156 return RBAsSlice((BufferObject *)(self), start, stop, val, 1,
1157 (PyInt)((BufferObject *)(self))->buf->b_ml.ml_line_count,
1158 NULL);
Bram Moolenaardb913952012-06-29 12:54:53 +02001159 }
1160 else
1161 {
Bram Moolenaar8661b172013-05-15 15:44:28 +02001162 PyErr_SetString(PyExc_TypeError, _("index must be int or slice"));
Bram Moolenaar19e60942011-06-19 00:27:51 +02001163 return -1;
1164 }
1165}
1166
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001167static PySequenceMethods RangeAsSeq = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001168 (lenfunc) RangeLength, /* sq_length, len(x) */
1169 (binaryfunc) 0, /* RangeConcat, sq_concat, x+y */
1170 (ssizeargfunc) 0, /* RangeRepeat, sq_repeat, x*n */
1171 (ssizeargfunc) RangeItem, /* sq_item, x[i] */
1172 0, /* was_sq_slice, x[i:j] */
1173 (ssizeobjargproc) RangeAsItem, /* sq_as_item, x[i]=v */
1174 0, /* sq_ass_slice, x[i:j]=v */
1175 0, /* sq_contains */
1176 0, /* sq_inplace_concat */
1177 0, /* sq_inplace_repeat */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001178};
1179
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001180static PyMappingMethods RangeAsMapping = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001181 /* mp_length */ (lenfunc)RangeLength,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001182 /* mp_subscript */ (binaryfunc)RangeSubscript,
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001183 /* mp_ass_subscript */ (objobjargproc)RangeAsSubscript,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001184};
1185
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001186/* Line range object - Implementation
1187 */
1188
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001189 static PyObject *
1190RangeGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001191{
Bram Moolenaar77045652012-09-21 13:46:06 +02001192 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001193
1194 if (strcmp(name, "start") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001195 return Py_BuildValue("n", ((RangeObject *)(self))->start - 1);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001196 else if (strcmp(name, "end") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001197 return Py_BuildValue("n", ((RangeObject *)(self))->end - 1);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001198 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001199 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001200}
1201
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001202/****************/
1203
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001204 static Py_ssize_t
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001205RangeAsItem(PyObject *self, Py_ssize_t n, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001206{
1207 return RBAsItem(((RangeObject *)(self))->buf, n, val,
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001208 ((RangeObject *)(self))->start,
1209 ((RangeObject *)(self))->end,
1210 &((RangeObject *)(self))->end);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001211}
1212
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001213 static Py_ssize_t
1214RangeAsSlice(PyObject *self, Py_ssize_t lo, Py_ssize_t hi, PyObject *val)
1215{
1216 return RBAsSlice(((RangeObject *)(self))->buf, lo, hi, val,
1217 ((RangeObject *)(self))->start,
1218 ((RangeObject *)(self))->end,
1219 &((RangeObject *)(self))->end);
1220}
1221
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001222 static PyObject *
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001223RangeSubscript(PyObject *self, PyObject* idx)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001224{
Bram Moolenaardb913952012-06-29 12:54:53 +02001225 if (PyLong_Check(idx))
1226 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001227 long _idx = PyLong_AsLong(idx);
Bram Moolenaard6e39182013-05-21 18:30:34 +02001228 return RangeItem((RangeObject *)(self), _idx);
Bram Moolenaardb913952012-06-29 12:54:53 +02001229 } else if (PySlice_Check(idx))
1230 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001231 Py_ssize_t start, stop, step, slicelen;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001232
Bram Moolenaar9e8edf62011-09-14 15:41:58 +02001233 if (PySlice_GetIndicesEx((PyObject *)idx,
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001234 ((RangeObject *)(self))->end-((RangeObject *)(self))->start+1,
1235 &start, &stop,
Bram Moolenaardb913952012-06-29 12:54:53 +02001236 &step, &slicelen) < 0)
1237 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001238 return NULL;
1239 }
Bram Moolenaard6e39182013-05-21 18:30:34 +02001240 return RangeSlice((RangeObject *)(self), start, stop);
Bram Moolenaardb913952012-06-29 12:54:53 +02001241 }
1242 else
1243 {
Bram Moolenaar8661b172013-05-15 15:44:28 +02001244 PyErr_SetString(PyExc_TypeError, _("index must be int or slice"));
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001245 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001246 }
1247}
1248
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001249 static Py_ssize_t
1250RangeAsSubscript(PyObject *self, PyObject *idx, PyObject *val)
1251{
Bram Moolenaardb913952012-06-29 12:54:53 +02001252 if (PyLong_Check(idx))
1253 {
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001254 long n = PyLong_AsLong(idx);
1255 return RangeAsItem(self, n, val);
Bram Moolenaardb913952012-06-29 12:54:53 +02001256 } else if (PySlice_Check(idx))
1257 {
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001258 Py_ssize_t start, stop, step, slicelen;
1259
Bram Moolenaar9e8edf62011-09-14 15:41:58 +02001260 if (PySlice_GetIndicesEx((PyObject *)idx,
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001261 ((RangeObject *)(self))->end-((RangeObject *)(self))->start+1,
1262 &start, &stop,
Bram Moolenaardb913952012-06-29 12:54:53 +02001263 &step, &slicelen) < 0)
1264 {
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001265 return -1;
1266 }
1267 return RangeAsSlice(self, start, stop, val);
Bram Moolenaardb913952012-06-29 12:54:53 +02001268 }
1269 else
1270 {
Bram Moolenaar8661b172013-05-15 15:44:28 +02001271 PyErr_SetString(PyExc_TypeError, _("index must be int or slice"));
Bram Moolenaarba4897e2011-09-14 15:01:58 +02001272 return -1;
1273 }
1274}
1275
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001276/* TabPage object - Implementation
1277 */
1278
1279 static PyObject *
1280TabPageGetattro(PyObject *self, PyObject *nameobj)
1281{
1282 PyObject *r;
1283
1284 GET_ATTR_STRING(name, nameobj);
1285
1286 if (CheckTabPage((TabPageObject *)(self)))
1287 return NULL;
1288
1289 r = TabPageAttr((TabPageObject *)(self), name);
1290 if (r || PyErr_Occurred())
1291 return r;
1292 else
1293 return PyObject_GenericGetAttr(self, nameobj);
1294}
1295
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001296/* Window object - Implementation
1297 */
1298
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001299 static PyObject *
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001300WindowGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001301{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001302 PyObject *r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001303
Bram Moolenaar77045652012-09-21 13:46:06 +02001304 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001305
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001306 if (CheckWindow((WindowObject *)(self)))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001307 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001308
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001309 r = WindowAttr((WindowObject *)(self), name);
1310 if (r || PyErr_Occurred())
1311 return r;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001312 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001313 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001314}
1315
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001316 static int
1317WindowSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001318{
Bram Moolenaar77045652012-09-21 13:46:06 +02001319 GET_ATTR_STRING(name, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001320
Bram Moolenaard6e39182013-05-21 18:30:34 +02001321 return WindowSetattr((WindowObject *)(self), name, val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001322}
1323
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001324/* Tab page list object - Definitions
1325 */
1326
1327static PySequenceMethods TabListAsSeq = {
1328 (lenfunc) TabListLength, /* sq_length, len(x) */
1329 (binaryfunc) 0, /* sq_concat, x+y */
1330 (ssizeargfunc) 0, /* sq_repeat, x*n */
1331 (ssizeargfunc) TabListItem, /* sq_item, x[i] */
1332 0, /* sq_slice, x[i:j] */
1333 (ssizeobjargproc)0, /* sq_as_item, x[i]=v */
1334 0, /* sq_ass_slice, x[i:j]=v */
1335 0, /* sq_contains */
1336 0, /* sq_inplace_concat */
1337 0, /* sq_inplace_repeat */
1338};
1339
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001340/* Window list object - Definitions
1341 */
1342
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001343static PySequenceMethods WinListAsSeq = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001344 (lenfunc) WinListLength, /* sq_length, len(x) */
1345 (binaryfunc) 0, /* sq_concat, x+y */
1346 (ssizeargfunc) 0, /* sq_repeat, x*n */
1347 (ssizeargfunc) WinListItem, /* sq_item, x[i] */
1348 0, /* sq_slice, x[i:j] */
1349 (ssizeobjargproc)0, /* sq_as_item, x[i]=v */
1350 0, /* sq_ass_slice, x[i:j]=v */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001351 0, /* sq_contains */
1352 0, /* sq_inplace_concat */
1353 0, /* sq_inplace_repeat */
1354};
1355
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001356/* Current items object - Implementation
1357 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001358 static PyObject *
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001359CurrentGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001360{
Bram Moolenaar77045652012-09-21 13:46:06 +02001361 GET_ATTR_STRING(name, nameobj);
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001362 return CurrentGetattr(self, name);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001363}
1364
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001365 static int
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001366CurrentSetattro(PyObject *self, PyObject *nameobj, PyObject *value)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001367{
Bram Moolenaar4d1da492013-04-24 13:39:15 +02001368 GET_ATTR_STRING(name, nameobj);
1369 return CurrentSetattr(self, name, value);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001370}
1371
Bram Moolenaardb913952012-06-29 12:54:53 +02001372/* Dictionary object - Definitions
1373 */
1374
Bram Moolenaar66b79852012-09-21 14:00:35 +02001375 static PyObject *
1376DictionaryGetattro(PyObject *self, PyObject *nameobj)
1377{
1378 DictionaryObject *this = ((DictionaryObject *) (self));
1379
1380 GET_ATTR_STRING(name, nameobj);
1381
1382 if (strcmp(name, "locked") == 0)
1383 return PyLong_FromLong(this->dict->dv_lock);
1384 else if (strcmp(name, "scope") == 0)
1385 return PyLong_FromLong(this->dict->dv_scope);
1386
1387 return PyObject_GenericGetAttr(self, nameobj);
1388}
1389
1390 static int
1391DictionarySetattro(PyObject *self, PyObject *nameobj, PyObject *val)
1392{
1393 GET_ATTR_STRING(name, nameobj);
Bram Moolenaard6e39182013-05-21 18:30:34 +02001394 return DictionarySetattr((DictionaryObject *)(self), name, val);
Bram Moolenaardb913952012-06-29 12:54:53 +02001395}
1396
1397/* List object - Definitions
1398 */
1399
Bram Moolenaardb913952012-06-29 12:54:53 +02001400static PySequenceMethods ListAsSeq = {
1401 (lenfunc) ListLength, /* sq_length, len(x) */
1402 (binaryfunc) 0, /* RangeConcat, sq_concat, x+y */
1403 (ssizeargfunc) 0, /* RangeRepeat, sq_repeat, x*n */
1404 (ssizeargfunc) ListItem, /* sq_item, x[i] */
1405 (void *) 0, /* was_sq_slice, x[i:j] */
1406 (ssizeobjargproc) ListAssItem, /* sq_as_item, x[i]=v */
1407 (void *) 0, /* was_sq_ass_slice, x[i:j]=v */
1408 0, /* sq_contains */
1409 (binaryfunc) ListConcatInPlace,/* sq_inplace_concat */
1410 0, /* sq_inplace_repeat */
1411};
1412
1413static PyObject *ListSubscript(PyObject *, PyObject *);
1414static Py_ssize_t ListAsSubscript(PyObject *, PyObject *, PyObject *);
1415
1416static PyMappingMethods ListAsMapping = {
1417 /* mp_length */ (lenfunc) ListLength,
1418 /* mp_subscript */ (binaryfunc) ListSubscript,
1419 /* mp_ass_subscript */ (objobjargproc) ListAsSubscript,
1420};
1421
Bram Moolenaardb913952012-06-29 12:54:53 +02001422 static PyObject *
Bram Moolenaard6e39182013-05-21 18:30:34 +02001423ListSubscript(PyObject *self, PyObject* idx)
Bram Moolenaardb913952012-06-29 12:54:53 +02001424{
Bram Moolenaard6e39182013-05-21 18:30:34 +02001425 if (PyLong_Check(idx))
Bram Moolenaardb913952012-06-29 12:54:53 +02001426 {
Bram Moolenaard6e39182013-05-21 18:30:34 +02001427 long _idx = PyLong_AsLong(idx);
1428 return ListItem((ListObject *)(self), _idx);
Bram Moolenaardb913952012-06-29 12:54:53 +02001429 }
Bram Moolenaard6e39182013-05-21 18:30:34 +02001430 else if (PySlice_Check(idx))
Bram Moolenaardb913952012-06-29 12:54:53 +02001431 {
1432 Py_ssize_t start, stop, step, slicelen;
1433
Bram Moolenaard6e39182013-05-21 18:30:34 +02001434 if (PySlice_GetIndicesEx(idx, ListLength((ListObject *)(self)),
1435 &start, &stop, &step, &slicelen) < 0)
Bram Moolenaardb913952012-06-29 12:54:53 +02001436 return NULL;
Bram Moolenaard6e39182013-05-21 18:30:34 +02001437 return ListSlice((ListObject *)(self), start, stop);
Bram Moolenaardb913952012-06-29 12:54:53 +02001438 }
1439 else
1440 {
Bram Moolenaar8661b172013-05-15 15:44:28 +02001441 PyErr_SetString(PyExc_TypeError, _("index must be int or slice"));
Bram Moolenaardb913952012-06-29 12:54:53 +02001442 return NULL;
1443 }
1444}
1445
1446 static Py_ssize_t
Bram Moolenaard6e39182013-05-21 18:30:34 +02001447ListAsSubscript(PyObject *self, PyObject *idx, PyObject *obj)
Bram Moolenaardb913952012-06-29 12:54:53 +02001448{
Bram Moolenaard6e39182013-05-21 18:30:34 +02001449 if (PyLong_Check(idx))
Bram Moolenaardb913952012-06-29 12:54:53 +02001450 {
Bram Moolenaard6e39182013-05-21 18:30:34 +02001451 long _idx = PyLong_AsLong(idx);
1452 return ListAssItem((ListObject *)(self), _idx, obj);
Bram Moolenaardb913952012-06-29 12:54:53 +02001453 }
Bram Moolenaard6e39182013-05-21 18:30:34 +02001454 else if (PySlice_Check(idx))
Bram Moolenaardb913952012-06-29 12:54:53 +02001455 {
1456 Py_ssize_t start, stop, step, slicelen;
1457
Bram Moolenaard6e39182013-05-21 18:30:34 +02001458 if (PySlice_GetIndicesEx(idx, ListLength((ListObject *)(self)),
1459 &start, &stop, &step, &slicelen) < 0)
Bram Moolenaardb913952012-06-29 12:54:53 +02001460 return -1;
Bram Moolenaard6e39182013-05-21 18:30:34 +02001461 return ListAssSlice((ListObject *)(self), start, stop, obj);
Bram Moolenaardb913952012-06-29 12:54:53 +02001462 }
1463 else
1464 {
Bram Moolenaar8661b172013-05-15 15:44:28 +02001465 PyErr_SetString(PyExc_TypeError, _("index must be int or slice"));
Bram Moolenaardb913952012-06-29 12:54:53 +02001466 return -1;
1467 }
1468}
1469
Bram Moolenaar66b79852012-09-21 14:00:35 +02001470 static PyObject *
1471ListGetattro(PyObject *self, PyObject *nameobj)
1472{
1473 GET_ATTR_STRING(name, nameobj);
1474
1475 if (strcmp(name, "locked") == 0)
1476 return PyLong_FromLong(((ListObject *) (self))->list->lv_lock);
1477
1478 return PyObject_GenericGetAttr(self, nameobj);
1479}
1480
1481 static int
1482ListSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
1483{
1484 GET_ATTR_STRING(name, nameobj);
Bram Moolenaard6e39182013-05-21 18:30:34 +02001485 return ListSetattr((ListObject *)(self), name, val);
Bram Moolenaardb913952012-06-29 12:54:53 +02001486}
1487
1488/* Function object - Definitions
1489 */
1490
Bram Moolenaardb913952012-06-29 12:54:53 +02001491 static PyObject *
1492FunctionGetattro(PyObject *self, PyObject *nameobj)
1493{
1494 FunctionObject *this = (FunctionObject *)(self);
Bram Moolenaar77045652012-09-21 13:46:06 +02001495
1496 GET_ATTR_STRING(name, nameobj);
Bram Moolenaardb913952012-06-29 12:54:53 +02001497
1498 if (strcmp(name, "name") == 0)
1499 return PyUnicode_FromString((char *)(this->name));
1500
1501 return PyObject_GenericGetAttr(self, nameobj);
1502}
1503
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001504/* External interface
1505 */
1506
1507 void
1508python3_buffer_free(buf_T *buf)
1509{
Bram Moolenaar971db462013-05-12 18:44:48 +02001510 if (BUF_PYTHON_REF(buf) != NULL)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001511 {
Bram Moolenaar971db462013-05-12 18:44:48 +02001512 BufferObject *bp = BUF_PYTHON_REF(buf);
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001513 bp->buf = INVALID_BUFFER_VALUE;
Bram Moolenaar971db462013-05-12 18:44:48 +02001514 BUF_PYTHON_REF(buf) = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001515 }
1516}
1517
1518#if defined(FEAT_WINDOWS) || defined(PROTO)
1519 void
1520python3_window_free(win_T *win)
1521{
Bram Moolenaar971db462013-05-12 18:44:48 +02001522 if (WIN_PYTHON_REF(win) != NULL)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001523 {
Bram Moolenaar971db462013-05-12 18:44:48 +02001524 WindowObject *wp = WIN_PYTHON_REF(win);
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001525 wp->win = INVALID_WINDOW_VALUE;
Bram Moolenaar971db462013-05-12 18:44:48 +02001526 WIN_PYTHON_REF(win) = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001527 }
1528}
Bram Moolenaar5e538ec2013-05-15 15:12:29 +02001529
1530 void
1531python3_tabpage_free(tabpage_T *tab)
1532{
1533 if (TAB_PYTHON_REF(tab) != NULL)
1534 {
1535 TabPageObject *tp = TAB_PYTHON_REF(tab);
1536 tp->tab = INVALID_TABPAGE_VALUE;
1537 TAB_PYTHON_REF(tab) = NULL;
1538 }
1539}
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001540#endif
1541
Bram Moolenaar7854e3a2012-11-28 15:33:14 +01001542 static PyObject *
1543Py3Init_vim(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001544{
1545 PyObject *mod;
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001546
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001547 /* The special value is removed from sys.path in Python3_Init(). */
1548 static wchar_t *(argv[2]) = {L"/must>not&exist/foo", NULL};
1549
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001550 if (init_types())
1551 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001552
1553 /* Set sys.argv[] to avoid a crash in warn(). */
1554 PySys_SetArgv(1, argv);
1555
1556 mod = PyModule_Create(&vimmodule);
Bram Moolenaar19e60942011-06-19 00:27:51 +02001557 if (mod == NULL)
1558 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001559
Bram Moolenaar1dc28782013-05-21 19:11:01 +02001560 if (populate_module(mod, PyModule_AddObject))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001561 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001562
1563 return mod;
1564}
1565
1566/*************************************************************************
1567 * 4. Utility functions for handling the interface between Vim and Python.
1568 */
1569
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001570/* Convert a Vim line into a Python string.
1571 * All internal newlines are replaced by null characters.
1572 *
1573 * On errors, the Python exception data is set, and NULL is returned.
1574 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001575 static PyObject *
1576LineToString(const char *str)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001577{
1578 PyObject *result;
1579 Py_ssize_t len = strlen(str);
1580 char *tmp,*p;
1581
1582 tmp = (char *)alloc((unsigned)(len+1));
1583 p = tmp;
1584 if (p == NULL)
1585 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001586 PyErr_NoMemory();
1587 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001588 }
1589
1590 while (*str)
1591 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001592 if (*str == '\n')
1593 *p = '\0';
1594 else
1595 *p = *str;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001596
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001597 ++p;
1598 ++str;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001599 }
1600 *p = '\0';
1601
Bram Moolenaar3d64a312011-07-15 15:54:44 +02001602 result = PyUnicode_Decode(tmp, len, (char *)ENC_OPT, CODEC_ERROR_HANDLER);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001603
1604 vim_free(tmp);
1605 return result;
1606}
1607
Bram Moolenaardb913952012-06-29 12:54:53 +02001608 void
1609do_py3eval (char_u *str, typval_T *rettv)
1610{
Bram Moolenaarb52f4c02013-05-21 18:19:38 +02001611 DoPyCommand((char *) str,
1612 (rangeinitializer) init_range_eval,
1613 (runner) run_eval,
1614 (void *) rettv);
Bram Moolenaardb913952012-06-29 12:54:53 +02001615 switch(rettv->v_type)
1616 {
1617 case VAR_DICT: ++rettv->vval.v_dict->dv_refcount; break;
1618 case VAR_LIST: ++rettv->vval.v_list->lv_refcount; break;
1619 case VAR_FUNC: func_ref(rettv->vval.v_string); break;
Bram Moolenaar77fceb82012-09-05 18:54:48 +02001620 case VAR_UNKNOWN:
1621 rettv->v_type = VAR_NUMBER;
1622 rettv->vval.v_number = 0;
1623 break;
Bram Moolenaardb913952012-06-29 12:54:53 +02001624 }
1625}
1626
1627 void
1628set_ref_in_python3 (int copyID)
1629{
1630 set_ref_in_py(copyID);
1631}