Restore support for floating point numbers in number_format_i18n(). Fixes #10555.
git-svn-id: https://develop.svn.wordpress.org/trunk@14190 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
cae7b3b275
commit
3f2ee78320
@ -43,7 +43,8 @@ var userSettings = {
|
|||||||
pagenow = '<?php echo $current_screen->id; ?>',
|
pagenow = '<?php echo $current_screen->id; ?>',
|
||||||
typenow = '<?php if ( isset($current_screen->post_type) ) echo $current_screen->post_type; ?>',
|
typenow = '<?php if ( isset($current_screen->post_type) ) echo $current_screen->post_type; ?>',
|
||||||
adminpage = '<?php echo $admin_body_class; ?>',
|
adminpage = '<?php echo $admin_body_class; ?>',
|
||||||
thousandsSeparator = '<?php echo addslashes( $wp_locale->number_format['thousands_sep'] ); ?>';
|
thousandsSeparator = '<?php echo addslashes( $wp_locale->number_format['thousands_sep'] ); ?>',
|
||||||
|
decimalPoint = '<?php echo addslashes( $wp_locale->number_format['decimal_point'] ); ?>';
|
||||||
//]]>
|
//]]>
|
||||||
</script>
|
</script>
|
||||||
<?php
|
<?php
|
||||||
|
@ -131,14 +131,13 @@ function date_i18n( $dateformatstring, $unixtimestamp = false, $gmt = false ) {
|
|||||||
* @since 2.3.0
|
* @since 2.3.0
|
||||||
*
|
*
|
||||||
* @param int $number The number to convert based on locale.
|
* @param int $number The number to convert based on locale.
|
||||||
* @param int $decimals Precision of the number of decimal places. Deprectated.
|
* @param int $decimals Precision of the number of decimal places.
|
||||||
* @return string Converted number in string format.
|
* @return string Converted number in string format.
|
||||||
*/
|
*/
|
||||||
function number_format_i18n( $number, $decimals = null ) {
|
function number_format_i18n( $number, $decimals = 0 ) {
|
||||||
global $wp_locale;
|
global $wp_locale;
|
||||||
$number = (int)$number;
|
$number = (int)$number;
|
||||||
if ( !is_null( $decimals ) ) _deprecated_argument( __FUNCTION__, '3.0' );
|
$formatted = number_format( $number, absint( $decimals ), $wp_locale->number_format['decimal_point'], $wp_locale->number_format['thousands_sep'] );
|
||||||
$formatted = number_format( $number, 0, null, $wp_locale->number_format['thousands_sep'] );
|
|
||||||
return apply_filters( 'number_format_i18n', $formatted );
|
return apply_filters( 'number_format_i18n', $formatted );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -163,7 +162,7 @@ function number_format_i18n( $number, $decimals = null ) {
|
|||||||
* @param int $decimals Precision of number of decimal places. Deprecated.
|
* @param int $decimals Precision of number of decimal places. Deprecated.
|
||||||
* @return bool|string False on failure. Number string on success.
|
* @return bool|string False on failure. Number string on success.
|
||||||
*/
|
*/
|
||||||
function size_format( $bytes, $decimals = null ) {
|
function size_format( $bytes, $decimals = 0 ) {
|
||||||
$quant = array(
|
$quant = array(
|
||||||
// ========================= Origin ====
|
// ========================= Origin ====
|
||||||
'TB' => 1099511627776, // pow( 1024, 4)
|
'TB' => 1099511627776, // pow( 1024, 4)
|
||||||
@ -172,10 +171,9 @@ function size_format( $bytes, $decimals = null ) {
|
|||||||
'kB' => 1024, // pow( 1024, 1)
|
'kB' => 1024, // pow( 1024, 1)
|
||||||
'B ' => 1, // pow( 1024, 0)
|
'B ' => 1, // pow( 1024, 0)
|
||||||
);
|
);
|
||||||
if ( !is_null( $decimals ) ) _deprecated_argument( __FUNCTION__, '3.0' );
|
|
||||||
foreach ( $quant as $unit => $mag )
|
foreach ( $quant as $unit => $mag )
|
||||||
if ( doubleval($bytes) >= $mag )
|
if ( doubleval($bytes) >= $mag )
|
||||||
return number_format_i18n( round( $bytes / $mag ) ) . ' ' . $unit;
|
return number_format_i18n( $bytes / $mag, $decimals ) . ' ' . $unit;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -219,7 +219,7 @@ function timer_stop( $display = 0, $precision = 3 ) { // if called like timer_st
|
|||||||
$mtime = explode( ' ', $mtime );
|
$mtime = explode( ' ', $mtime );
|
||||||
$timeend = $mtime[1] + $mtime[0];
|
$timeend = $mtime[1] + $mtime[0];
|
||||||
$timetotal = $timeend - $timestart;
|
$timetotal = $timeend - $timestart;
|
||||||
$r = number_format( $timetotal, $precision );
|
$r = ( function_exists( 'number_format_i18n' ) ) ? number_format_i18n( $timetotal, $precision ) : number_format( $timetotal, $precision );
|
||||||
if ( $display )
|
if ( $display )
|
||||||
echo $r;
|
echo $r;
|
||||||
return $r;
|
return $r;
|
||||||
|
@ -181,6 +181,10 @@ class WP_Locale {
|
|||||||
/* translators: $thousands_sep argument for http://php.net/number_format, default is , */
|
/* translators: $thousands_sep argument for http://php.net/number_format, default is , */
|
||||||
$trans = __('number_format_thousands_sep');
|
$trans = __('number_format_thousands_sep');
|
||||||
$this->number_format['thousands_sep'] = ('number_format_thousands_sep' == $trans) ? ',' : $trans;
|
$this->number_format['thousands_sep'] = ('number_format_thousands_sep' == $trans) ? ',' : $trans;
|
||||||
|
|
||||||
|
/* translators: $dec_point argument for http://php.net/number_format, default is . */
|
||||||
|
$trans = __('number_format_decimal_point');
|
||||||
|
$this->number_format['decimal_point'] = ('number_format_decimal_point' == $trans) ? '.' : $trans;
|
||||||
|
|
||||||
// Import global locale vars set during inclusion of $locale.php.
|
// Import global locale vars set during inclusion of $locale.php.
|
||||||
foreach ( (array) $this->locale_vars as $var ) {
|
foreach ( (array) $this->locale_vars as $var ) {
|
||||||
|
Loading…
Reference in New Issue
Block a user