summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFlorent Xicluna <florent.xicluna@gmail.com>2010-08-09 12:26:44 (GMT)
committerFlorent Xicluna <florent.xicluna@gmail.com>2010-08-09 12:26:44 (GMT)
commitc7eaede21ecb5259f2bd9e160a89b82d19cfb19b (patch)
treee1e692ae4b404fb94438250a6961047000732bc4
parente4a3380bb07a1bae5fde5d7b4e96519ca603319c (diff)
downloadcpython-c7eaede21ecb5259f2bd9e160a89b82d19cfb19b.zip
cpython-c7eaede21ecb5259f2bd9e160a89b82d19cfb19b.tar.gz
cpython-c7eaede21ecb5259f2bd9e160a89b82d19cfb19b.tar.bz2
Fix ``Tools/scripts/checkpyc.py`` after PEP 3147.
-rw-r--r--Misc/NEWS2
-rwxr-xr-xTools/scripts/checkpyc.py37
2 files changed, 22 insertions, 17 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index 00188d4..454534d 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -150,6 +150,8 @@ Library
Tools/Demos
-----------
+- Fix ``Tools/scripts/checkpyc.py`` after PEP 3147.
+
- Issue #8867: Fix ``Tools/scripts/serve.py`` to work with files containing
non-ASCII content.
diff --git a/Tools/scripts/checkpyc.py b/Tools/scripts/checkpyc.py
index 2dc948a..d4fdce2 100755
--- a/Tools/scripts/checkpyc.py
+++ b/Tools/scripts/checkpyc.py
@@ -7,14 +7,17 @@ import os
from stat import ST_MTIME
import imp
+# PEP 3147 compatibility (PYC Repository Directories)
+cache_from_source = (imp.cache_from_source if hasattr(imp, 'get_tag') else
+ lambda path: path + 'c')
+
+
def main():
- silent = 0
- verbose = 0
- if sys.argv[1:]:
- if sys.argv[1] == '-v':
- verbose = 1
- elif sys.argv[1] == '-s':
- silent = 1
+ if len(sys.argv) > 1:
+ verbose = (sys.argv[1] == '-v')
+ silent = (sys.argv[1] == '-s')
+ else:
+ verbose = silent = False
MAGIC = imp.get_magic()
if not silent:
print('Using MAGIC word', repr(MAGIC))
@@ -26,9 +29,8 @@ def main():
continue
if not silent:
print('Checking ', repr(dirname), '...')
- names.sort()
- for name in names:
- if name[-3:] == '.py':
+ for name in sorted(names):
+ if name.endswith('.py'):
name = os.path.join(dirname, name)
try:
st = os.stat(name)
@@ -37,30 +39,31 @@ def main():
continue
if verbose:
print('Check', repr(name), '...')
- name_c = name + 'c'
+ name_c = cache_from_source(name)
try:
- f = open(name_c, 'r')
+ with open(name_c, 'rb') as f:
+ magic_str = f.read(4)
+ mtime_str = f.read(4)
except IOError:
print('Cannot open', repr(name_c))
continue
- magic_str = f.read(4)
- mtime_str = f.read(4)
- f.close()
if magic_str != MAGIC:
print('Bad MAGIC word in ".pyc" file', end=' ')
print(repr(name_c))
continue
mtime = get_long(mtime_str)
- if mtime == 0 or mtime == -1:
+ if mtime in {0, -1}:
print('Bad ".pyc" file', repr(name_c))
elif mtime != st[ST_MTIME]:
print('Out-of-date ".pyc" file', end=' ')
print(repr(name_c))
+
def get_long(s):
if len(s) != 4:
return -1
- return ord(s[0]) + (ord(s[1])<<8) + (ord(s[2])<<16) + (ord(s[3])<<24)
+ return s[0] + (s[1] << 8) + (s[2] << 16) + (s[3] << 24)
+
if __name__ == '__main__':
main()