代码拉取完成,页面将自动刷新
#!/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.
"""Usage: %prog <commit>*
Given a commit, finds the release where it first appeared (e.g. 47.0.2500.0) as
well as attempting to determine the branches to which it was merged.
Note that it uses the "cherry picked from" annotation to find merges, so it will
only work on merges that followed the "use cherry-pick -x" instructions.
"""
import optparse
import re
import sys
import git_common as git
def GetNameForCommit(sha1):
name = re.sub(r'~.*$', '', git.run('name-rev', '--tags', '--name-only', sha1))
if name == 'undefined':
name = git.run(
'name-rev', '--refs', 'remotes/branch-heads/*', '--name-only',
sha1) + ' [untagged]'
return name
def GetMergesForCommit(sha1):
return [c.split()[0] for c in
git.run('log', '--oneline', '-F', '--all', '--no-abbrev', '--grep',
'cherry picked from commit %s' % sha1).splitlines()]
def main():
parser = optparse.OptionParser(usage=sys.modules[__name__].__doc__)
_, args = parser.parse_args()
if len(args) == 0:
parser.error('Need at least one commit.')
for arg in args:
commit_name = GetNameForCommit(arg)
if not commit_name:
print '%s not found' % arg
return 1
print 'commit %s was:' % arg
print ' initially in ' + commit_name
merges = GetMergesForCommit(arg)
for merge in merges:
print ' merged to ' + GetNameForCommit(merge) + ' (as ' + merge + ')'
if not merges:
print 'No merges found. If this seems wrong, be sure that you did:'
print ' git fetch origin && gclient sync --with_branch_heads'
return 0
if __name__ == '__main__':
try:
sys.exit(main())
except KeyboardInterrupt:
sys.stderr.write('interrupted\n')
sys.exit(1)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。