~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/config.py

  • Committer: Aaron Bentley
  • Date: 2008-04-24 04:58:42 UTC
  • mfrom: (3377 +trunk)
  • mto: This revision was merged to the branch mainline in revision 3380.
  • Revision ID: aaron@aaronbentley.com-20080424045842-0cajl9v6s4u52kaw
Merge bzr.dev

Show diffs side-by-side

added added

removed removed

Lines of Context:
151
151
            mail_client_class = {
152
152
                None: mail_client.DefaultMail,
153
153
                # Specific clients
 
154
                'emacsclient': mail_client.EmacsMail,
154
155
                'evolution': mail_client.Evolution,
155
156
                'kmail': mail_client.KMail,
156
157
                'mutt': mail_client.Mutt,
159
160
                'default': mail_client.DefaultMail,
160
161
                'editor': mail_client.Editor,
161
162
                'mapi': mail_client.MAPIClient,
162
 
                'emacs-mailmode': mail_client.EmacsMailMode,
163
163
                'xdg-email': mail_client.XDGEmail,
164
164
            }[selected_client]
165
165
        except KeyError:
892
892
    """Branch configuration data associated with its contents, not location"""
893
893
 
894
894
    def __init__(self, branch):
 
895
        transport = branch.control_files._transport
 
896
        self._config = TransportConfig(transport, 'branch.conf')
895
897
        self.branch = branch
896
898
 
897
899
    def _get_parser(self, file=None):
898
900
        if file is not None:
899
901
            return IniBasedConfig._get_parser(file)
900
 
        return self._get_config()
901
 
 
902
 
    def _get_config(self):
903
 
        try:
904
 
            obj = ConfigObj(self.branch.control_files.get('branch.conf'),
905
 
                            encoding='utf-8')
906
 
        except errors.NoSuchFile:
907
 
            obj = ConfigObj(encoding='utf=8')
908
 
        return obj
 
902
        return self._config._get_configobj()
909
903
 
910
904
    def get_option(self, name, section=None, default=None):
911
905
        self.branch.lock_read()
912
906
        try:
913
 
            obj = self._get_config()
914
 
            try:
915
 
                if section is not None:
916
 
                    obj = obj[section]
917
 
                result = obj[name]
918
 
            except KeyError:
919
 
                result = default
 
907
            return self._config.get_option(name, section, default)
920
908
        finally:
921
909
            self.branch.unlock()
922
910
        return result
925
913
        """Set a per-branch configuration option"""
926
914
        self.branch.lock_write()
927
915
        try:
928
 
            cfg_obj = self._get_config()
929
 
            if section is None:
930
 
                obj = cfg_obj
931
 
            else:
932
 
                try:
933
 
                    obj = cfg_obj[section]
934
 
                except KeyError:
935
 
                    cfg_obj[section] = {}
936
 
                    obj = cfg_obj[section]
937
 
            obj[name] = value
938
 
            out_file = StringIO()
939
 
            cfg_obj.write(out_file)
940
 
            out_file.seek(0)
941
 
            self.branch.control_files.put('branch.conf', out_file)
 
916
            self._config.set_option(value, name, section)
942
917
        finally:
943
918
            self.branch.unlock()
944
919
 
1126
1101
 
1127
1102
    def decode_password(self, credentials, encoding):
1128
1103
        return credentials
 
1104
 
 
1105
 
 
1106
class TransportConfig(object):
 
1107
    """A Config that reads/writes a config file on a Transport.
 
1108
 
 
1109
    It is a low-level object that considers config data to be name/value pairs
 
1110
    that may be associated with a section.  Assigning meaning to the these
 
1111
    values is done at higher levels like TreeConfig.
 
1112
    """
 
1113
 
 
1114
    def __init__(self, transport, filename):
 
1115
        self._transport = transport
 
1116
        self._filename = filename
 
1117
 
 
1118
    def get_option(self, name, section=None, default=None):
 
1119
        """Return the value associated with a named option.
 
1120
 
 
1121
        :param name: The name of the value
 
1122
        :param section: The section the option is in (if any)
 
1123
        :param default: The value to return if the value is not set
 
1124
        :return: The value or default value
 
1125
        """
 
1126
        configobj = self._get_configobj()
 
1127
        if section is None:
 
1128
            section_obj = configobj
 
1129
        else:
 
1130
            try:
 
1131
                section_obj = configobj[section]
 
1132
            except KeyError:
 
1133
                return default
 
1134
        return section_obj.get(name, default)
 
1135
 
 
1136
    def set_option(self, value, name, section=None):
 
1137
        """Set the value associated with a named option.
 
1138
 
 
1139
        :param value: The value to set
 
1140
        :param name: The name of the value to set
 
1141
        :param section: The section the option is in (if any)
 
1142
        """
 
1143
        configobj = self._get_configobj()
 
1144
        if section is None:
 
1145
            configobj[name] = value
 
1146
        else:
 
1147
            configobj.setdefault(section, {})[name] = value
 
1148
        self._set_configobj(configobj)
 
1149
 
 
1150
    def _get_configobj(self):
 
1151
        try:
 
1152
            return ConfigObj(self._transport.get(self._filename),
 
1153
                             encoding='utf-8')
 
1154
        except errors.NoSuchFile:
 
1155
            return ConfigObj(encoding='utf-8')
 
1156
 
 
1157
    def _set_configobj(self, configobj):
 
1158
        out_file = StringIO()
 
1159
        configobj.write(out_file)
 
1160
        out_file.seek(0)
 
1161
        self._transport.put_file(self._filename, out_file)