diff --git a/update-sha1sums.py b/update-sha1sums.py index 70ad3ace..0b0ce4df 100755 --- a/update-sha1sums.py +++ b/update-sha1sums.py @@ -16,8 +16,9 @@ # limitations under the License. # -from hashlib import sha1 +import os import sys +from hashlib import sha1 device = 'sm8150-common' vendor = 'oneplus' @@ -31,13 +32,11 @@ needSHA1 = False def cleanup(): for index, line in enumerate(lines): # Skip empty or commented lines - if len(line) == 0 or line[0] == '#': + if len(line) == 0 or line[0] == '#' or '|' not in line: continue # Drop SHA1 hash, if existing - if '|' in line: - line = line.split('|')[0] - lines[index] = '%s' % (line) + lines[index] = line.split('|')[0] def update(): @@ -54,15 +53,14 @@ def update(): if needSHA1: # Remove existing SHA1 hash line = line.split('|')[0] - filePath = line.split(':')[1] if len( - line.split(':')) == 2 else line + filePath = line.split(';')[0].split(':')[-1] if filePath[0] == '-': - file = open('%s/%s' % (vendorPath, filePath[1:]), 'rb').read() - else: - file = open('%s/%s' % (vendorPath, filePath), 'rb').read() + filePath = filePath[1:] + + with open(os.path.join(vendorPath, filePath), 'rb') as f: + hash = sha1(f.read()).hexdigest() - hash = sha1(file).hexdigest() lines[index] = '%s|%s' % (line, hash)