Kaydet (Commit) 776e7014 authored tarafından Brett Cannon's avatar Brett Cannon

Simplify write_bytecode for importlib.

üst 20b56e1a
...@@ -403,9 +403,8 @@ class _PyFileLoader(object): ...@@ -403,9 +403,8 @@ class _PyFileLoader(object):
return open(source_path, encoding=encoding).read() return open(source_path, encoding=encoding).read()
@check_name @check_name
def write_bytecode(self, name, magic, timestamp, data): def write_bytecode(self, name, data):
"""Write out 'data' for the specified module using the specific """Write out 'data' for the specified module, returning a boolean
timestamp, returning a boolean
signifying if the write-out actually occurred. signifying if the write-out actually occurred.
Raises ImportError (just like get_source) if the specified module Raises ImportError (just like get_source) if the specified module
...@@ -418,8 +417,6 @@ class _PyFileLoader(object): ...@@ -418,8 +417,6 @@ class _PyFileLoader(object):
file = _fileio._FileIO(bytecode_path, 'w') file = _fileio._FileIO(bytecode_path, 'w')
try: try:
with closing(file) as bytecode_file: with closing(file) as bytecode_file:
bytecode_file.write(magic)
bytecode_file.write(marshal._w_long(timestamp))
bytecode_file.write(data) bytecode_file.write(data)
return True return True
except IOError as exc: except IOError as exc:
...@@ -430,29 +427,7 @@ class _PyFileLoader(object): ...@@ -430,29 +427,7 @@ class _PyFileLoader(object):
@check_name @check_name
def get_code(self, name): def get_code(self, name):
"""Return the code object for the module. """Return the code object for the module."""
'self' must implement:
* read_bytecode(name:str) -> (int, int, bytes) or None
Return the magic number, timestamp, and bytecode for the
module. None is returned if not bytecode is available.
* source_mtime(name:str) -> int
Return the last modification time for the source of the module.
Returns None if their is no source.
* read_source(name:str) -> (bytes, str)
Return the source code for the module and the path to use in
the call to 'compile'. Not called if source_mtime returned
None.
* write_bytecode(name:str, magic:bytes, timestamp:int, data:str)
Write out bytecode for the module with the specified magic
number and timestamp. Not called if sys.dont_write_bytecode is
True.
"""
# XXX Care enough to make sure this call does not happen if the magic # XXX Care enough to make sure this call does not happen if the magic
# number is bad? # number is bad?
source_timestamp = self.source_mtime(name) source_timestamp = self.source_mtime(name)
...@@ -507,8 +482,10 @@ class _PyFileLoader(object): ...@@ -507,8 +482,10 @@ class _PyFileLoader(object):
code_object = compile(source, source_path, 'exec', dont_inherit=True) code_object = compile(source, source_path, 'exec', dont_inherit=True)
# Generate bytecode and write it out. # Generate bytecode and write it out.
if not sys.dont_write_bytecode: if not sys.dont_write_bytecode:
data = marshal.dumps(code_object) data = bytearray(imp.get_magic())
self.write_bytecode(name, imp.get_magic(), source_timestamp, data) data.extend(marshal._w_long(source_timestamp))
data.extend(marshal.dumps(code_object))
self.write_bytecode(name, data)
return code_object return code_object
def get_data(self, path): def get_data(self, path):
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment