Improve CustomConfig documentation
Improve documentation about what CustomConfigHelperMixin does, it was not very clear without a close look to the code before. Signed-off-by: Sebastian Spaeth <Sebastian@SSpaeth.de>
This commit is contained in:
		 Sebastian Spaeth
					Sebastian Spaeth
				
			
				
					committed by
					
						 Nicolas Sebrecht
						Nicolas Sebrecht
					
				
			
			
				
	
			
			
			 Nicolas Sebrecht
						Nicolas Sebrecht
					
				
			
						parent
						
							d9a72c30ba
						
					
				
				
					commit
					c5d49cec3e
				
			| @@ -20,6 +20,7 @@ New Features | |||||||
| Changes | Changes | ||||||
| ------- | ------- | ||||||
|  |  | ||||||
|  | * Improve CustomConfig documentation. | ||||||
| * Imply single threading mode in debug mode exept for "-d thread". | * Imply single threading mode in debug mode exept for "-d thread". | ||||||
| * Code and import cleanups. | * Code and import cleanups. | ||||||
| * Allow UI to have arbitrary names. | * Allow UI to have arbitrary names. | ||||||
|   | |||||||
| @@ -71,18 +71,33 @@ class CustomConfigParser(ConfigParser): | |||||||
|                 if x.startswith(key)] |                 if x.startswith(key)] | ||||||
|  |  | ||||||
| def CustomConfigDefault(): | def CustomConfigDefault(): | ||||||
|     """Just a sample constant that won't occur anywhere else to use for the |     """Just a constant that won't occur anywhere else. | ||||||
|     default.""" |  | ||||||
|  |     This allows us to differentiate if the user has passed in any | ||||||
|  |     default value to the getconf* functions in ConfigHelperMixin | ||||||
|  |     derived classes.""" | ||||||
|     pass |     pass | ||||||
|  |  | ||||||
| class ConfigHelperMixin: | class ConfigHelperMixin: | ||||||
|     def _confighelper_runner(self, option, default, defaultfunc, mainfunc): |     """Allow comfortable retrieving of config values pertaining to a section. | ||||||
|         if default != CustomConfigDefault: |  | ||||||
|             return apply(defaultfunc, [self.getsection(), option, default]) |  | ||||||
|         else: |  | ||||||
|             return apply(mainfunc, [self.getsection(), option]) |  | ||||||
|  |  | ||||||
|     def getconf(self, option, default = CustomConfigDefault): |     If a class inherits from this cls:`ConfigHelperMixin`, it needs | ||||||
|  |     to provide 2 functions: meth:`getconfig` (returning a | ||||||
|  |     ConfigParser object) and meth:`getsection` (returning a string | ||||||
|  |     which represents the section to look up). All calls to getconf* | ||||||
|  |     will then return the configuration values for the ConfigParser | ||||||
|  |     object in the specific section.""" | ||||||
|  |  | ||||||
|  |     def _confighelper_runner(self, option, default, defaultfunc, mainfunc): | ||||||
|  |         """Return config value for getsection()""" | ||||||
|  |         if default == CustomConfigDefault: | ||||||
|  |             return apply(mainfunc, [self.getsection(), option]) | ||||||
|  |         else: | ||||||
|  |             return apply(defaultfunc, [self.getsection(), option, default]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     def getconf(self, option, | ||||||
|  |                 default = CustomConfigDefault): | ||||||
|         return self._confighelper_runner(option, default, |         return self._confighelper_runner(option, default, | ||||||
|                                          self.getconfig().getdefault, |                                          self.getconfig().getdefault, | ||||||
|                                          self.getconfig().get) |                                          self.getconfig().get) | ||||||
| @@ -101,4 +116,3 @@ class ConfigHelperMixin: | |||||||
|         return self._confighelper_runner(option, default, |         return self._confighelper_runner(option, default, | ||||||
|                                          self.getconfig().getdefaultfloat, |                                          self.getconfig().getdefaultfloat, | ||||||
|                                          self.getconfig().getfloat) |                                          self.getconfig().getfloat) | ||||||
|      |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user