mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	Merged revisions 60080-60089,60091-60093 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r60080 | andrew.kuchling | 2008-01-19 17:26:13 +0100 (Sat, 19 Jan 2008) | 2 lines Patch #742598 from Michael Pomraning: add .timeout attribute to SocketServer that will call .handle_timeout() method when no requests are received within the timeout period. ........ r60081 | andrew.kuchling | 2008-01-19 17:34:09 +0100 (Sat, 19 Jan 2008) | 1 line Add item ........ r60082 | christian.heimes | 2008-01-19 17:39:27 +0100 (Sat, 19 Jan 2008) | 2 lines Disabled test_xmlrpc:test_404. It's causing lots of false alarms. I also disabled a test in test_ssl which requires network access to svn.python.org. This fixes a bug Skip has reported a while ago. ........ r60083 | georg.brandl | 2008-01-19 18:38:53 +0100 (Sat, 19 Jan 2008) | 2 lines Clarify thread.join() docs. #1873. ........ r60084 | georg.brandl | 2008-01-19 19:02:46 +0100 (Sat, 19 Jan 2008) | 2 lines #1782: don't leak in error case in PyModule_AddXxxConstant. Patch by Hrvoje Nik?\197?\161i?\196?\135. ........ r60085 | andrew.kuchling | 2008-01-19 19:08:52 +0100 (Sat, 19 Jan 2008) | 1 line Sort two names into position ........ r60086 | andrew.kuchling | 2008-01-19 19:18:41 +0100 (Sat, 19 Jan 2008) | 2 lines Patch #976880: add mmap .rfind() method, and 'end' paramter to .find(). Contributed by John Lenton. ........ r60087 | facundo.batista | 2008-01-19 19:38:19 +0100 (Sat, 19 Jan 2008) | 5 lines Fix #1693149. Now you can pass several modules separated by coma to trace.py in the same --ignore-module option. Thanks Raghuram Devarakonda. ........ r60088 | facundo.batista | 2008-01-19 19:45:46 +0100 (Sat, 19 Jan 2008) | 3 lines Comment in NEWS regarding the change in trace.py. ........ r60089 | skip.montanaro | 2008-01-19 19:47:24 +0100 (Sat, 19 Jan 2008) | 2 lines missing from r60088 checkin. ........ r60091 | andrew.kuchling | 2008-01-19 20:14:05 +0100 (Sat, 19 Jan 2008) | 1 line Add item ........ r60092 | georg.brandl | 2008-01-19 20:27:05 +0100 (Sat, 19 Jan 2008) | 4 lines Fix #1679: "0x" was taken as a valid integer literal. Fixes the tokenizer, tokenize.py and int() to reject this. Patches by Malte Helmert. ........ r60093 | georg.brandl | 2008-01-19 20:48:19 +0100 (Sat, 19 Jan 2008) | 3 lines Fix #1146: TextWrap vs words 1-character shorter than the width. Patch by Quentin Gallet-Gilles. ........
This commit is contained in:
		
							parent
							
								
									2336bddd5d
								
							
						
					
					
						commit
						fceab5a385
					
				
					 21 changed files with 301 additions and 40 deletions
				
			
		|  | @ -696,11 +696,23 @@ PyModule_AddObject(PyObject *m, const char *name, PyObject *o) | |||
| int  | ||||
| PyModule_AddIntConstant(PyObject *m, const char *name, long value) | ||||
| { | ||||
| 	return PyModule_AddObject(m, name, PyLong_FromLong(value)); | ||||
| 	PyObject *o = PyLong_FromLong(value); | ||||
| 	if (!o) | ||||
| 		return -1; | ||||
| 	if (PyModule_AddObject(m, name, o) == 0) | ||||
| 		return 0; | ||||
| 	Py_DECREF(o); | ||||
| 	return -1; | ||||
| } | ||||
| 
 | ||||
