Class: RDoc::ERBIO
- Inherits:
-
ERB
- Object
- ERB
- RDoc::ERBIO
- Defined in:
- lib/rdoc/erbio.rb
Overview
A subclass of ERB that writes directly to an IO. Credit to Aaron Patterson and Masatoshi SEKI.
To use:
erbio = RDoc::ERBIO.new '<%= "hello world" %>', nil, nil
open 'hello.txt', 'w' do |io|
erbio.result binding
end
Note that binding must enclose the io you wish to output on.
Instance Method Summary collapse
-
#initialize(str, safe_level = nil, trim_mode = nil, eoutvar = 'io') ⇒ ERBIO
constructor
Defaults
eoutvar
to ‘io’, otherwise is identical to ERB’s initialize. -
#set_eoutvar(compiler, io_variable) ⇒ Object
Instructs
compiler
how to write toio_variable
.
Constructor Details
#initialize(str, safe_level = nil, trim_mode = nil, eoutvar = 'io') ⇒ ERBIO
Defaults eoutvar
to ‘io’, otherwise is identical to ERB’s initialize
22 23 24 |
# File 'lib/rdoc/erbio.rb', line 22 def initialize str, safe_level = nil, trim_mode = nil, eoutvar = 'io' super end |
Instance Method Details
#set_eoutvar(compiler, io_variable) ⇒ Object
Instructs compiler
how to write to io_variable
29 30 31 32 33 34 |
# File 'lib/rdoc/erbio.rb', line 29 def set_eoutvar compiler, io_variable compiler.put_cmd = "#{io_variable}.write" compiler.insert_cmd = "#{io_variable}.write" compiler.pre_cmd = [] compiler.post_cmd = [] end |