blob: 644cf188aa8e0e8ecd010981bf8af10c0f754e8f [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 Moolenaarbd5e15f2010-07-17 21:19:38 +020027
28#include "vim.h"
29
30#include <limits.h>
31
32/* Python.h defines _POSIX_THREADS itself (if needed) */
33#ifdef _POSIX_THREADS
34# undef _POSIX_THREADS
35#endif
36
Bram Moolenaard68554d2010-07-25 13:43:20 +020037#if defined(_WIN32) && defined(HAVE_FCNTL_H)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020038# undef HAVE_FCNTL_H
39#endif
40
41#ifdef _DEBUG
42# undef _DEBUG
43#endif
44
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020045#define PY_SSIZE_T_CLEAN
46
47#ifdef F_BLANK
48# undef F_BLANK
49#endif
50
Bram Moolenaar6df6f472010-07-18 18:04:50 +020051#ifdef HAVE_STDARG_H
52# undef HAVE_STDARG_H /* Python's config.h defines it as well. */
53#endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020054#ifdef _POSIX_C_SOURCE /* defined in feature.h */
55# undef _POSIX_C_SOURCE
56#endif
Bram Moolenaar6df6f472010-07-18 18:04:50 +020057#ifdef _XOPEN_SOURCE
58# undef _XOPEN_SOURCE /* pyconfig.h defines it as well. */
59#endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020060
61#include <Python.h>
62#if defined(MACOS) && !defined(MACOS_X_UNIX)
63# include "macglue.h"
64# include <CodeFragments.h>
65#endif
66#undef main /* Defined in python.h - aargh */
67#undef HAVE_FCNTL_H /* Clash with os_win32.h */
68
69static void init_structs(void);
70
Bram Moolenaar3d64a312011-07-15 15:54:44 +020071/* The "surrogateescape" error handler is new in Python 3.1 */
72#if PY_VERSION_HEX >= 0x030100f0
73# define CODEC_ERROR_HANDLER "surrogateescape"
74#else
75# define CODEC_ERROR_HANDLER NULL
76#endif
77
Bram Moolenaar170bf1a2010-07-24 23:51:45 +020078#define PyInt Py_ssize_t
Bram Moolenaarca8a4df2010-07-31 19:54:14 +020079#define PyString_Check(obj) PyUnicode_Check(obj)
Bram Moolenaar3d64a312011-07-15 15:54:44 +020080#define PyString_AsBytes(obj) PyUnicode_AsEncodedString(obj, (char *)ENC_OPT, CODEC_ERROR_HANDLER);
Bram Moolenaar19e60942011-06-19 00:27:51 +020081#define PyString_FreeBytes(obj) Py_XDECREF(bytes)
82#define PyString_AsString(obj) PyBytes_AsString(obj)
83#define PyString_Size(obj) PyBytes_GET_SIZE(bytes)
Bram Moolenaarca8a4df2010-07-31 19:54:14 +020084#define PyString_FromString(repr) PyUnicode_FromString(repr)
Bram Moolenaar170bf1a2010-07-24 23:51:45 +020085
Bram Moolenaar0c1f3f42011-02-25 15:18:50 +010086#if defined(DYNAMIC_PYTHON3) || defined(PROTO)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +020087
Bram Moolenaarb61f95c2010-08-09 22:06:13 +020088# ifndef WIN3264
89# include <dlfcn.h>
90# define FARPROC void*
91# define HINSTANCE void*
Bram Moolenaar644d37b2010-11-16 19:26:02 +010092# if defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)
Bram Moolenaarb61f95c2010-08-09 22:06:13 +020093# define load_dll(n) dlopen((n), RTLD_LAZY)
94# else
95# define load_dll(n) dlopen((n), RTLD_LAZY|RTLD_GLOBAL)
96# endif
97# define close_dll dlclose
98# define symbol_from_dll dlsym
99# else
Bram Moolenaarebbcb822010-10-23 14:02:54 +0200100# define load_dll vimLoadLib
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200101# define close_dll FreeLibrary
102# define symbol_from_dll GetProcAddress
103# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200104/*
105 * Wrapper defines
106 */
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200107# undef PyArg_Parse
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200108# define PyArg_Parse py3_PyArg_Parse
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200109# undef PyArg_ParseTuple
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200110# define PyArg_ParseTuple py3_PyArg_ParseTuple
Bram Moolenaar19e60942011-06-19 00:27:51 +0200111# define PyMem_Free py3_PyMem_Free
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200112# define PyDict_SetItemString py3_PyDict_SetItemString
113# define PyErr_BadArgument py3_PyErr_BadArgument
114# define PyErr_Clear py3_PyErr_Clear
115# define PyErr_NoMemory py3_PyErr_NoMemory
116# define PyErr_Occurred py3_PyErr_Occurred
117# define PyErr_SetNone py3_PyErr_SetNone
118# define PyErr_SetString py3_PyErr_SetString
119# define PyEval_InitThreads py3_PyEval_InitThreads
120# define PyEval_RestoreThread py3_PyEval_RestoreThread
121# define PyEval_SaveThread py3_PyEval_SaveThread
122# define PyGILState_Ensure py3_PyGILState_Ensure
123# define PyGILState_Release py3_PyGILState_Release
124# define PyLong_AsLong py3_PyLong_AsLong
125# define PyLong_FromLong py3_PyLong_FromLong
126# define PyList_GetItem py3_PyList_GetItem
127# define PyList_Append py3_PyList_Append
128# define PyList_New py3_PyList_New
129# define PyList_SetItem py3_PyList_SetItem
130# define PyList_Size py3_PyList_Size
131# define PySlice_GetIndicesEx py3_PySlice_GetIndicesEx
132# define PyImport_ImportModule py3_PyImport_ImportModule
133# define PyObject_Init py3__PyObject_Init
134# define PyDict_New py3_PyDict_New
135# define PyDict_GetItemString py3_PyDict_GetItemString
136# define PyModule_GetDict py3_PyModule_GetDict
137#undef PyRun_SimpleString
138# define PyRun_SimpleString py3_PyRun_SimpleString
139# define PySys_SetObject py3_PySys_SetObject
140# define PySys_SetArgv py3_PySys_SetArgv
141# define PyType_Type (*py3_PyType_Type)
142# define PyType_Ready py3_PyType_Ready
143#undef Py_BuildValue
144# define Py_BuildValue py3_Py_BuildValue
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100145# define Py_SetPythonHome py3_Py_SetPythonHome
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200146# define Py_Initialize py3_Py_Initialize
147# define Py_Finalize py3_Py_Finalize
148# define Py_IsInitialized py3_Py_IsInitialized
149# define _Py_NoneStruct (*py3__Py_NoneStruct)
150# define PyModule_AddObject py3_PyModule_AddObject
151# define PyImport_AppendInittab py3_PyImport_AppendInittab
152# define _PyUnicode_AsString py3__PyUnicode_AsString
Bram Moolenaar19e60942011-06-19 00:27:51 +0200153# undef PyUnicode_AsEncodedString
154# define PyUnicode_AsEncodedString py3_PyUnicode_AsEncodedString
155# undef PyBytes_AsString
156# define PyBytes_AsString py3_PyBytes_AsString
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200157# define PyObject_GenericGetAttr py3_PyObject_GenericGetAttr
158# define PySlice_Type (*py3_PySlice_Type)
Bram Moolenaar19e60942011-06-19 00:27:51 +0200159# define PyErr_NewException py3_PyErr_NewException
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200160# ifdef Py_DEBUG
161# define _Py_NegativeRefcount py3__Py_NegativeRefcount
162# define _Py_RefTotal (*py3__Py_RefTotal)
163# define _Py_Dealloc py3__Py_Dealloc
164# define _PyObject_DebugMalloc py3__PyObject_DebugMalloc
165# define _PyObject_DebugFree py3__PyObject_DebugFree
166# else
167# define PyObject_Malloc py3_PyObject_Malloc
168# define PyObject_Free py3_PyObject_Free
169# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200170# define PyType_GenericAlloc py3_PyType_GenericAlloc
171# define PyType_GenericNew py3_PyType_GenericNew
172# define PyModule_Create2 py3_PyModule_Create2
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200173# undef PyUnicode_FromString
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200174# define PyUnicode_FromString py3_PyUnicode_FromString
Bram Moolenaar19e60942011-06-19 00:27:51 +0200175# undef PyUnicode_Decode
176# define PyUnicode_Decode py3_PyUnicode_Decode
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200177
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200178# ifdef Py_DEBUG
179# undef PyObject_NEW
180# define PyObject_NEW(type, typeobj) \
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200181( (type *) PyObject_Init( \
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200182 (PyObject *) _PyObject_DebugMalloc( _PyObject_SIZE(typeobj) ), (typeobj)) )
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200183# endif
184
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200185/*
186 * Pointers for dynamic link
187 */
188static int (*py3_PySys_SetArgv)(int, wchar_t **);
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100189static void (*py3_Py_SetPythonHome)(wchar_t *home);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200190static void (*py3_Py_Initialize)(void);
191static PyObject* (*py3_PyList_New)(Py_ssize_t size);
192static PyGILState_STATE (*py3_PyGILState_Ensure)(void);
193static void (*py3_PyGILState_Release)(PyGILState_STATE);
194static int (*py3_PySys_SetObject)(char *, PyObject *);
195static PyObject* (*py3_PyList_Append)(PyObject *, PyObject *);
196static Py_ssize_t (*py3_PyList_Size)(PyObject *);
197static int (*py3_PySlice_GetIndicesEx)(PySliceObject *r, Py_ssize_t length,
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200198 Py_ssize_t *start, Py_ssize_t *stop, Py_ssize_t *step, Py_ssize_t *slicelength);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200199static PyObject* (*py3_PyErr_NoMemory)(void);
200static void (*py3_Py_Finalize)(void);
201static void (*py3_PyErr_SetString)(PyObject *, const char *);
202static int (*py3_PyRun_SimpleString)(char *);
203static PyObject* (*py3_PyList_GetItem)(PyObject *, Py_ssize_t);
204static PyObject* (*py3_PyImport_ImportModule)(const char *);
205static int (*py3_PyErr_BadArgument)(void);
206static PyTypeObject* py3_PyType_Type;
207static PyObject* (*py3_PyErr_Occurred)(void);
208static PyObject* (*py3_PyModule_GetDict)(PyObject *);
209static int (*py3_PyList_SetItem)(PyObject *, Py_ssize_t, PyObject *);
210static PyObject* (*py3_PyDict_GetItemString)(PyObject *, const char *);
211static PyObject* (*py3_PyLong_FromLong)(long);
212static PyObject* (*py3_PyDict_New)(void);
213static PyObject* (*py3_Py_BuildValue)(char *, ...);
214static int (*py3_PyType_Ready)(PyTypeObject *type);
215static int (*py3_PyDict_SetItemString)(PyObject *dp, char *key, PyObject *item);
216static PyObject* (*py3_PyUnicode_FromString)(const char *u);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200217static PyObject* (*py3_PyUnicode_Decode)(const char *u, Py_ssize_t size,
218 const char *encoding, const char *errors);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200219static long (*py3_PyLong_AsLong)(PyObject *);
220static void (*py3_PyErr_SetNone)(PyObject *);
221static void (*py3_PyEval_InitThreads)(void);
222static void(*py3_PyEval_RestoreThread)(PyThreadState *);
223static PyThreadState*(*py3_PyEval_SaveThread)(void);
224static int (*py3_PyArg_Parse)(PyObject *, char *, ...);
225static int (*py3_PyArg_ParseTuple)(PyObject *, char *, ...);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200226static int (*py3_PyMem_Free)(void *);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200227static int (*py3_Py_IsInitialized)(void);
228static void (*py3_PyErr_Clear)(void);
229static PyObject*(*py3__PyObject_Init)(PyObject *, PyTypeObject *);
230static PyObject* py3__Py_NoneStruct;
231static int (*py3_PyModule_AddObject)(PyObject *m, const char *name, PyObject *o);
232static int (*py3_PyImport_AppendInittab)(const char *name, PyObject* (*initfunc)(void));
233static char* (*py3__PyUnicode_AsString)(PyObject *unicode);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200234static PyObject* (*py3_PyUnicode_AsEncodedString)(PyObject *unicode, const char* encoding, const char* errors);
235static char* (*py3_PyBytes_AsString)(PyObject *bytes);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200236static PyObject* (*py3_PyObject_GenericGetAttr)(PyObject *obj, PyObject *name);
237static PyObject* (*py3_PyModule_Create2)(struct PyModuleDef* module, int module_api_version);
238static PyObject* (*py3_PyType_GenericAlloc)(PyTypeObject *type, Py_ssize_t nitems);
239static PyObject* (*py3_PyType_GenericNew)(PyTypeObject *type, PyObject *args, PyObject *kwds);
240static PyTypeObject* py3_PySlice_Type;
Bram Moolenaar19e60942011-06-19 00:27:51 +0200241static PyObject* (*py3_PyErr_NewException)(char *name, PyObject *base, PyObject *dict);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200242# ifdef Py_DEBUG
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200243 static void (*py3__Py_NegativeRefcount)(const char *fname, int lineno, PyObject *op);
244 static Py_ssize_t* py3__Py_RefTotal;
245 static void (*py3__Py_Dealloc)(PyObject *obj);
246 static void (*py3__PyObject_DebugFree)(void*);
247 static void* (*py3__PyObject_DebugMalloc)(size_t);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200248# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200249 static void (*py3_PyObject_Free)(void*);
250 static void* (*py3_PyObject_Malloc)(size_t);
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200251# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200252
253static HINSTANCE hinstPy3 = 0; /* Instance of python.dll */
254
255/* Imported exception objects */
256static PyObject *p3imp_PyExc_AttributeError;
257static PyObject *p3imp_PyExc_IndexError;
258static PyObject *p3imp_PyExc_KeyboardInterrupt;
259static PyObject *p3imp_PyExc_TypeError;
260static PyObject *p3imp_PyExc_ValueError;
261
262# define PyExc_AttributeError p3imp_PyExc_AttributeError
263# define PyExc_IndexError p3imp_PyExc_IndexError
264# define PyExc_KeyboardInterrupt p3imp_PyExc_KeyboardInterrupt
265# define PyExc_TypeError p3imp_PyExc_TypeError
266# define PyExc_ValueError p3imp_PyExc_ValueError
267
268/*
269 * Table of name to function pointer of python.
270 */
271# define PYTHON_PROC FARPROC
272static struct
273{
274 char *name;
275 PYTHON_PROC *ptr;
276} py3_funcname_table[] =
277{
278 {"PySys_SetArgv", (PYTHON_PROC*)&py3_PySys_SetArgv},
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100279 {"Py_SetPythonHome", (PYTHON_PROC*)&py3_Py_SetPythonHome},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200280 {"Py_Initialize", (PYTHON_PROC*)&py3_Py_Initialize},
281 {"PyArg_ParseTuple", (PYTHON_PROC*)&py3_PyArg_ParseTuple},
Bram Moolenaar19e60942011-06-19 00:27:51 +0200282 {"PyMem_Free", (PYTHON_PROC*)&py3_PyMem_Free},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200283 {"PyList_New", (PYTHON_PROC*)&py3_PyList_New},
284 {"PyGILState_Ensure", (PYTHON_PROC*)&py3_PyGILState_Ensure},
285 {"PyGILState_Release", (PYTHON_PROC*)&py3_PyGILState_Release},
286 {"PySys_SetObject", (PYTHON_PROC*)&py3_PySys_SetObject},
287 {"PyList_Append", (PYTHON_PROC*)&py3_PyList_Append},
288 {"PyList_Size", (PYTHON_PROC*)&py3_PyList_Size},
289 {"PySlice_GetIndicesEx", (PYTHON_PROC*)&py3_PySlice_GetIndicesEx},
290 {"PyErr_NoMemory", (PYTHON_PROC*)&py3_PyErr_NoMemory},
291 {"Py_Finalize", (PYTHON_PROC*)&py3_Py_Finalize},
292 {"PyErr_SetString", (PYTHON_PROC*)&py3_PyErr_SetString},
293 {"PyRun_SimpleString", (PYTHON_PROC*)&py3_PyRun_SimpleString},
294 {"PyList_GetItem", (PYTHON_PROC*)&py3_PyList_GetItem},
295 {"PyImport_ImportModule", (PYTHON_PROC*)&py3_PyImport_ImportModule},
296 {"PyErr_BadArgument", (PYTHON_PROC*)&py3_PyErr_BadArgument},
297 {"PyType_Type", (PYTHON_PROC*)&py3_PyType_Type},
298 {"PyErr_Occurred", (PYTHON_PROC*)&py3_PyErr_Occurred},
299 {"PyModule_GetDict", (PYTHON_PROC*)&py3_PyModule_GetDict},
300 {"PyList_SetItem", (PYTHON_PROC*)&py3_PyList_SetItem},
301 {"PyDict_GetItemString", (PYTHON_PROC*)&py3_PyDict_GetItemString},
302 {"PyLong_FromLong", (PYTHON_PROC*)&py3_PyLong_FromLong},
303 {"PyDict_New", (PYTHON_PROC*)&py3_PyDict_New},
304 {"Py_BuildValue", (PYTHON_PROC*)&py3_Py_BuildValue},
305 {"PyType_Ready", (PYTHON_PROC*)&py3_PyType_Ready},
306 {"PyDict_SetItemString", (PYTHON_PROC*)&py3_PyDict_SetItemString},
307 {"PyLong_AsLong", (PYTHON_PROC*)&py3_PyLong_AsLong},
308 {"PyErr_SetNone", (PYTHON_PROC*)&py3_PyErr_SetNone},
309 {"PyEval_InitThreads", (PYTHON_PROC*)&py3_PyEval_InitThreads},
310 {"PyEval_RestoreThread", (PYTHON_PROC*)&py3_PyEval_RestoreThread},
311 {"PyEval_SaveThread", (PYTHON_PROC*)&py3_PyEval_SaveThread},
312 {"PyArg_Parse", (PYTHON_PROC*)&py3_PyArg_Parse},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200313 {"Py_IsInitialized", (PYTHON_PROC*)&py3_Py_IsInitialized},
314 {"_Py_NoneStruct", (PYTHON_PROC*)&py3__Py_NoneStruct},
315 {"PyErr_Clear", (PYTHON_PROC*)&py3_PyErr_Clear},
316 {"PyObject_Init", (PYTHON_PROC*)&py3__PyObject_Init},
317 {"PyModule_AddObject", (PYTHON_PROC*)&py3_PyModule_AddObject},
318 {"PyImport_AppendInittab", (PYTHON_PROC*)&py3_PyImport_AppendInittab},
319 {"_PyUnicode_AsString", (PYTHON_PROC*)&py3__PyUnicode_AsString},
Bram Moolenaar19e60942011-06-19 00:27:51 +0200320 {"PyBytes_AsString", (PYTHON_PROC*)&py3_PyBytes_AsString},
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200321 {"PyObject_GenericGetAttr", (PYTHON_PROC*)&py3_PyObject_GenericGetAttr},
322 {"PyModule_Create2", (PYTHON_PROC*)&py3_PyModule_Create2},
323 {"PyType_GenericAlloc", (PYTHON_PROC*)&py3_PyType_GenericAlloc},
324 {"PyType_GenericNew", (PYTHON_PROC*)&py3_PyType_GenericNew},
325 {"PySlice_Type", (PYTHON_PROC*)&py3_PySlice_Type},
Bram Moolenaar19e60942011-06-19 00:27:51 +0200326 {"PyErr_NewException", (PYTHON_PROC*)&py3_PyErr_NewException},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200327# ifdef Py_DEBUG
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200328 {"_Py_NegativeRefcount", (PYTHON_PROC*)&py3__Py_NegativeRefcount},
329 {"_Py_RefTotal", (PYTHON_PROC*)&py3__Py_RefTotal},
330 {"_Py_Dealloc", (PYTHON_PROC*)&py3__Py_Dealloc},
331 {"_PyObject_DebugFree", (PYTHON_PROC*)&py3__PyObject_DebugFree},
332 {"_PyObject_DebugMalloc", (PYTHON_PROC*)&py3__PyObject_DebugMalloc},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200333# else
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200334 {"PyObject_Malloc", (PYTHON_PROC*)&py3_PyObject_Malloc},
335 {"PyObject_Free", (PYTHON_PROC*)&py3_PyObject_Free},
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200336# endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200337 {"", NULL},
338};
339
340/*
341 * Free python.dll
342 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200343 static void
344end_dynamic_python3(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200345{
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200346 if (hinstPy3 != 0)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200347 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200348 close_dll(hinstPy3);
349 hinstPy3 = 0;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200350 }
351}
352
353/*
354 * Load library and get all pointers.
355 * Parameter 'libname' provides name of DLL.
356 * Return OK or FAIL.
357 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200358 static int
359py3_runtime_link_init(char *libname, int verbose)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200360{
361 int i;
Bram Moolenaar19e60942011-06-19 00:27:51 +0200362 void *ucs_from_string, *ucs_decode, *ucs_as_encoded_string;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200363
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100364# if !(defined(PY_NO_RTLD_GLOBAL) && defined(PY3_NO_RTLD_GLOBAL)) && defined(UNIX) && defined(FEAT_PYTHON)
Bram Moolenaarb744b2f2010-08-13 16:22:57 +0200365 /* Can't have Python and Python3 loaded at the same time.
366 * It cause a crash, because RTLD_GLOBAL is needed for
367 * standard C extension libraries of one or both python versions. */
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200368 if (python_loaded())
369 {
Bram Moolenaar9dc93ae2011-08-28 16:00:19 +0200370 if (verbose)
371 EMSG(_("E837: This Vim cannot execute :py3 after using :python"));
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200372 return FAIL;
373 }
Bram Moolenaarb61f95c2010-08-09 22:06:13 +0200374# endif
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200375
376 if (hinstPy3 != 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200377 return OK;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200378 hinstPy3 = load_dll(libname);
379
380 if (!hinstPy3)
381 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200382 if (verbose)
383 EMSG2(_(e_loadlib), libname);
384 return FAIL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200385 }
386
387 for (i = 0; py3_funcname_table[i].ptr; ++i)
388 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200389 if ((*py3_funcname_table[i].ptr = symbol_from_dll(hinstPy3,
390 py3_funcname_table[i].name)) == NULL)
391 {
392 close_dll(hinstPy3);
393 hinstPy3 = 0;
394 if (verbose)
395 EMSG2(_(e_loadfunc), py3_funcname_table[i].name);
396 return FAIL;
397 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200398 }
399
Bram Moolenaar69154f22010-07-18 21:42:34 +0200400 /* Load unicode functions separately as only the ucs2 or the ucs4 functions
401 * will be present in the library. */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200402 ucs_from_string = symbol_from_dll(hinstPy3, "PyUnicodeUCS2_FromString");
Bram Moolenaar19e60942011-06-19 00:27:51 +0200403 ucs_decode = symbol_from_dll(hinstPy3,
404 "PyUnicodeUCS2_Decode");
405 ucs_as_encoded_string = symbol_from_dll(hinstPy3,
406 "PyUnicodeUCS2_AsEncodedString");
407 if (!ucs_from_string || !ucs_decode || !ucs_as_encoded_string)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200408 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200409 ucs_from_string = symbol_from_dll(hinstPy3,
410 "PyUnicodeUCS4_FromString");
Bram Moolenaar19e60942011-06-19 00:27:51 +0200411 ucs_decode = symbol_from_dll(hinstPy3,
412 "PyUnicodeUCS4_Decode");
413 ucs_as_encoded_string = symbol_from_dll(hinstPy3,
414 "PyUnicodeUCS4_AsEncodedString");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200415 }
Bram Moolenaar19e60942011-06-19 00:27:51 +0200416 if (ucs_from_string && ucs_decode && ucs_as_encoded_string)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200417 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200418 py3_PyUnicode_FromString = ucs_from_string;
Bram Moolenaar19e60942011-06-19 00:27:51 +0200419 py3_PyUnicode_Decode = ucs_decode;
420 py3_PyUnicode_AsEncodedString = ucs_as_encoded_string;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200421 }
422 else
423 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200424 close_dll(hinstPy3);
425 hinstPy3 = 0;
426 if (verbose)
427 EMSG2(_(e_loadfunc), "PyUnicode_UCSX_*");
428 return FAIL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200429 }
430
431 return OK;
432}
433
434/*
435 * If python is enabled (there is installed python on Windows system) return
436 * TRUE, else FALSE.
437 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200438 int
439python3_enabled(int verbose)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200440{
441 return py3_runtime_link_init(DYNAMIC_PYTHON3_DLL, verbose) == OK;
442}
443
444/* Load the standard Python exceptions - don't import the symbols from the
445 * DLL, as this can cause errors (importing data symbols is not reliable).
446 */
447static void get_py3_exceptions __ARGS((void));
448
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200449 static void
450get_py3_exceptions()
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200451{
452 PyObject *exmod = PyImport_ImportModule("builtins");
453 PyObject *exdict = PyModule_GetDict(exmod);
454 p3imp_PyExc_AttributeError = PyDict_GetItemString(exdict, "AttributeError");
455 p3imp_PyExc_IndexError = PyDict_GetItemString(exdict, "IndexError");
456 p3imp_PyExc_KeyboardInterrupt = PyDict_GetItemString(exdict, "KeyboardInterrupt");
457 p3imp_PyExc_TypeError = PyDict_GetItemString(exdict, "TypeError");
458 p3imp_PyExc_ValueError = PyDict_GetItemString(exdict, "ValueError");
459 Py_XINCREF(p3imp_PyExc_AttributeError);
460 Py_XINCREF(p3imp_PyExc_IndexError);
461 Py_XINCREF(p3imp_PyExc_KeyboardInterrupt);
462 Py_XINCREF(p3imp_PyExc_TypeError);
463 Py_XINCREF(p3imp_PyExc_ValueError);
464 Py_XDECREF(exmod);
465}
466#endif /* DYNAMIC_PYTHON3 */
467
Bram Moolenaarca8a4df2010-07-31 19:54:14 +0200468static PyObject *BufferNew (buf_T *);
469static PyObject *WindowNew(win_T *);
470static PyObject *LineToString(const char *);
471
472static PyTypeObject RangeType;
473
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200474/*
475 * Include the code shared with if_python.c
476 */
477#include "if_py_both.h"
478
479 static void
480call_PyObject_Free(void *p)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200481{
482#ifdef Py_DEBUG
483 _PyObject_DebugFree(p);
484#else
485 PyObject_Free(p);
486#endif
487}
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200488
489 static PyObject *
490call_PyType_GenericNew(PyTypeObject *type, PyObject *args, PyObject *kwds)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200491{
492 return PyType_GenericNew(type,args,kwds);
493}
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200494
495 static PyObject *
496call_PyType_GenericAlloc(PyTypeObject *type, Py_ssize_t nitems)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200497{
498 return PyType_GenericAlloc(type,nitems);
499}
500
501/******************************************************
502 * Internal function prototypes.
503 */
504
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200505static Py_ssize_t RangeStart;
506static Py_ssize_t RangeEnd;
507
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200508static int PythonIO_Init(void);
509static void PythonIO_Fini(void);
Bram Moolenaar69154f22010-07-18 21:42:34 +0200510PyMODINIT_FUNC Py3Init_vim(void);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200511
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200512/******************************************************
513 * 1. Python interpreter main program.
514 */
515
516static int py3initialised = 0;
517
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200518static PyGILState_STATE pygilstate = PyGILState_UNLOCKED;
519
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200520 void
521python3_end()
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200522{
523 static int recurse = 0;
524
525 /* If a crash occurs while doing this, don't try again. */
526 if (recurse != 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200527 return;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200528
529 ++recurse;
530
531#ifdef DYNAMIC_PYTHON3
532 if (hinstPy3)
533#endif
534 if (Py_IsInitialized())
535 {
536 // acquire lock before finalizing
537 pygilstate = PyGILState_Ensure();
538
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200539 PythonIO_Fini();
540 Py_Finalize();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200541 }
542
543#ifdef DYNAMIC_PYTHON3
544 end_dynamic_python3();
545#endif
546
547 --recurse;
548}
549
Bram Moolenaar4c3a3262010-07-24 15:42:14 +0200550#if (defined(DYNAMIC_PYTHON) && defined(FEAT_PYTHON)) || defined(PROTO)
551 int
552python3_loaded()
553{
554 return (hinstPy3 != 0);
555}
556#endif
557
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200558 static int
559Python3_Init(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200560{
561 if (!py3initialised)
562 {
563#ifdef DYNAMIC_PYTHON3
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200564 if (!python3_enabled(TRUE))
565 {
566 EMSG(_("E263: Sorry, this command is disabled, the Python library could not be loaded."));
567 goto fail;
568 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200569#endif
570
571 init_structs();
572
Bram Moolenaar644d37b2010-11-16 19:26:02 +0100573
574#ifdef PYTHON3_HOME
575 Py_SetPythonHome(PYTHON3_HOME);
576#endif
577
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200578#if !defined(MACOS) || defined(MACOS_X_UNIX)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200579 Py_Initialize();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200580#else
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200581 PyMac_Initialize();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200582#endif
Bram Moolenaar456f2bb2011-06-12 21:37:13 +0200583 /* initialise threads, must be after Py_Initialize() */
584 PyEval_InitThreads();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200585
586#ifdef DYNAMIC_PYTHON3
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200587 get_py3_exceptions();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200588#endif
589
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200590 if (PythonIO_Init())
591 goto fail;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200592
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200593 PyImport_AppendInittab("vim", Py3Init_vim);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200594
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200595 /* Remove the element from sys.path that was added because of our
596 * argv[0] value in Py3Init_vim(). Previously we used an empty
597 * string, but dependinding on the OS we then get an empty entry or
Bram Moolenaar19e60942011-06-19 00:27:51 +0200598 * the current directory in sys.path.
599 * Only after vim has been imported, the element does exist in
600 * sys.path.
601 */
602 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 +0200603
604 // lock is created and acquired in PyEval_InitThreads() and thread
605 // state is created in Py_Initialize()
606 // there _PyGILState_NoteThreadState() also sets gilcounter to 1
607 // (python must have threads enabled!)
608 // so the following does both: unlock GIL and save thread state in TLS
609 // without deleting thread state
610 PyGILState_Release(pygilstate);
611
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200612 py3initialised = 1;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200613 }
614
615 return 0;
616
617fail:
618 /* We call PythonIO_Flush() here to print any Python errors.
619 * This is OK, as it is possible to call this function even
620 * if PythonIO_Init() has not completed successfully (it will
621 * not do anything in this case).
622 */
623 PythonIO_Flush();
624 return -1;
625}
626
627/*
628 * External interface
629 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200630 static void
631DoPy3Command(exarg_T *eap, const char *cmd)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200632{
633#if defined(MACOS) && !defined(MACOS_X_UNIX)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200634 GrafPtr oldPort;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200635#endif
636#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200637 char *saved_locale;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200638#endif
Bram Moolenaar19e60942011-06-19 00:27:51 +0200639 PyObject *cmdstr;
640 PyObject *cmdbytes;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200641
642#if defined(MACOS) && !defined(MACOS_X_UNIX)
643 GetPort(&oldPort);
644 /* Check if the Python library is available */
645 if ((Ptr)PyMac_Initialize == (Ptr)kUnresolvedCFragSymbolAddress)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200646 goto theend;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200647#endif
648 if (Python3_Init())
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200649 goto theend;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200650
651 RangeStart = eap->line1;
652 RangeEnd = eap->line2;
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200653 Python_Release_Vim(); /* leave vim */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200654
655#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
656 /* Python only works properly when the LC_NUMERIC locale is "C". */
657 saved_locale = setlocale(LC_NUMERIC, NULL);
658 if (saved_locale == NULL || STRCMP(saved_locale, "C") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200659 saved_locale = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200660 else
661 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200662 /* Need to make a copy, value may change when setting new locale. */
663 saved_locale = (char *)vim_strsave((char_u *)saved_locale);
664 (void)setlocale(LC_NUMERIC, "C");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200665 }
666#endif
667
668 pygilstate = PyGILState_Ensure();
669
Bram Moolenaar19e60942011-06-19 00:27:51 +0200670 /* PyRun_SimpleString expects a UTF-8 string. Wrong encoding may cause
671 * SyntaxError (unicode error). */
Bram Moolenaar3d64a312011-07-15 15:54:44 +0200672 cmdstr = PyUnicode_Decode(cmd, strlen(cmd),
673 (char *)ENC_OPT, CODEC_ERROR_HANDLER);
674 cmdbytes = PyUnicode_AsEncodedString(cmdstr, "utf-8", CODEC_ERROR_HANDLER);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200675 Py_XDECREF(cmdstr);
676 PyRun_SimpleString(PyBytes_AsString(cmdbytes));
677 Py_XDECREF(cmdbytes);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200678
679 PyGILState_Release(pygilstate);
680
681#if defined(HAVE_LOCALE_H) || defined(X_LOCALE)
682 if (saved_locale != NULL)
683 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200684 (void)setlocale(LC_NUMERIC, saved_locale);
685 vim_free(saved_locale);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200686 }
687#endif
688
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200689 Python_Lock_Vim(); /* enter vim */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200690 PythonIO_Flush();
691#if defined(MACOS) && !defined(MACOS_X_UNIX)
692 SetPort(oldPort);
693#endif
694
695theend:
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200696 return; /* keeps lint happy */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200697}
698
699/*
Bram Moolenaar368373e2010-07-19 20:46:22 +0200700 * ":py3"
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200701 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200702 void
703ex_py3(exarg_T *eap)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200704{
705 char_u *script;
706
707 script = script_get(eap, eap->arg);
708 if (!eap->skip)
709 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200710 if (script == NULL)
711 DoPy3Command(eap, (char *)eap->arg);
712 else
713 DoPy3Command(eap, (char *)script);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200714 }
715 vim_free(script);
716}
717
718#define BUFFER_SIZE 2048
719
720/*
Bram Moolenaar6df6f472010-07-18 18:04:50 +0200721 * ":py3file"
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200722 */
723 void
724ex_py3file(exarg_T *eap)
725{
726 static char buffer[BUFFER_SIZE];
727 const char *file;
728 char *p;
729 int i;
730
731 /* Have to do it like this. PyRun_SimpleFile requires you to pass a
732 * stdio file pointer, but Vim and the Python DLL are compiled with
733 * different options under Windows, meaning that stdio pointers aren't
734 * compatible between the two. Yuk.
735 *
Bram Moolenaar19e60942011-06-19 00:27:51 +0200736 * construct: exec(compile(open('a_filename', 'rb').read(), 'a_filename', 'exec'))
737 *
738 * Using bytes so that Python can detect the source encoding as it normally
739 * does. The doc does not say "compile" accept bytes, though.
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200740 *
741 * We need to escape any backslashes or single quotes in the file name, so that
742 * Python won't mangle the file name.
743 */
744
745 strcpy(buffer, "exec(compile(open('");
746 p = buffer + 19; /* size of "exec(compile(open('" */
747
748 for (i=0; i<2; ++i)
749 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200750 file = (char *)eap->arg;
751 while (*file && p < buffer + (BUFFER_SIZE - 3))
752 {
753 if (*file == '\\' || *file == '\'')
754 *p++ = '\\';
755 *p++ = *file++;
756 }
757 /* If we didn't finish the file name, we hit a buffer overflow */
758 if (*file != '\0')
759 return;
760 if (i==0)
761 {
Bram Moolenaar19e60942011-06-19 00:27:51 +0200762 strcpy(p,"','rb').read(),'");
763 p += 16;
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200764 }
765 else
766 {
767 strcpy(p,"','exec'))");
768 p += 10;
769 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200770 }
771
772
773 /* Execute the file */
774 DoPy3Command(eap, buffer);
775}
776
777/******************************************************
778 * 2. Python output stream: writes output via [e]msg().
779 */
780
781/* Implementation functions
782 */
783
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200784 static PyObject *
785OutputGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200786{
787 char *name = "";
788 if (PyUnicode_Check(nameobj))
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200789 name = _PyUnicode_AsString(nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200790
791 if (strcmp(name, "softspace") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200792 return PyLong_FromLong(((OutputObject *)(self))->softspace);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200793
794 return PyObject_GenericGetAttr(self, nameobj);
795}
796
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200797 static int
798OutputSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200799{
800 char *name = "";
801 if (PyUnicode_Check(nameobj))
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200802 name = _PyUnicode_AsString(nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200803
804 if (val == NULL) {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200805 PyErr_SetString(PyExc_AttributeError, _("can't delete OutputObject attributes"));
806 return -1;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200807 }
808
809 if (strcmp(name, "softspace") == 0)
810 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200811 if (!PyLong_Check(val)) {
812 PyErr_SetString(PyExc_TypeError, _("softspace must be an integer"));
813 return -1;
814 }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200815
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200816 ((OutputObject *)(self))->softspace = PyLong_AsLong(val);
817 return 0;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200818 }
819
820 PyErr_SetString(PyExc_AttributeError, _("invalid attribute"));
821 return -1;
822}
823
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200824/***************/
825
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200826 static int
827PythonIO_Init(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200828{
829 PyType_Ready(&OutputType);
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200830 return PythonIO_Init_io();
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200831}
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200832
833 static void
834PythonIO_Fini(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200835{
836 PySys_SetObject("stdout", NULL);
837 PySys_SetObject("stderr", NULL);
838}
839
840/******************************************************
841 * 3. Implementation of the Vim module for Python
842 */
843
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200844/* Window type - Implementation functions
845 * --------------------------------------
846 */
847
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200848#define WindowType_Check(obj) ((obj)->ob_base.ob_type == &WindowType)
849
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200850/* Buffer type - Implementation functions
851 * --------------------------------------
852 */
853
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200854#define BufferType_Check(obj) ((obj)->ob_base.ob_type == &BufferType)
855
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200856static Py_ssize_t BufferLength(PyObject *);
857static PyObject *BufferItem(PyObject *, Py_ssize_t);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200858static PyObject* BufferSubscript(PyObject *self, PyObject* idx);
Bram Moolenaar19e60942011-06-19 00:27:51 +0200859static Py_ssize_t BufferAsSubscript(PyObject *self, PyObject* idx, PyObject* val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200860
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200861
862/* Line range type - Implementation functions
863 * --------------------------------------
864 */
865
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200866#define RangeType_Check(obj) ((obj)->ob_base.ob_type == &RangeType)
867
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200868static PyObject* RangeSubscript(PyObject *self, PyObject* idx);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200869static Py_ssize_t RangeAsItem(PyObject *, Py_ssize_t, PyObject *);
870
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200871/* Current objects type - Implementation functions
872 * -----------------------------------------------
873 */
874
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200875static PySequenceMethods BufferAsSeq = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200876 (lenfunc) BufferLength, /* sq_length, len(x) */
877 (binaryfunc) 0, /* sq_concat, x+y */
878 (ssizeargfunc) 0, /* sq_repeat, x*n */
879 (ssizeargfunc) BufferItem, /* sq_item, x[i] */
880 0, /* was_sq_slice, x[i:j] */
Bram Moolenaar19e60942011-06-19 00:27:51 +0200881 0, /* sq_ass_item, x[i]=v */
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200882 0, /* sq_ass_slice, x[i:j]=v */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200883 0, /* sq_contains */
884 0, /* sq_inplace_concat */
885 0, /* sq_inplace_repeat */
886};
887
888PyMappingMethods BufferAsMapping = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200889 /* mp_length */ (lenfunc)BufferLength,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200890 /* mp_subscript */ (binaryfunc)BufferSubscript,
Bram Moolenaar19e60942011-06-19 00:27:51 +0200891 /* mp_ass_subscript */ (objobjargproc)BufferAsSubscript,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200892};
893
894
895/* Buffer object - Definitions
896 */
897
898static PyTypeObject BufferType;
899
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200900 static PyObject *
901BufferNew(buf_T *buf)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200902{
903 /* We need to handle deletion of buffers underneath us.
904 * If we add a "b_python3_ref" field to the buf_T structure,
905 * then we can get at it in buf_freeall() in vim. We then
906 * need to create only ONE Python object per buffer - if
907 * we try to create a second, just INCREF the existing one
908 * and return it. The (single) Python object referring to
909 * the buffer is stored in "b_python3_ref".
910 * Question: what to do on a buf_freeall(). We'll probably
911 * have to either delete the Python object (DECREF it to
912 * zero - a bad idea, as it leaves dangling refs!) or
913 * set the buf_T * value to an invalid value (-1?), which
914 * means we need checks in all access functions... Bah.
915 */
916
917 BufferObject *self;
918
919 if (buf->b_python3_ref != NULL)
920 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200921 self = buf->b_python3_ref;
922 Py_INCREF(self);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200923 }
924 else
925 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200926 self = PyObject_NEW(BufferObject, &BufferType);
927 buf->b_python3_ref = self;
928 if (self == NULL)
929 return NULL;
930 self->buf = buf;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200931 }
932
933 return (PyObject *)(self);
934}
935
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200936 static void
937BufferDestructor(PyObject *self)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200938{
939 BufferObject *this = (BufferObject *)(self);
940
941 if (this->buf && this->buf != INVALID_BUFFER_VALUE)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200942 this->buf->b_python3_ref = NULL;
Bram Moolenaar19e60942011-06-19 00:27:51 +0200943
944 Py_TYPE(self)->tp_free((PyObject*)self);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200945}
946
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200947 static PyObject *
948BufferGetattro(PyObject *self, PyObject*nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200949{
950 BufferObject *this = (BufferObject *)(self);
951
952 char *name = "";
953 if (PyUnicode_Check(nameobj))
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200954 name = _PyUnicode_AsString(nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200955
956 if (CheckBuffer(this))
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200957 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200958
959 if (strcmp(name, "name") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200960 return Py_BuildValue("s", this->buf->b_ffname);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200961 else if (strcmp(name, "number") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200962 return Py_BuildValue("n", this->buf->b_fnum);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200963 else if (strcmp(name,"__members__") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200964 return Py_BuildValue("[ss]", "name", "number");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200965 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200966 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200967}
968
Bram Moolenaar170bf1a2010-07-24 23:51:45 +0200969 static PyObject *
970BufferRepr(PyObject *self)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200971{
972 static char repr[100];
973 BufferObject *this = (BufferObject *)(self);
974
975 if (this->buf == INVALID_BUFFER_VALUE)
976 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200977 vim_snprintf(repr, 100, _("<buffer object (deleted) at %p>"), (self));
978 return PyUnicode_FromString(repr);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200979 }
980 else
981 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200982 char *name = (char *)this->buf->b_fname;
983 Py_ssize_t len;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200984
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200985 if (name == NULL)
986 name = "";
987 len = strlen(name);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200988
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200989 if (len > 35)
990 name = name + (35 - len);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200991
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200992 vim_snprintf(repr, 100, "<buffer %s%s>", len > 35 ? "..." : "", name);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200993
Bram Moolenaar55d5c032010-07-17 23:52:29 +0200994 return PyUnicode_FromString(repr);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +0200995 }
996}
997
998/******************/
999
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001000 static Py_ssize_t
1001BufferLength(PyObject *self)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001002{
1003 if (CheckBuffer((BufferObject *)(self)))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001004 return -1;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001005
1006 return (Py_ssize_t)(((BufferObject *)(self))->buf->b_ml.ml_line_count);
1007}
1008
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001009 static PyObject *
1010BufferItem(PyObject *self, Py_ssize_t n)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001011{
1012 return RBItem((BufferObject *)(self), n, 1,
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001013 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001014}
1015
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001016 static PyObject *
1017BufferSlice(PyObject *self, Py_ssize_t lo, Py_ssize_t hi)
1018{
1019 return RBSlice((BufferObject *)(self), lo, hi, 1,
1020 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count);
1021}
1022
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001023 static PyObject *
1024BufferSubscript(PyObject *self, PyObject* idx)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001025{
1026 if (PyLong_Check(idx)) {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001027 long _idx = PyLong_AsLong(idx);
1028 return BufferItem(self,_idx);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001029 } else if (PySlice_Check(idx)) {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001030 Py_ssize_t start, stop, step, slicelen;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001031
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001032 if (PySlice_GetIndicesEx((PySliceObject *)idx,
1033 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count+1,
1034 &start, &stop,
1035 &step, &slicelen) < 0) {
1036 return NULL;
1037 }
Bram Moolenaar19e60942011-06-19 00:27:51 +02001038 return BufferSlice(self,start,stop);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001039 } else {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001040 PyErr_SetString(PyExc_IndexError, "Index must be int or slice");
1041 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001042 }
1043}
1044
Bram Moolenaar19e60942011-06-19 00:27:51 +02001045 static Py_ssize_t
1046BufferAsSubscript(PyObject *self, PyObject* idx, PyObject* val)
1047{
1048 if (PyLong_Check(idx)) {
1049 long n = PyLong_AsLong(idx);
1050 return RBAsItem((BufferObject *)(self), n, val, 1,
1051 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count,
1052 NULL);
1053 } else if (PySlice_Check(idx)) {
1054 Py_ssize_t start, stop, step, slicelen;
1055
1056 if (PySlice_GetIndicesEx((PySliceObject *)idx,
1057 (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count+1,
1058 &start, &stop,
1059 &step, &slicelen) < 0) {
1060 return -1;
1061 }
1062 return RBAsSlice((BufferObject *)(self), start, stop, val, 1,
1063 (PyInt)((BufferObject *)(self))->buf->b_ml.ml_line_count,
1064 NULL);
1065 } else {
1066 PyErr_SetString(PyExc_IndexError, "Index must be int or slice");
1067 return -1;
1068 }
1069}
1070
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001071static PySequenceMethods RangeAsSeq = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001072 (lenfunc) RangeLength, /* sq_length, len(x) */
1073 (binaryfunc) 0, /* RangeConcat, sq_concat, x+y */
1074 (ssizeargfunc) 0, /* RangeRepeat, sq_repeat, x*n */
1075 (ssizeargfunc) RangeItem, /* sq_item, x[i] */
1076 0, /* was_sq_slice, x[i:j] */
1077 (ssizeobjargproc) RangeAsItem, /* sq_as_item, x[i]=v */
1078 0, /* sq_ass_slice, x[i:j]=v */
1079 0, /* sq_contains */
1080 0, /* sq_inplace_concat */
1081 0, /* sq_inplace_repeat */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001082};
1083
1084PyMappingMethods RangeAsMapping = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001085 /* mp_length */ (lenfunc)RangeLength,
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001086 /* mp_subscript */ (binaryfunc)RangeSubscript,
1087 /* mp_ass_subscript */ (objobjargproc)0,
1088};
1089
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001090/* Line range object - Implementation
1091 */
1092
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001093 static void
1094RangeDestructor(PyObject *self)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001095{
1096 Py_DECREF(((RangeObject *)(self))->buf);
Bram Moolenaar19e60942011-06-19 00:27:51 +02001097 Py_TYPE(self)->tp_free((PyObject*)self);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001098}
1099
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001100 static PyObject *
1101RangeGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001102{
1103 char *name = "";
1104 if (PyUnicode_Check(nameobj))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001105 name = _PyUnicode_AsString(nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001106
1107 if (strcmp(name, "start") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001108 return Py_BuildValue("n", ((RangeObject *)(self))->start - 1);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001109 else if (strcmp(name, "end") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001110 return Py_BuildValue("n", ((RangeObject *)(self))->end - 1);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001111 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001112 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001113}
1114
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001115/****************/
1116
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001117 static Py_ssize_t
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001118RangeAsItem(PyObject *self, Py_ssize_t n, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001119{
1120 return RBAsItem(((RangeObject *)(self))->buf, n, val,
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001121 ((RangeObject *)(self))->start,
1122 ((RangeObject *)(self))->end,
1123 &((RangeObject *)(self))->end);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001124}
1125
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001126 static PyObject *
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001127RangeSubscript(PyObject *self, PyObject* idx)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001128{
1129 if (PyLong_Check(idx)) {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001130 long _idx = PyLong_AsLong(idx);
1131 return RangeItem(self,_idx);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001132 } else if (PySlice_Check(idx)) {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001133 Py_ssize_t start, stop, step, slicelen;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001134
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001135 if (PySlice_GetIndicesEx((PySliceObject *)idx,
1136 ((RangeObject *)(self))->end-((RangeObject *)(self))->start+1,
1137 &start, &stop,
1138 &step, &slicelen) < 0) {
1139 return NULL;
1140 }
1141 return RangeSlice(self,start,stop+1);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001142 } else {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001143 PyErr_SetString(PyExc_IndexError, "Index must be int or slice");
1144 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001145 }
1146}
1147
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001148/* Buffer list object - Definitions
1149 */
1150
1151typedef struct
1152{
1153 PyObject_HEAD
Bram Moolenaarca8a4df2010-07-31 19:54:14 +02001154} BufListObject;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001155
1156static PySequenceMethods BufListAsSeq = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001157 (lenfunc) BufListLength, /* sq_length, len(x) */
1158 (binaryfunc) 0, /* sq_concat, x+y */
1159 (ssizeargfunc) 0, /* sq_repeat, x*n */
1160 (ssizeargfunc) BufListItem, /* sq_item, x[i] */
1161 0, /* was_sq_slice, x[i:j] */
1162 (ssizeobjargproc) 0, /* sq_as_item, x[i]=v */
1163 0, /* sq_ass_slice, x[i:j]=v */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001164 0, /* sq_contains */
1165 0, /* sq_inplace_concat */
1166 0, /* sq_inplace_repeat */
1167};
1168
1169static PyTypeObject BufListType;
1170
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001171/* Window object - Definitions
1172 */
1173
1174static struct PyMethodDef WindowMethods[] = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001175 /* name, function, calling, documentation */
1176 { NULL, NULL, 0, NULL }
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001177};
1178
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001179static PyTypeObject WindowType;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001180
1181/* Window object - Implementation
1182 */
1183
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001184 static PyObject *
1185WindowNew(win_T *win)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001186{
1187 /* We need to handle deletion of windows underneath us.
1188 * If we add a "w_python3_ref" field to the win_T structure,
1189 * then we can get at it in win_free() in vim. We then
1190 * need to create only ONE Python object per window - if
1191 * we try to create a second, just INCREF the existing one
1192 * and return it. The (single) Python object referring to
1193 * the window is stored in "w_python3_ref".
1194 * On a win_free() we set the Python object's win_T* field
1195 * to an invalid value. We trap all uses of a window
1196 * object, and reject them if the win_T* field is invalid.
1197 */
1198
1199 WindowObject *self;
1200
1201 if (win->w_python3_ref)
1202 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001203 self = win->w_python3_ref;
1204 Py_INCREF(self);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001205 }
1206 else
1207 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001208 self = PyObject_NEW(WindowObject, &WindowType);
1209 if (self == NULL)
1210 return NULL;
1211 self->win = win;
1212 win->w_python3_ref = self;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001213 }
1214
1215 return (PyObject *)(self);
1216}
1217
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001218 static void
1219WindowDestructor(PyObject *self)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001220{
1221 WindowObject *this = (WindowObject *)(self);
1222
1223 if (this->win && this->win != INVALID_WINDOW_VALUE)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001224 this->win->w_python3_ref = NULL;
Bram Moolenaar19e60942011-06-19 00:27:51 +02001225
1226 Py_TYPE(self)->tp_free((PyObject*)self);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001227}
1228
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001229 static PyObject *
1230WindowGetattro(PyObject *self, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001231{
1232 WindowObject *this = (WindowObject *)(self);
1233
1234 char *name = "";
1235 if (PyUnicode_Check(nameobj))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001236 name = _PyUnicode_AsString(nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001237
1238
1239 if (CheckWindow(this))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001240 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001241
1242 if (strcmp(name, "buffer") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001243 return (PyObject *)BufferNew(this->win->w_buffer);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001244 else if (strcmp(name, "cursor") == 0)
1245 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001246 pos_T *pos = &this->win->w_cursor;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001247
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001248 return Py_BuildValue("(ll)", (long)(pos->lnum), (long)(pos->col));
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001249 }
1250 else if (strcmp(name, "height") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001251 return Py_BuildValue("l", (long)(this->win->w_height));
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001252#ifdef FEAT_VERTSPLIT
1253 else if (strcmp(name, "width") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001254 return Py_BuildValue("l", (long)(W_WIDTH(this->win)));
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001255#endif
1256 else if (strcmp(name,"__members__") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001257 return Py_BuildValue("[sss]", "buffer", "cursor", "height");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001258 else
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001259 return PyObject_GenericGetAttr(self, nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001260}
1261
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001262 static int
1263WindowSetattro(PyObject *self, PyObject *nameobj, PyObject *val)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001264{
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001265 char *name = "";
Bram Moolenaarca8a4df2010-07-31 19:54:14 +02001266
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001267 if (PyUnicode_Check(nameobj))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001268 name = _PyUnicode_AsString(nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001269
Bram Moolenaarca8a4df2010-07-31 19:54:14 +02001270 return WindowSetattr(self, name, val);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001271}
1272
1273/* Window list object - Definitions
1274 */
1275
1276typedef struct
1277{
1278 PyObject_HEAD
1279}
1280WinListObject;
1281
1282static PySequenceMethods WinListAsSeq = {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001283 (lenfunc) WinListLength, /* sq_length, len(x) */
1284 (binaryfunc) 0, /* sq_concat, x+y */
1285 (ssizeargfunc) 0, /* sq_repeat, x*n */
1286 (ssizeargfunc) WinListItem, /* sq_item, x[i] */
1287 0, /* sq_slice, x[i:j] */
1288 (ssizeobjargproc)0, /* sq_as_item, x[i]=v */
1289 0, /* sq_ass_slice, x[i:j]=v */
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001290 0, /* sq_contains */
1291 0, /* sq_inplace_concat */
1292 0, /* sq_inplace_repeat */
1293};
1294
1295static PyTypeObject WinListType;
1296
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001297/* Current items object - Definitions
1298 */
1299
1300typedef struct
1301{
1302 PyObject_HEAD
Bram Moolenaarca8a4df2010-07-31 19:54:14 +02001303} CurrentObject;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001304
1305static PyTypeObject CurrentType;
1306
1307/* Current items object - Implementation
1308 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001309 static PyObject *
1310CurrentGetattro(PyObject *self UNUSED, PyObject *nameobj)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001311{
1312 char *name = "";
1313 if (PyUnicode_Check(nameobj))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001314 name = _PyUnicode_AsString(nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001315
1316 if (strcmp(name, "buffer") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001317 return (PyObject *)BufferNew(curbuf);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001318 else if (strcmp(name, "window") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001319 return (PyObject *)WindowNew(curwin);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001320 else if (strcmp(name, "line") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001321 return GetBufferLine(curbuf, (Py_ssize_t)curwin->w_cursor.lnum);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001322 else if (strcmp(name, "range") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001323 return RangeNew(curbuf, RangeStart, RangeEnd);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001324 else if (strcmp(name,"__members__") == 0)
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001325 return Py_BuildValue("[ssss]", "buffer", "window", "line", "range");
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001326 else
1327 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001328 PyErr_SetString(PyExc_AttributeError, name);
1329 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001330 }
1331}
1332
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001333 static int
1334CurrentSetattro(PyObject *self UNUSED, PyObject *nameobj, PyObject *value)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001335{
1336 char *name = "";
1337 if (PyUnicode_Check(nameobj))
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001338 name = _PyUnicode_AsString(nameobj);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001339
1340 if (strcmp(name, "line") == 0)
1341 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001342 if (SetBufferLine(curbuf, (Py_ssize_t)curwin->w_cursor.lnum, value, NULL) == FAIL)
1343 return -1;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001344
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001345 return 0;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001346 }
1347 else
1348 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001349 PyErr_SetString(PyExc_AttributeError, name);
1350 return -1;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001351 }
1352}
1353
1354/* External interface
1355 */
1356
1357 void
1358python3_buffer_free(buf_T *buf)
1359{
1360 if (buf->b_python3_ref != NULL)
1361 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001362 BufferObject *bp = buf->b_python3_ref;
1363 bp->buf = INVALID_BUFFER_VALUE;
1364 buf->b_python3_ref = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001365 }
1366}
1367
1368#if defined(FEAT_WINDOWS) || defined(PROTO)
1369 void
1370python3_window_free(win_T *win)
1371{
1372 if (win->w_python3_ref != NULL)
1373 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001374 WindowObject *wp = win->w_python3_ref;
1375 wp->win = INVALID_WINDOW_VALUE;
1376 win->w_python3_ref = NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001377 }
1378}
1379#endif
1380
1381static BufListObject TheBufferList =
1382{
1383 PyObject_HEAD_INIT(&BufListType)
1384};
1385
1386static WinListObject TheWindowList =
1387{
1388 PyObject_HEAD_INIT(&WinListType)
1389};
1390
1391static CurrentObject TheCurrent =
1392{
1393 PyObject_HEAD_INIT(&CurrentType)
1394};
1395
1396PyDoc_STRVAR(vim_module_doc,"vim python interface\n");
1397
1398static struct PyModuleDef vimmodule;
1399
Bram Moolenaar69154f22010-07-18 21:42:34 +02001400#ifndef PROTO
1401PyMODINIT_FUNC Py3Init_vim(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001402{
1403 PyObject *mod;
1404 /* The special value is removed from sys.path in Python3_Init(). */
1405 static wchar_t *(argv[2]) = {L"/must>not&exist/foo", NULL};
1406
1407 PyType_Ready(&BufferType);
1408 PyType_Ready(&RangeType);
1409 PyType_Ready(&WindowType);
1410 PyType_Ready(&BufListType);
1411 PyType_Ready(&WinListType);
1412 PyType_Ready(&CurrentType);
1413
1414 /* Set sys.argv[] to avoid a crash in warn(). */
1415 PySys_SetArgv(1, argv);
1416
1417 mod = PyModule_Create(&vimmodule);
Bram Moolenaar19e60942011-06-19 00:27:51 +02001418 if (mod == NULL)
1419 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001420
Bram Moolenaar19e60942011-06-19 00:27:51 +02001421 VimError = PyErr_NewException("vim.error", NULL, NULL);
1422 Py_INCREF(VimError);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001423
1424 PyModule_AddObject(mod, "error", VimError);
1425 Py_INCREF((PyObject *)(void *)&TheBufferList);
1426 PyModule_AddObject(mod, "buffers", (PyObject *)(void *)&TheBufferList);
1427 Py_INCREF((PyObject *)(void *)&TheCurrent);
1428 PyModule_AddObject(mod, "current", (PyObject *)(void *)&TheCurrent);
1429 Py_INCREF((PyObject *)(void *)&TheWindowList);
1430 PyModule_AddObject(mod, "windows", (PyObject *)(void *)&TheWindowList);
1431
1432 if (PyErr_Occurred())
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001433 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001434
1435 return mod;
1436}
Bram Moolenaar69154f22010-07-18 21:42:34 +02001437#endif
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001438
1439/*************************************************************************
1440 * 4. Utility functions for handling the interface between Vim and Python.
1441 */
1442
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001443/* Convert a Vim line into a Python string.
1444 * All internal newlines are replaced by null characters.
1445 *
1446 * On errors, the Python exception data is set, and NULL is returned.
1447 */
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001448 static PyObject *
1449LineToString(const char *str)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001450{
1451 PyObject *result;
1452 Py_ssize_t len = strlen(str);
1453 char *tmp,*p;
1454
1455 tmp = (char *)alloc((unsigned)(len+1));
1456 p = tmp;
1457 if (p == NULL)
1458 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001459 PyErr_NoMemory();
1460 return NULL;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001461 }
1462
1463 while (*str)
1464 {
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001465 if (*str == '\n')
1466 *p = '\0';
1467 else
1468 *p = *str;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001469
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001470 ++p;
1471 ++str;
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001472 }
1473 *p = '\0';
1474
Bram Moolenaar3d64a312011-07-15 15:54:44 +02001475 result = PyUnicode_Decode(tmp, len, (char *)ENC_OPT, CODEC_ERROR_HANDLER);
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001476
1477 vim_free(tmp);
1478 return result;
1479}
1480
Bram Moolenaar170bf1a2010-07-24 23:51:45 +02001481 static void
1482init_structs(void)
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001483{
1484 vim_memset(&OutputType, 0, sizeof(OutputType));
1485 OutputType.tp_name = "vim.message";
1486 OutputType.tp_basicsize = sizeof(OutputObject);
1487 OutputType.tp_getattro = OutputGetattro;
1488 OutputType.tp_setattro = OutputSetattro;
1489 OutputType.tp_flags = Py_TPFLAGS_DEFAULT;
1490 OutputType.tp_doc = "vim message object";
1491 OutputType.tp_methods = OutputMethods;
1492 OutputType.tp_alloc = call_PyType_GenericAlloc;
1493 OutputType.tp_new = call_PyType_GenericNew;
1494 OutputType.tp_free = call_PyObject_Free;
1495
1496 vim_memset(&BufferType, 0, sizeof(BufferType));
1497 BufferType.tp_name = "vim.buffer";
1498 BufferType.tp_basicsize = sizeof(BufferType);
1499 BufferType.tp_dealloc = BufferDestructor;
1500 BufferType.tp_repr = BufferRepr;
1501 BufferType.tp_as_sequence = &BufferAsSeq;
1502 BufferType.tp_as_mapping = &BufferAsMapping;
1503 BufferType.tp_getattro = BufferGetattro;
1504 BufferType.tp_flags = Py_TPFLAGS_DEFAULT;
1505 BufferType.tp_doc = "vim buffer object";
1506 BufferType.tp_methods = BufferMethods;
1507 BufferType.tp_alloc = call_PyType_GenericAlloc;
1508 BufferType.tp_new = call_PyType_GenericNew;
1509 BufferType.tp_free = call_PyObject_Free;
1510
Bram Moolenaar55d5c032010-07-17 23:52:29 +02001511 vim_memset(&WindowType, 0, sizeof(WindowType));
1512 WindowType.tp_name = "vim.window";
1513 WindowType.tp_basicsize = sizeof(WindowObject);
1514 WindowType.tp_dealloc = WindowDestructor;
1515 WindowType.tp_repr = WindowRepr;
1516 WindowType.tp_getattro = WindowGetattro;
1517 WindowType.tp_setattro = WindowSetattro;
1518 WindowType.tp_flags = Py_TPFLAGS_DEFAULT;
1519 WindowType.tp_doc = "vim Window object";
1520 WindowType.tp_methods = WindowMethods;
1521 WindowType.tp_alloc = call_PyType_GenericAlloc;
1522 WindowType.tp_new = call_PyType_GenericNew;
1523 WindowType.tp_free = call_PyObject_Free;
1524
Bram Moolenaarbd5e15f2010-07-17 21:19:38 +02001525 vim_memset(&BufListType, 0, sizeof(BufListType));
1526 BufListType.tp_name = "vim.bufferlist";
1527 BufListType.tp_basicsize = sizeof(BufListObject);
1528 BufListType.tp_as_sequence = &BufListAsSeq;
1529 BufListType.tp_flags = Py_TPFLAGS_DEFAULT;
1530 BufferType.tp_doc = "vim buffer list";
1531
1532 vim_memset(&WinListType, 0, sizeof(WinListType));
1533 WinListType.tp_name = "vim.windowlist";
1534 WinListType.tp_basicsize = sizeof(WinListType);
1535 WinListType.tp_as_sequence = &WinListAsSeq;
1536 WinListType.tp_flags = Py_TPFLAGS_DEFAULT;
1537 WinListType.tp_doc = "vim window list";
1538
1539 vim_memset(&RangeType, 0, sizeof(RangeType));
1540 RangeType.tp_name = "vim.range";
1541 RangeType.tp_basicsize = sizeof(RangeObject);
1542 RangeType.tp_dealloc = RangeDestructor;
1543 RangeType.tp_repr = RangeRepr;
1544 RangeType.tp_as_sequence = &RangeAsSeq;
1545 RangeType.tp_as_mapping = &RangeAsMapping;
1546 RangeType.tp_getattro = RangeGetattro;
1547 RangeType.tp_flags = Py_TPFLAGS_DEFAULT;
1548 RangeType.tp_doc = "vim Range object";
1549 RangeType.tp_methods = RangeMethods;
1550 RangeType.tp_alloc = call_PyType_GenericAlloc;
1551 RangeType.tp_new = call_PyType_GenericNew;
1552 RangeType.tp_free = call_PyObject_Free;
1553
1554 vim_memset(&CurrentType, 0, sizeof(CurrentType));
1555 CurrentType.tp_name = "vim.currentdata";
1556 CurrentType.tp_basicsize = sizeof(CurrentObject);
1557 CurrentType.tp_getattro = CurrentGetattro;
1558 CurrentType.tp_setattro = CurrentSetattro;
1559 CurrentType.tp_flags = Py_TPFLAGS_DEFAULT;
1560 CurrentType.tp_doc = "vim current object";
1561
1562 vim_memset(&vimmodule, 0, sizeof(vimmodule));
1563 vimmodule.m_name = "vim";
1564 vimmodule.m_doc = vim_module_doc;
1565 vimmodule.m_size = -1;
1566 vimmodule.m_methods = VimMethods;
1567}