diff options
| author | Stephen A. Zarkos <stephen.zarkos@microsoft.com> | 2013-03-04 09:09:45 +0100 | 
|---|---|---|
| committer | Anatol Belski <ab@php.net> | 2013-03-04 09:09:45 +0100 | 
| commit | b6fdb60ecf33b3d549d5d69e245b04d68ab3e824 (patch) | |
| tree | dfbc52a005ac127a8505eb6404dc1c8c46a45602 /ext/pcre/php_pcre.c | |
| parent | 656fcb67f1edbd2bde1b93577cdc273ad27e0d8f (diff) | |
| download | php-git-b6fdb60ecf33b3d549d5d69e245b04d68ab3e824.tar.gz | |
Fixed PCRE locale crash in Windows/TS
Diffstat (limited to 'ext/pcre/php_pcre.c')
| -rw-r--r-- | ext/pcre/php_pcre.c | 9 | 
1 files changed, 8 insertions, 1 deletions
| diff --git a/ext/pcre/php_pcre.c b/ext/pcre/php_pcre.c index b9cb4f4a7c..cab3a4c8dd 100644 --- a/ext/pcre/php_pcre.c +++ b/ext/pcre/php_pcre.c @@ -244,11 +244,18 @@ PHPAPI pcre_cache_entry* pcre_get_compiled_regex_cache(char *regex, int regex_le  	int				count = 0;  	unsigned const char *tables = NULL;  #if HAVE_SETLOCALE -	char				*locale = setlocale(LC_CTYPE, NULL); +	char				*locale;  #endif  	pcre_cache_entry	*pce;  	pcre_cache_entry	 new_entry; +#if HAVE_SETLOCALE +# ifdef PHP_WIN32 && ZTS +	_configthreadlocale(_ENABLE_PER_THREAD_LOCALE); +# endif +	locale = setlocale(LC_CTYPE, NULL); +#endif +  	/* Try to lookup the cached regex entry, and if successful, just pass  	   back the compiled pattern, otherwise go on and compile it. */  	if (zend_hash_find(&PCRE_G(pcre_cache), regex, regex_len+1, (void **)&pce) == SUCCESS) { | 
