Formatting: In sanitize_title_with_dashes(), convert &nbsp, &ndash, and &mdash HTML entities to hyphens on save.

Props polevaultweb for initial patch.
Fixes #31790.

git-svn-id: https://develop.svn.wordpress.org/trunk@36775 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Sergey Biryukov 2016-02-29 04:41:03 +00:00
parent f188597025
commit 13e409ac15
2 changed files with 20 additions and 2 deletions

View File

@ -1584,12 +1584,12 @@ function sanitize_title_with_dashes( $title, $raw_title = '', $context = 'displa
} }
$title = strtolower($title); $title = strtolower($title);
$title = preg_replace('/&.+?;/', '', $title); // kill entities
$title = str_replace('.', '-', $title);
if ( 'save' == $context ) { if ( 'save' == $context ) {
// Convert nbsp, ndash and mdash to hyphens // Convert nbsp, ndash and mdash to hyphens
$title = str_replace( array( '%c2%a0', '%e2%80%93', '%e2%80%94' ), '-', $title ); $title = str_replace( array( '%c2%a0', '%e2%80%93', '%e2%80%94' ), '-', $title );
// Convert nbsp, ndash and mdash HTML entities to hyphens
$title = str_replace( array( ' ', ' ', '–', '–', '—', '—' ), '-', $title );
// Strip these characters entirely // Strip these characters entirely
$title = str_replace( array( $title = str_replace( array(
@ -1612,6 +1612,9 @@ function sanitize_title_with_dashes( $title, $raw_title = '', $context = 'displa
$title = str_replace( '%c3%97', 'x', $title ); $title = str_replace( '%c3%97', 'x', $title );
} }
$title = preg_replace('/&.+?;/', '', $title); // kill entities
$title = str_replace('.', '-', $title);
$title = preg_replace('/[^%a-z0-9 _-]/', '', $title); $title = preg_replace('/[^%a-z0-9 _-]/', '', $title);
$title = preg_replace('/\s+/', '-', $title); $title = preg_replace('/\s+/', '-', $title);
$title = preg_replace('|-+|', '-', $title); $title = preg_replace('|-+|', '-', $title);

View File

@ -63,11 +63,26 @@ class Tests_Formatting_SanitizeTitleWithDashes extends WP_UnitTestCase {
$this->assertEquals("dont-break-the-space", sanitize_title_with_dashes("don't break the space", '', 'save')); $this->assertEquals("dont-break-the-space", sanitize_title_with_dashes("don't break the space", '', 'save'));
} }
/**
* @ticket 31790
*/
function test_replaces_nbsp_entities() {
$this->assertEquals("dont-break-the-space", sanitize_title_with_dashes("don't break the space", '', 'save'));
}
function test_replaces_ndash_mdash() { function test_replaces_ndash_mdash() {
$this->assertEquals("do-the-dash", sanitize_title_with_dashes("Do the Dash", '', 'save')); $this->assertEquals("do-the-dash", sanitize_title_with_dashes("Do the Dash", '', 'save'));
$this->assertEquals("do-the-dash", sanitize_title_with_dashes("Do the — Dash", '', 'save')); $this->assertEquals("do-the-dash", sanitize_title_with_dashes("Do the — Dash", '', 'save'));
} }
/**
* @ticket 31790
*/
function test_replaces_ndash_mdash_entities() {
$this->assertEquals("do-the-dash", sanitize_title_with_dashes("Do – the – Dash", '', 'save'));
$this->assertEquals("do-the-dash", sanitize_title_with_dashes("Do — the — Dash", '', 'save'));
}
function test_replaces_iexcel_iquest() { function test_replaces_iexcel_iquest() {
$this->assertEquals("just-a-slug", sanitize_title_with_dashes("Just ¡a Slug", '', 'save')); $this->assertEquals("just-a-slug", sanitize_title_with_dashes("Just ¡a Slug", '', 'save'));
$this->assertEquals("just-a-slug", sanitize_title_with_dashes("Just a Slug¿", '', 'save')); $this->assertEquals("just-a-slug", sanitize_title_with_dashes("Just a Slug¿", '', 'save'));