]> granicus.if.org Git - python/commitdiff
Let the world know that UserList is a MutableSequence.
authorRaymond Hettinger <python@rcn.com>
Wed, 6 Feb 2008 20:59:41 +0000 (20:59 +0000)
committerRaymond Hettinger <python@rcn.com>
Wed, 6 Feb 2008 20:59:41 +0000 (20:59 +0000)
Lib/UserList.py
Lib/UserString.py

index 116122f6238dc70036f77ffec33fe9b169e07169..348ea76cdba632da9a25d4721bdff732235a5bd0 100644 (file)
@@ -1,6 +1,8 @@
 """A more or less complete user-defined wrapper around list objects."""
 
-class UserList:
+import collections
+
+class UserList(collections.MutableSequence):
     def __init__(self, initlist=None):
         self.data = []
         if initlist is not None:
@@ -69,3 +71,5 @@ class UserList:
             self.data.extend(other.data)
         else:
             self.data.extend(other)
+
+collections.MutableSequence.register(UserList)
index a8b805f6bc07ef35bef1d6d7df4750f17081e5d4..615c135f164576706b329b8df68de98326184ca1 100755 (executable)
@@ -6,10 +6,11 @@ Note: string objects have grown methods in Python 1.6
 This module requires Python 1.6 or later.
 """
 import sys
+import collections
 
 __all__ = ["UserString","MutableString"]
 
-class UserString:
+class UserString(collections.Sequence):
     def __init__(self, seq):
         if isinstance(seq, str):
             self.data = seq
@@ -161,7 +162,9 @@ class UserString:
     def upper(self): return self.__class__(self.data.upper())
     def zfill(self, width): return self.__class__(self.data.zfill(width))
 
-class MutableString(UserString):
+collections.Sequence.register(UserString)
+
+class MutableString(UserString, collections.MutableSequence):
     """mutable string objects
 
     Python strings are immutable objects.  This has the advantage, that
@@ -230,6 +233,8 @@ class MutableString(UserString):
         self.data *= n
         return self
 
+collections.MutableSequence.register(MutableString)
+
 if __name__ == "__main__":
     # execute the regression test to stdout, if called as a script:
     import os