mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 02:43:41 +00:00 
			
		
		
		
	Issue #23466: Raised OverflowError if %c argument is out of range.
This commit is contained in:
		
							parent
							
								
									45ec3288d0
								
							
						
					
					
						commit
						41525e31a5
					
				
					 2 changed files with 14 additions and 9 deletions
				
			
		|  | @ -358,12 +358,12 @@ def test_exc(formatstr, args, exception, excmsg): | |||
|                  "not all arguments converted during bytes formatting") | ||||
|         test_exc(b'no format', bytearray(b'1'), TypeError, | ||||
|                  "not all arguments converted during bytes formatting") | ||||
|         test_exc(b"%c", -1, TypeError, | ||||
|                 "%c requires an integer in range(256) or a single byte") | ||||
|         test_exc(b"%c", 256, TypeError, | ||||
|                 "%c requires an integer in range(256) or a single byte") | ||||
|         test_exc(b"%c", 2**128, TypeError, | ||||
|                 "%c requires an integer in range(256) or a single byte") | ||||
|         test_exc(b"%c", -1, OverflowError, | ||||
|                 "%c arg not in range(256)") | ||||
|         test_exc(b"%c", 256, OverflowError, | ||||
|                 "%c arg not in range(256)") | ||||
|         test_exc(b"%c", 2**128, OverflowError, | ||||
|                 "%c arg not in range(256)") | ||||
|         test_exc(b"%c", b"Za", TypeError, | ||||
|                 "%c requires an integer in range(256) or a single byte") | ||||
|         test_exc(b"%c", "Y", TypeError, | ||||
|  |  | |||
|  | @ -496,10 +496,15 @@ byte_converter(PyObject *arg, char *p) | |||
|             ival = PyLong_AsLongAndOverflow(iobj, &overflow); | ||||
|             Py_DECREF(iobj); | ||||
|         } | ||||
|         if (!overflow && 0 <= ival && ival <= 255) { | ||||
|             *p = (char)ival; | ||||
|             return 1; | ||||
|         if (!overflow && ival == -1 && PyErr_Occurred()) | ||||
|             goto onError; | ||||
|         if (overflow || !(0 <= ival && ival <= 255)) { | ||||
|             PyErr_SetString(PyExc_OverflowError, | ||||
|                             "%c arg not in range(256)"); | ||||
|             return 0; | ||||
|         } | ||||
|         *p = (char)ival; | ||||
|         return 1; | ||||
|     } | ||||
|   onError: | ||||
|     PyErr_SetString(PyExc_TypeError, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Serhiy Storchaka
						Serhiy Storchaka