diff options
author | Daniel Narvaez <dwnarvaez@gmail.com> | 2012-11-16 09:07:19 (GMT) |
---|---|---|
committer | Daniel Narvaez <dwnarvaez@gmail.com> | 2012-11-16 09:07:19 (GMT) |
commit | cc034825744856b9936a518cef0215d9096a8f98 (patch) | |
tree | cdeeccde6ae7865073945394ba7e5ab56651f0c6 /commands/send-patches | |
parent | 6b22c805e7fc22be53088897e2a1e17acf77753a (diff) |
Port auto-install and send-patches to the new commands scheme
Diffstat (limited to 'commands/send-patches')
-rwxr-xr-x | commands/send-patches | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/commands/send-patches b/commands/send-patches new file mode 100755 index 0000000..bea7f79 --- /dev/null +++ b/commands/send-patches @@ -0,0 +1,111 @@ +#!/usr/bin/python + +import argparse +import os +import re +import subprocess +import sys + +import common + +from devbot import config + +GIT_CONFIG_SETUP = "sugar-build.send-patches.setup" + +def get_git_config(name, is_global=False): + args = ["git", "config"] + + if is_global: + args.append("--global") + + args.append(name) + + try: + return subprocess.check_output(args) + except subprocess.CalledProcessError: + return None + +def set_git_config(name, value): + return subprocess.check_output(["git", "config", name, value]) + +def unset_git_config(name): + try: + subprocess.check_output(["git", "config", "--unset", name]) + return True + except subprocess.CalledProcessError: + return False + +def get_from(): + name = get_git_config("user.name", is_global=True) + email = get_git_config("user.email", is_global=True) + + if not name or not email: + print "Please configure your name and email\n\n" \ + "git config --global user.name Your Name\n" \ + "git config --global user.email youremail@example.com" + sys.exit(1) + + return "%s <%s>" % (name, email) + +def get_module(): + for line in open("configure.ac"): + m = re.match("AC_INIT\((.+)\)", line) + if m: + return m.group(1).split(",")[-1][1:-1] + +def setup(): + print "Choose how to send email \n\n" \ + "1 Google account\n" \ + "2 Sugar Labs shell account\n" \ + "3 System sendmail" + + choice = None + + while choice not in ["1", "2", "3"]: + choice = raw_input("# ") + + if choice == "1": + print "\nEnter your user name" + smtpuser = raw_input("# ") + + set_git_config("sendemail.smtpencryption", "tls") + set_git_config("sendemail.smtpserver", "smtp.gmail.com") + set_git_config("sendemail.smtpserverport", "587") + set_git_config("sendemail.smtpuser", smtpuser) + elif choice == "2": + print "\nEnter your user name" + smtpuser = raw_input("# ") + + set_git_config("sendemail.smtpencryption", "tls") + set_git_config("sendemail.smtpserver", "smtp.sugarlabs.org") + set_git_config("sendemail.smtpserverport", "587") + set_git_config("sendemail.smtpuser", smtpuser) + elif choice == "3": + unset_git_config("sendemail.smtpencryption") + unset_git_config("sendemail.smtpserver") + unset_git_config("sendemail.smtpserverport") + unset_git_config("sendemail.smtpuser") + + set_git_config(GIT_CONFIG_SETUP, "true") + +common.setup() + +if os.path.dirname(os.getcwd()) != config.source_dir: + print "The command must be run inside one of the source modules." + sys.exit(1) + +parser = argparse.ArgumentParser() +parser.add_argument("--setup", action="store_true", + help="interactive configuration") +parser.add_argument('rev_list', nargs='?', default='origin') + +args = parser.parse_args() + +if not get_git_config(GIT_CONFIG_SETUP) or args.setup: + setup() + +subprocess.call(["git", "send-email", + "-from", get_from(), + "-to", "sugar-devel <sugar-devel@lists.sugarlabs.org>", + "--subject-prefix", "PATCH %s" % get_module(), + args.rev_list]) |