| int  | ||||
| PyModule_AddStringConstant(PyObject *m, const char *name, const char *value) | ||||
| { | ||||
| 	return PyModule_AddObject(m, name, PyUnicode_FromString(value)); | ||||
| 	PyObject *o = PyUnicode_FromString(value); | ||||
| 	if (!o) | ||||
| 		return -1; | ||||
| 	if (PyModule_AddObject(m, name, o) == 0) | ||||
| 		return 0; | ||||
| 	Py_DECREF(o); | ||||
| 	return -1; | ||||
| } | ||||
|  |  | |||
|  | @ -116,12 +116,30 @@ PyOS_strtoul(register char *str, char **ptr, int base) | |||
| 		if (*str == '0') { | ||||
| 			++str; | ||||
| 			if (*str == 'x' || *str == 'X') { | ||||
| 				/* there must be at least one digit after 0x */ | ||||
| 				if (_PyLong_DigitValue[Py_CHARMASK(str[1])] >= 16) { | ||||
| 					if (ptr) | ||||
| 						*ptr = str; | ||||
| 					return 0; | ||||
| 				} | ||||
| 				++str; | ||||
| 				base = 16; | ||||
| 			} else if (*str == 'o' || *str == 'O') { | ||||
| 				/* there must be at least one digit after 0o */ | ||||
| 				if (_PyLong_DigitValue[Py_CHARMASK(str[1])] >= 8) { | ||||
| 					if (ptr) | ||||
| 						*ptr = str; | ||||
| 					return 0; | ||||
| 				} | ||||
| 				++str; | ||||
| 				base = 8; | ||||
| 			} else if (*str == 'b' || *str == 'B') { | ||||
| 				/* there must be at least one digit after 0b */ | ||||
| 				if (_PyLong_DigitValue[Py_CHARMASK(str[1])] >= 2) { | ||||
| 					if (ptr) | ||||
| 						*ptr = str; | ||||
| 					return 0; | ||||
| 				} | ||||
| 				++str; | ||||
| 				base = 2; | ||||
| 			} else { | ||||
|  | @ -143,22 +161,43 @@ PyOS_strtoul(register char *str, char **ptr, int base) | |||
| 	case 16: | ||||
| 		if (*str == '0') { | ||||
| 			++str; | ||||
| 			if (*str == 'x' || *str == 'X') | ||||
| 			if (*str == 'x' || *str == 'X') { | ||||
| 				/* there must be at least one digit after 0x */ | ||||
| 				if (_PyLong_DigitValue[Py_CHARMASK(str[1])] >= 16) { | ||||
| 					if (ptr) | ||||
| 						*ptr = str; | ||||
| 					return 0; | ||||
| 				} | ||||
| 				++str; | ||||
| 			} | ||||
| 		} | ||||
| 		break; | ||||
| 	case 8: | ||||
| 		if (*str == '0') { | ||||
| 			++str; | ||||
| 			if (*str == 'o' || *str == 'O') | ||||
| 			if (*str == 'o' || *str == 'O') { | ||||
| 				/* there must be at least one digit after 0o */ | ||||
| 				if (_PyLong_DigitValue[Py_CHARMASK(str[1])] >= 8) { | ||||
| 					if (ptr) | ||||
| 						*ptr = str; | ||||
| 					return 0; | ||||
| 				} | ||||
| 				++str; | ||||
| 			} | ||||
| 		} | ||||
| 		break; | ||||
| 	case 2: | ||||
| 		if(*str == '0') { | ||||
| 			++str; | ||||
| 			if (*str == 'b' || *str == 'B') | ||||
| 			if (*str == 'b' || *str == 'B') { | ||||
| 				/* there must be at least one digit after 0b */ | ||||
| 				if (_PyLong_DigitValue[Py_CHARMASK(str[1])] >= 2) { | ||||
| 					if (ptr) | ||||
| 						*ptr = str; | ||||
| 					return 0; | ||||
| 				} | ||||
| 				++str; | ||||
| 			} | ||||
| 		} | ||||
| 		break; | ||||
| 	} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Georg Brandl
						Georg Brandl