Template rendering methods. Each method takes the name of a template to render as a Symbol and returns a String with the rendered output, as well as an optional hash with additional options.
`template` is either the name or path of the template as symbol (Use `:'subdir/myview'` for views in subdirectories), or a string that will be rendered.
Possible options are:
:content_type The content type to use, same arguments as content_type. :layout If set to false, no layout is rendered, otherwise the specified layout is used (Ignored for `sass` and `less`) :layout_engine Engine to use for rendering the layout. :locals A hash with local variables that should be available in the template :scope If set, template is evaluate with the binding of the given object rather than the application instance. :views Views directory to use.
# File lib/sinatra/base.rb, line 516 def initialize super @default_layout = :layout end
# File lib/sinatra/base.rb, line 550 def builder(template=nil, options={}, locals={}, &block) options[:default_content_type] = :xml render_ruby(:builder, template, options, locals, &block) end
# File lib/sinatra/base.rb, line 579 def coffee(template, options={}, locals={}) options.merge! :layout => false, :default_content_type => :js render :coffee, template, options, locals end
# File lib/sinatra/base.rb, line 593 def creole(template, options={}, locals={}) render :creole, template, options, locals end
# File lib/sinatra/base.rb, line 521 def erb(template, options={}, locals={}) render :erb, template, options, locals end
# File lib/sinatra/base.rb, line 525 def erubis(template, options={}, locals={}) warn "Sinatra::Templates#erubis is deprecated and will be removed, use #erb instead.\n" "If you have Erubis installed, it will be used automatically." render :erubis, template, options, locals end
Calls the given block for every possible template file in views, named name.ext, where ext is registered on engine.
# File lib/sinatra/base.rb, line 599 def find_template(views, name, engine) yield ::File.join(views, "#{name}.#{@preferred_extension}") Tilt.mappings.each do |ext, engines| next unless ext != @preferred_extension and engines.include? engine yield ::File.join(views, "#{name}.#{ext}") end end
# File lib/sinatra/base.rb, line 531 def haml(template, options={}, locals={}) render :haml, template, options, locals end
# File lib/sinatra/base.rb, line 545 def less(template, options={}, locals={}) options.merge! :layout => false, :default_content_type => :css render :less, template, options, locals end
# File lib/sinatra/base.rb, line 555 def liquid(template, options={}, locals={}) render :liquid, template, options, locals end
# File lib/sinatra/base.rb, line 575 def markaby(template=nil, options={}, locals={}, &block) render_ruby(:mab, template, options, locals, &block) end
# File lib/sinatra/base.rb, line 559 def markdown(template, options={}, locals={}) render :markdown, template, options, locals end
# File lib/sinatra/base.rb, line 584 def nokogiri(template=nil, options={}, locals={}, &block) options[:default_content_type] = :xml render_ruby(:nokogiri, template, options, locals, &block) end
# File lib/sinatra/base.rb, line 571 def radius(template, options={}, locals={}) render :radius, template, options, locals end
# File lib/sinatra/base.rb, line 567 def rdoc(template, options={}, locals={}) render :rdoc, template, options, locals end
# File lib/sinatra/base.rb, line 535 def sass(template, options={}, locals={}) options.merge! :layout => false, :default_content_type => :css render :sass, template, options, locals end
# File lib/sinatra/base.rb, line 540 def scss(template, options={}, locals={}) options.merge! :layout => false, :default_content_type => :css render :scss, template, options, locals end
# File lib/sinatra/base.rb, line 589 def slim(template, options={}, locals={}) render :slim, template, options, locals end
# File lib/sinatra/base.rb, line 563 def textile(template, options={}, locals={}) render :textile, template, options, locals end