]> granicus.if.org Git - vim/commitdiff
updated for version 7.3.942 v7.3.942
authorBram Moolenaar <Bram@vim.org>
Sun, 12 May 2013 18:36:14 +0000 (20:36 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 12 May 2013 18:36:14 +0000 (20:36 +0200)
Problem:    Python: SEGV in Buffer functions.
Solution:   Call CheckBuffer() at the right time. (ZyX)

src/if_py_both.h
src/if_python.c
src/if_python3.c
src/version.c

index d8b0f70d9db097c0613de23b8c0b060d5067a508..681b7a17295d76e6c24c4aac75fd7d6c87a0e968 100644 (file)
@@ -2391,6 +2391,9 @@ RBItem(BufferObject *self, PyInt n, PyInt start, PyInt end)
     if (CheckBuffer(self))
        return NULL;
 
+    if (end == -1)
+       end = self->buf->b_ml.ml_line_count;
+
     if (n < 0 || n > end - start)
     {
        PyErr_SetString(PyExc_IndexError, _("line number out of range"));
@@ -2408,6 +2411,9 @@ RBSlice(BufferObject *self, PyInt lo, PyInt hi, PyInt start, PyInt end)
     if (CheckBuffer(self))
        return NULL;
 
+    if (end == -1)
+       end = self->buf->b_ml.ml_line_count;
+
     size = end - start + 1;
 
     if (lo < 0)
@@ -2432,6 +2438,9 @@ RBAsItem(BufferObject *self, PyInt n, PyObject *val, PyInt start, PyInt end, PyI
     if (CheckBuffer(self))
        return -1;
 
+    if (end == -1)
+       end = self->buf->b_ml.ml_line_count;
+
     if (n < 0 || n > end - start)
     {
        PyErr_SetString(PyExc_IndexError, _("line number out of range"));
@@ -2457,6 +2466,9 @@ RBAsSlice(BufferObject *self, PyInt lo, PyInt hi, PyObject *val, PyInt start, Py
     if (CheckBuffer(self))
        return -1;
 
+    if (end == -1)
+       end = self->buf->b_ml.ml_line_count;
+
     /* Sort out the slice range */
     size = end - start + 1;
 
@@ -2493,6 +2505,9 @@ RBAppend(BufferObject *self, PyObject *args, PyInt start, PyInt end, PyInt *new_
     if (CheckBuffer(self))
        return NULL;
 
+    if (end == -1)
+       end = self->buf->b_ml.ml_line_count;
+
     max = n = end - start + 1;
 
     if (!PyArg_ParseTuple(args, "O|n", &lines, &n))
@@ -2700,15 +2715,13 @@ BufferLength(PyObject *self)
     static PyObject *
 BufferItem(PyObject *self, PyInt n)
 {
-    return RBItem((BufferObject *)(self), n, 1,
-                 (PyInt)((BufferObject *)(self))->buf->b_ml.ml_line_count);
+    return RBItem((BufferObject *)(self), n, 1, -1);
 }
 
     static PyObject *
 BufferSlice(PyObject *self, PyInt lo, PyInt hi)
 {
-    return RBSlice((BufferObject *)(self), lo, hi, 1,
-                  (PyInt)((BufferObject *)(self))->buf->b_ml.ml_line_count);
+    return RBSlice((BufferObject *)(self), lo, hi, 1, -1);
 }
 
     static PyObject *
@@ -2732,9 +2745,7 @@ BufferAttr(BufferObject *this, char *name)
     static PyObject *
 BufferAppend(PyObject *self, PyObject *args)
 {
-    return RBAppend((BufferObject *)(self), args, 1,
-                   (PyInt)((BufferObject *)(self))->buf->b_ml.ml_line_count,
-                   NULL);
+    return RBAppend((BufferObject *)(self), args, 1, -1, NULL);
 }
 
     static PyObject *
index 8e3621caf4dd4e8ffd02a8144fd09e48492c2ad6..dda65affc611c526f21bd9c1650107a527dc8adb 100644 (file)
@@ -1073,17 +1073,13 @@ BufferGetattr(PyObject *self, char *name)
     static PyInt
 BufferAssItem(PyObject *self, PyInt n, PyObject *val)
 {
-    return RBAsItem((BufferObject *)(self), n, val, 1,
-                    (PyInt)((BufferObject *)(self))->buf->b_ml.ml_line_count,
-                    NULL);
+    return RBAsItem((BufferObject *)(self), n, val, 1, -1, NULL);
 }
 
     static PyInt
 BufferAssSlice(PyObject *self, PyInt lo, PyInt hi, PyObject *val)
 {
-    return RBAsSlice((BufferObject *)(self), lo, hi, val, 1,
-                     (PyInt)((BufferObject *)(self))->buf->b_ml.ml_line_count,
-                     NULL);
+    return RBAsSlice((BufferObject *)(self), lo, hi, val, 1, -1, NULL);
 }
 
 static PySequenceMethods RangeAsSeq = {
index 77d7cd3ce71d1446f8b1d8617ea550a0421544dc..da0867b7e0a9c09374468e9474292823067da5f2 100644 (file)
@@ -1110,6 +1110,9 @@ BufferSubscript(PyObject *self, PyObject* idx)
     {
        Py_ssize_t start, stop, step, slicelen;
 
+       if (CheckBuffer((BufferObject *) self))
+           return NULL;
+
        if (PySlice_GetIndicesEx((PyObject *)idx,
              (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count+1,
              &start, &stop,
@@ -1139,6 +1142,9 @@ BufferAsSubscript(PyObject *self, PyObject* idx, PyObject* val)
     {
        Py_ssize_t start, stop, step, slicelen;
 
+       if (CheckBuffer((BufferObject *) self))
+           return -1;
+
        if (PySlice_GetIndicesEx((PyObject *)idx,
              (Py_ssize_t)((BufferObject *)(self))->buf->b_ml.ml_line_count+1,
              &start, &stop,
index 8bc257f5f055ec2134582bd9c57ba1a2212094af..be2138c055f9e11e6239d0c7eb841489ed41bc1d 100644 (file)
@@ -728,6 +728,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    942,
 /**/
     941,
 /**/