Move some common code from if_python.c and if_python3.c to if_py_both.h.
This commit is contained in:
		
							
								
								
									
										1
									
								
								Filelist
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								Filelist
									
									
									
									
									
								
							| @ -217,6 +217,7 @@ SRC_DOS_UNIX =	\ | |||||||
| 		src/if_perlsfio.c \ | 		src/if_perlsfio.c \ | ||||||
| 		src/if_python.c \ | 		src/if_python.c \ | ||||||
| 		src/if_python3.c \ | 		src/if_python3.c \ | ||||||
|  | 		src/if_py_both.h \ | ||||||
| 		src/if_ruby.c \ | 		src/if_ruby.c \ | ||||||
| 		src/if_sniff.h \ | 		src/if_sniff.h \ | ||||||
| 		src/if_tcl.c \ | 		src/if_tcl.c \ | ||||||
|  | |||||||
| @ -2517,10 +2517,10 @@ objects/py3_config.o: $(PYTHON3_CONFDIR)/config.c | |||||||
| 	$(CCC) $(PYTHON3_CFLAGS) -o $@ $(PYTHON3_CONFDIR)/config.c \ | 	$(CCC) $(PYTHON3_CFLAGS) -o $@ $(PYTHON3_CONFDIR)/config.c \ | ||||||
| 		-I$(PYTHON3_CONFDIR) -DHAVE_CONFIG_H -DNO_MAIN | 		-I$(PYTHON3_CONFDIR) -DHAVE_CONFIG_H -DNO_MAIN | ||||||
|  |  | ||||||
| objects/if_python.o: if_python.c  | objects/if_python.o: if_python.c if_py_both.h | ||||||
| 	$(CCC) $(PYTHON_CFLAGS) $(PYTHON_CFLAGS_EXTRA) -o $@ if_python.c | 	$(CCC) $(PYTHON_CFLAGS) $(PYTHON_CFLAGS_EXTRA) -o $@ if_python.c | ||||||
|  |  | ||||||
| objects/if_python3.o: if_python3.c  | objects/if_python3.o: if_python3.c if_py_both.h | ||||||
| 	$(CCC) $(PYTHON3_CFLAGS) $(PYTHON3_CFLAGS_EXTRA) -o $@ if_python3.c | 	$(CCC) $(PYTHON3_CFLAGS) $(PYTHON3_CFLAGS_EXTRA) -o $@ if_python3.c | ||||||
|  |  | ||||||
| objects/if_ruby.o: if_ruby.c | objects/if_ruby.o: if_ruby.c | ||||||
|  | |||||||
							
								
								
									
										256
									
								
								src/if_py_both.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										256
									
								
								src/if_py_both.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,256 @@ | |||||||
