Show More
@@ -381,6 +381,7 b' def patchbomb(ui, repo, *revs, **opts):' | |||||
381 | parent = None |
|
381 | parent = None | |
382 |
|
382 | |||
383 | sender_addr = email.Utils.parseaddr(sender)[1] |
|
383 | sender_addr = email.Utils.parseaddr(sender)[1] | |
|
384 | sendmail = None | |||
384 | for m in msgs: |
|
385 | for m in msgs: | |
385 | try: |
|
386 | try: | |
386 | m['Message-Id'] = genmsgid(m['X-Mercurial-Node']) |
|
387 | m['Message-Id'] = genmsgid(m['X-Mercurial-Node']) | |
@@ -426,10 +427,12 b' def patchbomb(ui, repo, *revs, **opts):' | |||||
426 | fp.write('\n\n') |
|
427 | fp.write('\n\n') | |
427 | fp.close() |
|
428 | fp.close() | |
428 | else: |
|
429 | else: | |
|
430 | if not sendmail: | |||
|
431 | sendmail = mail.connect(ui) | |||
429 | ui.status('Sending ', m['Subject'], ' ...\n') |
|
432 | ui.status('Sending ', m['Subject'], ' ...\n') | |
430 | # Exim does not remove the Bcc field |
|
433 | # Exim does not remove the Bcc field | |
431 | del m['Bcc'] |
|
434 | del m['Bcc'] | |
432 |
|
|
435 | sendmail(ui, sender, to + bcc + cc, m.as_string(0)) | |
433 |
|
436 | |||
434 | cmdtable = { |
|
437 | cmdtable = { | |
435 | "email": |
|
438 | "email": |
@@ -38,39 +38,43 b' def _smtp(ui):' | |||||
38 | s.login(username, password) |
|
38 | s.login(username, password) | |
39 | return s |
|
39 | return s | |
40 |
|
40 | |||
41 | class _sendmail(object): |
|
41 | def _sendmail(ui, sender, recipients, msg): | |
42 | '''send mail using sendmail.''' |
|
42 | '''send mail using sendmail.''' | |
43 |
|
43 | program = ui.config('email', 'method') | ||
44 | def __init__(self, ui, program): |
|
44 | cmdline = '%s -f %s %s' % (program, templater.email(sender), | |
45 | self.ui = ui |
|
|||
46 | self.program = program |
|
|||
47 |
|
||||
48 | def sendmail(self, sender, recipients, msg): |
|
|||
49 | cmdline = '%s -f %s %s' % ( |
|
|||
50 | self.program, templater.email(sender), |
|
|||
51 | ' '.join(map(templater.email, recipients))) |
|
45 | ' '.join(map(templater.email, recipients))) | |
52 |
|
|
46 | ui.note(_('sending mail: %s\n') % cmdline) | |
53 |
|
|
47 | fp = os.popen(cmdline, 'w') | |
54 |
|
|
48 | fp.write(msg) | |
55 |
|
|
49 | ret = fp.close() | |
56 |
|
|
50 | if ret: | |
57 |
|
|
51 | raise util.Abort('%s %s' % ( | |
58 |
|
|
52 | os.path.basename(program.split(None, 1)[0]), | |
59 |
|
|
53 | util.explain_exit(ret)[0])) | |
60 |
|
54 | |||
61 | def connect(ui): |
|
55 | def connect(ui): | |
62 |
'''make a mail connection. |
|
56 | '''make a mail connection. return a function to send mail. | |
63 | call as sendmail(sender, list-of-recipients, msg).''' |
|
57 | call as sendmail(sender, list-of-recipients, msg).''' | |
64 |
|
58 | |||
65 | method = ui.config('email', 'method', 'smtp') |
|
59 | func = _sendmail | |
66 | if method == 'smtp': |
|
60 | if ui.config('email', 'method', 'smtp') == 'smtp': | |
67 |
|
|
61 | func = _smtp(ui) | |
68 |
|
62 | |||
69 | return _sendmail(ui, method) |
|
63 | def send(ui, sender, recipients, msg): | |
|
64 | try: | |||
|
65 | return func.sendmail(sender, recipients, msg) | |||
|
66 | except smtplib.SMTPRecipientsRefused, inst: | |||
|
67 | recipients = [r[1] for r in inst.recipients.values()] | |||
|
68 | raise util.Abort('\n' + '\n'.join(recipients)) | |||
|
69 | except smtplib.SMTPException, inst: | |||
|
70 | raise util.Abort(inst) | |||
|
71 | ||||
|
72 | return send | |||
70 |
|
73 | |||
71 | def sendmail(ui, sender, recipients, msg): |
|
74 | def sendmail(ui, sender, recipients, msg): | |
72 | try: |
|
75 | try: | |
73 | return connect(ui).sendmail(sender, recipients, msg) |
|
76 | send = connect(ui) | |
|
77 | return send(sender, recipients, msg) | |||
74 | except smtplib.SMTPRecipientsRefused, inst: |
|
78 | except smtplib.SMTPRecipientsRefused, inst: | |
75 | recipients = [r[1] for r in inst.recipients.values()] |
|
79 | recipients = [r[1] for r in inst.recipients.values()] | |
76 | raise util.Abort('\n' + '\n'.join(recipients)) |
|
80 | raise util.Abort('\n' + '\n'.join(recipients)) |
General Comments 0
You need to be logged in to leave comments.
Login now