[Zodb-checkins] SVN: ZODB/trunk/src/ZODB/utils.py Merge rev 29370 from 3.3 branch.

Tim Peters tim.one at comcast.net
Tue Mar 1 14:57:40 EST 2005


Log message for revision 29371:
  Merge rev 29370 from 3.3 branch.
  
  positive_id():  Use a trick from Armin Rigo to deduce the
  native platorm address size.
  

Changed:
  U   ZODB/trunk/src/ZODB/utils.py

-=-
Modified: ZODB/trunk/src/ZODB/utils.py
===================================================================
--- ZODB/trunk/src/ZODB/utils.py	2005-03-01 19:56:23 UTC (rev 29370)
+++ ZODB/trunk/src/ZODB/utils.py	2005-03-01 19:57:39 UTC (rev 29371)
@@ -14,6 +14,7 @@
 
 import sys
 import time
+import struct
 from struct import pack, unpack
 from binascii import hexlify
 import cPickle as pickle
@@ -140,22 +141,18 @@
 # unsigned, but produces a FutureWarning, because Python 2.4 will display
 # it as signed.  So when you want to prodce an address, use positive_id() to
 # obtain it.
+# _ADDRESS_MASK is 2**(number_of_bits_in_a_native_pointer).  Adding this to
+# a negative address gives a positive int with the same hex representation as
+# the significant bits in the original.
+
+_ADDRESS_MASK = 256 ** struct.calcsize('P')
 def positive_id(obj):
     """Return id(obj) as a non-negative integer."""
 
     result = id(obj)
     if result < 0:
-        # This is a puzzle:  there's no way to know the natural width of
-        # addresses on this box (in particular, there's no necessary
-        # relation to sys.maxint).  Try 32 bits first (and on a 32-bit
-        # box, adding 2**32 gives a positive number with the same hex
-        # representation as the original result).
-        result += 1L << 32
-        if result < 0:
-            # Undo that, and try 64 bits.
-            result -= 1L << 32
-            result += 1L << 64
-            assert result >= 0 # else addresses are fatter than 64 bits
+        result += _ADDRESS_MASK
+        assert result > 0
     return result
 
 # So full of undocumented magic it's hard to fathom.



More information about the Zodb-checkins mailing list