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にもこの変更を入れました。