[Zope-Checkins] CVS: Zope/lib/python/ZPublisher - BaseRequest.py:1.43.2.2 BaseResponse.py:1.10.2.1 Client.py:1.43.2.1 Converters.py:1.13.2.1 HTTPRangeSupport.py:1.3.2.3 HTTPRequest.py:1.57.2.3 HTTPResponse.py:1.52.2.1 Publish.py:1.154.2.1 Test.py:1.38.2.1 xmlrpc.py:1.9.2.1

Andreas Jung andreas@zope.com
Wed, 2 Jan 2002 11:06:55 -0500


Update of /cvs-repository/Zope/lib/python/ZPublisher
In directory cvs.zope.org:/tmp/cvs-serv22711/lib/python/ZPublisher

Modified Files:
      Tag: Zope-2_5-branch
	BaseRequest.py BaseResponse.py Client.py Converters.py 
	HTTPRangeSupport.py HTTPRequest.py HTTPResponse.py Publish.py 
	Test.py xmlrpc.py 
Log Message:
merge from trunk


=== Zope/lib/python/ZPublisher/BaseRequest.py 1.43.2.1 => 1.43.2.2 ===
 # 
 ##############################################################################
+
 __version__='$Revision$'[11:-2]
 
-from string import join, split, find, rfind, lower, upper
 from urllib import quote
 
 UNSPECIFIED_ROLES=''
@@ -162,7 +162,7 @@
     def __str__(self):
         L1 = self.items()
         L1.sort()
-        return join(map(lambda item: "%s:\t%s" % item, L1), "\n")
+        return '\n'.join(map(lambda item: "%s:\t%s" % item, L1))
 
     __repr__=__str__
 
@@ -182,7 +182,7 @@
         if path[:1]=='/':  path=path[1:]
         if path[-1:]=='/': path=path[:-1]
         clean=[]
-        for item in split(path, '/'):
+        for item in path.split('/'):
             # Make sure that certain things that dont make sense
             # cannot be traversed.
             if item in ('REQUEST', 'aq_self', 'aq_base'):
@@ -195,7 +195,7 @@
         path=clean
     
         # How did this request come in? (HTTP GET, PUT, POST, etc.)
-        method=req_method=upper(request_get('REQUEST_METHOD', 'GET'))
+        method=req_method=request_get('REQUEST_METHOD', 'GET').upper()
         
         no_acquire_flag=0
 
@@ -261,7 +261,7 @@
                         hasattr(object.__call__,'__roles__')):
                         roles=object.__call__.__roles__
                     if request._hacked_path:
-                        i=rfind(URL,'/')
+                        i=URL.rfind('/')
                         if i > 0: response.setBase(URL[:i])
                     break
                 if not entry_name: continue
@@ -407,7 +407,7 @@
         if user is not None:
             if validated_hook is not None: validated_hook(self, user)
             request['AUTHENTICATED_USER']=user
-            request['AUTHENTICATION_PATH']=join(steps[:-i],'/')
+            request['AUTHENTICATION_PATH']='/'.join(steps[:-i])
 
         # Remove http request method from the URL.
         request['URL']=URL


=== Zope/lib/python/ZPublisher/BaseResponse.py 1.10 => 1.10.2.1 ===
 __version__='$Revision$'[11:-2]
 
-import string, types, sys
-from string import find, rfind, lower, upper, strip, split, join, translate
+import  types, sys
 from types import StringType, InstanceType
 from zExceptions import Unauthorized
 


=== Zope/lib/python/ZPublisher/Client.py 1.43 => 1.43.2.1 ===
 from urllib import urlopen, quote
 from types import FileType, ListType, DictType, TupleType
-from string import strip, split, atoi, join, rfind, translate, maketrans, replace, lower
+from string import translate, maketrans
 from urlparse import urlparse
 
 class Function:
@@ -59,7 +59,7 @@
         self.headers=headers
         if not headers.has_key('Host') and not headers.has_key('host'):
             headers['Host']=urlparse(url)[1]
-        self.func_name=url[rfind(url,'/')+1:]
+        self.func_name=url[url.rfind('/')+1:]
         self.__dict__['__name__']=self.func_name
         self.func_defaults=()
         
@@ -73,7 +73,7 @@
         mo = urlregex.match(url)
         if mo is not None:
             host,port,rurl=mo.group(1,2,3)
