summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEli Bendersky <eliben@gmail.com>2012-07-17 12:09:12 (GMT)
committerEli Bendersky <eliben@gmail.com>2012-07-17 12:09:12 (GMT)
commit43cc5f29a8666404255c9d1619c1aef0fe817486 (patch)
treeba85b1377dba2602fcd47f7c102e7bf0d2a4315e
parent94554921421145569bfa4319e0a0610afdb68c78 (diff)
downloadcpython-43cc5f29a8666404255c9d1619c1aef0fe817486.zip
cpython-43cc5f29a8666404255c9d1619c1aef0fe817486.tar.gz
cpython-43cc5f29a8666404255c9d1619c1aef0fe817486.tar.bz2
Optimize tostringlist by taking the stream class outside the function. It's now 2x faster on short calls. Related to #1767933
-rw-r--r--Lib/xml/etree/ElementTree.py32
1 files changed, 19 insertions, 13 deletions
diff --git a/Lib/xml/etree/ElementTree.py b/Lib/xml/etree/ElementTree.py
index 3981659..be6cf11 100644
--- a/Lib/xml/etree/ElementTree.py
+++ b/Lib/xml/etree/ElementTree.py
@@ -1184,23 +1184,29 @@ def tostring(element, encoding=None, method=None):
# @defreturn sequence
# @since 1.3
-def tostringlist(element, encoding=None, method=None):
- data = []
- class DataStream(io.BufferedIOBase):
- def writable(self):
- return True
+class _ListDataStream(io.BufferedIOBase):
+ """ An auxiliary stream accumulating into a list reference
+ """
+ def __init__(self, lst):
+ self.lst = lst
+
+ def writable(self):
+ return True
- def seekable(self):
- return True
+ def seekable(self):
+ return True
- def write(self, b):
- data.append(b)
+ def write(self, b):
+ self.lst.append(b)
- def tell(self):
- return len(data)
+ def tell(self):
+ return len(self.lst)
- ElementTree(element).write(DataStream(), encoding, method=method)
- return data
+def tostringlist(element, encoding=None, method=None):
+ lst = []
+ stream = _ListDataStream(lst)
+ ElementTree(element).write(stream, encoding, method=method)
+ return lst
##
# Writes an element tree or element structure to sys.stdout. This