Fix create_chrome_version_h in bootstrap.py

The code was supposed to compare the content of the existing file with
the new content and only replace the file if the content was different,
but it had a fatal flow. It opened the existing file with 'w+' or 'wb+'
and they both truncate the file, so the compare was always false and we
always overwrote the file.
The updated code compares the file content ignoring line endings and
writes the file only if its different or if it didn't exist.
This commit is contained in:
Eran Tiktin 2015-09-07 21:55:02 +03:00
parent b521e45ef8
commit db3e27ceaa

View file

@ -162,13 +162,16 @@ def create_chrome_version_h():
version = f.read() version = f.read()
with open(template_file, 'r') as f: with open(template_file, 'r') as f:
template = f.read() template = f.read()
if sys.platform in ['win32', 'cygwin']: content = template.replace('{PLACEHOLDER}', version.strip())
open_mode = 'wb+'
else: # We update the file only if the content has changed (ignoring line ending
open_mode = 'w+' # differences).
with open(target_file, open_mode) as f: should_write = True
content = template.replace('{PLACEHOLDER}', version.strip()) if os.path.isfile(target_file):
if f.read() != content: with open(target_file, 'r') as f:
should_write = f.read().replace('r', '') != content.replace('r', '')
if should_write:
with open(target_file, 'w') as f:
f.write(content) f.write(content)