diff options
author | Guido van Rossum <guido@python.org> | 1994-08-29 10:52:58 +0000 |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1994-08-29 10:52:58 +0000 |
commit | 92ea6f84dcb5dd336e554e49f6c917e067a2033e (patch) | |
tree | 64107fd12f55c7dda531d2de8aeb9d2e9b9f01a6 /Lib/py_compile.py | |
parent | 038d9b75fa0ffe5cbd9b284684d488c5bc7f4f2c (diff) | |
download | cpython-92ea6f84dcb5dd336e554e49f6c917e067a2033e.tar.gz |
New way of generating .pyc files, thanks to Sjoerd.
urllib.py: '+' is not always safe (even though the RFC says so :-( )
whrandom.py: throw away top bits of time to avoid overflow on Mac
(where times can be negative)
Diffstat (limited to 'Lib/py_compile.py')
-rw-r--r-- | Lib/py_compile.py | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/Lib/py_compile.py b/Lib/py_compile.py new file mode 100644 index 0000000000..ed54f47a70 --- /dev/null +++ b/Lib/py_compile.py @@ -0,0 +1,25 @@ +# Routine to "compile" a .py file to a .pyc file. +# This has intimate knowledge of how Python/import.c does it. +# By Sjoerd Mullender (I forced him to write it :-). + +MAGIC = 0x999903 + +def wr_long(f, x): + f.write(chr( x & 0xff)) + f.write(chr((x >> 8) & 0xff)) + f.write(chr((x >> 16) & 0xff)) + f.write(chr((x >> 24) & 0xff)) + +def compile(file, cfile = None): + import os, marshal, __builtin__ + f = open(file) + codestring = f.read() + timestamp = os.fstat(f.fileno())[8] + f.close() + codeobject = __builtin__.compile(codestring, file, 'exec') + if not cfile: + cfile = file + 'c' + fc = open(cfile, 'w') + wr_long(fc, MAGIC) + wr_long(fc, timestamp) + marshal.dump(codeobject, fc) |