/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: 2020-02-07 02:14:30 UTC
  • mto: This revision was merged to the branch mainline in revision 7492.
  • Revision ID: jelmer@jelmer.uk-20200207021430-m49iq3x4x8xlib6x
Drop python2 support.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2009-2010 Jelmer Vernooij <jelmer@samba.org>
 
1
# Copyright (C) 2009-2018 Jelmer Vernooij <jelmer@jelmer.uk>
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
17
"""Config file handling for Git."""
18
18
 
19
 
from bzrlib import (
 
19
from __future__ import absolute_import
 
20
 
 
21
from .. import (
20
22
    config,
21
23
    )
22
24
 
 
25
 
23
26
class GitBranchConfig(config.BranchConfig):
24
27
    """BranchConfig that uses locations.conf in place of branch.conf"""
25
28
 
26
29
    def __init__(self, branch):
27
 
        config.BranchConfig.__init__(self, branch)
 
30
        super(GitBranchConfig, self).__init__(branch)
28
31
        # do not provide a BranchDataConfig
29
32
        self.option_sources = self.option_sources[0], self.option_sources[2]
30
33
 
 
34
    def __repr__(self):
 
35
        return "<%s of %r>" % (self.__class__.__name__, self.branch)
 
36
 
31
37
    def set_user_option(self, name, value, store=config.STORE_BRANCH,
32
 
            warn_masked=False):
 
38
                        warn_masked=False):
33
39
        """Force local to True"""
34
 
        config.BranchConfig.set_user_option(self, name, value,
35
 
            store=config.STORE_LOCATION, warn_masked=warn_masked)
 
40
        config.BranchConfig.set_user_option(
 
41
            self, name, value, store=config.STORE_LOCATION,
 
42
            warn_masked=warn_masked)
36
43
 
37
44
    def _get_user_id(self):
38
45
        # TODO: Read from ~/.gitconfig
39
46
        return self._get_best_value('_get_user_id')
 
47
 
 
48
 
 
49
class GitBranchStack(config._CompatibleStack):
 
50
    """GitBranch stack."""
 
51
 
 
52
    def __init__(self, branch):
 
53
        lstore = config.LocationStore()
 
54
        loc_matcher = config.LocationMatcher(lstore, branch.base)
 
55
        # FIXME: This should also be looking in .git/config for
 
56
        # local git branches.
 
57
        gstore = config.GlobalStore()
 
58
        super(GitBranchStack, self).__init__(
 
59
            [self._get_overrides,
 
60
             loc_matcher.get_sections,
 
61
             gstore.get_sections],
 
62
            # All modifications go to the corresponding section in
 
63
            # locations.conf
 
64
            lstore, branch.base)
 
65
        self.branch = branch