mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge branch '3' into 4
This commit is contained in:
commit
d7095c2213
@ -385,10 +385,10 @@ class Convert
|
|||||||
|
|
||||||
// Expand hyperlinks
|
// Expand hyperlinks
|
||||||
if (!$preserveLinks && !$config['PreserveLinks']) {
|
if (!$preserveLinks && !$config['PreserveLinks']) {
|
||||||
$data = preg_replace_callback('/<a[^>]*href\s*=\s*"([^"]*)">(.*?)<\/a>/i', function ($matches) {
|
$data = preg_replace_callback('/<a[^>]*href\s*=\s*"([^"]*)">(.*?)<\/a>/ui', function ($matches) {
|
||||||
return Convert::html2raw($matches[2]) . "[$matches[1]]";
|
return Convert::html2raw($matches[2]) . "[$matches[1]]";
|
||||||
}, $data);
|
}, $data);
|
||||||
$data = preg_replace_callback('/<a[^>]*href\s*=\s*([^ ]*)>(.*?)<\/a>/i', function ($matches) {
|
$data = preg_replace_callback('/<a[^>]*href\s*=\s*([^ ]*)>(.*?)<\/a>/ui', function ($matches) {
|
||||||
return Convert::html2raw($matches[2]) . "[$matches[1]]";
|
return Convert::html2raw($matches[2]) . "[$matches[1]]";
|
||||||
}, $data);
|
}, $data);
|
||||||
}
|
}
|
||||||
@ -401,13 +401,13 @@ class Convert
|
|||||||
|
|
||||||
// Compress whitespace
|
// Compress whitespace
|
||||||
if ($config['CompressWhitespace']) {
|
if ($config['CompressWhitespace']) {
|
||||||
$data = preg_replace("/\s+/", " ", $data);
|
$data = preg_replace("/\s+/u", " ", $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Parse newline tags
|
// Parse newline tags
|
||||||
$data = preg_replace("/\s*<[Hh][1-6]([^A-Za-z0-9>][^>]*)?> */", "\n\n", $data);
|
$data = preg_replace("/\s*<[Hh][1-6]([^A-Za-z0-9>][^>]*)?> */u", "\n\n", $data);
|
||||||
$data = preg_replace("/\s*<[Pp]([^A-Za-z0-9>][^>]*)?> */", "\n\n", $data);
|
$data = preg_replace("/\s*<[Pp]([^A-Za-z0-9>][^>]*)?> */u", "\n\n", $data);
|
||||||
$data = preg_replace("/\s*<[Dd][Ii][Vv]([^A-Za-z0-9>][^>]*)?> */", "\n\n", $data);
|
$data = preg_replace("/\s*<[Dd][Ii][Vv]([^A-Za-z0-9>][^>]*)?> */u", "\n\n", $data);
|
||||||
$data = preg_replace("/\n\n\n+/", "\n\n", $data);
|
$data = preg_replace("/\n\n\n+/", "\n\n", $data);
|
||||||
|
|
||||||
$data = preg_replace("/<[Bb][Rr]([^A-Za-z0-9>][^>]*)?> */", "\n", $data);
|
$data = preg_replace("/<[Bb][Rr]([^A-Za-z0-9>][^>]*)?> */", "\n", $data);
|
||||||
|
@ -80,7 +80,7 @@ class DBText extends DBString
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Do a word-search
|
// Do a word-search
|
||||||
$words = preg_split('/\s+/', $value);
|
$words = preg_split('/\s+/u', $value);
|
||||||
$sentences = 0;
|
$sentences = 0;
|
||||||
foreach ($words as $i => $word) {
|
foreach ($words as $i => $word) {
|
||||||
if (preg_match('/(!|\?|\.)$/', $word) && !preg_match('/(Dr|Mr|Mrs|Ms|Miss|Sr|Jr|No)\.$/i', $word)) {
|
if (preg_match('/(!|\?|\.)$/', $word) && !preg_match('/(Dr|Mr|Mrs|Ms|Miss|Sr|Jr|No)\.$/i', $word)) {
|
||||||
@ -130,7 +130,7 @@ class DBText extends DBString
|
|||||||
$sentences = array_filter(array_map(function ($str) {
|
$sentences = array_filter(array_map(function ($str) {
|
||||||
return trim($str);
|
return trim($str);
|
||||||
}, preg_split('@(?<=\.)@', $value)));
|
}, preg_split('@(?<=\.)@', $value)));
|
||||||
$wordCount = count(preg_split('#\s+#', $sentences[0]));
|
$wordCount = count(preg_split('#\s+#u', $sentences[0]));
|
||||||
|
|
||||||
// if the first sentence is too long, show only the first $maxWords words
|
// if the first sentence is too long, show only the first $maxWords words
|
||||||
if ($wordCount > $maxWords) {
|
if ($wordCount > $maxWords) {
|
||||||
@ -145,7 +145,7 @@ class DBText extends DBString
|
|||||||
|
|
||||||
// If more sentences to process, count number of words
|
// If more sentences to process, count number of words
|
||||||
if ($sentences) {
|
if ($sentences) {
|
||||||
$wordCount += count(preg_split('#\s+#', $sentences[0]));
|
$wordCount += count(preg_split('#\s+#u', $sentences[0]));
|
||||||
}
|
}
|
||||||
} while ($wordCount < $maxWords && $sentences && trim($sentences[0]));
|
} while ($wordCount < $maxWords && $sentences && trim($sentences[0]));
|
||||||
|
|
||||||
|
@ -17,6 +17,24 @@ class ConvertTest extends SapphireTest
|
|||||||
|
|
||||||
protected $usesDatabase = false;
|
protected $usesDatabase = false;
|
||||||
|
|
||||||
|
private $previousLocaleSetting = null;
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
// clear the previous locale setting
|
||||||
|
$this->previousLocaleSetting = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function tearDown()
|
||||||
|
{
|
||||||
|
parent::tearDown();
|
||||||
|
// If a test sets the locale, reset it on teardown
|
||||||
|
if ($this->previousLocaleSetting) {
|
||||||
|
setlocale(LC_CTYPE, $this->previousLocaleSetting);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests {@link Convert::raw2att()}
|
* Tests {@link Convert::raw2att()}
|
||||||
*/
|
*/
|
||||||
@ -479,6 +497,30 @@ XML
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testValidUtf8()
|
||||||
|
{
|
||||||
|
// Install a UTF-8 locale
|
||||||
|
$this->previousLocaleSetting = setlocale(LC_CTYPE, 0);
|
||||||
|
|
||||||
|
$locales = array('en_US.UTF-8', 'en_NZ.UTF-8', 'de_DE.UTF-8');
|
||||||
|
$localeInstalled = false;
|
||||||
|
foreach ($locales as $locale) {
|
||||||
|
if ($localeInstalled = setlocale(LC_CTYPE, $locale)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the system doesn't have any of the UTF-8 locales, exit early
|
||||||
|
if ($localeInstalled === false) {
|
||||||
|
$this->markTestIncomplete('Unable to run this test because of missing locale!');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$problematicText = html_entity_decode('<p>This is a Test with non-breaking space!</p>', ENT_COMPAT, 'UTF-8');
|
||||||
|
|
||||||
|
$this->assertTrue(mb_check_encoding(Convert::html2raw($problematicText), 'UTF-8'));
|
||||||
|
}
|
||||||
|
|
||||||
public function testUpperCamelToLowerCamel()
|
public function testUpperCamelToLowerCamel()
|
||||||
{
|
{
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
|
@ -15,10 +15,15 @@ use SilverStripe\View\Parsers\ShortcodeParser;
|
|||||||
class DBHTMLTextTest extends SapphireTest
|
class DBHTMLTextTest extends SapphireTest
|
||||||
{
|
{
|
||||||
|
|
||||||
|
private $previousLocaleSetting = null;
|
||||||
|
|
||||||
protected function setUp()
|
protected function setUp()
|
||||||
{
|
{
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
|
// clear the previous locale setting
|
||||||
|
$this->previousLocaleSetting = null;
|
||||||
|
|
||||||
// Set test handler
|
// Set test handler
|
||||||
ShortcodeParser::get('htmltest')
|
ShortcodeParser::get('htmltest')
|
||||||
->register('test_shortcode', array(TestShortcode::class, 'handle_shortcode'));
|
->register('test_shortcode', array(TestShortcode::class, 'handle_shortcode'));
|
||||||
@ -27,6 +32,12 @@ class DBHTMLTextTest extends SapphireTest
|
|||||||
|
|
||||||
protected function tearDown()
|
protected function tearDown()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
// If a test sets the locale, reset it on teardown
|
||||||
|
if ($this->previousLocaleSetting) {
|
||||||
|
setlocale(LC_CTYPE, $this->previousLocaleSetting);
|
||||||
|
}
|
||||||
|
|
||||||
ShortcodeParser::set_active('default');
|
ShortcodeParser::set_active('default');
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
}
|
}
|
||||||
@ -581,4 +592,31 @@ class DBHTMLTextTest extends SapphireTest
|
|||||||
|
|
||||||
ShortcodeParser::set_active('default');
|
ShortcodeParser::set_active('default');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testValidUtf8()
|
||||||
|
{
|
||||||
|
// Install a UTF-8 locale
|
||||||
|
$this->previousLocaleSetting = setlocale(LC_CTYPE, 0);
|
||||||
|
$locales = array('en_US.UTF-8', 'en_NZ.UTF-8', 'de_DE.UTF-8');
|
||||||
|
$localeInstalled = false;
|
||||||
|
foreach ($locales as $locale) {
|
||||||
|
if ($localeInstalled = setlocale(LC_CTYPE, $locale)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the system doesn't have any of the UTF-8 locales, exit early
|
||||||
|
if ($localeInstalled === false) {
|
||||||
|
$this->markTestIncomplete('Unable to run this test because of missing locale!');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$problematicText = html_entity_decode('<p>This is a Test with non-breaking space!</p>', ENT_COMPAT, 'UTF-8');
|
||||||
|
|
||||||
|
$textObj = new DBHTMLText('Test');
|
||||||
|
$textObj->setValue($problematicText);
|
||||||
|
|
||||||
|
$this->assertTrue(mb_check_encoding($textObj->FirstSentence(), 'UTF-8'));
|
||||||
|
$this->assertTrue(mb_check_encoding($textObj->Summary(), 'UTF-8'));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ namespace SilverStripe\ORM\Tests;
|
|||||||
|
|
||||||
use SilverStripe\ORM\FieldType\DBField;
|
use SilverStripe\ORM\FieldType\DBField;
|
||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\ORM\FieldType\DBText;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests parsing and summary methods on DBText
|
* Tests parsing and summary methods on DBText
|
||||||
@ -11,6 +12,24 @@ use SilverStripe\Dev\SapphireTest;
|
|||||||
class DBTextTest extends SapphireTest
|
class DBTextTest extends SapphireTest
|
||||||
{
|
{
|
||||||
|
|
||||||
|
private $previousLocaleSetting = null;
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
// clear the previous locale setting
|
||||||
|
$this->previousLocaleSetting = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function tearDown()
|
||||||
|
{
|
||||||
|
parent::tearDown();
|
||||||
|
// If a test sets the locale, reset it on teardown
|
||||||
|
if ($this->previousLocaleSetting) {
|
||||||
|
setlocale(LC_CTYPE, $this->previousLocaleSetting);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test {@link Text->LimitCharacters()}
|
* Test {@link Text->LimitCharacters()}
|
||||||
*/
|
*/
|
||||||
@ -272,4 +291,30 @@ class DBTextTest extends SapphireTest
|
|||||||
$data = DBField::create_field('Text', '"this is a test"');
|
$data = DBField::create_field('Text', '"this is a test"');
|
||||||
$this->assertEquals($data->ATT(), '"this is a test"');
|
$this->assertEquals($data->ATT(), '"this is a test"');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testValidUtf8()
|
||||||
|
{
|
||||||
|
// Install a UTF-8 locale
|
||||||
|
$this->previousLocaleSetting = setlocale(LC_CTYPE, 0);
|
||||||
|
$locales = array('en_US.UTF-8', 'en_NZ.UTF-8', 'de_DE.UTF-8');
|
||||||
|
$localeInstalled = false;
|
||||||
|
foreach ($locales as $locale) {
|
||||||
|
if ($localeInstalled = setlocale(LC_CTYPE, $locale)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the system doesn't have any of the UTF-8 locales, exit early
|
||||||
|
if ($localeInstalled === false) {
|
||||||
|
$this->markTestIncomplete('Unable to run this test because of missing locale!');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$problematicText = html_entity_decode('This is a Test with non-breaking space!', ENT_COMPAT, 'UTF-8');
|
||||||
|
|
||||||
|
$textObj = new DBText('Test');
|
||||||
|
$textObj->setValue($problematicText);
|
||||||
|
|
||||||
|
$this->assertTrue(mb_check_encoding($textObj->FirstSentence(), 'UTF-8'));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user