Hello, While testing a bit of code under a different locale (de_DE) we found that var_export() uses a , for representing floating point decimal separators. As var_export() is supposed to generate "valid PHP code" there is now a bug in this function.
While looking into this, I found that internally it uses the following call: php_printf("%.*G", (int) EG(precision), Z_DVAL_PP(struc)); However, the G modifier, unlike F, is locale-aware and will happily create "5,12" as a "valid PHP float". This of course does not parse. I expected the uppercase G to be locale-insensitve and the lowercase g to be locale-sensitive. However, looking at the code it only switched between E and e. The g/G modifier as is implemented now does not seem to have any locale-insensitive option. The difference between "f" and "g" is that g/G is smarter regarding appending 0's. Trailing zeroes are not wanted when rendering a float as "valid PHP code" (as it looks different than when it was written in the application). I see a few options to address this: 1. Change "G" to be locale-insensitve. We can't really do that as it's also use in _convert_to_string. 2. Add a new modifier "H" or "L" that is like G, but locale-insensitive. 3. Change "g" to be locale-insensitve, as this one does not seem to be used anywhere in the code base. I think we should pick option 2, find another modifier letter as it won't impact anything else. Notes: - _build_trace_args (from Zend/zend_exceptions.c) seems also to be affected, as it uses the G modifier to build argument lists as string for exception traces. So now it uses the , to separate arguments AND as float decimal sep in case of a de_DE locale. regards, Derick -- Derick Rethans http://derickrethans.nl | http://ez.no | http://xdebug.org -- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: http://www.php.net/unsub.php