##// END OF EJS Templates
speedup completion of unicode names
Matthias Bussonnier -
Show More
@@ -156,6 +156,14 b' except ImportError:'
156 # Globals
156 # Globals
157 #-----------------------------------------------------------------------------
157 #-----------------------------------------------------------------------------
158
158
159 # ranges where we have most of the valid unicode names. We could be more finer
160 # grained but is it worth it for performace While unicode have character in the
161 # rage 0, 0x110000, we seem to have name for about 10% of those. (131808 as I
162 # write this). With below range we cover them all, with a density of ~67%
163 # biggest next gap we consider only adds up about 1% density and there are 600
164 # gaps that would need hard coding.
165 _UNICODE_RANGES = [(32, 0x2fa1e), (0xe0001, 0xe01f0)]
166
159 # Public API
167 # Public API
160 __all__ = ['Completer','IPCompleter']
168 __all__ = ['Completer','IPCompleter']
161
169
@@ -2195,6 +2203,16 b' class IPCompleter(Completer):'
2195 names.append(unicodedata.name(chr(c)))
2203 names.append(unicodedata.name(chr(c)))
2196 except ValueError:
2204 except ValueError:
2197 pass
2205 pass
2198 self._unicode_names = names
2206 self._unicode_names = _unicode_name_compute(_UNICODE_RANGES)
2199
2207
2200 return self._unicode_names
2208 return self._unicode_names
2209
2210 def _unicode_name_compute(ranges:List[Tuple[int,int]]) -> List[str]:
2211 names = []
2212 for start,stop in ranges:
2213 for c in range(start, stop) :
2214 try:
2215 names.append(unicodedata.name(chr(c)))
2216 except ValueError:
2217 pass
2218 return names
@@ -33,6 +33,19 b' from nose.tools import assert_in, assert_not_in'
33 # Test functions
33 # Test functions
34 # -----------------------------------------------------------------------------
34 # -----------------------------------------------------------------------------
35
35
36 def test_unicode_range():
37 """
38 Test that the ranges we test for unicode names give the same number of
39 results than testing the full length.
40 """
41 from IPython.core.completer import _unicode_name_compute, _UNICODE_RANGES
42
43 expected_list = _unicode_name_compute([(0, 0x110000)])
44 test = _unicode_name_compute(_UNICODE_RANGES)
45
46 assert len(expected_list) == len(test)
47 assert len(expected_list) == 131808
48
36
49
37 @contextmanager
50 @contextmanager
38 def greedy_completion():
51 def greedy_completion():
@@ -230,7 +243,7 b' class TestCompleter(unittest.TestCase):'
230 ip = get_ipython()
243 ip = get_ipython()
231 text, matches = ip.Completer.latex_matches("\\really_i_should_match_nothing")
244 text, matches = ip.Completer.latex_matches("\\really_i_should_match_nothing")
232 nt.assert_equal(text, "")
245 nt.assert_equal(text, "")
233 nt.assert_equal(matches, [])
246 nt.assert_equal(matches, ())
234
247
235 def test_back_latex_completion(self):
248 def test_back_latex_completion(self):
236 ip = get_ipython()
249 ip = get_ipython()
General Comments 0
You need to be logged in to leave comments. Login now