Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(186)

Side by Side Diff: recipe_modules/git_cl/api.py

Issue 2087093002: Add upload and issue to git_cl recipe module (Closed) Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@master
Patch Set: Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | recipe_modules/git_cl/example.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright 2016 The Chromium Authors. All rights reserved. 1 # Copyright 2016 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 from recipe_engine import recipe_api 5 from recipe_engine import recipe_api
6 6
7 import string
8
9 def clean_message(msg):
10 """Cleans a commit message to be able to be printed on the command line."""
11 i = 0
12 for i in range(len(msg)):
tandrii(chromium) 2016/06/22 14:41:15 1. Pythonic way: for i, c in enumerate(msg):
martiniss 2016/06/22 22:47:33 Great, thanks.
13 if not msg[i] in string.printable:
14 break
15 if i < len(msg) - 1:
16 msg = msg[:i]
17
18 return msg
19
7 class GitClApi(recipe_api.RecipeApi): 20 class GitClApi(recipe_api.RecipeApi):
8 def __call__(self, subcmd, args, name=None, **kwargs): 21 def __call__(self, subcmd, args, name=None, **kwargs):
9 if not name: 22 if not name:
10 name = 'git_cl ' + subcmd 23 name = 'git_cl ' + subcmd
11 24
12 if kwargs.get('suffix'): 25 if kwargs.get('suffix'):
13 name = name + ' (%s)' % kwargs.pop('suffix') 26 name = name + ' (%s)' % kwargs.pop('suffix')
14 27
15 if 'cwd' not in kwargs: 28 if 'cwd' not in kwargs:
16 kwargs['cwd'] = (self.c and self.c.repo_location) or None 29 kwargs['cwd'] = (self.c and self.c.repo_location) or None
(...skipping 15 matching lines...) Expand all
32 args = ['-n', '-'] 45 args = ['-n', '-']
33 if patch or codereview: 46 if patch or codereview:
34 assert patch and codereview, "Both patch and codereview must be provided" 47 assert patch and codereview, "Both patch and codereview must be provided"
35 args.append(patch) 48 args.append(patch)
36 args.append('--%s' % codereview) 49 args.append('--%s' % codereview)
37 50
38 return self( 51 return self(
39 'description', args, stdout=self.m.raw_io.output(), 52 'description', args, stdout=self.m.raw_io.output(),
40 stdin=self.m.raw_io.input(data=description), 53 stdin=self.m.raw_io.input(data=description),
41 name='git_cl set description', **kwargs) 54 name='git_cl set description', **kwargs)
55
56 def upload(self, message, upload_args=None, **kwargs):
57 upload_args = upload_args or []
58 # message can have unicode, which we can't pass on the command line, so
tandrii(chromium) 2016/06/22 14:41:15 why not pass it in a temp file, or stdin? Patching
martiniss 2016/06/22 22:47:33 I do that below, in the call to set description.
tandrii(chromium) 2016/06/23 11:23:50 oh, well, then why do you even need to clean the m
martiniss 2016/06/23 18:35:41 It sends out an email immediately, which has the s
martiniss 2016/06/23 18:44:15 Look at https://codereview.chromium.org/2098603002
59 # upload it separately. Get a one line message for the subject for now.
60 one_line_message = clean_message(message.split('\n')[0]) + "..."
tandrii(chromium) 2016/06/22 14:41:15 message.splitlines()[0]
martiniss 2016/06/22 22:47:34 Done.
61
62 upload_args.extend(['-m', one_line_message])
tandrii(chromium) 2016/06/23 11:23:50 s/one_line_message/"whatever"
63
64 result = self('upload', upload_args, **kwargs)
65
66 # Really set the description
67 self.set_description(message)
68 return result
69
70 def issue(self, **kwargs):
71 return self('issue', [], stdout=self.m.raw_io.output(), **kwargs)
72
OLDNEW
« no previous file with comments | « no previous file | recipe_modules/git_cl/example.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698