mirror of
https://github.com/python/cpython.git
synced 2025-07-22 10:45:22 +00:00
Issue #4885: Add weakref support to mmap objects. Patch by Valerie Lambert.
This commit is contained in:
parent
914061ab15
commit
c53204b947
4 changed files with 23 additions and 3 deletions
|
@ -1,11 +1,12 @@
|
||||||
from test.support import (TESTFN, run_unittest, import_module, unlink,
|
from test.support import (TESTFN, run_unittest, import_module, unlink,
|
||||||
requires, _2G, _4G)
|
requires, _2G, _4G, gc_collect)
|
||||||
import unittest
|
import unittest
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
import itertools
|
import itertools
|
||||||
import socket
|
import socket
|
||||||
import sys
|
import sys
|
||||||
|
import weakref
|
||||||
|
|
||||||
# Skip test if we can't import mmap.
|
# Skip test if we can't import mmap.
|
||||||
mmap = import_module('mmap')
|
mmap = import_module('mmap')
|
||||||
|
@ -692,6 +693,15 @@ class MmapTests(unittest.TestCase):
|
||||||
"wrong exception raised in context manager")
|
"wrong exception raised in context manager")
|
||||||
self.assertTrue(m.closed, "context manager failed")
|
self.assertTrue(m.closed, "context manager failed")
|
||||||
|
|
||||||
|
def test_weakref(self):
|
||||||
|
# Check mmap objects are weakrefable
|
||||||
|
mm = mmap.mmap(-1, 16)
|
||||||
|
wr = weakref.ref(mm)
|
||||||
|
self.assertIs(wr(), mm)
|
||||||
|
del mm
|
||||||
|
gc_collect()
|
||||||
|
self.assertIs(wr(), None)
|
||||||
|
|
||||||
class LargeMmapTests(unittest.TestCase):
|
class LargeMmapTests(unittest.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
|
|
|
@ -701,6 +701,7 @@ Ross Lagerwall
|
||||||
Cameron Laird
|
Cameron Laird
|
||||||
David Lam
|
David Lam
|
||||||
Thomas Lamb
|
Thomas Lamb
|
||||||
|
Valerie Lambert
|
||||||
Jean-Baptiste "Jiba" Lamy
|
Jean-Baptiste "Jiba" Lamy
|
||||||
Ronan Lamy
|
Ronan Lamy
|
||||||
Torsten Landschoff
|
Torsten Landschoff
|
||||||
|
|
|
@ -13,7 +13,10 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
- Issue 8860: Fixed rounding in timedelta constructor.
|
- Issue #4885: Add weakref support to mmap objects. Patch by Valerie Lambert.
|
||||||
|
|
||||||
|
- Issue #8860: Fixed rounding in timedelta constructor.
|
||||||
|
|
||||||
|
|
||||||
What's New in Python 3.4.0 Alpha 1?
|
What's New in Python 3.4.0 Alpha 1?
|
||||||
===================================
|
===================================
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
|
|
||||||
#define PY_SSIZE_T_CLEAN
|
#define PY_SSIZE_T_CLEAN
|
||||||
#include <Python.h>
|
#include <Python.h>
|
||||||
|
#include "structmember.h"
|
||||||
|
|
||||||
#ifndef MS_WINDOWS
|
#ifndef MS_WINDOWS
|
||||||
#define UNIX
|
#define UNIX
|
||||||
|
@ -108,6 +109,7 @@ typedef struct {
|
||||||
int fd;
|
int fd;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
PyObject *weakreflist;
|
||||||
access_mode access;
|
access_mode access;
|
||||||
} mmap_object;
|
} mmap_object;
|
||||||
|
|
||||||
|
@ -134,6 +136,8 @@ mmap_object_dealloc(mmap_object *m_obj)
|
||||||
}
|
}
|
||||||
#endif /* UNIX */
|
#endif /* UNIX */
|
||||||
|
|
||||||
|
if (m_obj->weakreflist != NULL)
|
||||||
|
PyObject_ClearWeakRefs((PyObject *) m_obj);
|
||||||
Py_TYPE(m_obj)->tp_free((PyObject*)m_obj);
|
Py_TYPE(m_obj)->tp_free((PyObject*)m_obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1032,7 +1036,7 @@ static PyTypeObject mmap_object_type = {
|
||||||
0, /* tp_traverse */
|
0, /* tp_traverse */
|
||||||
0, /* tp_clear */
|
0, /* tp_clear */
|
||||||
0, /* tp_richcompare */
|
0, /* tp_richcompare */
|
||||||
0, /* tp_weaklistoffset */
|
offsetof(mmap_object, weakreflist), /* tp_weaklistoffset */
|
||||||
0, /* tp_iter */
|
0, /* tp_iter */
|
||||||
0, /* tp_iternext */
|
0, /* tp_iternext */
|
||||||
mmap_object_methods, /* tp_methods */
|
mmap_object_methods, /* tp_methods */
|
||||||
|
@ -1190,6 +1194,7 @@ new_mmap_object(PyTypeObject *type, PyObject *args, PyObject *kwdict)
|
||||||
m_obj->data = NULL;
|
m_obj->data = NULL;
|
||||||
m_obj->size = (size_t) map_size;
|
m_obj->size = (size_t) map_size;
|
||||||
m_obj->pos = (size_t) 0;
|
m_obj->pos = (size_t) 0;
|
||||||
|
m_obj->weakreflist = NULL;
|
||||||
m_obj->exports = 0;
|
m_obj->exports = 0;
|
||||||
m_obj->offset = offset;
|
m_obj->offset = offset;
|
||||||
if (fd == -1) {
|
if (fd == -1) {
|
||||||
|
@ -1394,6 +1399,7 @@ new_mmap_object(PyTypeObject *type, PyObject *args, PyObject *kwdict)
|
||||||
/* set the initial position */
|
/* set the initial position */
|
||||||
m_obj->pos = (size_t) 0;
|
m_obj->pos = (size_t) 0;
|
||||||
|
|
||||||
|
m_obj->weakreflist = NULL;
|
||||||
m_obj->exports = 0;
|
m_obj->exports = 0;
|
||||||
/* set the tag name */
|
/* set the tag name */
|
||||||
if (tagname != NULL && *tagname != '\0') {
|
if (tagname != NULL && *tagname != '\0') {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue