ERB, quote
<%=h %>が自動的に行われるってどういうことだろう。
なんで?
おおいわさんの 自動quoteつきERBの実験などの 記事を受けて咳も考えてみました。
ところで、こういった処理は「quote」と呼ぶものなのですか?
ERB for HTML
CVSのruby-1.9、ruby-1.8*1に入ってるerb.rbと一緒に使う、ちょっとした実験スクリプト。 (このためにerb.rbに新しいインターフェイスを追加しました。作者はズルができるのです。)
<%= ... %>の内容をhtml_escapeで処理してから挿入します。 ただし、具がERB4Html::HtmlStringであるときはそのまま挿入します。
ERBのアプリケーションの多くは、何らかのフレームワーク(たとえばDiv, Rails, おそらくtDiaryも)によって 生成されたHTML片を<%= .. %>に渡すことが多いと思います。 そういうときはERB4Html.quoted()メソッドなどでStringをERB4Html::HtmlString化して返すように しなくてはなりません。
h, uメソッドがERB4Html::HtmlStringを返すのもいいかもしれないけど、hは使わないんだろうから、 ま、いっか。従来のERBスクリプトと互換である必要はないだろうし。
require 'erb'
class ERB
  class ERBString < String
    def to_s; self; end
    def erb_concat(s)
      if self.class === s
        concat(s)
      else
        concat(erb_quote(s))
      end
    end
    def erb_quote(s); s; end
  end
end
class ERB4Html < ERB
  def self.quoted(s)
    HtmlString.new(s)
  end
  class HtmlString < ERB::ERBString
    def erb_quote(s)
      ERB::Util::html_escape(s)
    end
  end
  def set_eoutvar(compiler, eoutvar = '_erbout')
    compiler.put_cmd = "#{eoutvar}.concat"
    compiler.insert_cmd = "#{eoutvar}.erb_concat"
    cmd = []
    cmd.push "#{eoutvar} = ERB4Html.quoted('')"
    compiler.pre_cmd = cmd
    cmd = []
    cmd.push(eoutvar)
    compiler.post_cmd = cmd
  end
end
*1先日ruby-1.8にもこの変更を入れました。



