| 1 |
class CaseInsensitiveDict(dict): |
|---|
| 2 |
def __init__(self, *kw, **kwargs): |
|---|
| 3 |
super(CaseInsensitiveDict, self).__init__(*kw, **kwargs) |
|---|
| 4 |
# Set up case insensitive dict for future reference. |
|---|
| 5 |
keys = {} |
|---|
| 6 |
for key in self.keys(): |
|---|
| 7 |
if isinstance(key, basestring): |
|---|
| 8 |
keys[key.lower()] = key |
|---|
| 9 |
self._case_insensitive_keys = keys |
|---|
| 10 |
|
|---|
| 11 |
def _get_case_sensitive_key(self, key): |
|---|
| 12 |
if isinstance(key, basestring): |
|---|
| 13 |
key = self._case_insensitive_keys.get(key.lower(), key) |
|---|
| 14 |
return key |
|---|
| 15 |
|
|---|
| 16 |
def __getitem__(self, key): |
|---|
| 17 |
key = self._get_case_sensitive_key(key) |
|---|
| 18 |
return super(CaseInsensitiveDict, self).__getitem__(key) |
|---|
| 19 |
|
|---|
| 20 |
def __setitem__(self, key, value): |
|---|
| 21 |
if isinstance(key, basestring): |
|---|
| 22 |
key_lower = key.lower() |
|---|
| 23 |
if key_lower in self._case_insensitive_keys.keys(): |
|---|
| 24 |
# Delete old key (since it may be a different case). |
|---|
| 25 |
old_key = self._case_insensitive_keys[key_lower] |
|---|
| 26 |
super(CaseInsensitiveDict, self).__delitem__(old_key) |
|---|
| 27 |
# Save new key in case insensitive dict. |
|---|
| 28 |
self._case_insensitive_keys[key_lower] = key |
|---|
| 29 |
return super(CaseInsensitiveDict, self).__setitem__(key, value) |
|---|
| 30 |
|
|---|
| 31 |
def __delitem__(self, key): |
|---|
| 32 |
key = self._get_case_sensitive_key(key) |
|---|
| 33 |
if isinstance(key, basestring): |
|---|
| 34 |
# Delete key from case insensitive dict. |
|---|
| 35 |
del self._case_insensitive_keys[key.lower()] |
|---|
| 36 |
return super(CaseInsensitiveDict, self).__delitem__(key) |
|---|
| 37 |
|
|---|
| 38 |
def __contains__(self, key): |
|---|
| 39 |
key = self._get_case_sensitive_key(key) |
|---|
| 40 |
return super(CaseInsensitiveDict, self).__contains__(key) |
|---|
| 41 |
|
|---|
| 42 |
def get(self, key): |
|---|
| 43 |
key = self._get_case_sensitive_key(key) |
|---|
| 44 |
return super(CaseInsensitiveDict, self).get(key) |
|---|
| 45 |
|
|---|
| 46 |
def has_key(self, key): |
|---|
| 47 |
key = self._get_case_sensitive_key(key) |
|---|
| 48 |
return super(CaseInsensitiveDict, self).has_key(key) |
|---|
| 49 |
|
|---|
| 50 |
def pop(self, key): |
|---|
| 51 |
key = self._get_case_sensitive_key(key) |
|---|
| 52 |
return super(CaseInsensitiveDict, self).pop(key) |
|---|
| 53 |
|
|---|
| 54 |
def update(self, dict=None, **kwargs): |
|---|
| 55 |
if dict is None: |
|---|
| 56 |
dict = kwargs |
|---|
| 57 |
if dict: |
|---|
| 58 |
# Check for keys in new dict which may differ to the current keys. |
|---|
| 59 |
for key in dict.keys(): |
|---|
| 60 |
case_sensitive_key = self._get_case_sensitive_key(key) |
|---|
| 61 |
if key != case_sensitive_key: |
|---|
| 62 |
# Change case to match existing key. |
|---|
| 63 |
dict[case_sensitive_key] = dict[key] |
|---|
| 64 |
del dict[key] |
|---|
| 65 |
return super(CaseInsensitiveDict, self).update(dict) |
|---|
| 66 |
|
|---|
| 67 |
def clear(self): |
|---|
| 68 |
# Reset case insensitive dict |
|---|
| 69 |
self._case_insensitive_keys = {} |
|---|
| 70 |
return super(CaseInsensitiveDict, self).clear() |
|---|
| 71 |
|
|---|
| 72 |
def setdefault(self, key, default=None): |
|---|
| 73 |
key = self._get_case_sensitive_key(key) |
|---|
| 74 |
return super(CaseInsensitiveDict, self).setdefault(key, default) |
|---|
| 75 |
|
|---|