-            if port: port=atoi(port[1:])
+            if port: port=int(port[1:])
             else: port=80
             self.host=host
             self.port=port
@@ -117,7 +117,7 @@
 
         url=self.rurl
         if query:
-            query=join(query,'&')
+            query='&'.join(query)
             method=method or 'POST'
             if method == 'PUT':
                 headers['Content-Length']=str(len(query))
@@ -133,8 +133,9 @@
             not headers.has_key('Authorization')):
             headers['Authorization']=(
                 "Basic %s" %
-                replace(encodestring('%s:%s' % (self.username,self.password)),
-				     '\012',''))
+                encodestring('%s:%s' % (self.username,self.password)).replace(
+				     '\012','')
+                )
 	    
         try:
             h=HTTP()
@@ -196,10 +197,10 @@
         for n,v in self.headers.items():
             rq.append('%s: %s' % (n,v))
         if self.username and self.password:
-            c=replace(encodestring('%s:%s' % (self.username,self.password)),'\012','')
+            c=encodestring('%s:%s' % (self.username,self.password)).replace('\012','')
             rq.append('Authorization: Basic %s' % c)
         rq.append(MultiPart(d).render())
-        rq=join(rq,'\r\n')   
+        rq='\r\n'.join(rq)   
 
         try:
             sock=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
@@ -210,14 +211,14 @@
             line=reply.readline()
 
             try:
-                [ver, ec, em] = split(line, None, 2)
+                [ver, ec, em] = line.split(None, 2)
             except ValueError:
                 raise 'BadReply','Bad reply from server: '+line
             if ver[:5] != 'HTTP/':
                 raise 'BadReply','Bad reply from server: '+line
 
-            ec=atoi(ec)
-            em=strip(em)
+            ec=int(ec)
+            em=em.strip()
             headers=mimetools.Message(reply,0)
             response=reply.read()
         finally:
@@ -295,7 +296,7 @@
             raise TypeError, 'Invalid recursion in data to be marshaled.'
         r.append(marshal_whatever("%s:%s" % (n,tname) ,v))
     
-    return join(r,'&')
+    return '&'.join(r)
 
 def marshal_tuple(n,l):
     return marshal_list(n,l,'tuple')
@@ -317,7 +318,7 @@
     query=[]
     for k,v in items: query.append(marshal_whatever(k,v))
 
-    return query and join(query,'&') or ''
+    return query and '&'.join(query) or ''
 
 NotFound     ='bci.NotFound'
 InternalError='bci.InternalError'
@@ -400,9 +401,9 @@
 
         elif dt==FileType or hasattr(val,'read'):
             if hasattr(val,'name'):
-                fn=replace(val.name, '\\', '/')
-                fn=fn[(rfind(fn,'/')+1):]
-                ex=lower(fn[(rfind(fn,'.')+1):])
+                fn=val.name.replace( '\\', '/')
+                fn=fn[(fn.rfind('/')+1):]
+                ex=(fn[(fn.rfind('.')+1):]).lower()
                 if self._extmap.has_key(ex):
                     ct=self._extmap[ex]
                 else:
@@ -454,12 +455,12 @@
             b=self._boundary
             for d in self._data: p.append(d.render())
             t.append('--%s\n' % b)
-            t.append(join(p,'\n--%s\n' % b))
+            t.append(('\n--%s\n' % b).join(p))
             t.append('\n--%s--\n' % b)
-            t=join(t,'')
+            t=''.join(t)
             s.append('Content-Length: %s\r\n\r\n' % len(t))
             s.append(t)
-            return join(s,'')
+            return ''.join(s)
 
         else:
             for n,v in h.items():
@@ -475,11 +476,11 @@
                 b=self._boundary
                 for d in self._data: p.append(d.render())
                 s.append('--%s\n' % b)
-                s.append(join(p,'\n--%s\n' % b))
+                s.append(('\n--%s\n' % b).join(p))
                 s.append('\n--%s--\n' % b)
-                return join(s,'')
+                return ''.join(s)
             else:
