/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: 2018-06-14 17:59:16 UTC
  • mto: This revision was merged to the branch mainline in revision 7065.
  • Revision ID: jelmer@jelmer.uk-20180614175916-a2e2xh5k533guq1x
Move breezy.plugins.git to breezy.git.

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
    )
22
24
 
23
 
 
24
25
class GitBranchConfig(config.BranchConfig):
25
26
    """BranchConfig that uses locations.conf in place of branch.conf"""
26
27
 
33
34
        return "<%s of %r>" % (self.__class__.__name__, self.branch)
34
35
 
35
36
    def set_user_option(self, name, value, store=config.STORE_BRANCH,
36
 
                        warn_masked=False):
 
37
            warn_masked=False):
37
38
        """Force local to True"""
38
 
        config.BranchConfig.set_user_option(
39
 
            self, name, value, store=config.STORE_LOCATION,
40
 
            warn_masked=warn_masked)
 
39
        config.BranchConfig.set_user_option(self, name, value,
 
40
            store=config.STORE_LOCATION, warn_masked=warn_masked)
41
41
 
42
42
    def _get_user_id(self):
43
43
        # TODO: Read from ~/.gitconfig
44
44
        return self._get_best_value('_get_user_id')
45
45
 
46
46
 
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
47
class GitBranchStack(config._CompatibleStack):
86
48
    """GitBranch stack."""
87
49
 
88
50
    def __init__(self, branch):
89
 
        section_getters = [self._get_overrides]
90
51
        lstore = config.LocationStore()
91
52
        loc_matcher = config.LocationMatcher(lstore, branch.base)
92
 
        section_getters.append(loc_matcher.get_sections)
93
53
        # FIXME: This should also be looking in .git/config for
94
54
        # 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
55
        gstore = config.GlobalStore()
100
 
        section_getters.append(gstore.get_sections)
101
56
        super(GitBranchStack, self).__init__(
102
 
            section_getters,
 
57
            [self._get_overrides,
 
58
             loc_matcher.get_sections,
 
59
             gstore.get_sections],
103
60
            # All modifications go to the corresponding section in
104
61
            # locations.conf
105
62
            lstore, branch.base)