Add option to automatically invoke the interactive merger
[stgit] / stgit / config.py
CommitLineData
41a6d859
CM
1"""Handles the Stacked GIT configuration files
2"""
3
4__copyright__ = """
5Copyright (C) 2005, Catalin Marinas <catalin.marinas@gmail.com>
6
7This program is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License version 2 as
9published by the Free Software Foundation.
10
11This program is distributed in the hope that it will be useful,
12but WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with this program; if not, write to the Free Software
18Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19"""
20
21import os, ConfigParser
abcc2620 22from StringIO import StringIO
170f576b 23from stgit import basedir
41a6d859 24
41a6d859
CM
25config = ConfigParser.RawConfigParser()
26
abcc2620
CM
27def git_config(filename):
28 """Open a git config file and convert it to be understood by
29 Python."""
30 try:
31 f = file(filename)
32 cont = False
33 lines = []
34 for line in f:
35 line = line.strip()
36
37 if cont:
38 # continued line, add a space at the beginning
39 line = ' ' + line
40
41 if line and line[-1] == '\\':
42 line = line[:-1].rstrip()
43 cont = True
44 else:
45 line = line + '\n'
46 cont = False
47
48 lines.append(line)
49
50 f.close()
51 cfg_str = ''.join(lines)
52 except IOError:
53 cfg_str = ''
54
55 strio = StringIO(cfg_str)
56 strio.name = filename
57
58 return strio
59
eee7283e
CM
60def config_setup():
61 global config
62
63 # Set the defaults
64 config.add_section('stgit')
65 config.set('stgit', 'autoresolved', 'no')
66 config.set('stgit', 'smtpserver', 'localhost:25')
67 config.set('stgit', 'smtpdelay', '5')
68 config.set('stgit', 'pullcmd', 'git-pull')
69 config.set('stgit', 'merger',
70 'diff3 -L current -L ancestor -L patched -m -E ' \
71 '"%(branch1)s" "%(ancestor)s" "%(branch2)s" > "%(output)s"')
f7ed76a9 72 config.set('stgit', 'autoimerge', 'no')
eee7283e
CM
73 config.set('stgit', 'keeporig', 'yes')
74 config.set('stgit', 'keepoptimized', 'no')
75 config.set('stgit', 'extensions', '.ancestor .current .patched')
76
77 # Read the configuration files (if any) and override the default settings
abcc2620 78 # stgitrc are read for backward compatibility
eee7283e
CM
79 config.read('/etc/stgitrc')
80 config.read(os.path.expanduser('~/.stgitrc'))
81 config.read(os.path.join(basedir.get(), 'stgitrc'))
82
abcc2620 83 # GIT configuration files can have a [stgit] section
9e3f506f
KH
84 try:
85 global_config = os.environ['GIT_CONFIG']
86 except KeyError:
87 global_config = os.path.expanduser('~/.gitconfig')
88 try:
89 local_config = os.environ['GIT_CONFIG_LOCAL']
90 except KeyError:
91 local_config = os.path.join(basedir.get(), 'config')
92 config.readfp(git_config(global_config))
93 config.readfp(git_config(local_config))
abcc2620 94
eee7283e
CM
95 # Set the PAGER environment to the config value (if any)
96 if config.has_option('stgit', 'pager'):
97 os.environ['PAGER'] = config.get('stgit', 'pager')
98
99 # [gitmergeonefile] section is deprecated. In case it exists copy the
100 # options/values to the [stgit] one
101 if config.has_section('gitmergeonefile'):
102 for option, value in config.items('gitmergeonefile'):
103 config.set('stgit', option, value)
104
105
106class ConfigOption:
107 """Delayed cached reading of a configuration option.
108 """
109 def __init__(self, section, option):
110 self.__section = section
111 self.__option = option
112 self.__value = None
113
114 def __str__(self):
115 if not self.__value:
116 self.__value = config.get(self.__section, self.__option)
117 return self.__value
d7fade4b
CM
118
119
120# cached extensions
121__extensions = None
122
123def file_extensions():
124 """Returns a dictionary with the conflict file extensions
125 """
126 global __extensions
127
128 if not __extensions:
129 cfg_ext = config.get('stgit', 'extensions').split()
130 if len(cfg_ext) != 3:
131 raise CmdException, '"extensions" configuration error'
132
133 __extensions = { 'ancestor': cfg_ext[0],
134 'current': cfg_ext[1],
135 'patched': cfg_ext[2] }
136
137 return __extensions