| OLD | NEW |
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 # Copyright (c) 2009 The Chromium Authors. All rights reserved. | 2 # Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| 3 # Use of this source code is governed by a BSD-style license that can be | 3 # Use of this source code is governed by a BSD-style license that can be |
| 4 # found in the LICENSE file. | 4 # found in the LICENSE file. |
| 5 | 5 |
| 6 """ | 6 """ |
| 7 lastchange.py -- Chromium revision fetching utility. | 7 lastchange.py -- Chromium revision fetching utility. |
| 8 """ | 8 """ |
| 9 | 9 |
| 10 import optparse | 10 import optparse |
| 11 import os | 11 import os |
| 12 import re | 12 import re |
| (...skipping 23 matching lines...) Expand all Loading... |
| 36 revision = m.group(1) | 36 revision = m.group(1) |
| 37 return revision | 37 return revision |
| 38 | 38 |
| 39 | 39 |
| 40 def git_fetch_id(): | 40 def git_fetch_id(): |
| 41 """ | 41 """ |
| 42 Fetch the GIT identifier for the local tree. | 42 Fetch the GIT identifier for the local tree. |
| 43 | 43 |
| 44 Errors are swallowed. | 44 Errors are swallowed. |
| 45 """ | 45 """ |
| 46 git_re = re.compile('^\s*git-svn-id:\s+(\S+)@(\d+)', re.M) |
| 46 try: | 47 try: |
| 47 p = subprocess.Popen(['git', 'log', '-1'], | 48 proc = subprocess.Popen(['git', 'log', '-999'], |
| 48 stdout=subprocess.PIPE, | 49 stdout=subprocess.PIPE, |
| 49 stderr=subprocess.PIPE, | 50 stderr=subprocess.PIPE, |
| 50 shell=(sys.platform=='win32')) | 51 shell=(sys.platform=='win32')) |
| 52 for line in proc.stdout: |
| 53 match = git_re.search(line) |
| 54 if match: |
| 55 id = match.group(2) |
| 56 if id: |
| 57 proc.stdout.close() # Cut pipe. |
| 58 return id |
| 51 except OSError: | 59 except OSError: |
| 52 # 'git' is apparently either not installed or not executable. | 60 # 'git' is apparently either not installed or not executable. |
| 53 return None | 61 pass |
| 54 id = None | 62 return None |
| 55 if p: | |
| 56 git_re = re.compile('^\s*git-svn-id:\s+(\S+)@(\d+)', re.M) | |
| 57 m = git_re.search(p.stdout.read()) | |
| 58 if m: | |
| 59 id = m.group(2) | |
| 60 return id | |
| 61 | 63 |
| 62 | 64 |
| 63 def fetch_change(default_lastchange): | 65 def fetch_change(default_lastchange): |
| 64 """ | 66 """ |
| 65 Returns the last change, from some appropriate revision control system. | 67 Returns the last change, from some appropriate revision control system. |
| 66 """ | 68 """ |
| 67 change = svn_fetch_revision() | 69 change = svn_fetch_revision() |
| 68 if not change and sys.platform in ('linux2',): | 70 if not change and sys.platform in ('linux2',): |
| 69 change = git_fetch_id() | 71 change = git_fetch_id() |
| 70 if not change: | 72 if not change: |
| (...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 119 if out_file: | 121 if out_file: |
| 120 write_if_changed(out_file, contents) | 122 write_if_changed(out_file, contents) |
| 121 else: | 123 else: |
| 122 sys.stdout.write(contents) | 124 sys.stdout.write(contents) |
| 123 | 125 |
| 124 return 0 | 126 return 0 |
| 125 | 127 |
| 126 | 128 |
| 127 if __name__ == '__main__': | 129 if __name__ == '__main__': |
| 128 sys.exit(main()) | 130 sys.exit(main()) |
| OLD | NEW |