settings -> config

reimpliment settings as singleton
This commit is contained in:
Kenneth Reitz
2011-05-22 13:27:17 -04:00
parent 0741448798
commit 49f1ec1efb
2 changed files with 52 additions and 38 deletions
+52
View File
@@ -0,0 +1,52 @@
# -*- coding: utf-8 -*-
"""
requests.config
~~~~~~~~~~~~~~~
This module provides the Requests settings feature set.
"""
# Time (in seconds) to allow the request to connect to
# the remote host before timing it out.
# timeout = None
class Settings(object):
_singleton = {}
__attrs__ = ('timeout',)
def __init__(self, **kwargs):
super(Settings, self).__init__()
self.__dict__ = self._singleton
def __getattribute__(self, key):
if key in object.__getattribute__(self, '__attrs__'):
try:
return object.__getattribute__(self, key)
except AttributeError:
return None
return object.__getattribute__(self, key)
def __enter__(self):
pass
def __exit__(self, *args):
self.__dict__.update(self.__cache.copy())
del self.__cache
def __call__(self, *args, **kwargs):
r = self.__class__()
r.__cache = self.__dict__.copy()
self.__dict__.update(*args, **kwargs)
return r
settings = Settings()
-38
View File
@@ -1,38 +0,0 @@
# -*- coding: utf-8 -*-
"""
requests.settings
~~~~~~~~~~~~~~~~~
This module provides the Requests settings feature set.
"""
# Time (in seconds) to allow the request to connect to
# the remote host before timing it out.
timeout = None
class Settings(object):
def __init__(self, **settings):
self._cache_settings(**settings)
self._alter_settings(**settings)
def __enter__(self):
pass
def __exit__(self, type, value, traceback):
self._restore_settings()
def _cache_settings(self, **settings):
self.cache = {}
for setting in settings:
self.cache[setting] = globals()[setting]
def _alter_settings(self, **settings):
for setting, value in settings.items():
globals()[setting] = value
def _restore_settings(self):
for setting, value in self.cache.items():
globals()[setting] = value