# Copyright (C) 2013 The Android Open Source Project # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. import os from os import path REPO_ROOTS = { 'GERRIT': 'http://gerrit-maven.storage.googleapis.com', 'GERRIT_API': 'https://gerrit-api.commondatastorage.googleapis.com/release', 'MAVEN_CENTRAL': 'http://repo1.maven.org/maven2', 'MAVEN_LOCAL': 'file://' + path.expanduser('~/.m2/repository'), } def resolve_url(url, redirects): """ Resolve URL of a Maven artifact. prefix:path is passed as URL. prefix identifies known or custom repositories that can be rewritten in redirects set, passed as second arguments. A special case is supported, when prefix neither exists in REPO_ROOTS, no in redirects set: the url is returned as is. This enables plugins to pass custom maven_repository URL as is directly to maven_jar(). Returns a resolved path for Maven artifact. """ s = url.find(':') if s < 0: return url scheme, rest = url[:s], url[s+1:] if scheme in redirects: root = redirects[scheme] elif scheme in REPO_ROOTS: root = REPO_ROOTS[scheme] else: return url root = root.rstrip('/') rest = rest.lstrip('/') return '/'.join([root, rest]) def hash_file(hash_obj, path): """Hash the contents of a file. Args: hash_obj: an open hash object, e.g. hashlib.sha1(). path: path to the file to hash. Returns: The passed-in hash_obj. """ with open(path, 'rb') as f: while True: b = f.read(8192) if not b: break hash_obj.update(b) return hash_obj def hash_bower_component(hash_obj, path): """Hash the contents of a bower component directory. This is a stable hash of a directory downloaded with `bower install`, minus the .bower.json file, which is autogenerated each time by bower. Used in lieu of hashing a zipfile of the contents, since zipfiles are difficult to hash in a stable manner. Args: hash_obj: an open hash object, e.g. hashlib.sha1(). path: path to the directory to hash. Returns: The passed-in hash_obj. """ if not os.path.isdir(path): raise ValueError('Not a directory: %s' % path) path = os.path.abspath(path) for root, dirs, files in os.walk(path): dirs.sort() for f in sorted(files): if f == '.bower.json': continue p = os.path.join(root, f) hash_obj.update(p[len(path)+1:]) hash_file(hash_obj, p) return hash_obj