Strip backslashes, not just forward slashes, from untrailingslashit().

trailingslashit() will now remove any forward or backslashes from the end of a string before appending a forward slash.

props knutsp, willmot.
fixes #22267.


git-svn-id: https://develop.svn.wordpress.org/trunk@27344 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Nacin 2014-03-01 21:44:43 +00:00
parent 2b03ef73ae
commit 8a617607a7
3 changed files with 35 additions and 13 deletions

View File

@ -1482,35 +1482,34 @@ function backslashit($string) {
/**
* Appends a trailing slash.
*
* Will remove trailing slash if it exists already before adding a trailing
* slash. This prevents double slashing a string or path.
* Will remove trailing forward and backslashes if it exists already before adding
* a trailing forward slash. This prevents double slashing a string or path.
*
* The primary use of this is for paths and thus should be used for paths. It is
* not restricted to paths and offers no specific path support.
*
* @since 1.2.0
* @uses untrailingslashit() Unslashes string if it was slashed already.
*
* @param string $string What to add the trailing slash to.
* @return string String with trailing slash added.
*/
function trailingslashit($string) {
return untrailingslashit($string) . '/';
function trailingslashit( $string ) {
return untrailingslashit( $string ) . '/';
}
/**
* Removes trailing slash if it exists.
* Removes trailing forward slashes and backslashes if they exist.
*
* The primary use of this is for paths and thus should be used for paths. It is
* not restricted to paths and offers no specific path support.
*
* @since 2.2.0
*
* @param string $string What to remove the trailing slash from.
* @return string String without the trailing slash.
* @param string $string What to remove the trailing slashes from.
* @return string String without the trailing slashes.
*/
function untrailingslashit($string) {
return rtrim($string, '/');
function untrailingslashit( $string ) {
return rtrim( $string, '/\\' );
}
/**

View File

@ -1455,17 +1455,17 @@ function get_temp_dir() {
return trailingslashit(WP_TEMP_DIR);
if ( $temp )
return trailingslashit( rtrim( $temp, '\\' ) );
return trailingslashit( $temp );
if ( function_exists('sys_get_temp_dir') ) {
$temp = sys_get_temp_dir();
if ( @is_dir( $temp ) && wp_is_writable( $temp ) )
return trailingslashit( rtrim( $temp, '\\' ) );
return trailingslashit( $temp );
}
$temp = ini_get('upload_tmp_dir');
if ( @is_dir( $temp ) && wp_is_writable( $temp ) )
return trailingslashit( rtrim( $temp, '\\' ) );
return trailingslashit( $temp );
$temp = WP_CONTENT_DIR . '/';
if ( is_dir( $temp ) && wp_is_writable( $temp ) )

View File

@ -21,6 +21,22 @@ class Tests_Formatting_Slashit extends WP_UnitTestCase {
$this->assertEquals("a", untrailingslashit("a////"));
}
/**
* @ticket 22267
*/
function test_removes_trailing_backslashes() {
$this->assertEquals("a", untrailingslashit("a\\"));
$this->assertEquals("a", untrailingslashit("a\\\\\\\\"));
}
/**
* @ticket 22267
*/
function test_removes_trailing_mixed_slashes() {
$this->assertEquals("a", untrailingslashit("a/\\"));
$this->assertEquals("a", untrailingslashit("a\\/\\///\\\\//"));
}
function test_adds_trailing_slash() {
$this->assertEquals("a/", trailingslashit("a"));
}
@ -28,4 +44,11 @@ class Tests_Formatting_Slashit extends WP_UnitTestCase {
function test_does_not_add_trailing_slash_if_one_exists() {
$this->assertEquals("a/", trailingslashit("a/"));
}
/**
* @ticket 22267
*/
function test_converts_trailing_backslash_to_slash_if_one_exists() {
$this->assertEquals("a/", trailingslashit("a\\"));
}
}