summaryrefslogtreecommitdiff
path: root/coverage/execfile.py
diff options
context:
space:
mode:
authorNed Batchelder <ned@nedbatchelder.com>2018-01-10 21:47:09 -0500
committerNed Batchelder <ned@nedbatchelder.com>2018-01-10 21:47:09 -0500
commite3761571cfe9c21baa138d58c1f304bdbca572ae (patch)
treec621d6290307736ca8951296cd1135a91dae18d7 /coverage/execfile.py
parent74e7651c2500eb4f39bf8bf8f39c591d20b81fe3 (diff)
downloadpython-coveragepy-git-e3761571cfe9c21baa138d58c1f304bdbca572ae.tar.gz
Python 3.7 tweaked the layout of .pyc files
Diffstat (limited to 'coverage/execfile.py')
-rw-r--r--coverage/execfile.py19
1 files changed, 14 insertions, 5 deletions
diff --git a/coverage/execfile.py b/coverage/execfile.py
index 693f54fb..ffe3ca18 100644
--- a/coverage/execfile.py
+++ b/coverage/execfile.py
@@ -5,6 +5,7 @@
import marshal
import os
+import struct
import sys
import types
@@ -253,11 +254,19 @@ def make_code_from_pyc(filename):
if magic != PYC_MAGIC_NUMBER:
raise NoCode("Bad magic number in .pyc file")
- # Skip the junk in the header that we don't need.
- fpyc.read(4) # Skip the moddate.
- if sys.version_info >= (3, 3):
- # 3.3 added another long to the header (size), skip it.
- fpyc.read(4)
+ date_based = True
+ if sys.version_info >= (3, 7):
+ flags = struct.unpack('<L', fpyc.read(4))[0]
+ hash_based = flags & 0x01
+ if hash_based:
+ fpyc.read(8) # Skip the hash.
+ date_based = False
+ if date_based:
+ # Skip the junk in the header that we don't need.
+ fpyc.read(4) # Skip the moddate.
+ if sys.version_info >= (3, 3):
+ # 3.3 added another long to the header (size), skip it.
+ fpyc.read(4)
# The rest of the file is the code object we want.
code = marshal.load(fpyc)