aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_view/erb
diff options
context:
space:
mode:
authorJoshua Peek <josh@joshpeek.com>2008-11-23 13:42:07 -0600
committerJoshua Peek <josh@joshpeek.com>2008-11-23 13:42:07 -0600
commit2c01f2b4e9d4a95bb2baca8ae57209eb10aa78b2 (patch)
tree7ef23887bc8642b99d9b99736ccccf89eaf5a6d9 /actionpack/lib/action_view/erb
parente201fc750bf4b7dff1875b7fcdd47f1686ef2052 (diff)
downloadrails-2c01f2b4e9d4a95bb2baca8ae57209eb10aa78b2.tar.gz
rails-2c01f2b4e9d4a95bb2baca8ae57209eb10aa78b2.tar.bz2
rails-2c01f2b4e9d4a95bb2baca8ae57209eb10aa78b2.zip
use autoload instead of explicit requires for ActionView
Diffstat (limited to 'actionpack/lib/action_view/erb')
-rw-r--r--actionpack/lib/action_view/erb/util.rb38
1 files changed, 38 insertions, 0 deletions
diff --git a/actionpack/lib/action_view/erb/util.rb b/actionpack/lib/action_view/erb/util.rb
new file mode 100644
index 0000000000..3c77c5ce76
--- /dev/null
+++ b/actionpack/lib/action_view/erb/util.rb
@@ -0,0 +1,38 @@
+require 'erb'
+
+class ERB
+ module Util
+ HTML_ESCAPE = { '&' => '&amp;', '>' => '&gt;', '<' => '&lt;', '"' => '&quot;' }
+ JSON_ESCAPE = { '&' => '\u0026', '>' => '\u003E', '<' => '\u003C' }
+
+ # A utility method for escaping HTML tag characters.
+ # This method is also aliased as <tt>h</tt>.
+ #
+ # In your ERb templates, use this method to escape any unsafe content. For example:
+ # <%=h @person.name %>
+ #
+ # ==== Example:
+ # puts html_escape("is a > 0 & a < 10?")
+ # # => is a &gt; 0 &amp; a &lt; 10?
+ def html_escape(s)
+ s.to_s.gsub(/[&"><]/) { |special| HTML_ESCAPE[special] }
+ end
+
+ # A utility method for escaping HTML entities in JSON strings.
+ # This method is also aliased as <tt>j</tt>.
+ #
+ # In your ERb templates, use this method to escape any HTML entities:
+ # <%=j @person.to_json %>
+ #
+ # ==== Example:
+ # puts json_escape("is a > 0 & a < 10?")
+ # # => is a \u003E 0 \u0026 a \u003C 10?
+ def json_escape(s)
+ s.to_s.gsub(/[&"><]/) { |special| JSON_ESCAPE[special] }
+ end
+
+ alias j json_escape
+ module_function :j
+ module_function :json_escape
+ end
+end