Index: native_client_sdk/src/build_tools/update_sdktools.py |
diff --git a/native_client_sdk/src/build_tools/update_sdktools.py b/native_client_sdk/src/build_tools/update_sdktools.py |
new file mode 100755 |
index 0000000000000000000000000000000000000000..5a3519177ae3fc1582843da81911ef01859a2aca |
--- /dev/null |
+++ b/native_client_sdk/src/build_tools/update_sdktools.py |
@@ -0,0 +1,124 @@ |
+#!/usr/bin/env python |
+# Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+# Use of this source code is governed by a BSD-style license that can be |
+# found in the LICENSE file. |
+ |
+"""Script that reads omahaproxy and gsutil to determine a version of the |
+sdk_tools bundle to use. |
+ |
+Please note the differences between this script and update_nacl_manifest.py: |
+ |
+update_sdktools.py is run by a SDK-team developer to assist in updating to a |
+new sdk_tools bundle. A file on the developer's hard drive is modified, and |
+must be checked in for the new sdk_tools bundle to be used. |
+ |
+update_nacl_manifest.py is customarily run by a cron job, and does not check in |
+any changes. Instead it modifies the manifest file in commondatastorage.""" |
+ |
+ |
+import collections |
+import difflib |
+import json |
+from manifest_util import DownloadAndComputeHash |
+import optparse |
+import re |
+import sys |
+from update_nacl_manifest import RealDelegate |
noelallen1
2013/01/08 23:22:57
optional seperate CL: The name RealDelegate is un
binji
2013/01/09 19:13:25
Added TODO with bug# below.
|
+import urllib2 |
+ |
+ |
+SDK_TOOLS_DESCRIPTION_FORMAT = 'Native Client SDK Tools, revision %d' |
+BUCKET_PATH = 'nativeclient-mirror/nacl/nacl_sdk/' |
+GS_BUCKET_PATH = 'gs://' + BUCKET_PATH |
+HTTPS_BUCKET_PATH = 'https://commondatastorage.googleapis.com/' + BUCKET_PATH |
+ |
+ |
+def GetSdkToolsUrl(revision): |
+ return HTTPS_BUCKET_PATH + 'trunk.%d/sdk_tools.tgz' % revision |
+ |
+ |
+def GetTrunkRevisions(delegate): |
+ urls = delegate.GsUtil_ls(GS_BUCKET_PATH) |
+ revisions = [] |
+ for url in urls: |
+ m = re.match(GS_BUCKET_PATH + 'trunk\.(\d+)', url) |
+ if m: |
+ revisions.append((int(m.group(1)), url)) |
+ return sorted(revisions) |
+ |
+ |
+def FindMostRecentSdkTools(delegate): |
noelallen1
2013/01/08 23:22:57
Why is this called MostRecentSdkTools? I don't se
binji
2013/01/09 19:13:25
Done.
|
+ for revision, url in reversed(GetTrunkRevisions(delegate)): |
+ if delegate.GsUtil_ls(url): |
+ return revision, url |
+ return None |
+ |
+ |
+def JsonLoadFromString(json_string): |
+ if sys.version_info > (2, 7): |
+ return json.loads(json_string, object_pairs_hook=collections.OrderedDict) |
+ else: |
+ return json.loads(json_string) |
+ |
+ |
+def GetBundleByName(bundles, name): |
+ for bundle in bundles: |
+ if bundle['name'] == name: |
+ return bundle |
+ return None |
+ |
+ |
+def UpdateSdkToolsBundle(sdk_tools_bundle, revision, url, sha1, size): |
+ sdk_tools_bundle['description'] = SDK_TOOLS_DESCRIPTION_FORMAT % revision |
+ sdk_tools_bundle['revision'] = revision |
+ # Update archive for each OS |
+ for archive in sdk_tools_bundle['archives']: |
+ archive['url'] = url |
+ archive['checksum']['sha1'] = sha1 |
+ archive['size'] = size |
+ |
+ |
+def UpdateManifest(manifest, revision): |
+ sdk_tools_bundle = GetBundleByName(manifest['bundles'], 'sdk_tools') |
+ url = GetSdkToolsUrl(revision) |
+ sha1, size = DownloadAndComputeHash(urllib2.urlopen(url)) |
+ UpdateSdkToolsBundle(sdk_tools_bundle, revision, url, sha1, size) |
+ |
+ |
+def UpdateManifestFileToRevision(filename, revision): |
+ with open(filename) as stream: |
+ manifest_string = stream.read() |
+ |
+ manifest = JsonLoadFromString(manifest_string) |
+ UpdateManifest(manifest, revision) |
+ new_manifest_string = json.dumps(manifest, indent=2) |
+ |
+ diff_string = ''.join(difflib.unified_diff(manifest_string.splitlines(1), |
+ new_manifest_string.splitlines(1))) |
+ |
+ print 'diff %s' % filename |
noelallen1
2013/01/08 23:22:57
Did you mean to print this, or is this just diagno
binji
2013/01/09 19:13:25
I think it is useful output, but I can hide it beh
|
+ print diff_string |
+ |
+ with open(filename, 'w') as stream: |
+ stream.write(new_manifest_string) |
+ |
+ |
+def main(args): |
+ parser = optparse.OptionParser() |
+ parser.add_option('-r', '--revision', |
+ help='set revision manually, rather than using the latest version') |
+ options, _ = parser.parse_args(args[1:]) |
+ |
noelallen1
2013/01/08 23:22:57
nit: assert args = 0 instead of silently dropping
binji
2013/01/09 19:13:25
Done.
|
+ delegate = RealDelegate() |
+ if not options.revision: |
+ revision, _ = FindMostRecentSdkTools(delegate) |
+ else: |
+ revision = int(options.revision) |
+ |
+ UpdateManifestFileToRevision('json/naclsdk_manifest0.json', revision) |
+ UpdateManifestFileToRevision('json/naclsdk_manifest2.json', revision) |
+ |
+ |
+if __name__ == '__main__': |
+ sys.exit(main(sys.argv)) |