| OLD | NEW |
| 1 # Copyright 2014 The Chromium Authors. All rights reserved. | 1 # Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 # Use of this source code is governed by a BSD-style license that can be | 2 # Use of this source code is governed by a BSD-style license that can be |
| 3 # found in the LICENSE file. | 3 # found in the LICENSE file. |
| 4 | 4 |
| 5 import logging | 5 import logging |
| 6 | 6 |
| 7 # pylint: disable=E0611 | 7 # pylint: disable=E0611 |
| 8 from hashlib import sha256 | 8 from hashlib import sha256 |
| 9 | 9 |
| 10 from mopy.memoize import memoize | 10 from mopy_internal.memoize import memoize |
| 11 | 11 |
| 12 _logging = logging.getLogger() | 12 _logging = logging.getLogger() |
| 13 | 13 |
| 14 @memoize | 14 @memoize |
| 15 def file_hash(filename): | 15 def file_hash(filename): |
| 16 """Returns a string representing the hash of the given file.""" | 16 """Returns a string representing the hash of the given file.""" |
| 17 _logging.debug("Hashing %s ...", filename) | 17 _logging.debug("Hashing %s ...", filename) |
| 18 with open(filename, mode='rb') as f: | 18 with open(filename, mode='rb') as f: |
| 19 m = sha256() | 19 m = sha256() |
| 20 while True: | 20 while True: |
| 21 block = f.read(4096) | 21 block = f.read(4096) |
| 22 if not block: | 22 if not block: |
| 23 break | 23 break |
| 24 m.update(block) | 24 m.update(block) |
| 25 _logging.debug(" => %s", m.hexdigest()) | 25 _logging.debug(" => %s", m.hexdigest()) |
| 26 return m.hexdigest() | 26 return m.hexdigest() |
| OLD | NEW |