Commit 208fba0b authored by Victor Stinner's avatar Victor Stinner

Merged revisions 78647 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/branches/py3k

................
  r78647 | victor.stinner | 2010-03-04 13:14:57 +0100 (jeu., 04 mars 2010) | 12 lines

  Merged revisions 78646 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk

  ........
    r78646 | victor.stinner | 2010-03-04 13:09:33 +0100 (jeu., 04 mars 2010) | 5 lines

    Issue #1054943: Fix unicodedata.normalize('NFC', text) for the Public Review
    Issue #29.

    PR #29 was released in february 2004!
  ........
................
parent be2b5638
...@@ -186,6 +186,11 @@ class UnicodeFunctionsTest(UnicodeDatabaseTest): ...@@ -186,6 +186,11 @@ class UnicodeFunctionsTest(UnicodeDatabaseTest):
# The rest can be found in test_normalization.py # The rest can be found in test_normalization.py
# which requires an external file. # which requires an external file.
def test_pr29(self):
# http://www.unicode.org/review/pr-29.html
for text in (u"\u0b47\u0300\u0b3e", u"\u1100\u0300\u1161"):
self.assertEqual(self.db.normalize('NFC', text), text)
def test_east_asian_width(self): def test_east_asian_width(self):
eaw = self.db.east_asian_width eaw = self.db.east_asian_width
self.assertRaises(TypeError, eaw, b'a') self.assertRaises(TypeError, eaw, b'a')
......
...@@ -100,6 +100,9 @@ Core and Builtins ...@@ -100,6 +100,9 @@ Core and Builtins
Library Library
------- -------
- Issue #1054943: Fix unicodedata.normalize('NFC', text) for the Public Review
Issue #29
- Issue #7494: fix a crash in _lsprof (cProfile) after clearing the profiler, - Issue #7494: fix a crash in _lsprof (cProfile) after clearing the profiler,
reset also the pointer to the current pointer context. reset also the pointer to the current pointer context.
......
...@@ -684,7 +684,7 @@ nfc_nfkc(PyObject *self, PyObject *input, int k) ...@@ -684,7 +684,7 @@ nfc_nfkc(PyObject *self, PyObject *input, int k)
comb = 0; comb = 0;
while (i1 < end) { while (i1 < end) {
int comb1 = _getrecord_ex(*i1)->combining; int comb1 = _getrecord_ex(*i1)->combining;
if (comb1 && comb == comb1) { if (comb && (comb1 == 0 || comb == comb1)) {
/* Character is blocked. */ /* Character is blocked. */
i1++; i1++;
continue; continue;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment