Module: SDoc::Templatable

Included in:
RDoc::Generator::SDoc
Defined in:
lib/sdoc/templatable.rb

Instance Method Summary collapse

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.message,
      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>', '&lt;script;&gt;').force_encoding(encoding)
    else
      output = output.gsub('<script>', '&lt;script&gt;')
    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