Browse Source

fixed str test cases and str::limit function.

Taylor Otwell 13 years ago
parent
commit
17ea09364d
3 changed files with 11 additions and 10 deletions
  1. 1 0
      application/routes.php
  2. 8 8
      laravel/str.php
  3. 2 2
      tests/Cases/StrTest.php

+ 1 - 0
application/routes.php

@@ -39,6 +39,7 @@ return array(
 
 	'GET /' => function()
 	{
+		return Laravel\Str::limit('This is a string of text', 3, '...');
 		return View::make('home.index');
 	},
 

+ 8 - 8
laravel/str.php

@@ -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;
 	}
 
 	/**

+ 2 - 2
tests/Cases/StrTest.php

@@ -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;'));
 	}
 }