/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to hg.py

  • Committer: Vincent Ladeuil
  • Date: 2009-04-27 16:10:10 UTC
  • mto: (4310.1.1 integration)
  • mto: This revision was merged to the branch mainline in revision 4311.
  • Revision ID: v.ladeuil+lp@free.fr-20090427161010-7swfzeagf63cpixd
Fix bug #367726 by reverting some default user handling introduced
while fixing bug #256612.

* bzrlib/transport/ssh.py:
(_paramiko_auth): Explicitly use getpass.getuser() as default
user.

* bzrlib/transport/ftp/_gssapi.py:
(GSSAPIFtpTransport._create_connection): Explicitly use
getpass.getuser() as default user.

* bzrlib/transport/ftp/__init__.py:
(FtpTransport._create_connection): Explicitly use
getpass.getuser() as default user.

* bzrlib/tests/test_sftp_transport.py:
(TestUsesAuthConfig.test_sftp_is_none_if_no_config)
(TestUsesAuthConfig.test_sftp_doesnt_prompt_username): Revert to
None as the default user.

* bzrlib/tests/test_remote.py:
(TestRemoteSSHTransportAuthentication): The really offending one:
revert to None as the default user.

* bzrlib/tests/test_config.py:
(TestAuthenticationConfig.test_username_default_no_prompt): Update
test (and some PEP8).

* bzrlib/smtp_connection.py:
(SMTPConnection._authenticate): Revert to None as the default
user.

* bzrlib/plugins/launchpad/account.py:
(_get_auth_user): Revert default value handling.

* bzrlib/config.py:
(AuthenticationConfig.get_user): Fix doc-string. Leave default
value handling to callers.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2009 Scott Chacon <schacon@gmail.com>
2
 
# Copyright (C) 2009 Jelmer Vernooij <jelmer@samba.org>
3
 
 
4
 
# This program is free software; you can redistribute it and/or modify
5
 
# it under the terms of the GNU General Public License as published by
6
 
# the Free Software Foundation; either version 2 of the License, or
7
 
# (at your option) any later version.
8
 
#
9
 
# This program is distributed in the hope that it will be useful,
10
 
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 
# GNU General Public License for more details.
13
 
#
14
 
# You should have received a copy of the GNU General Public License
15
 
# along with this program; if not, write to the Free Software
16
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17
 
 
18
 
"""Compatibility for hg-git."""
19
 
 
20
 
import urllib
21
 
 
22
 
def format_hg_metadata(renames, branch, extra):
23
 
    """Construct a tail with hg-git metadata.
24
 
 
25
 
    :param renames: List of (oldpath, newpath) tuples with file renames
26
 
    :param branch: Branch name
27
 
    :param extra: Dictionary with extra data
28
 
    :return: Tail for commit message
29
 
    """
30
 
    extra_message = ''
31
 
    if branch != 'default':
32
 
        extra_message += "branch : " + branch + "\n"
33
 
 
34
 
    if renames:
35
 
        for oldfile, newfile in renames:
36
 
            extra_message += "rename : " + oldfile + " => " + newfile + "\n"
37
 
 
38
 
    for key, value in extra.iteritems():
39
 
        if key in ('author', 'committer', 'encoding', 'message', 'branch',
40
 
                   'hg-git'):
41
 
            continue
42
 
        else:
43
 
            extra_message += "extra : " + key + " : " +  urllib.quote(value) + "\n"
44
 
 
45
 
    if extra_message:
46
 
        return "\n--HG--\n" + extra_message
47
 
    else:
48
 
        return ""
49
 
 
50
 
 
51
 
def extract_hg_metadata(message):
52
 
    """Extract Mercurial metadata from a commit message.
53
 
 
54
 
    :param message: Commit message to extract from
55
 
    :return: Tuple with original commit message, renames, branch and
56
 
        extra data.
57
 
    """
58
 
    split = message.split("\n--HG--\n", 1)
59
 
    renames = {}
60
 
    extra = {}
61
 
    branch = None
62
 
    if len(split) == 2:
63
 
        message, meta = split
64
 
        lines = meta.split("\n")
65
 
        for line in lines:
66
 
            if line == '':
67
 
                continue
68
 
            command, data = line.split(" : ", 1)
69
 
            if command == 'rename':
70
 
                before, after = data.split(" => ", 1)
71
 
                renames[after] = before
72
 
            elif command == 'branch':
73
 
                branch = data
74
 
            elif command == 'extra':
75
 
                before, after = data.split(" : ", 1)
76
 
                extra[before] = urllib.unquote(after)
77
 
            else:
78
 
                raise KeyError("unknown hg-git metadata command %s" % command)
79
 
    return (message, renames, branch, extra)