Commit 17ea0936 by Taylor Otwell

fixed str test cases and str::limit function.

parent a6eaa069
......@@ -39,6 +39,7 @@ return array(
'GET /' => function()
{
return Laravel\Str::limit('This is a string of text', 3, '...');
return View::make('home.index');
},
......
......@@ -101,11 +101,8 @@ class Str {
/**
* Limit the number of characters in a string.
*
* Word integrity is preserved, so the number of characters in the
* truncated string will be rounded to the nearest word ending.
*
* <code>
* // Returns "Taylor..."
* // Returns "Tay..."
* echo Str::limit('Taylor Otwell', 3);
*
* // Limit the number of characters and append a custom ending
......@@ -113,17 +110,20 @@ class Str {
* </code>
*
* @param string $value
* @param int $length
* @param int $limit
* @param string $end
* @return string
*/
public static function limit($value, $limit = 100, $end = '...')
{
if (static::length($value) < $limit) return $value;
if (static::length($value) <= $limit) return $value;
$limit = preg_replace('/\s+?(\S+)?$/', '', substr($value, 0, $limit));
if (function_exists('mb_substr'))
{
return mb_substr($value, 0, $limit, Config::get('application.encoding')).$end;
}
return (static::length($limit) == static::length($value)) ? $value : $limit.$end;
return substr($value, 0, $limit).$end;
}
/**
......
......@@ -45,7 +45,7 @@ class StrTest extends PHPUnit_Framework_TestCase {
public function test_limit_words()
{
$this->assertEquals('This is a...', Laravel\Str::limit_words('This is a string of text', 3, '...'));
$this->assertEquals('This is a string&nbsp;', Laravel\Str::limit_words('This is a string of text', 4, '&nbsp;'));
$this->assertEquals('This is a...', Laravel\Str::words('This is a string of text', 3, '...'));
$this->assertEquals('This is a string&nbsp;', Laravel\Str::words('This is a string of text', 4, '&nbsp;'));
}
}
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment