mirror of
				https://github.com/python/cpython.git
				synced 2025-11-03 23:21:29 +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,
 | 
			
		||||
                          requires, _2G, _4G)
 | 
			
		||||
                          requires, _2G, _4G, gc_collect)
 | 
			
		||||
import unittest
 | 
			
		||||
import os
 | 
			
		||||
import re
 | 
			
		||||
import itertools
 | 
			
		||||
import socket
 | 
			
		||||
import sys
 | 
			
		||||
import weakref
 | 
			
		||||
 | 
			
		||||
# Skip test if we can't import mmap.
 | 
			
		||||
mmap = import_module('mmap')
 | 
			
		||||
| 
						 | 
				
			
			@ -692,6 +693,15 @@ def test_context_manager_exception(self):
 | 
			
		|||
                              "wrong exception raised in context manager")
 | 
			
		||||
        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):
 | 
			
		||||
 | 
			
		||||
    def setUp(self):
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -701,6 +701,7 @@ Ross Lagerwall
 | 
			
		|||
Cameron Laird
 | 
			
		||||
David Lam
 | 
			
		||||
Thomas Lamb
 | 
			
		||||
Valerie Lambert
 | 
			
		||||
Jean-Baptiste "Jiba" Lamy
 | 
			
		||||
Ronan Lamy
 | 
			
		||||
Torsten Landschoff
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -13,7 +13,10 @@ Core and Builtins
 | 
			
		|||
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?
 | 
			
		||||
===================================
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -20,6 +20,7 @@
 | 
			
		|||
 | 
			
		||||
#define PY_SSIZE_T_CLEAN
 | 
			
		||||
#include <Python.h>
 | 
			
		||||
#include "structmember.h"
 | 
			
		||||
 | 
			
		||||
#ifndef MS_WINDOWS
 | 
			
		||||
#define UNIX
 | 
			
		||||
| 
						 | 
				
			
			@ -108,6 +109,7 @@ typedef struct {
 | 
			
		|||
    int fd;
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    PyObject *weakreflist;
 | 
			
		||||
    access_mode access;
 | 
			
		||||
} mmap_object;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -134,6 +136,8 @@ mmap_object_dealloc(mmap_object *m_obj)
 | 
			
		|||
    }
 | 
			
		||||
#endif /* UNIX */
 | 
			
		||||
 | 
			
		||||
    if (m_obj->weakreflist != NULL)
 | 
			
		||||
        PyObject_ClearWeakRefs((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_clear */
 | 
			
		||||
    0,                                          /* tp_richcompare */
 | 
			
		||||
    0,                                          /* tp_weaklistoffset */
 | 
			
		||||
    offsetof(mmap_object, weakreflist),         /* tp_weaklistoffset */
 | 
			
		||||
    0,                                          /* tp_iter */
 | 
			
		||||
    0,                                          /* tp_iternext */
 | 
			
		||||
    mmap_object_methods,                        /* tp_methods */
 | 
			
		||||
| 
						 | 
				
			
			@ -1190,6 +1194,7 @@ new_mmap_object(PyTypeObject *type, PyObject *args, PyObject *kwdict)
 | 
			
		|||
    m_obj->data = NULL;
 | 
			
		||||
    m_obj->size = (size_t) map_size;
 | 
			
		||||
    m_obj->pos = (size_t) 0;
 | 
			
		||||
    m_obj->weakreflist = NULL;
 | 
			
		||||
    m_obj->exports = 0;
 | 
			
		||||
    m_obj->offset = offset;
 | 
			
		||||
    if (fd == -1) {
 | 
			
		||||
| 
						 | 
				
			
			@ -1394,6 +1399,7 @@ new_mmap_object(PyTypeObject *type, PyObject *args, PyObject *kwdict)
 | 
			
		|||
    /* set the initial position */
 | 
			
		||||
    m_obj->pos = (size_t) 0;
 | 
			
		||||
 | 
			
		||||
    m_obj->weakreflist = NULL;
 | 
			
		||||
    m_obj->exports = 0;
 | 
			
		||||
    /* set the tag name */
 | 
			
		||||
    if (tagname != NULL && *tagname != '\0') {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue