Browse Source

Refactor changes into single get_encoding() method within the HTML Class (in order to remove duplication of logic). All tests continue to pass.

thybag 12 years ago
parent
commit
a9be66d41a
1 changed files with 15 additions and 6 deletions
  1. 15 6
      laravel/html.php

+ 15 - 6
laravel/html.php

@@ -38,8 +38,7 @@ class HTML {
 	 */
 	 */
 	public static function entities($value)
 	public static function entities($value)
 	{
 	{
-		if(static::$encoding===null) static::$encoding = Config::get('application.encoding');
-		return htmlentities($value, ENT_QUOTES, static::$encoding, false);
+		return htmlentities($value, ENT_QUOTES, static::get_encoding(), false);
 	}
 	}
 
 
 	/**
 	/**
@@ -50,8 +49,7 @@ class HTML {
 	 */
 	 */
 	public static function decode($value)
 	public static function decode($value)
 	{
 	{
-		if(static::$encoding===null) static::$encoding = Config::get('application.encoding');
-		return html_entity_decode($value, ENT_QUOTES, static::$encoding);
+		return html_entity_decode($value, ENT_QUOTES, static::get_encoding());
 	}
 	}
 
 
 	/**
 	/**
@@ -64,8 +62,7 @@ class HTML {
 	 */
 	 */
 	public static function specialchars($value)
 	public static function specialchars($value)
 	{
 	{
-		if(static::$encoding===null) static::$encoding = Config::get('application.encoding');
-		return htmlspecialchars($value, ENT_QUOTES, static::$encoding, false);
+		return htmlspecialchars($value, ENT_QUOTES, static::get_encoding(), false);
 	}
 	}
 
 
 	/**
 	/**
@@ -417,6 +414,18 @@ class HTML {
 		return $safe;
 		return $safe;
 	}
 	}
 
 
+	/**
+	 * Get the appliction.encoding without needing to request it from Config::get() each time.
+	 *
+	 * @return string
+	 */
+	public static function get_encoding(){
+
+		if(static::$encoding===null) static::$encoding = Config::get('application.encoding');
+
+		return static::$encoding;
+	}
+
 	/**
 	/**
 	 * Dynamically handle calls to custom macros.
 	 * Dynamically handle calls to custom macros.
 	 *
 	 *