Introduce `map_deep()`, a utility function that recursively maps a callable function to every item in an array or object. Works like `array_walk_recursive()` but works with objects too.
Updates `rawurlencode_deep()`, `urlencode_deep()`, and `stripslashes_deep()` to use `map_deep()`. Introduces `urldecode_deep()` for completeness. Props wpmuguru, nbachiyski, boonebgorges, MikeHansenMe, chriscct7, realloc, johnbillion Fixes #22300 Built from https://develop.svn.wordpress.org/trunk@35252 git-svn-id: http://core.svn.wordpress.org/trunk@35218 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
f676fdcee3
commit
5576cd3978
|
@ -2009,10 +2009,7 @@ function addslashes_gpc($gpc) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Navigates through an array and removes slashes from the values.
|
* Navigates through an array, object, or scalar, and removes slashes from the values.
|
||||||
*
|
|
||||||
* If an array is passed, the array_map() function causes a callback to pass the
|
|
||||||
* value back to the function. The slashes from this value will removed.
|
|
||||||
*
|
*
|
||||||
* @since 2.0.0
|
* @since 2.0.0
|
||||||
*
|
*
|
||||||
|
@ -2020,43 +2017,55 @@ function addslashes_gpc($gpc) {
|
||||||
* @return mixed Stripped value.
|
* @return mixed Stripped value.
|
||||||
*/
|
*/
|
||||||
function stripslashes_deep( $value ) {
|
function stripslashes_deep( $value ) {
|
||||||
if ( is_array($value) ) {
|
return map_deep( $value, 'stripslashes_from_strings_only' );
|
||||||
$value = array_map('stripslashes_deep', $value);
|
|
||||||
} elseif ( is_object($value) ) {
|
|
||||||
$vars = get_object_vars( $value );
|
|
||||||
foreach ($vars as $key=>$data) {
|
|
||||||
$value->{$key} = stripslashes_deep( $data );
|
|
||||||
}
|
|
||||||
} elseif ( is_string( $value ) ) {
|
|
||||||
$value = stripslashes($value);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Navigates through an array and encodes the values to be used in a URL.
|
* Callback function for `stripslashes_deep()` which strips slashes from strings.
|
||||||
*
|
*
|
||||||
|
* @since 4.4.0
|
||||||
|
*
|
||||||
|
* @param mixed $value The array or string to be stripped.
|
||||||
|
* @return mixed $value The stripped value.
|
||||||
|
*/
|
||||||
|
function stripslashes_from_strings_only( $value ) {
|
||||||
|
return is_string( $value ) ? stripslashes( $value ) : $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Navigates through an array, object, or scalar, and encodes the values to be used in a URL.
|
||||||
*
|
*
|
||||||
* @since 2.2.0
|
* @since 2.2.0
|
||||||
*
|
*
|
||||||
* @param array|string $value The array or string to be encoded.
|
* @param mixed $value The array or string to be encoded.
|
||||||
* @return array|string $value The encoded array (or string from the callback).
|
* @return mixed $value The encoded value.
|
||||||
*/
|
*/
|
||||||
function urlencode_deep( $value ) {
|
function urlencode_deep( $value ) {
|
||||||
return is_array( $value ) ? array_map( 'urlencode_deep', $value ) : urlencode( $value );
|
return map_deep( $value, 'urlencode' );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Navigates through an array and raw encodes the values to be used in a URL.
|
* Navigates through an array, object, or scalar, and raw-encodes the values to be used in a URL.
|
||||||
*
|
*
|
||||||
* @since 3.4.0
|
* @since 3.4.0
|
||||||
*
|
*
|
||||||
* @param array|string $value The array or string to be encoded.
|
* @param mixed $value The array or string to be encoded.
|
||||||
* @return array|string $value The encoded array (or string from the callback).
|
* @return mixed $value The encoded value.
|
||||||
*/
|
*/
|
||||||
function rawurlencode_deep( $value ) {
|
function rawurlencode_deep( $value ) {
|
||||||
return is_array( $value ) ? array_map( 'rawurlencode_deep', $value ) : rawurlencode( $value );
|
return map_deep( $value, 'rawurlencode' );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Navigates through an array, object, or scalar, and decodes URL-encoded values
|
||||||
|
*
|
||||||
|
* @since 4.4.0
|
||||||
|
*
|
||||||
|
* @param mixed $value The array or string to be decoded.
|
||||||
|
* @return mixed $value The decoded value.
|
||||||
|
*/
|
||||||
|
function urldecode_deep( $value ) {
|
||||||
|
return map_deep( $value, 'urldecode' );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -3862,6 +3871,28 @@ function sanitize_option( $option, $value ) {
|
||||||
return apply_filters( "sanitize_option_{$option}", $value, $option, $original_value );
|
return apply_filters( "sanitize_option_{$option}", $value, $option, $original_value );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Maps a function to all non-iterable elements of an array or an object.
|
||||||
|
*
|
||||||
|
* This is similar to `array_walk_recursive()` but acts upon objects too.
|
||||||
|
*
|
||||||
|
* @since 4.4.0
|
||||||
|
*
|
||||||
|
* @param mixed $value The array, object, or scalar.
|
||||||
|
* @param callable $function The function to map onto $value.
|
||||||
|
* @return The value with the callback applied to all non-arrays and non-objects inside it.
|
||||||
|
*/
|
||||||
|
function map_deep( $value, $callback ) {
|
||||||
|
if ( is_array( $value ) || is_object( $value ) ) {
|
||||||
|
foreach ( $value as &$item ) {
|
||||||
|
$item = map_deep( $item, $callback );
|
||||||
|
}
|
||||||
|
return $value;
|
||||||
|
} else {
|
||||||
|
return call_user_func( $callback, $value );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parses a string into variables to be stored in an array.
|
* Parses a string into variables to be stored in an array.
|
||||||
*
|
*
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '4.4-alpha-35251';
|
$wp_version = '4.4-alpha-35252';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
Loading…
Reference in New Issue