From: William Meehan Date: Wed, 11 Feb 2026 20:58:24 +0000 (-0500) Subject: gh-84424: Use numeric_changed for UCD.numeric (GH-19457) X-Git-Tag: v3.15.0a7~306 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=3e0322ff16f47caa3e273d453f007d3918b8ac80;p=thirdparty%2FPython%2Fcpython.git gh-84424: Use numeric_changed for UCD.numeric (GH-19457) This was causing ucd_3_2_0.numeric() to pick up only decimal changes between Unicode 3.2.0 and the current version. --- diff --git a/Lib/test/test_unicodedata.py b/Lib/test/test_unicodedata.py index a46ca034f3bf..83b94f97c22c 100644 --- a/Lib/test/test_unicodedata.py +++ b/Lib/test/test_unicodedata.py @@ -182,10 +182,14 @@ class BaseUnicodeFunctionsTest: # New in 4.1.0 self.assertEqual(self.db.numeric('\U0001012A', None), None if self.old else 9000) + # Changed in 4.1.0 + self.assertEqual(self.db.numeric('\u5793', None), 1e20 if self.old else None) # New in 5.0.0 self.assertEqual(self.db.numeric('\u07c0', None), None if self.old else 0.0) # New in 5.1.0 self.assertEqual(self.db.numeric('\ua627', None), None if self.old else 7.0) + # Changed in 5.2.0 + self.assertEqual(self.db.numeric('\u09f6'), 3.0 if self.old else 3/16) # New in 6.0.0 self.assertEqual(self.db.numeric('\u0b72', None), None if self.old else 0.25) # New in 12.0.0 @@ -857,9 +861,9 @@ class UnicodeFunctionsTest(unittest.TestCase, BaseUnicodeFunctionsTest): class Unicode_3_2_0_FunctionsTest(unittest.TestCase, BaseUnicodeFunctionsTest): db = unicodedata.ucd_3_2_0 old = True - expectedchecksum = ('f4526159891a4b766dd48045646547178737ba09' + expectedchecksum = ('4154d8d1232837e255edf3cdcbb5ab184d71f4a4' if quicktest else - 'f217b8688d7bdff31db4207e078a96702f091597') + '3aabaf66823b21b3d305dad804a62f6f6387c93e') class UnicodeMiscTest(unittest.TestCase): diff --git a/Misc/NEWS.d/next/Library/2020-04-10-14-29-53.bpo-40243.85HRib.rst b/Misc/NEWS.d/next/Library/2020-04-10-14-29-53.bpo-40243.85HRib.rst new file mode 100644 index 000000000000..1f48525cdbec --- /dev/null +++ b/Misc/NEWS.d/next/Library/2020-04-10-14-29-53.bpo-40243.85HRib.rst @@ -0,0 +1 @@ +Fix :meth:`!unicodedata.ucd_3_2_0.numeric` for non-decimal values. diff --git a/Modules/unicodedata.c b/Modules/unicodedata.c index 586ce8d36dd4..091e6bcb9f3f 100644 --- a/Modules/unicodedata.c +++ b/Modules/unicodedata.c @@ -270,9 +270,9 @@ unicodedata_UCD_numeric_impl(PyObject *self, int chr, have_old = 1; rc = -1.0; } - else if (old->decimal_changed != 0xFF) { + else if (old->numeric_changed != 0.0) { have_old = 1; - rc = old->decimal_changed; + rc = old->numeric_changed; } }