diff options
| author | Kurt B. Kaiser <kbk@shore.net> | 2004-06-06 01:29:22 +0000 | 
|---|---|---|
| committer | Kurt B. Kaiser <kbk@shore.net> | 2004-06-06 01:29:22 +0000 | 
| commit | 4d5bc6031ca883201f87e0e3c94e5746f9f91439 (patch) | |
| tree | bebdc12778178ff31a076a6e6709e705531fc7c7 /Lib/idlelib/configHandler.py | |
| parent | cfa157d808d387551e3973c6e4e8e5eebca3b051 (diff) | |
| download | cpython-git-4d5bc6031ca883201f87e0e3c94e5746f9f91439.tar.gz | |
Noam Raphel:  Further developemt of CodeContext feature.
The visibility state of the code context pane is now persistent between
sessions and the pane does not appear in the shell window.
M CodeContext.py
M EditorWindow.py
M NEWS.txt
M PyShell.py
M config-extensions.def
M configHandler.py
Diffstat (limited to 'Lib/idlelib/configHandler.py')
| -rw-r--r-- | Lib/idlelib/configHandler.py | 52 | 
1 files changed, 36 insertions, 16 deletions
| diff --git a/Lib/idlelib/configHandler.py b/Lib/idlelib/configHandler.py index e0b1612c3a..370f3707de 100644 --- a/Lib/idlelib/configHandler.py +++ b/Lib/idlelib/configHandler.py @@ -215,7 +215,8 @@ class IdleConf:                  sys.stderr.write(warn)          return userDir -    def GetOption(self, configType, section, option, default=None, type=None): +    def GetOption(self, configType, section, option, default=None, type=None, +                  warn_on_default=True):          """          Get an option value for given config type and given general          configuration section/option or return a default. If type is specified, @@ -224,21 +225,30 @@ class IdleConf:          fallback to a useable passed-in default if the option isn't present in          either the user or the default configuration.          configType must be one of ('main','extensions','highlight','keys') -        If a default is returned a warning is printed to stderr. +        If a default is returned, and warn_on_default is True, a warning is +        printed to stderr. +          """          if self.userCfg[configType].has_option(section,option):              return self.userCfg[configType].Get(section, option, type=type)          elif self.defaultCfg[configType].has_option(section,option):              return self.defaultCfg[configType].Get(section, option, type=type)          else: #returning default, print warning -            warning=('\n Warning: configHandler.py - IdleConf.GetOption -\n' -                       ' problem retrieving configration option %r\n' -                       ' from section %r.\n' -                       ' returning default value: %r\n' %  -                       (option, section, default)) -            sys.stderr.write(warning) +            if warn_on_default: +                warning = ('\n Warning: configHandler.py - IdleConf.GetOption -\n' +                           ' problem retrieving configration option %r\n' +                           ' from section %r.\n' +                           ' returning default value: %r\n' % +                           (option, section, default)) +                sys.stderr.write(warning)              return default +    def SetOption(self, configType, section, option, value): +        """In user's config file, set section's option to value. + +        """ +        self.userCfg[configType].SetOption(section, option, value) +      def GetSectionList(self, configSet, configType):          """          Get a list of sections from either the user or default config for @@ -356,10 +366,10 @@ class IdleConf:          """          return self.GetOption('main','Keys','name',default='') -    def GetExtensions(self, activeOnly=1): +    def GetExtensions(self, active_only=True, editor_only=False, shell_only=False):          """          Gets a list of all idle extensions declared in the config files. -        activeOnly - boolean, if true only return active (enabled) extensions +        active_only - boolean, if true only return active (enabled) extensions          """          extns=self.RemoveKeyBindNames(                  self.GetSectionList('default','extensions')) @@ -368,13 +378,23 @@ class IdleConf:          for extn in userExtns:              if extn not in extns: #user has added own extension                  extns.append(extn) -        if activeOnly: +        if active_only:              activeExtns=[]              for extn in extns: -                if self.GetOption('extensions',extn,'enable',default=1, -                    type='bool'): +                if self.GetOption('extensions', extn, 'enable', default=True, +                                  type='bool'):                      #the extension is enabled -                    activeExtns.append(extn) +                    if editor_only or shell_only: +                        if editor_only: +                            option = "enable_editor" +                        else: +                            option = "enable_shell" +                        if self.GetOption('extensions', extn,option, +                                          default=True, type='bool', +                                          warn_on_default=False): +                            activeExtns.append(extn) +                    else: +                        activeExtns.append(extn)              return activeExtns          else:              return extns @@ -401,7 +421,7 @@ class IdleConf:          """          extName=None          vEvent='<<'+virtualEvent+'>>' -        for extn in self.GetExtensions(activeOnly=0): +        for extn in self.GetExtensions(active_only=0):              for event in self.GetExtensionKeys(extn).keys():                  if event == vEvent:                      extName=extn @@ -482,7 +502,7 @@ class IdleConf:          in an extension is already in use, that binding is disabled.          """          keySet=self.GetCoreKeys(keySetName) -        activeExtns=self.GetExtensions(activeOnly=1) +        activeExtns=self.GetExtensions(active_only=1)          for extn in activeExtns:              extKeys=self.__GetRawExtensionKeys(extn)              if extKeys: #the extension defines keybindings | 
