[pypy-commit] pypy list-strategies: StringListStartegy now inherits from AbstractUnwrappedStrategy too (removed unnecessary methods)
l.diekmann
noreply at buildbot.pypy.org
Fri Sep 23 13:11:29 CEST 2011
Author: Lukas Diekmann <lukas.diekmann at uni-duesseldorf.de>
Branch: list-strategies
Changeset: r47428:0f35f1ee48eb
Date: 2011-02-23 14:01 +0100
http://bitbucket.org/pypy/pypy/changeset/0f35f1ee48eb/
Log: StringListStartegy now inherits from AbstractUnwrappedStrategy too
(removed unnecessary methods)
diff --git a/pypy/objspace/std/listobject.py b/pypy/objspace/std/listobject.py
--- a/pypy/objspace/std/listobject.py
+++ b/pypy/objspace/std/listobject.py
@@ -306,70 +306,17 @@
def init_from_list_w(self, w_list, list_w):
w_list.storage = cast_to_void_star(list_w, "integer")
-class StringListStrategy(ListStrategy):
+class StringListStrategy(AbstractUnwrappedStrategy):
+
+ def cast_from_void_star(self, storage):
+ return cast_from_void_star(storage, "string")
+
+ def is_correct_type(self, w_obj):
+ return is_W_StringObject(w_obj)
def init_from_list_w(self, w_list, list_w):
w_list.storage = cast_to_void_star(list_w, "string")
- def length(self, w_list):
- return len(cast_from_void_star(w_list.storage, "string"))
-
- def getitem(self, w_list, index):
- return cast_from_void_star(w_list.storage, "string")[index]
-
- def getslice(self, w_list, start, stop, step, length):
- if step == 1:
- return W_ListObject(cast_from_void_star(w_list.storage, "string")[start:stop])
- else:
- subitems_w = [None] * length
- for i in range(length):
- subitems_w[i] = w_list.getitem(start)
- start += step
- return W_ListObject(subitems_w)
-
- def getitems(self, w_list):
- return cast_from_void_star(w_list.storage, "string")
-
- def append(self, w_list, w_item):
-
- if is_W_StringObject(w_item):
- cast_from_void_star(w_list.storage, "string").append(w_item)
- return
-
- list_w = w_list.getitems()
- w_list.strategy = ObjectListStrategy()
- w_list.strategy.init_from_list_w(w_list, list_w)
- w_list.append(w_item)
-
- def inplace_mul(self, w_list, times):
- list_w = cast_from_void_star(w_list.storage, "string")
- list_w *= times
-
- def deleteitem(self, w_list, index):
- list_w = cast_from_void_star(w_list.storage, "string")
- del list_w[index]
-
- def setitem(self, w_list, index, w_item):
- list_w = cast_from_void_star(w_list.storage, "string")
- if is_W_StringObject(w_item):
- list_w[index] = w_item
- return
-
- w_list.strategy = ObjectListStrategy()
- w_list.strategy.init_from_list_w(w_list, list_w)
- w_list.setitem(index, w_item)
-
- def insert(self, w_list, index, w_item):
- list_w = cast_from_void_star(w_list.storage, "string")
-
- if is_W_StringObject(w_item):
- list_w.insert(index, w_item)
- return
-
- w_list.strategy = ObjectListStrategy()
- w_list.strategy.init_from_list_w(w_list, list_w)
- w_list.insert(index, w_item)
-
# _______________________________________________________
init_signature = Signature(['sequence'], None, None)
More information about the pypy-commit
mailing list