[Zope-Checkins] CVS: Zope/utilities - requestprofiler.py:1.11
Chris McDonough
chrism@zope.com
Fri, 14 Dec 2001 14:26:31 -0500
Update of /cvs-repository/Zope/utilities
In directory cvs.zope.org:/tmp/cvs-serv25571
Modified Files:
requestprofiler.py
Log Message:
You can now again use requestprofiler with python1.5.
Timed modes no longer require a start and an end. If a start and an end
is not specified, the start time will be considered the first time
encountered in the set of log files and the end time will be considered
the last time encountered.
The default resolution for timed mode is now 60 seconds.
=== Zope/utilities/requestprofiler.py 1.10 => 1.11 ===
+#!/usr/bin/env python
##############################################################################
#
@@ -256,17 +256,22 @@
return retn
def analyze(files, top, sortf, start=None, end=None, mode='cumulative',
- resolution='10'):
+ resolution=60):
beginrequests = {}
cumulative = {}
finished = []
unfinished = {}
decidelines = {} # filename to filepos
+ computed_start = None
+ computed_end = None
while 1:
tup = get_earliest_file_data(files)
if tup is None:
break
code, id, fromepoch, desc = tup
+ if computed_start is None:
+ computed_start = fromepoch
+ computed_end = fromepoch
if start is not None and fromepoch < start: continue
if end is not None and fromepoch > end: break
if code == 'U':
@@ -284,7 +289,11 @@
for pending_req in unfinished.values():
pending_req.active = pending_req.active + 1
unfinished[id] = request
- request.put(code, int(fromepoch), desc)
+ t = int(fromepoch)
+ try:
+ request.put(code, t, desc)
+ except:
+ print "Unable to handle entry: %s %s %s"%(code, t, desc)
if request.isfinished():
del unfinished[id]
finished.append(request)
@@ -315,7 +324,14 @@
if mode=='timed':
timeDict = {}
timesort(timeDict,requests)
- timewrite(timeDict,start,end,resolution)
+ if start and end:
+ timewrite(timeDict,start,end,resolution)
+ if start and not end:
+ timewrite(timeDict,start,computed_end,resolution)
+ if end and not start:
+ timewrite(timeDict,computed_start,end,resolution)
+ if not end and not start:
+ timewrite(timeDict,computed_start,computed_end,resolution)
else:
dict.sort(sortf)
@@ -359,7 +375,7 @@
if not dict.has_key(t):
dict[t] = 0
- dict[t]+=1
+ dict[t]=dict[t]+1
def timewrite(dict,start,end,resolution):