mirror of
https://github.com/python/cpython.git
synced 2025-08-04 17:08:35 +00:00
Run this demo script through reindent.py; output has been verified to remain the same
This commit is contained in:
parent
9b12d9d0d2
commit
30dd9bc0bf
1 changed files with 77 additions and 77 deletions
|
@ -1,125 +1,125 @@
|
|||
import string
|
||||
|
||||
def MDPrint(str):
|
||||
outstr = ''
|
||||
for i in str:
|
||||
o = ord(i)
|
||||
outstr = outstr \
|
||||
+ string.hexdigits[(o >> 4) & 0xF] \
|
||||
+ string.hexdigits[o & 0xF]
|
||||
print outstr,
|
||||
|
||||
outstr = ''
|
||||
for i in str:
|
||||
o = ord(i)
|
||||
outstr = outstr \
|
||||
+ string.hexdigits[(o >> 4) & 0xF] \
|
||||
+ string.hexdigits[o & 0xF]
|
||||
print outstr,
|
||||
|
||||
|
||||
from time import time
|
||||
|
||||
def makestr(start, end):
|
||||
result = ''
|
||||
for i in range(start, end + 1):
|
||||
result = result + chr(i)
|
||||
result = ''
|
||||
for i in range(start, end + 1):
|
||||
result = result + chr(i)
|
||||
|
||||
return result
|
||||
|
||||
return result
|
||||
|
||||
|
||||
from md5 import md5
|
||||
|
||||
def MDTimeTrial():
|
||||
TEST_BLOCK_SIZE = 1000
|
||||
TEST_BLOCKS = 10000
|
||||
TEST_BLOCK_SIZE = 1000
|
||||
TEST_BLOCKS = 10000
|
||||
|
||||
TEST_BYTES = TEST_BLOCK_SIZE * TEST_BLOCKS
|
||||
TEST_BYTES = TEST_BLOCK_SIZE * TEST_BLOCKS
|
||||
|
||||
# initialize test data, need temporary string filler
|
||||
|
||||
filsiz = 1 << 8
|
||||
filler = makestr(0, filsiz-1)
|
||||
data = filler * (TEST_BLOCK_SIZE / filsiz);
|
||||
data = data + filler[:(TEST_BLOCK_SIZE % filsiz)]
|
||||
# initialize test data, need temporary string filler
|
||||
|
||||
del filsiz, filler
|
||||
filsiz = 1 << 8
|
||||
filler = makestr(0, filsiz-1)
|
||||
data = filler * (TEST_BLOCK_SIZE / filsiz);
|
||||
data = data + filler[:(TEST_BLOCK_SIZE % filsiz)]
|
||||
|
||||
del filsiz, filler
|
||||
|
||||
|
||||
# start timer
|
||||
print 'MD5 time trial. Processing', TEST_BYTES, 'characters...'
|
||||
t1 = time()
|
||||
# start timer
|
||||
print 'MD5 time trial. Processing', TEST_BYTES, 'characters...'
|
||||
t1 = time()
|
||||
|
||||
mdContext = md5()
|
||||
mdContext = md5()
|
||||
|
||||
for i in range(TEST_BLOCKS):
|
||||
mdContext.update(data)
|
||||
for i in range(TEST_BLOCKS):
|
||||
mdContext.update(data)
|
||||
|
||||
str = mdContext.digest()
|
||||
t2 = time()
|
||||
str = mdContext.digest()
|
||||
t2 = time()
|
||||
|
||||
MDPrint(str)
|
||||
print 'is digest of test input.'
|
||||
print 'Seconds to process test input:', t2 - t1
|
||||
print 'Characters processed per second:', TEST_BYTES / (t2 - t1)
|
||||
MDPrint(str)
|
||||
print 'is digest of test input.'
|
||||
print 'Seconds to process test input:', t2 - t1
|
||||
print 'Characters processed per second:', TEST_BYTES / (t2 - t1)
|
||||
|
||||
|
||||
def MDString(str):
|
||||
MDPrint(md5(str).digest())
|
||||
print '"' + str + '"'
|
||||
MDPrint(md5(str).digest())
|
||||
print '"' + str + '"'
|
||||
|
||||
|
||||
def MDFile(filename):
|
||||
f = open(filename, 'rb');
|
||||
mdContext = md5()
|
||||
f = open(filename, 'rb');
|
||||
mdContext = md5()
|
||||
|
||||
while 1:
|
||||
data = f.read(1024)
|
||||
if not data:
|
||||
break
|
||||
mdContext.update(data)
|
||||
while 1:
|
||||
data = f.read(1024)
|
||||
if not data:
|
||||
break
|
||||
mdContext.update(data)
|
||||
|
||||
MDPrint(mdContext.digest())
|
||||
print filename
|
||||
MDPrint(mdContext.digest())
|
||||
print filename
|
||||
|
||||
|
||||
import sys
|
||||
|
||||
def MDFilter():
|
||||
mdContext = md5()
|
||||
mdContext = md5()
|
||||
|
||||
while 1:
|
||||
data = sys.stdin.read(16)
|
||||
if not data:
|
||||
break
|
||||
mdContext.update(data)
|
||||
while 1:
|
||||
data = sys.stdin.read(16)
|
||||
if not data:
|
||||
break
|
||||
mdContext.update(data)
|
||||
|
||||
MDPrint(mdContext.digest())
|
||||
print
|
||||
MDPrint(mdContext.digest())
|
||||
print
|
||||
|
||||
|
||||
def MDTestSuite():
|
||||
print 'MD5 test suite results:'
|
||||
MDString('')
|
||||
MDString('a')
|
||||
MDString('abc')
|
||||
MDString('message digest')
|
||||
MDString(makestr(ord('a'), ord('z')))
|
||||
MDString(makestr(ord('A'), ord('Z')) \
|
||||
+ makestr(ord('a'), ord('z')) \
|
||||
+ makestr(ord('0'), ord('9')))
|
||||
MDString((makestr(ord('1'), ord('9')) + '0') * 8)
|
||||
print 'MD5 test suite results:'
|
||||
MDString('')
|
||||
MDString('a')
|
||||
MDString('abc')
|
||||
MDString('message digest')
|
||||
MDString(makestr(ord('a'), ord('z')))
|
||||
MDString(makestr(ord('A'), ord('Z')) \
|
||||
+ makestr(ord('a'), ord('z')) \
|
||||
+ makestr(ord('0'), ord('9')))
|
||||
MDString((makestr(ord('1'), ord('9')) + '0') * 8)
|
||||
|
||||
# Contents of file foo are "abc"
|
||||
MDFile('foo')
|
||||
# Contents of file foo are "abc"
|
||||
MDFile('foo')
|
||||
|
||||
|
||||
from sys import argv
|
||||
|
||||
# I don't wanna use getopt(), since I want to use the same i/f...
|
||||
def main():
|
||||
if len(argv) == 1:
|
||||
MDFilter()
|
||||
for arg in argv[1:]:
|
||||
if arg[:2] == '-s':
|
||||
MDString(arg[2:])
|
||||
elif arg == '-t':
|
||||
MDTimeTrial()
|
||||
elif arg == '-x':
|
||||
MDTestSuite()
|
||||
else:
|
||||
MDFile(arg)
|
||||
if len(argv) == 1:
|
||||
MDFilter()
|
||||
for arg in argv[1:]:
|
||||
if arg[:2] == '-s':
|
||||
MDString(arg[2:])
|
||||
elif arg == '-t':
|
||||
MDTimeTrial()
|
||||
elif arg == '-x':
|
||||
MDTestSuite()
|
||||
else:
|
||||
MDFile(arg)
|
||||
|
||||
main()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue