Skip to content

Commit

Permalink
Merge pull request #65 from abarth/roll_tools
Browse files Browse the repository at this point in the history
Add a script for updating code from Chromium and Mojo
  • Loading branch information
abarth committed Jul 17, 2015
2 parents 53e3570 + fe57061 commit e69b3d7
Show file tree
Hide file tree
Showing 2 changed files with 175 additions and 0 deletions.
146 changes: 146 additions & 0 deletions sky/tools/roll/roll.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
#!/usr/bin/env python
# Copyright 2015 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.

import argparse
import json
import os
import subprocess
import sys
import urllib2
from utils import commit
from utils import system

# //base and its dependencies
_base_deps = [
'base',
'testing',
'third_party/ashmem',
'third_party/libevent',
'third_party/libxml', # via //base/test
'third_party/modp_b64',
'third_party/tcmalloc',
]

# //build and its dependencies
_build_deps = [
'build',
'third_party/android_testrunner',
'third_party/binutils',
'third_party/pymock',
'tools/android',
'tools/clang',
'tools/generate_library_loader',
'tools/gritsettings',
'tools/relocation_packer',
'tools/valgrind',
]

# things used from //mojo/public
_mojo_sdk_deps = [
'third_party/cython',
]

_chromium_libs = [
'crypto',
'url',
]

_third_party_deps = [
'third_party/android_platform',
'third_party/apple_apsl',
'third_party/boringssl',
'third_party/brotli',
'third_party/expat',
'third_party/freetype-android',
'third_party/harfbuzz-ng',
'third_party/iccjpeg',
'third_party/jinja2',
'third_party/jsr-305',
'third_party/junit',
'third_party/khronos',
'third_party/libjpeg',
'third_party/libpng',
'third_party/libXNVCtrl',
'third_party/markupsafe',
'third_party/mesa',
'third_party/mockito',
'third_party/ots',
'third_party/ply',
'third_party/protobuf',
'third_party/qcms',
'third_party/re2',
'third_party/robolectric',
'third_party/smhasher',
'third_party/yasm',
'third_party/zlib',
]

dirs_from_chromium = _base_deps + _build_deps + _mojo_sdk_deps + _chromium_libs + _third_party_deps

dirs_from_mojo = [
'gpu',
'mojo',
'mojom',
'services/android',
'services/asset_bundle',
'services/keyboard',
'services/sensors',
]

# The contents of these files before the roll will be preserved after the roll,
# even though they live in directories rolled in from Chromium.
files_not_to_roll = [
'build/config/ui.gni',
'build/ls.py',
'build/module_args/mojo.gni',
]


def rev(source_dir, dest_dir, dirs_to_rev):
for d in dirs_to_rev:
print "removing directory %s" % d
try:
system(["git", "rm", "-r", d], cwd=dest_dir)
except subprocess.CalledProcessError:
print "Could not remove %s" % d
print "cloning directory %s" % d
files = system(["git", "ls-files", d], cwd=source_dir)
for f in files.splitlines():
source_path = os.path.join(source_dir, f)
if not os.path.isfile(source_path):
continue
dest_path = os.path.join(dest_dir, f)
system(["mkdir", "-p", os.path.dirname(dest_path)], cwd=source_dir)
system(["cp", source_path, dest_path], cwd=source_dir)
system(["git", "add", d], cwd=dest_dir)

for f in files_not_to_roll:
system(["git", "checkout", "HEAD", f], cwd=dest_dir)

system(["git", "add", "."], cwd=dest_dir)
src_commit = system(["git", "rev-parse", "HEAD"], cwd=source_dir).strip()
commit("Update to mojo %s" % src_commit, cwd=dest_dir)


def main():
parser = argparse.ArgumentParser(description="Update the mojo repo's " +
"snapshot of things imported from chromium.")
parser.add_argument("--mojo-dir", type=str)
parser.add_argument("--chromium-dir", type=str)
parser.add_argument("--dest-dir", type=str)

args = parser.parse_args()

if args.mojo_dir:
rev(args.mojo_dir, args.dest_dir, dirs_from_mojo)

if args.chromium_dir:
rev(args.chromium_dir, args.dest_dir, dirs_from_chromium)

return 0


if __name__ == "__main__":
sys.exit(main())
29 changes: 29 additions & 0 deletions sky/tools/roll/utils.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
#!/usr/bin/env python
# Copyright 2014 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.

import fnmatch
import os
import subprocess

def commit(message, cwd=None):
subprocess.call(['git', 'commit', '-a', '-m', message], cwd=cwd)

def system(command, cwd=None):
return subprocess.check_output(command, cwd=cwd)

def find(patterns, start='.'):
for path, dirs, files in os.walk(start):
for basename in files + dirs:
if any([fnmatch.fnmatch(basename, pattern) for pattern in patterns]):
filename = os.path.join(path, basename)
yield filename

def filter_file(path, predicate):
with open(path, 'r+') as f:
lines = f.readlines()
new_lines = [line for line in lines if predicate(line)]
f.seek(0)
f.truncate()
f.write(''.join(new_lines))

0 comments on commit e69b3d7

Please sign in to comment.