|  | /* vi:set ts=8 sts=4 sw=4: | ||||||
|  |  * | ||||||
|  |  * VIM - Vi IMproved	by Bram Moolenaar | ||||||
|  |  * | ||||||
|  |  * Do ":help uganda"  in Vim to read copying and usage conditions. | ||||||
|  |  * Do ":help credits" in Vim to see a list of people who contributed. | ||||||
|  |  * See README.txt for an overview of the Vim source code. | ||||||
|  |  */ | ||||||
|  | /* | ||||||
|  |  * Python extensions by Paul Moore, David Leonard, Roland Puntaier. | ||||||
|  |  * | ||||||
|  |  * Common code for if_python.c and if_python3.c. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * obtain a lock on the Vim data structures | ||||||
|  |  */ | ||||||
|  |     static void | ||||||
|  | Python_Lock_Vim(void) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * release a lock on the Vim data structures | ||||||
|  |  */ | ||||||
|  |     static void | ||||||
|  | Python_Release_Vim(void) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* Output object definition | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | static PyObject *OutputWrite(PyObject *, PyObject *); | ||||||
|  | static PyObject *OutputWritelines(PyObject *, PyObject *); | ||||||
|  |  | ||||||
|  | typedef void (*writefn)(char_u *); | ||||||
|  | static void writer(writefn fn, char_u *str, PyInt n); | ||||||
|  |  | ||||||
|  | typedef struct | ||||||
|  | { | ||||||
|  |     PyObject_HEAD | ||||||
|  |     long softspace; | ||||||
|  |     long error; | ||||||
|  | } OutputObject; | ||||||
|  |  | ||||||
|  | static struct PyMethodDef OutputMethods[] = { | ||||||
|  |     /* name,	    function,		calling,    documentation */ | ||||||
|  |     {"write",	    OutputWrite,	1,	    "" }, | ||||||
|  |     {"writelines",  OutputWritelines,	1,	    "" }, | ||||||
|  |     { NULL,	    NULL,		0,	    NULL } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /*************/ | ||||||
|  |  | ||||||
|  | /* Output buffer management | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |     static PyObject * | ||||||
|  | OutputWrite(PyObject *self, PyObject *args) | ||||||
|  | { | ||||||
|  |     int len; | ||||||
|  |     char *str; | ||||||
|  |     int error = ((OutputObject *)(self))->error; | ||||||
|  |  | ||||||
|  |     if (!PyArg_ParseTuple(args, "s#", &str, &len)) | ||||||
|  | 	return NULL; | ||||||
|  |  | ||||||
|  |     Py_BEGIN_ALLOW_THREADS | ||||||
|  |     Python_Lock_Vim(); | ||||||
|  |     writer((writefn)(error ? emsg : msg), (char_u *)str, len); | ||||||
|  |     Python_Release_Vim(); | ||||||
|  |     Py_END_ALLOW_THREADS | ||||||
|  |  | ||||||
|  |     Py_INCREF(Py_None); | ||||||
|  |     return Py_None; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |     static PyObject * | ||||||
|  | OutputWritelines(PyObject *self, PyObject *args) | ||||||
|  | { | ||||||
|  |     PyInt n; | ||||||
|  |     PyInt i; | ||||||
|  |     PyObject *list; | ||||||
|  |     int error = ((OutputObject *)(self))->error; | ||||||
|  |  | ||||||
|  |     if (!PyArg_ParseTuple(args, "O", &list)) | ||||||
|  | 	return NULL; | ||||||
|  |     Py_INCREF(list); | ||||||
|  |  | ||||||
|  |     if (!PyList_Check(list)) { | ||||||
|  | 	PyErr_SetString(PyExc_TypeError, _("writelines() requires list of strings")); | ||||||
|  | 	Py_DECREF(list); | ||||||
|  | 	return NULL; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     n = PyList_Size(list); | ||||||
|  |  | ||||||
|  |     for (i = 0; i < n; ++i) | ||||||
|  |     { | ||||||
|  | 	PyObject *line = PyList_GetItem(list, i); | ||||||
|  | 	char *str; | ||||||
|  | 	PyInt len; | ||||||
|  |  | ||||||
|  | 	if (!PyArg_Parse(line, "s#", &str, &len)) { | ||||||
|  | 	    PyErr_SetString(PyExc_TypeError, _("writelines() requires list of strings")); | ||||||
|  | 	    Py_DECREF(list); | ||||||
|  | 	    return NULL; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	Py_BEGIN_ALLOW_THREADS | ||||||
|  | 	Python_Lock_Vim(); | ||||||
|  | 	writer((writefn)(error ? emsg : msg), (char_u *)str, len); | ||||||
|  | 	Python_Release_Vim(); | ||||||
|  | 	Py_END_ALLOW_THREADS | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Py_DECREF(list); | ||||||
|  |     Py_INCREF(Py_None); | ||||||
|  |     return Py_None; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | static char_u *buffer = NULL; | ||||||
|  | static PyInt buffer_len = 0; | ||||||
|  | static PyInt buffer_size = 0; | ||||||
|  |  | ||||||
|  | static writefn old_fn = NULL; | ||||||
|  |  | ||||||
|  |     static void | ||||||
|  | buffer_ensure(PyInt n) | ||||||
|  | { | ||||||
|  |     PyInt new_size; | ||||||
|  |     char_u *new_buffer; | ||||||
|  |  | ||||||
|  |     if (n < buffer_size) | ||||||
|  | 	return; | ||||||
|  |  | ||||||
|  |     new_size = buffer_size; | ||||||
|  |     while (new_size < n) | ||||||
|  | 	new_size += 80; | ||||||
|  |  | ||||||
|  |     if (new_size != buffer_size) | ||||||
|  |     { | ||||||
|  | 	new_buffer = alloc((unsigned)new_size); | ||||||
|  | 	if (new_buffer == NULL) | ||||||
|  | 	    return; | ||||||
|  |  | ||||||
|  | 	if (buffer) | ||||||
|  | 	{ | ||||||
|  | 	    memcpy(new_buffer, buffer, buffer_len); | ||||||
|  | 	    vim_free(buffer); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	buffer = new_buffer; | ||||||
|  | 	buffer_size = new_size; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  |     static void | ||||||
|  | PythonIO_Flush(void) | ||||||
|  | { | ||||||
|  |     if (old_fn && buffer_len) | ||||||
|  |     { | ||||||
|  | 	buffer[buffer_len] = 0; | ||||||
|  | 	old_fn(buffer); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     buffer_len = 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |     static void | ||||||
|  | writer(writefn fn, char_u *str, PyInt n) | ||||||
|  | { | ||||||
|  |     char_u *ptr; | ||||||
|  |  | ||||||
|  |     if (fn != old_fn && old_fn != NULL) | ||||||
|  | 	PythonIO_Flush(); | ||||||
|  |  | ||||||
|  |     old_fn = fn; | ||||||
|  |  | ||||||
|  |     while (n > 0 && (ptr = memchr(str, '\n', n)) != NULL) | ||||||
|  |     { | ||||||
|  | 	PyInt len = ptr - str; | ||||||
|  |  | ||||||
|  | 	buffer_ensure(buffer_len + len + 1); | ||||||
|  |  | ||||||
|  | 	memcpy(buffer + buffer_len, str, len); | ||||||
|  | 	buffer_len += len; | ||||||
|  | 	buffer[buffer_len] = 0; | ||||||
|  | 	fn(buffer); | ||||||
|  | 	str = ptr + 1; | ||||||
|  | 	n -= len + 1; | ||||||
|  | 	buffer_len = 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /* Put the remaining text into the buffer for later printing */ | ||||||
|  |     buffer_ensure(buffer_len + n + 1); | ||||||
|  |     memcpy(buffer + buffer_len, str, n); | ||||||
|  |     buffer_len += n; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /***************/ | ||||||
|  |  | ||||||
|  | static PyTypeObject OutputType; | ||||||
|  |  | ||||||
|  | static OutputObject Output = | ||||||
|  | { | ||||||
|  |     PyObject_HEAD_INIT(&OutputType) | ||||||
|  |     0, | ||||||
|  |     0 | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | static OutputObject Error = | ||||||
|  | { | ||||||
|  |     PyObject_HEAD_INIT(&OutputType) | ||||||
|  |     0, | ||||||
|  |     1 | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |     static int | ||||||
|  | PythonIO_Init_io(void) | ||||||
|  | { | ||||||
|  |     PySys_SetObject("stdout", (PyObject *)(void *)&Output); | ||||||
|  |     PySys_SetObject("stderr", (PyObject *)(void *)&Error); | ||||||
|  |  | ||||||
|  |     if (PyErr_Occurred()) | ||||||
|  |     { | ||||||
|  | 	EMSG(_("E264: Python: Error initialising I/O objects")); | ||||||
|  | 	return -1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | static PyObject *VimError; | ||||||
|  |  | ||||||
|  | /* Check to see whether a Vim error has been reported, or a keyboard | ||||||
|  |  * interrupt has been detected. | ||||||
|  |  */ | ||||||
|  |     static int | ||||||
|  | VimErrorCheck(void) | ||||||
|  | { | ||||||
|  |     if (got_int) | ||||||
|  |     { | ||||||
|  | 	PyErr_SetNone(PyExc_KeyboardInterrupt); | ||||||
|  | 	return 1; | ||||||
|  |     } | ||||||
|  |     else if (did_emsg && !PyErr_Occurred()) | ||||||
|  |     { | ||||||
|  | 	PyErr_SetNone(VimError); | ||||||
|  | 	return 1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
							
								
								
									
										278
									
								
								src/if_python.c
									
									
									
									
									
								
							
							
						
						
									
										278
									
								
								src/if_python.c
									
									
									
									
									
								
							| @ -54,6 +54,8 @@ | |||||||
| #undef main /* Defined in python.h - aargh */ | #undef main /* Defined in python.h - aargh */ | ||||||
| #undef HAVE_FCNTL_H /* Clash with os_win32.h */ | #undef HAVE_FCNTL_H /* Clash with os_win32.h */ | ||||||
|  |  | ||||||
|  | static void init_structs(void); | ||||||
|  |  | ||||||
| #if !defined(FEAT_PYTHON) && defined(PROTO) | #if !defined(FEAT_PYTHON) && defined(PROTO) | ||||||
| /* Use this to be able to generate prototypes without python being used. */ | /* Use this to be able to generate prototypes without python being used. */ | ||||||
| # define PyObject Py_ssize_t | # define PyObject Py_ssize_t | ||||||
| @ -412,6 +414,12 @@ get_exceptions() | |||||||
| } | } | ||||||
| #endif /* DYNAMIC_PYTHON */ | #endif /* DYNAMIC_PYTHON */ | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Include the code shared with if_python3.c | ||||||
|  |  */ | ||||||
|  | #include "if_py_both.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| /****************************************************** | /****************************************************** | ||||||
|  * Internal function prototypes. |  * Internal function prototypes. | ||||||
|  */ |  */ | ||||||
| @ -437,8 +445,6 @@ static int InsertBufferLines(buf_T *, PyInt, PyObject *, PyInt *); | |||||||
| static PyObject *LineToString(const char *); | static PyObject *LineToString(const char *); | ||||||
| static char *StringToLine(PyObject *); | static char *StringToLine(PyObject *); | ||||||
|  |  | ||||||
| static int VimErrorCheck(void); |  | ||||||
|  |  | ||||||
| #define PyErr_SetVim(str) PyErr_SetString(VimError, str) | #define PyErr_SetVim(str) PyErr_SetString(VimError, str) | ||||||
|  |  | ||||||
| /****************************************************** | /****************************************************** | ||||||
| @ -484,20 +490,6 @@ Python_RestoreThread(void) | |||||||
|     PyEval_RestoreThread(saved_python_thread); |     PyEval_RestoreThread(saved_python_thread); | ||||||
|     saved_python_thread = NULL; |     saved_python_thread = NULL; | ||||||
| #endif | #endif | ||||||
| } |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * obtain a lock on the Vim data structures |  | ||||||
|  */ |  | ||||||
| static void Python_Lock_Vim(void) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * release a lock on the Vim data structures |  | ||||||
|  */ |  | ||||||
| static void Python_Release_Vim(void) |  | ||||||
| { |  | ||||||
| } | } | ||||||
|  |  | ||||||
|     void |     void | ||||||
| @ -550,6 +542,8 @@ Python_Init(void) | |||||||
| 	} | 	} | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | 	init_structs(); | ||||||
|  |  | ||||||
| #if !defined(MACOS) || defined(MACOS_X_UNIX) | #if !defined(MACOS) || defined(MACOS_X_UNIX) | ||||||
| 	Py_Initialize(); | 	Py_Initialize(); | ||||||
| #else | #else | ||||||
| @ -743,52 +737,6 @@ ex_pyfile(exarg_T *eap) | |||||||
| static PyObject *OutputGetattr(PyObject *, char *); | static PyObject *OutputGetattr(PyObject *, char *); | ||||||
| static int OutputSetattr(PyObject *, char *, PyObject *); | static int OutputSetattr(PyObject *, char *, PyObject *); | ||||||
|  |  | ||||||
| static PyObject *OutputWrite(PyObject *, PyObject *); |  | ||||||
| static PyObject *OutputWritelines(PyObject *, PyObject *); |  | ||||||
|  |  | ||||||
| typedef void (*writefn)(char_u *); |  | ||||||
| static void writer(writefn fn, char_u *str, PyInt n); |  | ||||||
|  |  | ||||||
| /* Output object definition |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| typedef struct |  | ||||||
| { |  | ||||||
|     PyObject_HEAD |  | ||||||
|     long softspace; |  | ||||||
|     long error; |  | ||||||
| } OutputObject; |  | ||||||
|  |  | ||||||
| static struct PyMethodDef OutputMethods[] = { |  | ||||||
|     /* name,	    function,		calling,    documentation */ |  | ||||||
|     {"write",	    OutputWrite,	1,	    "" }, |  | ||||||
|     {"writelines",  OutputWritelines,	1,	    "" }, |  | ||||||
|     { NULL,	    NULL,		0,	    NULL } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| static PyTypeObject OutputType = { |  | ||||||
| 	PyObject_HEAD_INIT(0) |  | ||||||
| 	0, |  | ||||||
| 	"message", |  | ||||||
| 	sizeof(OutputObject), |  | ||||||
| 	0, |  | ||||||
|  |  | ||||||
| 	(destructor) 0, |  | ||||||
| 	(printfunc) 0, |  | ||||||
| 	(getattrfunc) OutputGetattr, |  | ||||||
| 	(setattrfunc) OutputSetattr, |  | ||||||
| 	(cmpfunc) 0, |  | ||||||
| 	(reprfunc) 0, |  | ||||||
|  |  | ||||||
| 	0, /* as number */ |  | ||||||
| 	0, /* as sequence */ |  | ||||||
| 	0, /* as mapping */ |  | ||||||
|  |  | ||||||
| 	(hashfunc) 0, |  | ||||||
| 	(ternaryfunc) 0, |  | ||||||
| 	(reprfunc) 0 |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| /*************/ | /*************/ | ||||||
|  |  | ||||||
|     static PyObject * |     static PyObject * | ||||||
| @ -823,186 +771,15 @@ OutputSetattr(PyObject *self, char *name, PyObject *val) | |||||||
|     return -1; |     return -1; | ||||||
| } | } | ||||||
|  |  | ||||||
| /*************/ |  | ||||||
|  |  | ||||||
|     static PyObject * |  | ||||||
| OutputWrite(PyObject *self, PyObject *args) |  | ||||||
| { |  | ||||||
|     int len; |  | ||||||
|     char *str; |  | ||||||
|     int error = ((OutputObject *)(self))->error; |  | ||||||
|  |  | ||||||
|     if (!PyArg_ParseTuple(args, "s#", &str, &len)) |  | ||||||
| 	return NULL; |  | ||||||
|  |  | ||||||
|     Py_BEGIN_ALLOW_THREADS |  | ||||||
|     Python_Lock_Vim(); |  | ||||||
|     writer((writefn)(error ? emsg : msg), (char_u *)str, len); |  | ||||||
|     Python_Release_Vim(); |  | ||||||
|     Py_END_ALLOW_THREADS |  | ||||||
|  |  | ||||||
|     Py_INCREF(Py_None); |  | ||||||
|     return Py_None; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|     static PyObject * |  | ||||||
| OutputWritelines(PyObject *self, PyObject *args) |  | ||||||
| { |  | ||||||
|     PyInt n; |  | ||||||
|     PyInt i; |  | ||||||
|     PyObject *list; |  | ||||||
|     int error = ((OutputObject *)(self))->error; |  | ||||||
|  |  | ||||||
|     if (!PyArg_ParseTuple(args, "O", &list)) |  | ||||||
| 	return NULL; |  | ||||||
|     Py_INCREF(list); |  | ||||||
|  |  | ||||||
|     if (!PyList_Check(list)) { |  | ||||||
| 	PyErr_SetString(PyExc_TypeError, _("writelines() requires list of strings")); |  | ||||||
| 	Py_DECREF(list); |  | ||||||
| 	return NULL; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     n = PyList_Size(list); |  | ||||||
|  |  | ||||||
|     for (i = 0; i < n; ++i) |  | ||||||
|     { |  | ||||||
| 	PyObject *line = PyList_GetItem(list, i); |  | ||||||
| 	char *str; |  | ||||||
| 	PyInt len; |  | ||||||
|  |  | ||||||
| 	if (!PyArg_Parse(line, "s#", &str, &len)) { |  | ||||||
| 	    PyErr_SetString(PyExc_TypeError, _("writelines() requires list of strings")); |  | ||||||
| 	    Py_DECREF(list); |  | ||||||
| 	    return NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	Py_BEGIN_ALLOW_THREADS |  | ||||||
| 	Python_Lock_Vim(); |  | ||||||
| 	writer((writefn)(error ? emsg : msg), (char_u *)str, len); |  | ||||||
| 	Python_Release_Vim(); |  | ||||||
| 	Py_END_ALLOW_THREADS |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Py_DECREF(list); |  | ||||||
|     Py_INCREF(Py_None); |  | ||||||
|     return Py_None; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* Output buffer management |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| static char_u *buffer = NULL; |  | ||||||
| static PyInt buffer_len = 0; |  | ||||||
| static PyInt buffer_size = 0; |  | ||||||
|  |  | ||||||
| static writefn old_fn = NULL; |  | ||||||
|  |  | ||||||
|     static void |  | ||||||
| buffer_ensure(PyInt n) |  | ||||||
| { |  | ||||||
|     PyInt new_size; |  | ||||||
|     char_u *new_buffer; |  | ||||||
|  |  | ||||||
|     if (n < buffer_size) |  | ||||||
| 	return; |  | ||||||
|  |  | ||||||
|     new_size = buffer_size; |  | ||||||
|     while (new_size < n) |  | ||||||
| 	new_size += 80; |  | ||||||
|  |  | ||||||
|     if (new_size != buffer_size) |  | ||||||
|     { |  | ||||||
| 	new_buffer = alloc((unsigned)new_size); |  | ||||||
| 	if (new_buffer == NULL) |  | ||||||
| 	    return; |  | ||||||
|  |  | ||||||
| 	if (buffer) |  | ||||||
| 	{ |  | ||||||
| 	    memcpy(new_buffer, buffer, buffer_len); |  | ||||||
| 	    vim_free(buffer); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	buffer = new_buffer; |  | ||||||
| 	buffer_size = new_size; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
|     static void |  | ||||||
| PythonIO_Flush(void) |  | ||||||
| { |  | ||||||
|     if (old_fn && buffer_len) |  | ||||||
|     { |  | ||||||
| 	buffer[buffer_len] = 0; |  | ||||||
| 	old_fn(buffer); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     buffer_len = 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|     static void |  | ||||||
| writer(writefn fn, char_u *str, PyInt n) |  | ||||||
| { |  | ||||||
|     char_u *ptr; |  | ||||||
|  |  | ||||||
|     if (fn != old_fn && old_fn != NULL) |  | ||||||
| 	PythonIO_Flush(); |  | ||||||
|  |  | ||||||
|     old_fn = fn; |  | ||||||
|  |  | ||||||
|     while (n > 0 && (ptr = memchr(str, '\n', n)) != NULL) |  | ||||||
|     { |  | ||||||
| 	PyInt len = ptr - str; |  | ||||||
|  |  | ||||||
| 	buffer_ensure(buffer_len + len + 1); |  | ||||||
|  |  | ||||||
| 	memcpy(buffer + buffer_len, str, len); |  | ||||||
| 	buffer_len += len; |  | ||||||
| 	buffer[buffer_len] = 0; |  | ||||||
| 	fn(buffer); |  | ||||||
| 	str = ptr + 1; |  | ||||||
| 	n -= len + 1; |  | ||||||
| 	buffer_len = 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /* Put the remaining text into the buffer for later printing */ |  | ||||||
|     buffer_ensure(buffer_len + n + 1); |  | ||||||
|     memcpy(buffer + buffer_len, str, n); |  | ||||||
|     buffer_len += n; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /***************/ | /***************/ | ||||||
|  |  | ||||||
| static OutputObject Output = |  | ||||||
| { |  | ||||||
|     PyObject_HEAD_INIT(&OutputType) |  | ||||||
|     0, |  | ||||||
|     0 |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| static OutputObject Error = |  | ||||||
| { |  | ||||||
|     PyObject_HEAD_INIT(&OutputType) |  | ||||||
|     0, |  | ||||||
|     1 |  | ||||||
| }; |  | ||||||
|  |  | ||||||
|     static int |     static int | ||||||
| PythonIO_Init(void) | PythonIO_Init(void) | ||||||
| { | { | ||||||
|     /* Fixups... */ |     /* Fixups... */ | ||||||
|     OutputType.ob_type = &PyType_Type; |     OutputType.ob_type = &PyType_Type; | ||||||
|  |  | ||||||
|     PySys_SetObject("stdout", (PyObject *)(void *)&Output); |     return PythonIO_Init_io(); | ||||||
|     PySys_SetObject("stderr", (PyObject *)(void *)&Error); |  | ||||||
|  |  | ||||||
|     if (PyErr_Occurred()) |  | ||||||
|     { |  | ||||||
| 	EMSG(_("E264: Python: Error initialising I/O objects")); |  | ||||||
| 	return -1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /****************************************************** | /****************************************************** | ||||||
| @ -1013,8 +790,6 @@ PythonIO_Init(void) | |||||||
|  * ------------------------------------- |  * ------------------------------------- | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| static PyObject *VimError; |  | ||||||
|  |  | ||||||
| static PyObject *VimCommand(PyObject *, PyObject *); | static PyObject *VimCommand(PyObject *, PyObject *); | ||||||
| static PyObject *VimEval(PyObject *, PyObject *); | static PyObject *VimEval(PyObject *, PyObject *); | ||||||
|  |  | ||||||
| @ -1326,6 +1101,7 @@ VimEval(PyObject *self UNUSED, PyObject *args) | |||||||
| /* Common routines for buffers and line ranges | /* Common routines for buffers and line ranges | ||||||
|  * ------------------------------------------- |  * ------------------------------------------- | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|     static int |     static int | ||||||
| CheckBuffer(BufferObject *this) | CheckBuffer(BufferObject *this) | ||||||
| { | { | ||||||
| @ -3018,26 +2794,6 @@ StringToLine(PyObject *obj) | |||||||
|     return save; |     return save; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Check to see whether a Vim error has been reported, or a keyboard |  | ||||||
|  * interrupt has been detected. |  | ||||||
|  */ |  | ||||||
|     static int |  | ||||||
| VimErrorCheck(void) |  | ||||||
| { |  | ||||||
|     if (got_int) |  | ||||||
|     { |  | ||||||
| 	PyErr_SetNone(PyExc_KeyboardInterrupt); |  | ||||||
| 	return 1; |  | ||||||
|     } |  | ||||||
|     else if (did_emsg && !PyErr_Occurred()) |  | ||||||
|     { |  | ||||||
| 	PyErr_SetNone(VimError); |  | ||||||
| 	return 1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Don't generate a prototype for the next function, it generates an error on | /* Don't generate a prototype for the next function, it generates an error on | ||||||
|  * newer Python versions. */ |  * newer Python versions. */ | ||||||
| @ -3049,3 +2805,13 @@ Py_GetProgramName(void) | |||||||
|     return "vim"; |     return "vim"; | ||||||
| } | } | ||||||
| #endif /* Python 1.4 */ | #endif /* Python 1.4 */ | ||||||
|  |  | ||||||
|  |     static void | ||||||
|  | init_structs(void) | ||||||
|  | { | ||||||
|  |     vim_memset(&OutputType, 0, sizeof(OutputType)); | ||||||
|  |     OutputType.tp_name = "message"; | ||||||
|  |     OutputType.tp_basicsize = sizeof(OutputObject); | ||||||
|  |     OutputType.tp_getattr = OutputGetattr; | ||||||
|  |     OutputType.tp_setattr = OutputSetattr; | ||||||
|  | } | ||||||
|  | |||||||
							
								
								
									
										549
									
								
								src/if_python3.c
									
									
									
									
									
								
							
							
						
						
									
										549
									
								
								src/if_python3.c
									
									
									
									
									
								
							| @ -68,6 +68,8 @@ | |||||||
|  |  | ||||||
| static void init_structs(void); | static void init_structs(void); | ||||||
|  |  | ||||||
|  | #define PyInt Py_ssize_t | ||||||
|  |  | ||||||
| #if defined(DYNAMIC_PYTHON3) | #if defined(DYNAMIC_PYTHON3) | ||||||
|  |  | ||||||
| #ifndef WIN3264 | #ifndef WIN3264 | ||||||
| @ -304,7 +306,8 @@ static struct | |||||||
| /* | /* | ||||||
|  * Free python.dll |  * Free python.dll | ||||||
|  */ |  */ | ||||||
| static void end_dynamic_python3(void) |     static void | ||||||
|  | end_dynamic_python3(void) | ||||||
| { | { | ||||||
|     if (hinstPy3 != 0) |     if (hinstPy3 != 0) | ||||||
|     { |     { | ||||||
| @ -318,7 +321,8 @@ static void end_dynamic_python3(void) | |||||||
|  * Parameter 'libname' provides name of DLL. |  * Parameter 'libname' provides name of DLL. | ||||||
|  * Return OK or FAIL. |  * Return OK or FAIL. | ||||||
|  */ |  */ | ||||||
| static int py3_runtime_link_init(char *libname, int verbose) |     static int | ||||||
|  | py3_runtime_link_init(char *libname, int verbose) | ||||||
| { | { | ||||||
|     int i; |     int i; | ||||||
|     void *ucs_from_string, *ucs_from_string_and_size; |     void *ucs_from_string, *ucs_from_string_and_size; | ||||||
| @ -390,7 +394,8 @@ static int py3_runtime_link_init(char *libname, int verbose) | |||||||
|  * If python is enabled (there is installed python on Windows system) return |  * If python is enabled (there is installed python on Windows system) return | ||||||
|  * TRUE, else FALSE. |  * TRUE, else FALSE. | ||||||
|  */ |  */ | ||||||
| int python3_enabled(int verbose) |     int | ||||||
|  | python3_enabled(int verbose) | ||||||
| { | { | ||||||
|     return py3_runtime_link_init(DYNAMIC_PYTHON3_DLL, verbose) == OK; |     return py3_runtime_link_init(DYNAMIC_PYTHON3_DLL, verbose) == OK; | ||||||
| } | } | ||||||
| @ -400,7 +405,8 @@ int python3_enabled(int verbose) | |||||||
|  */ |  */ | ||||||
| static void get_py3_exceptions __ARGS((void)); | static void get_py3_exceptions __ARGS((void)); | ||||||
|  |  | ||||||
| static void get_py3_exceptions() |     static void | ||||||
|  | get_py3_exceptions() | ||||||
| { | { | ||||||
|     PyObject *exmod = PyImport_ImportModule("builtins"); |     PyObject *exmod = PyImport_ImportModule("builtins"); | ||||||
|     PyObject *exdict = PyModule_GetDict(exmod); |     PyObject *exdict = PyModule_GetDict(exmod); | ||||||
| @ -418,7 +424,13 @@ static void get_py3_exceptions() | |||||||
| } | } | ||||||
| #endif /* DYNAMIC_PYTHON3 */ | #endif /* DYNAMIC_PYTHON3 */ | ||||||
|  |  | ||||||
| static void call_PyObject_Free(void *p) | /* | ||||||
|  |  * Include the code shared with if_python.c | ||||||
|  |  */ | ||||||
|  | #include "if_py_both.h" | ||||||
|  |  | ||||||
|  |     static void | ||||||
|  | call_PyObject_Free(void *p) | ||||||
| { | { | ||||||
| #ifdef Py_DEBUG | #ifdef Py_DEBUG | ||||||
|     _PyObject_DebugFree(p); |     _PyObject_DebugFree(p); | ||||||
| @ -426,11 +438,15 @@ static void call_PyObject_Free(void *p) | |||||||
|     PyObject_Free(p); |     PyObject_Free(p); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
| static PyObject* call_PyType_GenericNew(PyTypeObject *type, PyObject *args, PyObject *kwds) |  | ||||||
|  |     static PyObject * | ||||||
|  | call_PyType_GenericNew(PyTypeObject *type, PyObject *args, PyObject *kwds) | ||||||
| { | { | ||||||
|     return PyType_GenericNew(type,args,kwds); |     return PyType_GenericNew(type,args,kwds); | ||||||
| } | } | ||||||
| static PyObject* call_PyType_GenericAlloc(PyTypeObject *type, Py_ssize_t nitems) |  | ||||||
|  |     static PyObject * | ||||||
|  | call_PyType_GenericAlloc(PyTypeObject *type, Py_ssize_t nitems) | ||||||
| { | { | ||||||
|     return PyType_GenericAlloc(type,nitems); |     return PyType_GenericAlloc(type,nitems); | ||||||
| } | } | ||||||
| @ -460,8 +476,6 @@ static PyObject *GetBufferLineList(buf_T *buf, Py_ssize_t lo, Py_ssize_t hi); | |||||||
| static PyObject *LineToString(const char *); | static PyObject *LineToString(const char *); | ||||||
| static char *StringToLine(PyObject *); | static char *StringToLine(PyObject *); | ||||||
|  |  | ||||||
| static int VimErrorCheck(void); |  | ||||||
|  |  | ||||||
| #define PyErr_SetVim(str) PyErr_SetString(VimError, str) | #define PyErr_SetVim(str) PyErr_SetString(VimError, str) | ||||||
|  |  | ||||||
| /****************************************************** | /****************************************************** | ||||||
| @ -473,21 +487,8 @@ static int py3initialised = 0; | |||||||
|  |  | ||||||
| static PyGILState_STATE pygilstate = PyGILState_UNLOCKED; | static PyGILState_STATE pygilstate = PyGILState_UNLOCKED; | ||||||
|  |  | ||||||
| /* |     void | ||||||
|  * obtain a lock on the Vim data structures | python3_end() | ||||||
|  */ |  | ||||||
| static void Python_Lock_Vim(void) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * release a lock on the Vim data structures |  | ||||||
|  */ |  | ||||||
| static void Python_Release_Vim(void) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void python3_end() |  | ||||||
| { | { | ||||||
|     static int recurse = 0; |     static int recurse = 0; | ||||||
|  |  | ||||||
| @ -524,7 +525,8 @@ python3_loaded() | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| static int Python3_Init(void) |     static int | ||||||
|  | Python3_Init(void) | ||||||
| { | { | ||||||
|     if (!py3initialised) |     if (!py3initialised) | ||||||
|     { |     { | ||||||
| @ -588,7 +590,8 @@ fail: | |||||||
| /* | /* | ||||||
|  * External interface |  * External interface | ||||||
|  */ |  */ | ||||||
| static void DoPy3Command(exarg_T *eap, const char *cmd) |     static void | ||||||
|  | DoPy3Command(exarg_T *eap, const char *cmd) | ||||||
| { | { | ||||||
| #if defined(MACOS) && !defined(MACOS_X_UNIX) | #if defined(MACOS) && !defined(MACOS_X_UNIX) | ||||||
|     GrafPtr		oldPort; |     GrafPtr		oldPort; | ||||||
| @ -650,7 +653,8 @@ theend: | |||||||
| /* | /* | ||||||
|  * ":py3" |  * ":py3" | ||||||
|  */ |  */ | ||||||
| void ex_py3(exarg_T *eap) |     void | ||||||
|  | ex_py3(exarg_T *eap) | ||||||
| { | { | ||||||
|     char_u *script; |     char_u *script; | ||||||
|  |  | ||||||
| @ -731,34 +735,10 @@ ex_py3file(exarg_T *eap) | |||||||
| static PyObject *OutputGetattro(PyObject *, PyObject *); | static PyObject *OutputGetattro(PyObject *, PyObject *); | ||||||
| static int OutputSetattro(PyObject *, PyObject *, PyObject *); | static int OutputSetattro(PyObject *, PyObject *, PyObject *); | ||||||
|  |  | ||||||
| static PyObject *OutputWrite(PyObject *, PyObject *); |  | ||||||
| static PyObject *OutputWritelines(PyObject *, PyObject *); |  | ||||||
|  |  | ||||||
| typedef void (*writefn)(char_u *); |  | ||||||
| static void writer(writefn fn, char_u *str, Py_ssize_t n); |  | ||||||
|  |  | ||||||
| /* Output object definition |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| typedef struct |  | ||||||
| { |  | ||||||
|     PyObject_HEAD |  | ||||||
|     long softspace; |  | ||||||
|     long error; |  | ||||||
| } OutputObject; |  | ||||||
|  |  | ||||||
| static struct PyMethodDef OutputMethods[] = { |  | ||||||
|     /* name,	    function,		calling,    documentation */ |  | ||||||
|     {"write",	    OutputWrite,	1,	    "" }, |  | ||||||
|     {"writelines",  OutputWritelines,	1,	    "" }, |  | ||||||
|     { NULL,	    NULL,		0,	    NULL } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| static PyTypeObject OutputType; |  | ||||||
|  |  | ||||||
| /*************/ | /*************/ | ||||||
|  |  | ||||||
| static PyObject * OutputGetattro(PyObject *self, PyObject *nameobj) |     static PyObject * | ||||||
|  | OutputGetattro(PyObject *self, PyObject *nameobj) | ||||||
| { | { | ||||||
|     char *name = ""; |     char *name = ""; | ||||||
|     if (PyUnicode_Check(nameobj)) |     if (PyUnicode_Check(nameobj)) | ||||||
| @ -770,7 +750,8 @@ static PyObject * OutputGetattro(PyObject *self, PyObject *nameobj) | |||||||
|     return PyObject_GenericGetAttr(self, nameobj); |     return PyObject_GenericGetAttr(self, nameobj); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int OutputSetattro(PyObject *self, PyObject *nameobj, PyObject *val) |     static int | ||||||
|  | OutputSetattro(PyObject *self, PyObject *nameobj, PyObject *val) | ||||||
| { | { | ||||||
|     char *name = ""; |     char *name = ""; | ||||||
|     if (PyUnicode_Check(nameobj)) |     if (PyUnicode_Check(nameobj)) | ||||||
| @ -796,181 +777,17 @@ static int OutputSetattro(PyObject *self, PyObject *nameobj, PyObject *val) | |||||||
|     return -1; |     return -1; | ||||||
| } | } | ||||||
|  |  | ||||||
| /*************/ |  | ||||||
|  |  | ||||||
| static PyObject * OutputWrite(PyObject *self, PyObject *args) |  | ||||||
| { |  | ||||||
|     int len; |  | ||||||
|     char *str; |  | ||||||
|     int error = ((OutputObject *)(self))->error; |  | ||||||
|  |  | ||||||
|     if (!PyArg_ParseTuple(args, "s#", &str, &len)) |  | ||||||
| 	return NULL; |  | ||||||
|  |  | ||||||
|     Py_BEGIN_ALLOW_THREADS |  | ||||||
|     Python_Lock_Vim(); |  | ||||||
|     writer((writefn)(error ? emsg : msg), (char_u *)str, len); |  | ||||||
|     Python_Release_Vim(); |  | ||||||
|     Py_END_ALLOW_THREADS |  | ||||||
|  |  | ||||||
|     Py_INCREF(Py_None); |  | ||||||
|     return Py_None; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static PyObject * OutputWritelines(PyObject *self, PyObject *args) |  | ||||||
| { |  | ||||||
|     Py_ssize_t n; |  | ||||||
|     Py_ssize_t i; |  | ||||||
|     PyObject *list; |  | ||||||
|     int error = ((OutputObject *)(self))->error; |  | ||||||
|  |  | ||||||
|     if (!PyArg_ParseTuple(args, "O", &list)) |  | ||||||
| 	return NULL; |  | ||||||
|     Py_INCREF(list); |  | ||||||
|  |  | ||||||
|     if (!PyList_Check(list)) { |  | ||||||
| 	PyErr_SetString(PyExc_TypeError, _("writelines() requires list of strings")); |  | ||||||
| 	Py_DECREF(list); |  | ||||||
| 	return NULL; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     n = PyList_Size(list); |  | ||||||
|  |  | ||||||
|     for (i = 0; i < n; ++i) |  | ||||||
|     { |  | ||||||
| 	PyObject *line = PyList_GetItem(list, i); |  | ||||||
| 	char *str; |  | ||||||
| 	Py_ssize_t len; |  | ||||||
|  |  | ||||||
| 	if (!PyArg_Parse(line, "s#", &str, &len)) { |  | ||||||
| 	    PyErr_SetString(PyExc_TypeError, _("writelines() requires list of strings")); |  | ||||||
| 	    Py_DECREF(list); |  | ||||||
| 	    return NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	Py_BEGIN_ALLOW_THREADS |  | ||||||
| 	    Python_Lock_Vim(); |  | ||||||
| 	writer((writefn)(error ? emsg : msg), (char_u *)str, len); |  | ||||||
| 	Python_Release_Vim(); |  | ||||||
| 	Py_END_ALLOW_THREADS |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Py_DECREF(list); |  | ||||||
|     Py_INCREF(Py_None); |  | ||||||
|     return Py_None; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* Output buffer management |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| static char_u *buffer = NULL; |  | ||||||
| static Py_ssize_t buffer_len = 0; |  | ||||||
| static Py_ssize_t buffer_size = 0; |  | ||||||
|  |  | ||||||
| static writefn old_fn = NULL; |  | ||||||
|  |  | ||||||
| static void buffer_ensure(Py_ssize_t n) |  | ||||||
| { |  | ||||||
|     Py_ssize_t new_size; |  | ||||||
|     char_u *new_buffer; |  | ||||||
|  |  | ||||||
|     if (n < buffer_size) |  | ||||||
| 	return; |  | ||||||
|  |  | ||||||
|     new_size = buffer_size; |  | ||||||
|     while (new_size < n) |  | ||||||
| 	new_size += 80; |  | ||||||
|  |  | ||||||
|     if (new_size != buffer_size) |  | ||||||
|     { |  | ||||||
| 	new_buffer = alloc((unsigned)new_size); |  | ||||||
| 	if (new_buffer == NULL) |  | ||||||
| 	    return; |  | ||||||
|  |  | ||||||
| 	if (buffer) |  | ||||||
| 	{ |  | ||||||
| 	    memcpy(new_buffer, buffer, buffer_len); |  | ||||||
| 	    vim_free(buffer); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	buffer = new_buffer; |  | ||||||
| 	buffer_size = new_size; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static void PythonIO_Flush(void) |  | ||||||
| { |  | ||||||
|     if (old_fn && buffer_len) |  | ||||||
|     { |  | ||||||
| 	buffer[buffer_len] = 0; |  | ||||||
| 	old_fn(buffer); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     buffer_len = 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static void writer(writefn fn, char_u *str, Py_ssize_t n) |  | ||||||
| { |  | ||||||
|     char_u *ptr; |  | ||||||
|  |  | ||||||
|     if (fn != old_fn && old_fn != NULL) |  | ||||||
| 	PythonIO_Flush(); |  | ||||||
|  |  | ||||||
|     old_fn = fn; |  | ||||||
|  |  | ||||||
|     while (n > 0 && (ptr = memchr(str, '\n', n)) != NULL) |  | ||||||
|     { |  | ||||||
| 	Py_ssize_t len = ptr - str; |  | ||||||
|  |  | ||||||
| 	buffer_ensure(buffer_len + len + 1); |  | ||||||
|  |  | ||||||
| 	memcpy(buffer + buffer_len, str, len); |  | ||||||
| 	buffer_len += len; |  | ||||||
| 	buffer[buffer_len] = 0; |  | ||||||
| 	fn(buffer); |  | ||||||
| 	str = ptr + 1; |  | ||||||
| 	n -= len + 1; |  | ||||||
| 	buffer_len = 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /* Put the remaining text into the buffer for later printing */ |  | ||||||
|     buffer_ensure(buffer_len + n + 1); |  | ||||||
|     memcpy(buffer + buffer_len, str, n); |  | ||||||
|     buffer_len += n; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /***************/ | /***************/ | ||||||
|  |  | ||||||
| static OutputObject Output = |     static int | ||||||
| { | PythonIO_Init(void) | ||||||
|     PyObject_HEAD_INIT(&OutputType) |  | ||||||
|     0, |  | ||||||
|     0 |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| static OutputObject Error = |  | ||||||
| { |  | ||||||
|     PyObject_HEAD_INIT(&OutputType) |  | ||||||
|     0, |  | ||||||
|     1 |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| static int PythonIO_Init(void) |  | ||||||
| { | { | ||||||
|     PyType_Ready(&OutputType); |     PyType_Ready(&OutputType); | ||||||
|  |     return PythonIO_Init_io(); | ||||||
|     PySys_SetObject("stdout", (PyObject *)(void *)&Output); |  | ||||||
|     PySys_SetObject("stderr", (PyObject *)(void *)&Error); |  | ||||||
|  |  | ||||||
|     if (PyErr_Occurred()) |  | ||||||
|     { |  | ||||||
| 	EMSG(_("E264: Python: Error initialising I/O objects")); |  | ||||||
| 	return -1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } | } | ||||||
| static void PythonIO_Fini(void) |  | ||||||
|  |     static void | ||||||
|  | PythonIO_Fini(void) | ||||||
| { | { | ||||||
|     PySys_SetObject("stdout", NULL); |     PySys_SetObject("stdout", NULL); | ||||||
|     PySys_SetObject("stderr", NULL); |     PySys_SetObject("stderr", NULL); | ||||||
| @ -984,8 +801,6 @@ static void PythonIO_Fini(void) | |||||||
|  * ------------------------------------- |  * ------------------------------------- | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| static PyObject *VimError; |  | ||||||
|  |  | ||||||
| static PyObject *VimCommand(PyObject *, PyObject *); | static PyObject *VimCommand(PyObject *, PyObject *); | ||||||
| static PyObject *VimEval(PyObject *, PyObject *); | static PyObject *VimEval(PyObject *, PyObject *); | ||||||
|  |  | ||||||
| @ -1096,15 +911,15 @@ static int CurrentSetattro(PyObject *, PyObject *, PyObject *); | |||||||
|  |  | ||||||
| static struct PyMethodDef VimMethods[] = { | static struct PyMethodDef VimMethods[] = { | ||||||
|     /* name,	     function,		calling,    documentation */ |     /* name,	     function,		calling,    documentation */ | ||||||
|     {"command",      VimCommand,	1,	    "Execute a Vim ex-mode command" }, |     {"command",	     VimCommand,	1,	    "Execute a Vim ex-mode command" }, | ||||||
|     {"eval",	     VimEval,		1,	    "Evaluate an expression using Vim evaluator" }, |     {"eval",	     VimEval,		1,	    "Evaluate an expression using Vim evaluator" }, | ||||||
|     { NULL,	     NULL,		0,	    NULL } |     { NULL,	     NULL,		0,	    NULL } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /* Vim module - Implementation | /* Vim module - Implementation | ||||||
|  */ |  */ | ||||||
| /*ARGSUSED*/ |     static PyObject * | ||||||
| static PyObject * VimCommand(PyObject *self UNUSED, PyObject *args) | VimCommand(PyObject *self UNUSED, PyObject *args) | ||||||
| { | { | ||||||
|     char *cmd; |     char *cmd; | ||||||
|     PyObject *result; |     PyObject *result; | ||||||
| @ -1140,10 +955,11 @@ static PyObject * VimCommand(PyObject *self UNUSED, PyObject *args) | |||||||
|  * The depth parameter is to avoid infinite recursion, set it to 1 when |  * The depth parameter is to avoid infinite recursion, set it to 1 when | ||||||
|  * you call VimToPython. |  * you call VimToPython. | ||||||
|  */ |  */ | ||||||
| static PyObject * VimToPython(typval_T *our_tv, int depth, PyObject *lookupDict) |     static PyObject * | ||||||
|  | VimToPython(typval_T *our_tv, int depth, PyObject *lookupDict) | ||||||
| { | { | ||||||
|     PyObject    *result; |     PyObject	*result; | ||||||
|     PyObject    *newObj; |     PyObject	*newObj; | ||||||
|     char	ptrBuf[NUMBUFLEN]; |     char	ptrBuf[NUMBUFLEN]; | ||||||
|  |  | ||||||
|     /* Avoid infinite recursion */ |     /* Avoid infinite recursion */ | ||||||
| @ -1216,18 +1032,18 @@ static PyObject * VimToPython(typval_T *our_tv, int depth, PyObject *lookupDict) | |||||||
|  |  | ||||||
| 	if (our_tv->vval.v_dict != NULL) | 	if (our_tv->vval.v_dict != NULL) | ||||||
| 	{ | 	{ | ||||||
| 	    hashtab_T   *ht = &our_tv->vval.v_dict->dv_hashtab; | 	    hashtab_T	*ht = &our_tv->vval.v_dict->dv_hashtab; | ||||||
| 	    long_u      t = ht->ht_used; | 	    long_u	todo = ht->ht_used; | ||||||
| 	    hashitem_T  *hi; | 	    hashitem_T	*hi; | ||||||
| 	    dictitem_T  *di; | 	    dictitem_T	*di; | ||||||
|  |  | ||||||
| 	    PyDict_SetItemString(lookupDict, ptrBuf, result); | 	    PyDict_SetItemString(lookupDict, ptrBuf, result); | ||||||
|  |  | ||||||
| 	    for (hi = ht->ht_array; t > 0; ++hi) | 	    for (hi = ht->ht_array; todo > 0; ++hi) | ||||||
| 	    { | 	    { | ||||||
| 		if (!HASHITEM_EMPTY(hi)) | 		if (!HASHITEM_EMPTY(hi)) | ||||||
| 		{ | 		{ | ||||||
| 		    --t; | 		    --todo; | ||||||
|  |  | ||||||
| 		    di = dict_lookup(hi); | 		    di = dict_lookup(hi); | ||||||
| 		    newObj = VimToPython(&di->di_tv, depth + 1, lookupDict); | 		    newObj = VimToPython(&di->di_tv, depth + 1, lookupDict); | ||||||
| @ -1247,13 +1063,13 @@ static PyObject * VimToPython(typval_T *our_tv, int depth, PyObject *lookupDict) | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /*ARGSUSED*/ |     static PyObject * | ||||||
| static PyObject * VimEval(PyObject *self UNUSED, PyObject *args) | VimEval(PyObject *self UNUSED, PyObject *args) | ||||||
| { | { | ||||||
| #ifdef FEAT_EVAL | #ifdef FEAT_EVAL | ||||||
|     char	*expr; |     char	*expr; | ||||||
|     typval_T    *our_tv; |     typval_T	*our_tv; | ||||||
|     PyObject    *result; |     PyObject	*result; | ||||||
|     PyObject    *lookup_dict; |     PyObject    *lookup_dict; | ||||||
|  |  | ||||||
|     if (!PyArg_ParseTuple(args, "s", &expr)) |     if (!PyArg_ParseTuple(args, "s", &expr)) | ||||||
| @ -1296,7 +1112,8 @@ static PyObject * VimEval(PyObject *self UNUSED, PyObject *args) | |||||||
|  * ------------------------------------------- |  * ------------------------------------------- | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| static int CheckBuffer(BufferObject *this) |     static int | ||||||
|  | CheckBuffer(BufferObject *this) | ||||||
| { | { | ||||||
|     if (this->buf == INVALID_BUFFER_VALUE) |     if (this->buf == INVALID_BUFFER_VALUE) | ||||||
|     { |     { | ||||||
| @ -1307,7 +1124,8 @@ static int CheckBuffer(BufferObject *this) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * RBItem(BufferObject *self, Py_ssize_t n, Py_ssize_t start, Py_ssize_t end) |     static PyObject * | ||||||
|  | RBItem(BufferObject *self, Py_ssize_t n, Py_ssize_t start, Py_ssize_t end) | ||||||
| { | { | ||||||
|     if (CheckBuffer(self)) |     if (CheckBuffer(self)) | ||||||
| 	return NULL; | 	return NULL; | ||||||
| @ -1321,29 +1139,8 @@ static PyObject * RBItem(BufferObject *self, Py_ssize_t n, Py_ssize_t start, Py_ | |||||||
|     return GetBufferLine(self->buf, n+start); |     return GetBufferLine(self->buf, n+start); | ||||||
| } | } | ||||||
|  |  | ||||||
| static Py_ssize_t RBAsItem(BufferObject *self, Py_ssize_t n, PyObject *val, Py_ssize_t start, Py_ssize_t end, Py_ssize_t *new_end) |     static PyObject * | ||||||
| { | RBSlice(BufferObject *self, Py_ssize_t lo, Py_ssize_t hi, Py_ssize_t start, Py_ssize_t end) | ||||||
|     Py_ssize_t len_change; |  | ||||||
|  |  | ||||||
|     if (CheckBuffer(self)) |  | ||||||
| 	return -1; |  | ||||||
|  |  | ||||||
|     if (n < 0 || n > end - start) |  | ||||||
|     { |  | ||||||
| 	PyErr_SetString(PyExc_IndexError, _("line number out of range")); |  | ||||||
| 	return -1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (SetBufferLine(self->buf, n+start, val, &len_change) == FAIL) |  | ||||||
| 	return -1; |  | ||||||
|  |  | ||||||
|     if (new_end) |  | ||||||
| 	*new_end = end + len_change; |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static PyObject * RBSlice(BufferObject *self, Py_ssize_t lo, Py_ssize_t hi, Py_ssize_t start, Py_ssize_t end) |  | ||||||
| { | { | ||||||
|     Py_ssize_t size; |     Py_ssize_t size; | ||||||
|  |  | ||||||
| @ -1366,7 +1163,31 @@ static PyObject * RBSlice(BufferObject *self, Py_ssize_t lo, Py_ssize_t hi, Py_s | |||||||
|     return GetBufferLineList(self->buf, lo+start, hi+start); |     return GetBufferLineList(self->buf, lo+start, hi+start); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * RBAppend(BufferObject *self, PyObject *args, Py_ssize_t start, Py_ssize_t end, Py_ssize_t *new_end) |     static Py_ssize_t | ||||||
|  | RBAsItem(BufferObject *self, Py_ssize_t n, PyObject *val, Py_ssize_t start, Py_ssize_t end, Py_ssize_t *new_end) | ||||||
|  | { | ||||||
|  |     Py_ssize_t len_change; | ||||||
|  |  | ||||||
|  |     if (CheckBuffer(self)) | ||||||
|  | 	return -1; | ||||||
|  |  | ||||||
|  |     if (n < 0 || n > end - start) | ||||||
|  |     { | ||||||
|  | 	PyErr_SetString(PyExc_IndexError, _("line number out of range")); | ||||||
|  | 	return -1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (SetBufferLine(self->buf, n+start, val, &len_change) == FAIL) | ||||||
|  | 	return -1; | ||||||
|  |  | ||||||
|  |     if (new_end) | ||||||
|  | 	*new_end = end + len_change; | ||||||
|  |  | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |     static PyObject * | ||||||
|  | RBAppend(BufferObject *self, PyObject *args, Py_ssize_t start, Py_ssize_t end, Py_ssize_t *new_end) | ||||||
| { | { | ||||||
|     PyObject *lines; |     PyObject *lines; | ||||||
|     Py_ssize_t len_change; |     Py_ssize_t len_change; | ||||||
| @ -1398,6 +1219,9 @@ static PyObject * RBAppend(BufferObject *self, PyObject *args, Py_ssize_t start, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Buffer object - Definitions | ||||||
|  |  */ | ||||||
|  |  | ||||||
| static struct PyMethodDef BufferMethods[] = { | static struct PyMethodDef BufferMethods[] = { | ||||||
|     /* name,	    function,		calling,    documentation */ |     /* name,	    function,		calling,    documentation */ | ||||||
|     {"append",	    BufferAppend,	1,	    "Append data to Vim buffer" }, |     {"append",	    BufferAppend,	1,	    "Append data to Vim buffer" }, | ||||||
| @ -1431,7 +1255,8 @@ PyMappingMethods BufferAsMapping = { | |||||||
|  |  | ||||||
| static PyTypeObject BufferType; | static PyTypeObject BufferType; | ||||||
|  |  | ||||||
| static PyObject * BufferNew(buf_T *buf) |     static PyObject * | ||||||
|  | BufferNew(buf_T *buf) | ||||||
| { | { | ||||||
|     /* We need to handle deletion of buffers underneath us. |     /* We need to handle deletion of buffers underneath us. | ||||||
|      * If we add a "b_python3_ref" field to the buf_T structure, |      * If we add a "b_python3_ref" field to the buf_T structure, | ||||||
| @ -1466,7 +1291,8 @@ static PyObject * BufferNew(buf_T *buf) | |||||||
|     return (PyObject *)(self); |     return (PyObject *)(self); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void BufferDestructor(PyObject *self) |     static void | ||||||
|  | BufferDestructor(PyObject *self) | ||||||
| { | { | ||||||
|     BufferObject *this = (BufferObject *)(self); |     BufferObject *this = (BufferObject *)(self); | ||||||
|  |  | ||||||
| @ -1474,7 +1300,8 @@ static void BufferDestructor(PyObject *self) | |||||||
| 	this->buf->b_python3_ref = NULL; | 	this->buf->b_python3_ref = NULL; | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * BufferGetattro(PyObject *self, PyObject*nameobj) |     static PyObject * | ||||||
|  | BufferGetattro(PyObject *self, PyObject*nameobj) | ||||||
| { | { | ||||||
|     BufferObject *this = (BufferObject *)(self); |     BufferObject *this = (BufferObject *)(self); | ||||||
|  |  | ||||||
| @ -1495,7 +1322,8 @@ static PyObject * BufferGetattro(PyObject *self, PyObject*nameobj) | |||||||
| 	return PyObject_GenericGetAttr(self, nameobj); | 	return PyObject_GenericGetAttr(self, nameobj); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * BufferRepr(PyObject *self) |     static PyObject * | ||||||
|  | BufferRepr(PyObject *self) | ||||||
| { | { | ||||||
|     static char repr[100]; |     static char repr[100]; | ||||||
|     BufferObject *this = (BufferObject *)(self); |     BufferObject *this = (BufferObject *)(self); | ||||||
| @ -1525,7 +1353,8 @@ static PyObject * BufferRepr(PyObject *self) | |||||||
|  |  | ||||||
| /******************/ | /******************/ | ||||||
|  |  | ||||||
| static Py_ssize_t BufferLength(PyObject *self) |     static Py_ssize_t | ||||||
|  | BufferLength(PyObject *self) | ||||||
| { | { | ||||||
|     if (CheckBuffer((BufferObject *)(self))) |     if (CheckBuffer((BufferObject *)(self))) | ||||||
| 	return -1; | 	return -1; | ||||||
| @ -1533,27 +1362,31 @@ static Py_ssize_t BufferLength(PyObject *self) | |||||||
|     return (Py_ssize_t)(((BufferObject *)(self))->buf->b_ml.ml_line_count); |     return (Py_ssize_t)(((BufferObject *)(self))->buf->b_ml.ml_line_count); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * BufferItem(PyObject *self, Py_ssize_t n) |     static PyObject * | ||||||
|  | BufferItem(PyObject *self, Py_ssize_t n) | ||||||
| { | { | ||||||
|     return RBItem((BufferObject *)(self), n, 1, |     return RBItem((BufferObject *)(self), n, 1, | ||||||
| 	       (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count); | 	       (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count); | ||||||
| } | } | ||||||
|  |  | ||||||
| static Py_ssize_t BufferAsItem(PyObject *self, Py_ssize_t n, PyObject *val) |     static PyObject * | ||||||
|  | BufferSlice(PyObject *self, Py_ssize_t lo, Py_ssize_t hi) | ||||||
|  | { | ||||||
|  |     return RBSlice((BufferObject *)(self), lo, hi, 1, | ||||||
|  | 	       (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |     static Py_ssize_t | ||||||
|  | BufferAsItem(PyObject *self, Py_ssize_t n, PyObject *val) | ||||||
| { | { | ||||||
|     return RBAsItem((BufferObject *)(self), n, val, 1, |     return RBAsItem((BufferObject *)(self), n, val, 1, | ||||||
| 		(Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count, | 		(Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count, | ||||||
| 		NULL); | 		NULL); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * BufferSlice(PyObject *self, Py_ssize_t lo, Py_ssize_t hi) |  | ||||||
| { |  | ||||||
|     return RBSlice((BufferObject *)(self), lo, hi, 1, |  | ||||||
| 	       (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |     static PyObject * | ||||||
| static PyObject* BufferSubscript(PyObject *self, PyObject* idx) | BufferSubscript(PyObject *self, PyObject* idx) | ||||||
| { | { | ||||||
|     if (PyLong_Check(idx)) { |     if (PyLong_Check(idx)) { | ||||||
| 	long _idx = PyLong_AsLong(idx); | 	long _idx = PyLong_AsLong(idx); | ||||||
| @ -1574,14 +1407,16 @@ static PyObject* BufferSubscript(PyObject *self, PyObject* idx) | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * BufferAppend(PyObject *self, PyObject *args) |     static PyObject * | ||||||
|  | BufferAppend(PyObject *self, PyObject *args) | ||||||
| { | { | ||||||
|     return RBAppend((BufferObject *)(self), args, 1, |     return RBAppend((BufferObject *)(self), args, 1, | ||||||
| 		(Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count, | 		(Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count, | ||||||
| 		NULL); | 		NULL); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * BufferMark(PyObject *self, PyObject *args) |     static PyObject * | ||||||
|  | BufferMark(PyObject *self, PyObject *args) | ||||||
| { | { | ||||||
|     pos_T       *posp; |     pos_T       *posp; | ||||||
|     char	*pmark;//test |     char	*pmark;//test | ||||||
| @ -1620,7 +1455,8 @@ static PyObject * BufferMark(PyObject *self, PyObject *args) | |||||||
|     return Py_BuildValue("(ll)", (long)(posp->lnum), (long)(posp->col)); |     return Py_BuildValue("(ll)", (long)(posp->lnum), (long)(posp->col)); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * BufferRange(PyObject *self, PyObject *args) |     static PyObject * | ||||||
|  | BufferRange(PyObject *self, PyObject *args) | ||||||
| { | { | ||||||
|     Py_ssize_t start; |     Py_ssize_t start; | ||||||
|     Py_ssize_t end; |     Py_ssize_t end; | ||||||
| @ -1667,7 +1503,8 @@ static PyTypeObject RangeType; | |||||||
| /* Line range object - Implementation | /* Line range object - Implementation | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| static PyObject * RangeNew(buf_T *buf, Py_ssize_t start, Py_ssize_t end) |     static PyObject * | ||||||
|  | RangeNew(buf_T *buf, Py_ssize_t start, Py_ssize_t end) | ||||||
| { | { | ||||||
|     BufferObject *bufr; |     BufferObject *bufr; | ||||||
|     RangeObject *self; |     RangeObject *self; | ||||||
| @ -1690,12 +1527,14 @@ static PyObject * RangeNew(buf_T *buf, Py_ssize_t start, Py_ssize_t end) | |||||||
|     return (PyObject *)(self); |     return (PyObject *)(self); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void RangeDestructor(PyObject *self) |     static void | ||||||
|  | RangeDestructor(PyObject *self) | ||||||
| { | { | ||||||
|     Py_DECREF(((RangeObject *)(self))->buf); |     Py_DECREF(((RangeObject *)(self))->buf); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * RangeGetattro(PyObject *self, PyObject *nameobj) |     static PyObject * | ||||||
|  | RangeGetattro(PyObject *self, PyObject *nameobj) | ||||||
| { | { | ||||||
|     char *name = ""; |     char *name = ""; | ||||||
|     if (PyUnicode_Check(nameobj)) |     if (PyUnicode_Check(nameobj)) | ||||||
| @ -1709,7 +1548,8 @@ static PyObject * RangeGetattro(PyObject *self, PyObject *nameobj) | |||||||
| 	return PyObject_GenericGetAttr(self, nameobj); | 	return PyObject_GenericGetAttr(self, nameobj); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * RangeRepr(PyObject *self) |     static PyObject * | ||||||
|  | RangeRepr(PyObject *self) | ||||||
| { | { | ||||||
|     static char repr[100]; |     static char repr[100]; | ||||||
|     RangeObject *this = (RangeObject *)(self); |     RangeObject *this = (RangeObject *)(self); | ||||||
| @ -1742,7 +1582,8 @@ static PyObject * RangeRepr(PyObject *self) | |||||||
|  |  | ||||||
| /****************/ | /****************/ | ||||||
|  |  | ||||||
| static Py_ssize_t RangeLength(PyObject *self) |     static Py_ssize_t | ||||||
|  | RangeLength(PyObject *self) | ||||||
| { | { | ||||||
|     /* HOW DO WE SIGNAL AN ERROR FROM THIS FUNCTION? */ |     /* HOW DO WE SIGNAL AN ERROR FROM THIS FUNCTION? */ | ||||||
|     if (CheckBuffer(((RangeObject *)(self))->buf)) |     if (CheckBuffer(((RangeObject *)(self))->buf)) | ||||||
| @ -1751,14 +1592,16 @@ static Py_ssize_t RangeLength(PyObject *self) | |||||||
|     return (((RangeObject *)(self))->end - ((RangeObject *)(self))->start + 1); |     return (((RangeObject *)(self))->end - ((RangeObject *)(self))->start + 1); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * RangeItem(PyObject *self, Py_ssize_t n) |     static PyObject * | ||||||
|  | RangeItem(PyObject *self, Py_ssize_t n) | ||||||
| { | { | ||||||
|     return RBItem(((RangeObject *)(self))->buf, n, |     return RBItem(((RangeObject *)(self))->buf, n, | ||||||
| 		  ((RangeObject *)(self))->start, | 		  ((RangeObject *)(self))->start, | ||||||
| 		  ((RangeObject *)(self))->end); | 		  ((RangeObject *)(self))->end); | ||||||
| } | } | ||||||
|  |  | ||||||
| static Py_ssize_t RangeAsItem(PyObject *self, Py_ssize_t n, PyObject *val) |     static Py_ssize_t | ||||||
|  | RangeAsItem(PyObject *self, Py_ssize_t n, PyObject *val) | ||||||
| { | { | ||||||
|     return RBAsItem(((RangeObject *)(self))->buf, n, val, |     return RBAsItem(((RangeObject *)(self))->buf, n, val, | ||||||
| 		    ((RangeObject *)(self))->start, | 		    ((RangeObject *)(self))->start, | ||||||
| @ -1766,14 +1609,16 @@ static Py_ssize_t RangeAsItem(PyObject *self, Py_ssize_t n, PyObject *val) | |||||||
| 		    &((RangeObject *)(self))->end); | 		    &((RangeObject *)(self))->end); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * RangeSlice(PyObject *self, Py_ssize_t lo, Py_ssize_t hi) |     static PyObject * | ||||||
|  | RangeSlice(PyObject *self, Py_ssize_t lo, Py_ssize_t hi) | ||||||
| { | { | ||||||
|     return RBSlice(((RangeObject *)(self))->buf, lo, hi, |     return RBSlice(((RangeObject *)(self))->buf, lo, hi, | ||||||
| 		   ((RangeObject *)(self))->start, | 		   ((RangeObject *)(self))->start, | ||||||
| 		   ((RangeObject *)(self))->end); | 		   ((RangeObject *)(self))->end); | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject* RangeSubscript(PyObject *self, PyObject* idx) |     static PyObject * | ||||||
|  | RangeSubscript(PyObject *self, PyObject* idx) | ||||||
| { | { | ||||||
|     if (PyLong_Check(idx)) { |     if (PyLong_Check(idx)) { | ||||||
| 	long _idx = PyLong_AsLong(idx); | 	long _idx = PyLong_AsLong(idx); | ||||||
| @ -1794,7 +1639,8 @@ static PyObject* RangeSubscript(PyObject *self, PyObject* idx) | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * RangeAppend(PyObject *self, PyObject *args) |     static PyObject * | ||||||
|  | RangeAppend(PyObject *self, PyObject *args) | ||||||
| { | { | ||||||
|     return RBAppend(((RangeObject *)(self))->buf, args, |     return RBAppend(((RangeObject *)(self))->buf, args, | ||||||
| 		    ((RangeObject *)(self))->start, | 		    ((RangeObject *)(self))->start, | ||||||
| @ -1829,8 +1675,8 @@ static PyTypeObject BufListType; | |||||||
| /* Buffer list object - Implementation | /* Buffer list object - Implementation | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /*ARGSUSED*/ |     static Py_ssize_t | ||||||
| static Py_ssize_t BufListLength(PyObject *self UNUSED) | BufListLength(PyObject *self UNUSED) | ||||||
| { | { | ||||||
|     buf_T       *b = firstbuf; |     buf_T       *b = firstbuf; | ||||||
|     Py_ssize_t  n = 0; |     Py_ssize_t  n = 0; | ||||||
| @ -1844,8 +1690,8 @@ static Py_ssize_t BufListLength(PyObject *self UNUSED) | |||||||
|     return n; |     return n; | ||||||
| } | } | ||||||
|  |  | ||||||
| /*ARGSUSED*/ |     static PyObject * | ||||||
| static PyObject * BufListItem(PyObject *self UNUSED, Py_ssize_t n) | BufListItem(PyObject *self UNUSED, Py_ssize_t n) | ||||||
| { | { | ||||||
|     buf_T *b; |     buf_T *b; | ||||||
|  |  | ||||||
| @ -1872,7 +1718,8 @@ static PyTypeObject WindowType; | |||||||
| /* Window object - Implementation | /* Window object - Implementation | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| static PyObject * WindowNew(win_T *win) |     static PyObject * | ||||||
|  | WindowNew(win_T *win) | ||||||
| { | { | ||||||
|     /* We need to handle deletion of windows underneath us. |     /* We need to handle deletion of windows underneath us. | ||||||
|      * If we add a "w_python3_ref" field to the win_T structure, |      * If we add a "w_python3_ref" field to the win_T structure, | ||||||
| @ -1905,7 +1752,8 @@ static PyObject * WindowNew(win_T *win) | |||||||
|     return (PyObject *)(self); |     return (PyObject *)(self); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void WindowDestructor(PyObject *self) |     static void | ||||||
|  | WindowDestructor(PyObject *self) | ||||||
| { | { | ||||||
|     WindowObject *this = (WindowObject *)(self); |     WindowObject *this = (WindowObject *)(self); | ||||||
|  |  | ||||||
| @ -1913,7 +1761,8 @@ static void WindowDestructor(PyObject *self) | |||||||
| 	this->win->w_python3_ref = NULL; | 	this->win->w_python3_ref = NULL; | ||||||
| } | } | ||||||
|  |  | ||||||
| static int CheckWindow(WindowObject *this) |     static int | ||||||
|  | CheckWindow(WindowObject *this) | ||||||
| { | { | ||||||
|     if (this->win == INVALID_WINDOW_VALUE) |     if (this->win == INVALID_WINDOW_VALUE) | ||||||
|     { |     { | ||||||
| @ -1924,7 +1773,8 @@ static int CheckWindow(WindowObject *this) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * WindowGetattro(PyObject *self, PyObject *nameobj) |     static PyObject * | ||||||
|  | WindowGetattro(PyObject *self, PyObject *nameobj) | ||||||
| { | { | ||||||
|     WindowObject *this = (WindowObject *)(self); |     WindowObject *this = (WindowObject *)(self); | ||||||
|  |  | ||||||
| @ -1956,7 +1806,8 @@ static PyObject * WindowGetattro(PyObject *self, PyObject *nameobj) | |||||||
| 	return PyObject_GenericGetAttr(self, nameobj); | 	return PyObject_GenericGetAttr(self, nameobj); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int WindowSetattro(PyObject *self, PyObject *nameobj, PyObject *val) |     static int | ||||||
|  | WindowSetattro(PyObject *self, PyObject *nameobj, PyObject *val) | ||||||
| { | { | ||||||
|     WindowObject *this = (WindowObject *)(self); |     WindowObject *this = (WindowObject *)(self); | ||||||
|  |  | ||||||
| @ -2001,8 +1852,8 @@ static int WindowSetattro(PyObject *self, PyObject *nameobj, PyObject *val) | |||||||
|     } |     } | ||||||
|     else if (strcmp(name, "height") == 0) |     else if (strcmp(name, "height") == 0) | ||||||
|     { |     { | ||||||
| 	int     height; | 	int	height; | ||||||
| 	win_T   *savewin; | 	win_T	*savewin; | ||||||
|  |  | ||||||
| 	if (!PyArg_Parse(val, "i", &height)) | 	if (!PyArg_Parse(val, "i", &height)) | ||||||
| 	    return -1; | 	    return -1; | ||||||
| @ -2024,8 +1875,8 @@ static int WindowSetattro(PyObject *self, PyObject *nameobj, PyObject *val) | |||||||
| #ifdef FEAT_VERTSPLIT | #ifdef FEAT_VERTSPLIT | ||||||
|     else if (strcmp(name, "width") == 0) |     else if (strcmp(name, "width") == 0) | ||||||
|     { |     { | ||||||
| 	int     width; | 	int	width; | ||||||
| 	win_T   *savewin; | 	win_T	*savewin; | ||||||
|  |  | ||||||
| 	if (!PyArg_Parse(val, "i", &width)) | 	if (!PyArg_Parse(val, "i", &width)) | ||||||
| 	    return -1; | 	    return -1; | ||||||
| @ -2052,7 +1903,8 @@ static int WindowSetattro(PyObject *self, PyObject *nameobj, PyObject *val) | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| static PyObject * WindowRepr(PyObject *self) |     static PyObject * | ||||||
|  | WindowRepr(PyObject *self) | ||||||
| { | { | ||||||
|     static char repr[100]; |     static char repr[100]; | ||||||
|     WindowObject *this = (WindowObject *)(self); |     WindowObject *this = (WindowObject *)(self); | ||||||
| @ -2064,8 +1916,8 @@ static PyObject * WindowRepr(PyObject *self) | |||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
| 	int     i = 0; | 	int	i = 0; | ||||||
| 	win_T   *w; | 	win_T	*w; | ||||||
|  |  | ||||||
| 	for (w = firstwin; w != NULL && w != this->win; w = W_NEXT(w)) | 	for (w = firstwin; w != NULL && w != this->win; w = W_NEXT(w)) | ||||||
| 	    ++i; | 	    ++i; | ||||||
| @ -2106,8 +1958,8 @@ static PyTypeObject WinListType; | |||||||
|  |  | ||||||
| /* Window list object - Implementation | /* Window list object - Implementation | ||||||
|  */ |  */ | ||||||
| /*ARGSUSED*/ |     static Py_ssize_t | ||||||
| static Py_ssize_t WinListLength(PyObject *self UNUSED) | WinListLength(PyObject *self UNUSED) | ||||||
| { | { | ||||||
|     win_T       *w = firstwin; |     win_T       *w = firstwin; | ||||||
|     Py_ssize_t  n = 0; |     Py_ssize_t  n = 0; | ||||||
| @ -2121,8 +1973,8 @@ static Py_ssize_t WinListLength(PyObject *self UNUSED) | |||||||
|     return n; |     return n; | ||||||
| } | } | ||||||
|  |  | ||||||
| /*ARGSUSED*/ |     static PyObject * | ||||||
| static PyObject * WinListItem(PyObject *self UNUSED, Py_ssize_t n) | WinListItem(PyObject *self UNUSED, Py_ssize_t n) | ||||||
| { | { | ||||||
|     win_T *w; |     win_T *w; | ||||||
|  |  | ||||||
| @ -2147,8 +1999,8 @@ static PyTypeObject CurrentType; | |||||||
|  |  | ||||||
| /* Current items object - Implementation | /* Current items object - Implementation | ||||||
|  */ |  */ | ||||||
| /*ARGSUSED*/ |     static PyObject * | ||||||
| static PyObject * CurrentGetattro(PyObject *self UNUSED, PyObject *nameobj) | CurrentGetattro(PyObject *self UNUSED, PyObject *nameobj) | ||||||
| { | { | ||||||
|     char *name = ""; |     char *name = ""; | ||||||
|     if (PyUnicode_Check(nameobj)) |     if (PyUnicode_Check(nameobj)) | ||||||
| @ -2171,8 +2023,8 @@ static PyObject * CurrentGetattro(PyObject *self UNUSED, PyObject *nameobj) | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| /*ARGSUSED*/ |     static int | ||||||
| static int CurrentSetattro(PyObject *self UNUSED, PyObject *nameobj, PyObject *value) | CurrentSetattro(PyObject *self UNUSED, PyObject *nameobj, PyObject *value) | ||||||
| { | { | ||||||
|     char *name = ""; |     char *name = ""; | ||||||
|     if (PyUnicode_Check(nameobj)) |     if (PyUnicode_Check(nameobj)) | ||||||
| @ -2278,12 +2130,23 @@ PyMODINIT_FUNC Py3Init_vim(void) | |||||||
|  * 4. Utility functions for handling the interface between Vim and Python. |  * 4. Utility functions for handling the interface between Vim and Python. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | /* Get a line from the specified buffer. The line number is | ||||||
|  |  * in Vim format (1-based). The line is returned as a Python | ||||||
|  |  * string object. | ||||||
|  |  */ | ||||||
|  |     static PyObject * | ||||||
|  | GetBufferLine(buf_T *buf, Py_ssize_t n) | ||||||
|  | { | ||||||
|  |     return LineToString((char *)ml_get_buf(buf, (linenr_T)n, FALSE)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Get a list of lines from the specified buffer. The line numbers | /* Get a list of lines from the specified buffer. The line numbers | ||||||
|  * are in Vim format (1-based). The range is from lo up to, but not |  * are in Vim format (1-based). The range is from lo up to, but not | ||||||
|  * including, hi. The list is returned as a Python list of string objects. |  * including, hi. The list is returned as a Python list of string objects. | ||||||
|  */ |  */ | ||||||
| static PyObject * GetBufferLineList(buf_T *buf, Py_ssize_t lo, Py_ssize_t hi) |     static PyObject * | ||||||
|  | GetBufferLineList(buf_T *buf, Py_ssize_t lo, Py_ssize_t hi) | ||||||
| { | { | ||||||
|     Py_ssize_t i; |     Py_ssize_t i; | ||||||
|     Py_ssize_t n = hi - lo; |     Py_ssize_t n = hi - lo; | ||||||
| @ -2320,21 +2183,13 @@ static PyObject * GetBufferLineList(buf_T *buf, Py_ssize_t lo, Py_ssize_t hi) | |||||||
|     return list; |     return list; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Get a line from the specified buffer. The line number is |  | ||||||
|  * in Vim format (1-based). The line is returned as a Python |  | ||||||
|  * string object. |  | ||||||
|  */ |  | ||||||
| static PyObject * GetBufferLine(buf_T *buf, Py_ssize_t n) |  | ||||||
| { |  | ||||||
|     return LineToString((char *)ml_get_buf(buf, (linenr_T)n, FALSE)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Check if deleting lines made the cursor position invalid. |  * Check if deleting lines made the cursor position invalid. | ||||||
|  * Changed the lines from "lo" to "hi" and added "extra" lines (negative if |  * Changed the lines from "lo" to "hi" and added "extra" lines (negative if | ||||||
|  * deleted). |  * deleted). | ||||||
|  */ |  */ | ||||||
| static void py_fix_cursor(linenr_T lo, linenr_T hi, linenr_T extra) |     static void | ||||||
|  | py_fix_cursor(linenr_T lo, linenr_T hi, linenr_T extra) | ||||||
| { | { | ||||||
|     if (curwin->w_cursor.lnum >= lo) |     if (curwin->w_cursor.lnum >= lo) | ||||||
|     { |     { | ||||||
| @ -2365,7 +2220,8 @@ static void py_fix_cursor(linenr_T lo, linenr_T hi, linenr_T extra) | |||||||
|  * If OK is returned and len_change is not NULL, *len_change |  * If OK is returned and len_change is not NULL, *len_change | ||||||
|  * is set to the change in the buffer length. |  * is set to the change in the buffer length. | ||||||
|  */ |  */ | ||||||
| static int SetBufferLine(buf_T *buf, Py_ssize_t n, PyObject *line, Py_ssize_t *len_change) |     static int | ||||||
|  | SetBufferLine(buf_T *buf, Py_ssize_t n, PyObject *line, Py_ssize_t *len_change) | ||||||
| { | { | ||||||
|     /* First of all, we check the thpe of the supplied Python object. |     /* First of all, we check the thpe of the supplied Python object. | ||||||
|      * There are three cases: |      * There are three cases: | ||||||
| @ -2455,7 +2311,8 @@ static int SetBufferLine(buf_T *buf, Py_ssize_t n, PyObject *line, Py_ssize_t *l | |||||||
|  * If OK is returned and len_change is not NULL, *len_change |  * If OK is returned and len_change is not NULL, *len_change | ||||||
|  * is set to the change in the buffer length. |  * is set to the change in the buffer length. | ||||||
|  */ |  */ | ||||||
| static int InsertBufferLines(buf_T *buf, Py_ssize_t n, PyObject *lines, Py_ssize_t *len_change) |     static int | ||||||
|  | InsertBufferLines(buf_T *buf, Py_ssize_t n, PyObject *lines, Py_ssize_t *len_change) | ||||||
| { | { | ||||||
|     /* First of all, we check the type of the supplied Python object. |     /* First of all, we check the type of the supplied Python object. | ||||||
|      * It must be a string or a list, or the call is in error. |      * It must be a string or a list, or the call is in error. | ||||||
| @ -2576,7 +2433,8 @@ static int InsertBufferLines(buf_T *buf, Py_ssize_t n, PyObject *lines, Py_ssize | |||||||
|  * |  * | ||||||
|  * On errors, the Python exception data is set, and NULL is returned. |  * On errors, the Python exception data is set, and NULL is returned. | ||||||
|  */ |  */ | ||||||
| static PyObject * LineToString(const char *str) |     static PyObject * | ||||||
|  | LineToString(const char *str) | ||||||
| { | { | ||||||
|     PyObject *result; |     PyObject *result; | ||||||
|     Py_ssize_t len = strlen(str); |     Py_ssize_t len = strlen(str); | ||||||
| @ -2616,7 +2474,8 @@ static PyObject * LineToString(const char *str) | |||||||
|  * |  * | ||||||
|  * On errors, the Python exception data is set, and NULL is returned. |  * On errors, the Python exception data is set, and NULL is returned. | ||||||
|  */ |  */ | ||||||
| static char * StringToLine(PyObject *obj) |     static char * | ||||||
|  | StringToLine(PyObject *obj) | ||||||
| { | { | ||||||
|     const char *str; |     const char *str; | ||||||
|     char *save; |     char *save; | ||||||
| @ -2674,26 +2533,8 @@ static char * StringToLine(PyObject *obj) | |||||||
|     return save; |     return save; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Check to see whether a Vim error has been reported, or a keyboard |     static void | ||||||
|  * interrupt has been detected. | init_structs(void) | ||||||
|  */ |  | ||||||
| static int VimErrorCheck(void) |  | ||||||
| { |  | ||||||
|     if (got_int) |  | ||||||
|     { |  | ||||||
| 	PyErr_SetNone(PyExc_KeyboardInterrupt); |  | ||||||
| 	return 1; |  | ||||||
|     } |  | ||||||
|     else if (did_emsg && !PyErr_Occurred()) |  | ||||||
|     { |  | ||||||
| 	PyErr_SetNone(VimError); |  | ||||||
| 	return 1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static void init_structs(void) |  | ||||||
| { | { | ||||||
|     vim_memset(&OutputType, 0, sizeof(OutputType)); |     vim_memset(&OutputType, 0, sizeof(OutputType)); | ||||||
|     OutputType.tp_name = "vim.message"; |     OutputType.tp_name = "vim.message"; | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user