Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
65548873
Commit
65548873
authored
Feb 02, 2011
by
Raymond Hettinger
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Issue #11089: Fix performance issue limiting the use of ConfigParser()
with large config files.
parent
9f1ab853
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
41 additions
and
4 deletions
+41
-4
Lib/configparser.py
Lib/configparser.py
+38
-4
Misc/NEWS
Misc/NEWS
+3
-0
No files found.
Lib/configparser.py
View file @
65548873
...
@@ -88,7 +88,7 @@ ConfigParser -- responsible for parsing a list of
...
@@ -88,7 +88,7 @@ ConfigParser -- responsible for parsing a list of
"""
"""
try
:
try
:
from
collections
import
OrderedDict
as
_default_dict
from
collections
import
Mapping
,
OrderedDict
as
_default_dict
except
ImportError
:
except
ImportError
:
# fallback for setup.py which hasn't yet built _collections
# fallback for setup.py which hasn't yet built _collections
_default_dict
=
dict
_default_dict
=
dict
...
@@ -515,6 +515,38 @@ class RawConfigParser:
...
@@ -515,6 +515,38 @@ class RawConfigParser:
if e:
if e:
raise e
raise e
class _Chainmap(Mapping):
"""
Combine
multiple
mappings
for
successive
lookups
.
For
example
,
to
emulate
Python
's normal lookup sequence:
import __builtin__
pylookup = _Chainmap(locals(), globals(), vars(__builtin__))
"""
def __init__(self, *maps):
self.maps = maps
def __getitem__(self, key):
for mapping in self.maps:
try:
return mapping[key]
except KeyError:
pass
raise KeyError(key)
def __iter__(self):
seen = set()
for mapping in self.maps:
s = set(mapping) - seen
for elem in s:
yield elem
seen.update(s)
def __len__(self):
s = set()
s.update(*self.maps)
return len(s)
class ConfigParser(RawConfigParser):
class ConfigParser(RawConfigParser):
...
@@ -530,16 +562,18 @@ class ConfigParser(RawConfigParser):
...
@@ -530,16 +562,18 @@ class ConfigParser(RawConfigParser):
The section DEFAULT is special.
The section DEFAULT is special.
"""
"""
d = self._defaults.copy()
sectiondict = {}
try:
try:
d.update(self._sections[section])
sectiondict = self._sections[section]
except KeyError:
except KeyError:
if section != DEFAULTSECT:
if section != DEFAULTSECT:
raise NoSectionError(section)
raise NoSectionError(section)
# Update with the entry specific variables
# Update with the entry specific variables
vardict = {}
if vars:
if vars:
for key, value in vars.items():
for key, value in vars.items():
d[self.optionxform(key)] = value
vardict[self.optionxform(key)] = value
d = _Chainmap(vardict, sectiondict, self._defaults)
option = self.optionxform(option)
option = self.optionxform(option)
try:
try:
value = d[option]
value = d[option]
...
...
Misc/NEWS
View file @
65548873
...
@@ -37,6 +37,9 @@ Core and Builtins
...
@@ -37,6 +37,9 @@ Core and Builtins
Library
Library
-------
-------
- Issue #11089: Fix performance issue limiting the use of ConfigParser()
with large config files.
- Issue #8275: Fix passing of callback arguments with ctypes under Win64.
- Issue #8275: Fix passing of callback arguments with ctypes under Win64.
Patch by Stan Mihai.
Patch by Stan Mihai.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment