Skip to content

Commit

Permalink
Define ERB::Escape module
Browse files Browse the repository at this point in the history
Close #32
  • Loading branch information
k0kubun committed Nov 25, 2022
1 parent 5c10f56 commit f32f6a8
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 9 deletions.
6 changes: 3 additions & 3 deletions ext/erb/escape/escape.c
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
#include "ruby.h"
#include "ruby/encoding.h"

static VALUE rb_cERB, rb_mUtil, rb_cCGI;
static VALUE rb_cERB, rb_mEscape, rb_cCGI;
static ID id_escapeHTML;

#define HTML_ESCAPE_MAX_LEN 6
Expand Down Expand Up @@ -87,8 +87,8 @@ void
Init_escape(void)
{
rb_cERB = rb_define_class("ERB", rb_cObject);
rb_mUtil = rb_define_module_under(rb_cERB, "Util");
rb_define_method(rb_mUtil, "html_escape", erb_escape_html, 1);
rb_mEscape = rb_define_module_under(rb_cERB, "Escape");
rb_define_module_function(rb_mEscape, "html_escape", erb_escape_html, 1);

rb_cCGI = rb_define_class("CGI", rb_cObject);
id_escapeHTML = rb_intern("escapeHTML");
Expand Down
20 changes: 14 additions & 6 deletions lib/erb/util.rb
Original file line number Diff line number Diff line change
@@ -1,8 +1,20 @@
#--
# ERB::Escape
#
# A subset of ERB::Util. Unlike ERB::Util#html_escape, we expect/hope
# Rails will not monkey-patch ERB::Escape#html_escape.
begin
# ERB::Util.html_escape
require 'erb/escape'
rescue LoadError # JRuby can't load .so
end
unless defined?(ERB::Escape) # JRuby
module ERB::Escape
def html_escape(s)
CGI.escapeHTML(s.to_s)
end
module_function :html_escape
end
end

#--
# ERB::Util
Expand All @@ -21,11 +33,7 @@ module ERB::Util
#
# is a > 0 & a < 10?
#
unless method_defined?(:html_escape) # for JRuby
def html_escape(s)
CGI.escapeHTML(s.to_s)
end
end
include ERB::Escape # html_escape
alias h html_escape
module_function :h
module_function :html_escape
Expand Down

0 comments on commit f32f6a8

Please sign in to comment.