| # A more or less complete user-defined wrapper around list objects | 
 |  | 
 | class UserList: | 
 | 	def __init__(self, list = None): | 
 | 		self.data = [] | 
 | 		if list is not None: | 
 | 			if type(list) == type(self.data): | 
 | 				self.data[:] = list | 
 | 			else: | 
 | 				self.data[:] = list.data[:] | 
 | 	def __repr__(self): return repr(self.data) | 
 | 	def __cmp__(self, list): | 
 | 		if type(list) == type(self.data): | 
 | 			return cmp(self.data, list) | 
 | 		else: | 
 | 			return cmp(self.data, list.data) | 
 | 	def __len__(self): return len(self.data) | 
 | 	def __getitem__(self, i): return self.data[i] | 
 | 	def __setitem__(self, i, item): self.data[i] = item | 
 | 	def __delitem__(self, i): del self.data[i] | 
 | 	def __getslice__(self, i, j): | 
 | 		userlist = UserList() | 
 | 		userlist.data[:] = self.data[i:j] | 
 | 		return userlist | 
 | 	def __setslice__(self, i, j, list): | 
 | 		if type(list) == type(self.data): | 
 | 			self.data[i:j] = list | 
 | 		else: | 
 | 			self.data[i:j] = list.data | 
 | 	def __delslice__(self, i, j): del self.data[i:j] | 
 | 	def __add__(self, list): | 
 | 		if type(list) == type(self.data): | 
 | 			return self.__class__(self.data + list) | 
 | 		else: | 
 | 			return self.__class__(self.data + list.data) | 
 | 	def __radd__(self, list): | 
 | 		if type(list) == type(self.data): | 
 | 			return self.__class__(list + self.data) | 
 | 		else: | 
 | 			return self.__class__(list.data + self.data) | 
 | 	def __mul__(self, n): | 
 | 		return self.__class__(self.data*n) | 
 | 	__rmul__ = __mul__ | 
 | 	def append(self, item): self.data.append(item) | 
 | 	def insert(self, i, item): self.data.insert(i, item) | 
 | 	def remove(self, item): self.data.remove(item) | 
 | 	def count(self, item): return self.data.count(item) | 
 | 	def index(self, item): return self.data.index(item) | 
 | 	def reverse(self): self.data.reverse() | 
 | 	def sort(self, *args): apply(self.data.sort, args) |