-                return join(s+self._data,'')
+                return ''.join(s+self._data)
 
 
     _extmap={'':     'text/plain',
@@ -526,7 +527,6 @@
 
 def main():
     import getopt
-    from string import split
 
     user=None
 
@@ -535,11 +535,11 @@
         url=args[0]
         u =filter(lambda o: o[0]=='-u', optlist)
         if u:
-            [user, pw] = split(u[0][1],':')
+            [user, pw] = u[0][1].split(':')
 
         kw={}
         for arg in args[1:]:
-            [name,v]=split(arg,'=')
+            [name,v]=arg.split('=')
             if name[-5:]==':file':
                 name=name[:-5]
                 if v=='-': v=sys.stdin
@@ -554,7 +554,7 @@
     f=Function(url)
     if user: f.username, f.password = user, pw
     headers, body = apply(f,(),kw)
-    sys.stderr.write(join(map(lambda h: "%s: %s\n" % h, headers.items()),"")
+    sys.stderr.write(''.join(map(lambda h: "%s: %s\n" % h, headers.items()))
                      +"\n\n")
     print body
 


=== Zope/lib/python/ZPublisher/Converters.py 1.13 => 1.13.2.1 ===
 
 import re
-from string import atoi, atol, atof, join, split, strip
-from types import ListType, TupleType
+from types import ListType, TupleType, UnicodeType
 
 def field2string(v):
-    if hasattr(v,'read'): v=v.read()
-    else: v=str(v)
-    return v
+    if hasattr(v,'read'): return v.read()
+    elif isinstance(v,UnicodeType) :
+        return v
+    else:  
+        return str(v)
 
 def field2text(v, nl=re.compile('\r\n|\n\r').search):
     if hasattr(v,'read'): v=v.read()
@@ -38,12 +39,12 @@
 
     r.append(v[s:])
         
-    return join(r,'\n')
+    return '\n'.join(r)
 
 def field2required(v):
     if hasattr(v,'read'): v=v.read()
     else: v=str(v)
-    if strip(v): return v
+    if v.strip(): return v
     raise ValueError, 'No input for required field<p>'
 
 def field2int(v):
@@ -52,7 +53,7 @@
     if hasattr(v,'read'): v=v.read()
     else: v=str(v)
     if v:
-        try: return atoi(v)
+        try: return int(v)
         except ValueError:
             raise ValueError, (
                 "An integer was expected in the value '%s'" % v
@@ -65,7 +66,7 @@
     if hasattr(v,'read'): v=v.read()
     else: v=str(v)
     if v:
-        try: return atof(v)
+        try: return float(v)
         except ValueError:
             raise ValueError, (
                 "A floating-point number was expected in the value '%s'" % v
@@ -83,7 +84,7 @@
     if v[-1:] in ('L', 'l'):
         v = v[:-1]
     if v:
-        try: return atol(v)
+        try: return long(v)
         except ValueError:
             raise ValueError, (
                 "A long integer was expected in the value '%s'" % v
@@ -93,7 +94,7 @@
 def field2tokens(v):
     if hasattr(v,'read'): v=v.read()
     else: v=str(v)
-    return split(v)
+    return v.split()
 
 def field2lines(v):
     if type(v) in (ListType, TupleType):
@@ -101,7 +102,7 @@
         for item in v:
             result.append(str(item))
         return result
-    return split(field2text(v),'\n')
+    return field2text(v).split('\n')
 
 def field2date(v):
     from DateTime import DateTime


=== Zope/lib/python/ZPublisher/HTTPRangeSupport.py 1.3.2.2 => 1.3.2.3 ===
 __version__='$Revision$'[11:-2]
 
-import re, string, sys
+import re, sys
 import Interface
 
 WHITESPACE = re.compile('\s*', re.MULTILINE)
@@ -45,13 +45,13 @@
     header = WHITESPACE.sub('', header)
 
     # A range header only can specify a byte range
-    try: spec, sets = string.split(header, '=')
+    try: spec, sets = header.split('=')
     except ValueError: return None
     if spec != 'bytes':
         return None
 
     # The sets are delimited by commas.
-    sets = string.split(sets, ',')
+    sets = sets.split(',')
     # Filter out empty values, things like ',,' are allowed in the spec
     sets = filter(None, sets)
     # We need at least one set
@@ -59,7 +59,7 @@
         return None
 
     for set in sets:
-        try: start, end = string.split(set, '-')
+        try: start, end = set.split('-')
         except ValueError: return None
 
         # Catch empty sets


=== Zope/lib/python/ZPublisher/HTTPRequest.py 1.57.2.2 => 1.57.2.3 ===
 __version__='$Revision$'[11:-2]
 
-import re, sys, os, string, urllib, time, whrandom, cgi
-from string import lower, atoi, rfind, split, strip, join, upper, find
+import re, sys, os,  urllib, time, whrandom, cgi
 from BaseRequest import BaseRequest
 from HTTPResponse import HTTPResponse
 from cgi import FieldStorage, escape
@@ -159,7 +158,7 @@
         """ Treat the current publishing object as a VirtualRoot """
         other = self.other
         if type(path) is type(''):
-            path = filter(None, split(path, '/'))
+            path = filter(None, path.split( '/'))
         self._script[:] = map(quote, path)
         del self._steps[:]
         parents = other['PARENTS']
@@ -171,7 +170,7 @@
     def physicalPathToVirtualPath(self, path):
         """ Remove the path to the VirtualRoot from a physical path """
         if type(path) is type(''):
-            path = split(path, '/')
+            path = path.split( '/')
         rpp = self.other.get('VirtualRootPhysicalPath', ('',))
         i = 0
         for name in rpp[:len(path)]:
@@ -188,7 +187,7 @@
             path.insert(0, '')
         else:
             path.insert(0, self['SERVER_URL'])
-        return join(path, '/')
+        return '/'.join(path)
 
     def physicalPathFromURL(self, URL):
         """ Convert a URL into a physical path in the current context.
@@ -196,9 +195,9 @@
             hosting context, a ValueError is raised."""
         other = self.other
         bad_server_url = 0
-        path = filter(None, split(URL, '/'))
+        path = filter(None, URL.split( '/'))
 
-        if find(URL, '://') >= 0:
+        if URL.find( '://') >= 0:
             path = path[2:]
 
         # Check the path against BASEPATH1
@@ -216,8 +215,8 @@
 
     def _resetURLS(self):
         other = self.other
-        other['URL'] = join([other['SERVER_URL']] + self._script +
-                            self._steps, '/')
+        other['URL'] = '/'.join([other['SERVER_URL']] + self._script +
+                            self._steps)
         for x in self._urls:
             del self.other[x]
         self._urls = ()
@@ -249,20 +248,20 @@
         ################################################################
         # Get base info first. This isn't likely to cause
         # errors and might be useful to error handlers.
-        b=script=strip(get_env('SCRIPT_NAME',''))
+        b=script=get_env('SCRIPT_NAME','').strip()
 
         # _script and the other _names are meant for URL construction
-        self._script = map(quote, filter(None, split(script, '/')))
+        self._script = map(quote, filter(None, script.split( '/')))
         
         while b and b[-1]=='/': b=b[:-1]
-        p = rfind(b,'/')
+        p = b.rfind('/')
         if p >= 0: b=b[:p+1]
         else: b=''
         while b and b[0]=='/': b=b[1:]
 
         server_url=get_env('SERVER_URL',None)
         if server_url is not None:
-             other['SERVER_URL'] = server_url = strip(server_url)
+             other['SERVER_URL'] = server_url = server_url.strip()
         else:
              if have_env('HTTPS') and (
                  environ['HTTPS'] == "on" or environ['HTTPS'] == "ON"):
@@ -273,7 +272,7 @@
              else: protocol = 'http'
 
              if have_env('HTTP_HOST'):
-                 host = strip(environ['HTTP_HOST'])
+                 host = environ['HTTP_HOST'].strip()
                  hostname, port = splitport(host)
 
                  # NOTE: some (DAV) clients manage to forget the port. This
@@ -288,7 +287,7 @@
                  #         port=s_port
 
              else:
-                 hostname = strip(environ['SERVER_NAME'])
+                 hostname = environ['SERVER_NAME'].strip()
                  port = environ['SERVER_PORT']
              self.setServerURL(protocol=protocol, hostname=hostname, port=port)
              server_url = other['SERVER_URL']
@@ -329,7 +328,6 @@
         getattr=getattr,
         setattr=setattr,
         search_type=re.compile('(:[a-zA-Z][a-zA-Z0-9_]+|\\.[xy])$').search,
-        rfind=string.rfind,
         ):
         """Process request inputs
 
@@ -396,7 +394,7 @@
                 # a re search.
                 
 
-                l=rfind(key,':')
+                l=key.rfind(':')
                 if l >= 0:
                     mo = search_type(key,l)
                     if mo: l=mo.start(0)
@@ -434,7 +432,7 @@
                         elif type_name == 'ignore_empty':
                             if not item: flags=flags|EMPTY
     
-                        l=rfind(key,':')
+                        l=key.rfind(':')
                         if l < 0: break
                         mo=search_type(key,l)
                         if mo: l = mo.start(0)
@@ -452,8 +450,8 @@
 
                     #Split the key and its attribute
                     if flags&REC:
-                        key=split(key,".")
-                        key, attr=join(key[:-1],"."), key[-1]
+                        key=key.split(".")
+                        key, attr=".".join(key[:-1]), key[-1]
                        
                     # defer conversion
                     if flags&CONVERTED:
@@ -632,13 +630,13 @@
             if tuple_items:
                 for key in tuple_items.keys():
                    # Split the key and get the attr
-                   k=split(key, ".")
-                   k,attr=join(k[:-1], "."), k[-1]
+                   k=key.split( ".")
+                   k,attr='.'.join(k[:-1]), k[-1]
                    a = attr
                    # remove any type_names in the attr
                    while not a=='':
-                      a=split(a, ":")
-                      a,new=join(a[:-1], ":"), a[-1]
+                      a=a.split( ":")
+                      a,new=':'.join(a[:-1]), a[-1]
                    attr = new
                    if form.has_key(k):
                       # If the form has the split key get its value
@@ -688,7 +686,7 @@
         # namespace (e.g. the host, port or script name dont
         # match that of the current request), a ValueError will
         # be raised.
-        if find(url, self.script) != 0:
+        if url.find(self.script) != 0:
             raise ValueError, 'Different namespace.'
         path=url[len(self.script):]
         while path and path[0]=='/':  path=path[1:]
@@ -746,7 +744,7 @@
         should all return the Content-Type header, if available.
         """
         environ=self.environ
-        name=upper(join(split(name,"-"),"_"))
+        name=('_'.join(name.split("-"))).upper()
         val=environ.get(name, None)
         if val is not None:
             return val
@@ -783,7 +781,7 @@
                     path = [''] + path[:n]
                 else:
                     path = [other['SERVER_URL']] + path[:n]
-                other[key] = URL = join(path, '/')
+                other[key] = URL = '/'.join(path)
                 self._urls = self._urls + (key,)
                 return URL
 
@@ -813,7 +811,7 @@
                     v.insert(0, '')
                 else:
                     v.insert(0, other['SERVER_URL'])
-                other[key] = URL = join(v, '/')
+                other[key] = URL = '/'.join(v)
                 self._urls = self._urls + (key,)
                 return URL
 
@@ -960,10 +958,10 @@
         global base64
         auth=self._auth
         if auth:
-            if lower(auth[:6]) == 'basic ':
+            if auth[:6].lower() == 'basic ':
                 if base64 is None: import base64
-                [name,password] = split(
-                    base64.decodestring(split(auth)[-1]), ':')
+                [name,password] = \
+                    base64.decodestring(split(auth)[-1]).split(':')
                 return name, password
 
 
@@ -1100,14 +1098,13 @@
     def __str__(self):
         L1 = self.__dict__.items()
         L1.sort()
-        return join(map(lambda item: "%s: %s" % item, L1), ", ") 
+        return ", ".join(map(lambda item: "%s: %s" % item, L1)) 
 
     def __repr__(self):
         L1 = self.__dict__.items()
         L1.sort()
-        return join(
-            map(lambda item: "%s: %s" % (item[0], repr(item[1])), L1)
-            , ", ") 
+        return ', '.join(
+            map(lambda item: "%s: %s" % (item[0], repr(item[1])), L1))
 
 # Flags
 SEQUENCE=1


=== Zope/lib/python/ZPublisher/HTTPResponse.py 1.52 => 1.52.2.1 ===
 __version__='$Revision$'[11:-2]
 
-import string, types, sys,  re
-from string import find, rfind, lower, upper, strip, split, join, translate
+import  types, sys,  re
+from string import translate, maketrans
 from types import StringType, InstanceType, LongType
 from BaseResponse import BaseResponse
 from zExceptions import Unauthorized
 
-nl2sp=string.maketrans('\n',' ')
+nl2sp=maketrans('\n',' ')
 
 status_reasons={
 100: 'Continue',
@@ -76,13 +76,13 @@
 # Add mappings for builtin exceptions and
 # provide text -> error code lookups.
 for key, val in status_reasons.items():
-    status_codes[lower(join(split(val, ' '), ''))]=key
-    status_codes[lower(val)]=key
+    status_codes[''.join(val.split(' ')).lower()]=key
+    status_codes[val.lower()]=key
     status_codes[key]=key
     status_codes[str(key)]=key
 en=filter(lambda n: n[-5:]=='Error', dir(__builtins__))
-for name in map(lower, en):
-    status_codes[name]=500
+for name in en:
+    status_codes[name.lower()]=500
 status_codes['nameerror']=503
 status_codes['keyerror']=503
 status_codes['redirect']=300
@@ -165,7 +165,7 @@
             return
                 
         if type(status) is types.StringType:
-            status=lower(status)
+            status=status.lower()
         if status_codes.has_key(status): status=status_codes[status]
         else: status=500
         self.status=status
@@ -182,7 +182,7 @@
         literal flag is true, the case of the header name is preserved,
         otherwise word-capitalization will be performed on the header
         name on output.'''
-        key=lower(name)
+        key=name.lower()
         if accumulate_header(key):
             self.accumulated_headers=(
                 "%s%s: %s\n" % (self.accumulated_headers, name, value))
@@ -232,7 +232,7 @@
 
         body=str(body)
         l=len(body)
-        if ((l < 200) and body[:1]=='<' and find(body,'>')==l-1 and 
+        if ((l < 200) and body[:1]=='<' and body.find('>')==l-1 and 
             bogus_str_search(body) is not None):
             self.notFoundError(body[1:-1])
         else:
@@ -258,8 +258,8 @@
         content_type=self.headers['content-type']
         if content_type == 'text/html' or latin1_alias_match(
             content_type) is not None:
-            body = join(split(body,'\213'),'&lt;')
-            body = join(split(body,'\233'),'&gt;')
+            body = '&lt;'.join(body.split('\213'))
+            body = '&gt;'.join(body.split('\233'))
 
         self.setHeader('content-length', len(self.body))
         self.insertBase()
@@ -276,7 +276,7 @@
                    ):
 
         # Only insert a base tag if content appears to be html.
-        content_type = split(self.headers.get('content-type', ''), ';')[0]
+        content_type = self.headers.get('content-type', '').split(';')[0]
         if content_type and (content_type != 'text/html'):
             return
 
@@ -355,14 +355,14 @@
         self.setHeader(name,h)
 
     def isHTML(self,str):
-        return lower(strip(str)[:6]) == '<html>' or find(str,'</') > 0
+        return str.strip().lower()[:6] == '<html>' or str.find('</') > 0
 
     def quoteHTML(self,text,
                   subs={'&':'&amp;', "<":'&lt;', ">":'&gt;', '\"':'&quot;'}
                   ):
         for ent in '&<>\"':
-            if find(text, ent) >= 0:
-                text=join(split(text,ent),subs[ent])
+            if text.find( ent) >= 0:
+                text=subs[ent].join(text.split(ent))
 
         return text
          
@@ -391,13 +391,12 @@
                 except: pass
                 tb = tb.tb_next
                 n = n + 1
-        result.append(join(traceback.format_exception_only(etype, value),
-                           ' '))
+        result.append(' '.join(traceback.format_exception_only(etype, value)))
         return result
 
     def _traceback(self, t, v, tb):
         tb = self.format_exception(t, v, tb, 200)
-        tb = join(tb, '\n')
+        tb = '\n'.join(tb)
         tb = self.quoteHTML(tb)
         if self.debug_mode: _tbopen, _tbclose = '<PRE>', '</PRE>'
         else:               _tbopen, _tbclose = '''<pre
@@ -533,7 +532,7 @@
             et = translate(str(t), nl2sp)
             self.setHeader('bobo-exception-type', et)
             ev = translate(str(v), nl2sp)
-            if find(ev, '<html>') >= 0:
+            if ev.find( '<html>') >= 0:
                 ev = 'bobo exception'
             self.setHeader('bobo-exception-value', ev[:255])
             # Get the tb tail, which is the interesting part:
@@ -590,8 +589,8 @@
                 'Sorry, a site error occurred.<p>'
                  + self._traceback(t, v, tb)),
                  is_error=1)
-        elif (lower(strip(b)[:6])=='<html>' or
-              lower(strip(b)[:14])=='<!doctype html'):
+        elif b.strip().lower()[:6]=='<html>' or \
+              b.strip().lower()[:14]=='<!doctype html':
             # error is an HTML document, not just a snippet of html
             body = self.setBody(b + self._traceback(t, '(see above)', tb),
                               is_error=1)
@@ -614,7 +613,7 @@
 
             cookie='Set-Cookie: %s="%s"' % (name, attrs['value'])
             for name, v in attrs.items():
-                name=lower(name)
+                name=name.lower()
                 if name=='expires': cookie = '%s; Expires=%s' % (cookie,v)
                 elif name=='domain': cookie = '%s; Domain=%s' % (cookie,v)
                 elif name=='path': cookie = '%s; Path=%s' % (cookie,v)
@@ -658,20 +657,20 @@
         if headers.has_key('status'):
             del headers['status']
         for key, val in headers.items():
-            if lower(key)==key:
+            if key.lower()==key:
                 # only change non-literal header names
-                key="%s%s" % (upper(key[:1]), key[1:])
+                key="%s%s" % (key[:1].upper(), key[1:])
                 start=0
-                l=find(key,'-',start)
+                l=key.find('-',start)
                 while l >= start:
-                    key="%s-%s%s" % (key[:l],upper(key[l+1:l+2]),key[l+2:])
+                    key="%s-%s%s" % (key[:l],key[l+1:l+2].upper(),key[l+2:])
                     start=l+1
-                    l=find(key,'-',start)
+                    l=key.find('-',start)
             append("%s: %s" % (key, val))
         if self.cookies:
             headersl=headersl+self._cookie_list()
         headersl[len(headersl):]=[self.accumulated_headers, body]
-        return join(headersl,'\n')
+        return '\n'.join(headersl)
 
     def write(self,data):
         """\


=== Zope/lib/python/ZPublisher/Publish.py 1.154 => 1.154.2.1 ===
 
 import sys, os
-from string import lower, atoi, rfind, strip
 from Response import Response
 from Request import Request
 from maybe_lock import allocate_lock
@@ -68,7 +67,7 @@
     
         # First check for "cancel" redirect:
         cancel=''
-        if lower(strip(request_get('SUBMIT','')))=='cancel':
+        if request_get('SUBMIT','').strip().lower()=='cancel':
             cancel=request_get('CANCEL_ACTION','')
             if cancel: raise 'Redirect', cancel
     
@@ -81,7 +80,7 @@
             bobo_before()
     
         # Get a nice clean path list:
-        path=strip(request_get('PATH_INFO'))
+        path=request_get('PATH_INFO').strip()
     
         request['PARENTS']=parents=[object]
         


=== Zope/lib/python/ZPublisher/Test.py 1.38 => 1.38.2.1 ===
 __version__='$Revision$'[11:-2]
 
-import sys, traceback, profile, os, getopt, string
+import sys, traceback, profile, os, getopt
 from time import clock
 repeat_count=100
 TupleType=type(())
 
 
 def main():
-    import sys, os, getopt, string
+    import sys, os, getopt
     global repeat_count
 
     try:
@@ -127,9 +127,9 @@
         elif opt=='-p':
             profile=val
         elif opt=='-r':
-            repeat_count=string.atoi(val)
+            repeat_count=int(val)
         elif opt=='-e':
-            opt=string.find(val,'=')
+            opt=val.find('=')
             if opt <= 0: raise 'Invalid argument to -e', val
             env[val[:opt]]=val[opt+1:]
 
@@ -266,7 +266,7 @@
     env['SERVER_HOSTNAME']='bobo.server.host'
     env['GATEWAY_INTERFACE']='CGI/1.1 '
     env['SCRIPT_NAME']=script
-    p=string.split(path_info,'?')
+    p=path_info.split('?')
     if   len(p)==1: env['PATH_INFO'] = p[0]
     elif len(p)==2: [env['PATH_INFO'], env['QUERY_STRING']]=p
     else: raise TypeError, ''


=== Zope/lib/python/ZPublisher/xmlrpc.py 1.9 => 1.9.2.1 ===
 
 import sys
-from string import replace
 from HTTPResponse import HTTPResponse
 import xmlrpclib
 
@@ -47,7 +46,7 @@
     #     ('examples.getStateName', (41,))
     params, method = xmlrpclib.loads(data)
     # Translate '.' to '/' in meth to represent object traversal.
-    method = replace(method, '.', '/')
+    method = method.replace('.', '/')
     return method, params
 
 # See below