159
158
return self[section][name]
162
# FIXME: Until we can guarantee that each config file is loaded once and and
161
# FIXME: Until we can guarantee that each config file is loaded once and
163
162
# only once for a given bzrlib session, we don't want to re-read the file every
164
163
# time we query for an option so we cache the value (bad ! watch out for tests
165
164
# needing to restore the proper value).This shouldn't be part of 2.4.0 final,
370
369
% (option_name,))
372
371
value = self._expand_options_in_string(value)
372
for hook in OldConfigHooks['get']:
373
hook(self, option_name, value)
375
def get_user_option_as_bool(self, option_name, expand=None):
376
"""Get a generic option as a boolean - no special process, no default.
376
def get_user_option_as_bool(self, option_name, expand=None, default=None):
377
"""Get a generic option as a boolean.
379
:param expand: Allow expanding references to other config values.
380
:param default: Default value if nothing is configured
378
381
:return None if the option doesn't exist or its value can't be
379
382
interpreted as a boolean. Returns True or False otherwise.
381
384
s = self.get_user_option(option_name, expand=expand)
383
386
# The option doesn't exist
385
388
val = ui.bool_from_string(s)
387
390
# The value can't be interpreted as a boolean
492
495
if policy is None:
493
496
policy = self._get_signature_checking()
494
497
if policy is not None:
498
#this warning should go away once check_signatures is
499
#implemented (if not before)
495
500
trace.warning("Please use create_signatures,"
496
501
" not check_signatures to set signing policy.")
497
if policy == CHECK_ALWAYS:
499
502
elif policy == SIGN_ALWAYS:
546
549
def find_merge_tool(self, name):
547
# We fake a defaults mechanism here by checking if the given name can
550
# We fake a defaults mechanism here by checking if the given name can
548
551
# be found in the known_merge_tools if it's not found in the config.
549
552
# This should be done through the proposed config defaults mechanism
550
553
# when it becomes available in the future.
554
557
return command_line
560
class _ConfigHooks(hooks.Hooks):
561
"""A dict mapping hook names and a list of callables for configs.
565
"""Create the default hooks.
567
These are all empty initially, because by default nothing should get
570
super(_ConfigHooks, self).__init__('bzrlib.config', 'ConfigHooks')
571
self.add_hook('load',
572
'Invoked when a config store is loaded.'
573
' The signature is (store).',
575
self.add_hook('save',
576
'Invoked when a config store is saved.'
577
' The signature is (store).',
579
# The hooks for config options
581
'Invoked when a config option is read.'
582
' The signature is (stack, name, value).',
585
'Invoked when a config option is set.'
586
' The signature is (stack, name, value).',
588
self.add_hook('remove',
589
'Invoked when a config option is removed.'
590
' The signature is (stack, name).',
592
ConfigHooks = _ConfigHooks()
595
class _OldConfigHooks(hooks.Hooks):
596
"""A dict mapping hook names and a list of callables for configs.
600
"""Create the default hooks.
602
These are all empty initially, because by default nothing should get
605
super(_OldConfigHooks, self).__init__('bzrlib.config', 'OldConfigHooks')
606
self.add_hook('load',
607
'Invoked when a config store is loaded.'
608
' The signature is (config).',
610
self.add_hook('save',
611
'Invoked when a config store is saved.'
612
' The signature is (config).',
614
# The hooks for config options
616
'Invoked when a config option is read.'
617
' The signature is (config, name, value).',
620
'Invoked when a config option is set.'
621
' The signature is (config, name, value).',
623
self.add_hook('remove',
624
'Invoked when a config option is removed.'
625
' The signature is (config, name).',
627
OldConfigHooks = _OldConfigHooks()
557
630
class IniBasedConfig(Config):
558
631
"""A configuration policy that draws from ini files."""
951
1032
self._get_parser().setdefault(section, {})[option] = value
952
1033
self._write_config_file()
1034
for hook in OldConfigHooks['set']:
1035
hook(self, option, value)
955
1037
def _get_sections(self, name=None):
956
1038
"""See IniBasedConfig._get_sections()."""
1152
1234
# the allowed values of store match the config policies
1153
1235
self._set_option_policy(location, option, store)
1154
1236
self._write_config_file()
1237
for hook in OldConfigHooks['set']:
1238
hook(self, option, value)
1157
1241
class BranchConfig(Config):
1635
1719
section[option_name] = value
1638
def get_credentials(self, scheme, host, port=None, user=None, path=None,
1722
def get_credentials(self, scheme, host, port=None, user=None, path=None,
1640
1724
"""Returns the matching credentials from authentication.conf file.
2054
2138
section_obj = configobj[section]
2055
2139
except KeyError:
2057
return section_obj.get(name, default)
2141
value = section_obj.get(name, default)
2142
for hook in OldConfigHooks['get']:
2143
hook(self, name, value)
2059
2146
def set_option(self, value, name, section=None):
2060
2147
"""Set the value associated with a named option.
2076
2165
del configobj[option_name]
2078
2167
del configobj[section_name][option_name]
2168
for hook in OldConfigHooks['remove']:
2169
hook(self, option_name)
2079
2170
self._set_configobj(configobj)
2081
2172
def _get_config_file(self):
2083
return StringIO(self._transport.get_bytes(self._filename))
2174
f = StringIO(self._transport.get_bytes(self._filename))
2175
for hook in OldConfigHooks['load']:
2084
2178
except errors.NoSuchFile:
2085
2179
return StringIO()
2604
2706
"""Set a new value for the option."""
2605
2707
section = self._get_mutable_section()
2606
2708
section.set(name, value)
2709
for hook in ConfigHooks['set']:
2710
hook(self, name, value)
2608
2712
def remove(self, name):
2609
2713
"""Remove an existing option."""
2610
2714
section = self._get_mutable_section()
2611
2715
section.remove(name)
2716
for hook in ConfigHooks['remove']:
2613
2719
def __repr__(self):
2614
2720
# Mostly for debugging use
2701
2807
' the configuration file'),
2810
_see_also = ['configuration']
2704
2812
@commands.display_command
2705
2813
def run(self, name=None, all=False, directory=None, scope=None,