/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 breezy/git/config.py

  • Committer: Jelmer Vernooij
  • Date: 2019-03-05 07:32:38 UTC
  • mto: (7290.1.21 work)
  • mto: This revision was merged to the branch mainline in revision 7311.
  • Revision ID: jelmer@jelmer.uk-20190305073238-zlqn981opwnqsmzi
Add appveyor configuration.

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
 
17
17
"""Config file handling for Git."""
18
18
 
 
19
from __future__ import absolute_import
 
20
 
19
21
from .. import (
20
22
    config,
21
23
    )
44
46
        return self._get_best_value('_get_user_id')
45
47
 
46
48
 
47
 
class GitConfigSectionDefault(config.Section):
48
 
    """The "default" config section in git config file"""
49
 
 
50
 
    def __init__(self, config):
51
 
        self._config = config
52
 
 
53
 
    def get(self, name, default=None, expand=True):
54
 
        if name == 'email':
55
 
            try:
56
 
                email = self._config.get((b'user', ), b'email')
57
 
            except KeyError:
58
 
                return None
59
 
            try:
60
 
                name = self._config.get((b'user', ), b'name')
61
 
            except KeyError:
62
 
                return email.decode()
63
 
            return '%s <%s>' % (name.decode(), email.decode())
64
 
        if name == 'gpg_signing_key':
65
 
            try:
66
 
                key = self._config.get((b'user', ), b'signingkey')
67
 
            except KeyError:
68
 
                return None
69
 
            return key.decode()
70
 
        return None
71
 
 
72
 
 
73
 
class GitConfigStore(config.Store):
74
 
    """Store that uses gitconfig."""
75
 
 
76
 
    def __init__(self, config):
77
 
        self._config = config
78
 
 
79
 
    def get_sections(self):
80
 
        return [
81
 
            (self, GitConfigSectionDefault(self._config)),
82
 
            ]
83
 
 
84
 
 
85
49
class GitBranchStack(config._CompatibleStack):
86
50
    """GitBranch stack."""
87
51
 
88
52
    def __init__(self, branch):
89
 
        section_getters = [self._get_overrides]
90
53
        lstore = config.LocationStore()
91
54
        loc_matcher = config.LocationMatcher(lstore, branch.base)
92
 
        section_getters.append(loc_matcher.get_sections)
93
55
        # FIXME: This should also be looking in .git/config for
94
56
        # local git branches.
95
 
        git = getattr(branch.repository, '_git', None)
96
 
        if git:
97
 
            cstore = GitConfigStore(git.get_config())
98
 
            section_getters.append(cstore.get_sections)
99
57
        gstore = config.GlobalStore()
100
 
        section_getters.append(gstore.get_sections)
101
58
        super(GitBranchStack, self).__init__(
102
 
            section_getters,
 
59
            [self._get_overrides,
 
60
             loc_matcher.get_sections,
 
61
             gstore.get_sections],
103
62
            # All modifications go to the corresponding section in
104
63
            # locations.conf
105
64
            lstore, branch.base)