Module: SDoc::Templatable
- Included in:
- RDoc::Generator::SDoc
- Defined in:
- lib/sdoc/templatable.rb
Instance Method Summary collapse
-
#eval_template(templatefile, context) ⇒ Object
Load and render the erb template in the given
templatefile
within the specifiedcontext
(a Binding object) and return output Bothtemplatefile
andoutfile
should be Pathname-like objects. -
#include_template(template_name, local_assigns = {}) ⇒ Object
Load and render the erb template with the given
template_name
within current context. -
#render_template(templatefile, context, outfile) ⇒ Object
Load and render the erb template in the given
templatefile
within the specifiedcontext
(a Binding object) and write it out tooutfile
.
Instance Method Details
#eval_template(templatefile, context) ⇒ Object
Load and render the erb template in the given templatefile
within the specified context
(a Binding object) and return output Both templatefile
and outfile
should be Pathname-like objects.
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/sdoc/templatable.rb', line 7 def eval_template(templatefile, context) template_src = templatefile.read template = if ERB.instance_method(:initialize).parameters.assoc(:key) # Ruby 2.6+ ERB.new( template_src, trim_mode: '<>' ) else ERB.new( template_src, nil, '<>' ) end template.filename = templatefile.to_s begin template.result( context ) rescue NoMethodError => err raise RDoc::Error, "Error while evaluating %s: %s (at %p)" % [ templatefile.to_s, err., eval( "_erbout[-50,50]", context ) ], err.backtrace end end |
#include_template(template_name, local_assigns = {}) ⇒ Object
Load and render the erb template with the given template_name
within current context. Adds all local_assigns
to context
29 30 31 32 33 |
# File 'lib/sdoc/templatable.rb', line 29 def include_template(template_name, local_assigns = {}) source = local_assigns.keys.map { |key| "#{key} = local_assigns[:#{key}];" }.join templatefile = templatefile = @template_dir + template_name eval("#{source};eval_template(templatefile, binding)") end |
#render_template(templatefile, context, outfile) ⇒ Object
Load and render the erb template in the given templatefile
within the specified context
(a Binding object) and write it out to outfile
. Both templatefile
and outfile
should be Pathname-like objects.
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/sdoc/templatable.rb', line 38 def render_template( templatefile, context, outfile ) output = eval_template(templatefile, context) # TODO delete this dirty hack when documentation for example for GeneratorMethods will not be cutted off by <script> tag begin if output.respond_to? :force_encoding encoding = output.encoding output = output.force_encoding('ASCII-8BIT').gsub('<script>', '<script;>').force_encoding(encoding) else output = output.gsub('<script>', '<script>') end rescue Exception end unless $dryrun outfile.dirname.mkpath outfile.open( 'w', 0644 ) do |file| file.print( output ) end else debug_msg " would have written %d bytes to %s" % [ output.length, outfile ] end end |