Merge pull request #521 from bhollis/markdown
Use middleman's image_tag and link_to helpers from within Redcarpet markdown
This commit is contained in:
commit
d88f2fade0
2 changed files with 25 additions and 6 deletions
|
@ -10,7 +10,6 @@ module Middleman
|
||||||
# Once registered
|
# Once registered
|
||||||
def registered(app)
|
def registered(app)
|
||||||
# Set our preference for a markdown engine
|
# Set our preference for a markdown engine
|
||||||
# TODO: Find a JRuby-compatible version
|
|
||||||
app.set :markdown_engine, :maruku
|
app.set :markdown_engine, :maruku
|
||||||
app.set :markdown_engine_prefix, ::Tilt
|
app.set :markdown_engine_prefix, ::Tilt
|
||||||
|
|
||||||
|
@ -54,4 +53,4 @@ module Middleman
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -7,12 +7,12 @@ module Middleman
|
||||||
|
|
||||||
# Overwrite built-in Tilt version.
|
# Overwrite built-in Tilt version.
|
||||||
# Don't overload :renderer option with smartypants
|
# Don't overload :renderer option with smartypants
|
||||||
# Supper renderer-level options
|
# Support renderer-level options
|
||||||
def generate_renderer
|
def generate_renderer
|
||||||
return options.delete(:renderer) if options.has_key?(:renderer)
|
return options.delete(:renderer) if options.has_key?(:renderer)
|
||||||
|
|
||||||
# Pick a renderer
|
# Pick a renderer
|
||||||
renderer = ::Redcarpet::Render::HTML
|
renderer = MiddlemanRedcarpetHTML
|
||||||
|
|
||||||
# Support SmartyPants
|
# Support SmartyPants
|
||||||
if options.delete(:smartypants)
|
if options.delete(:smartypants)
|
||||||
|
@ -28,11 +28,31 @@ module Middleman
|
||||||
sum[opt] = options.delete(opt) if options.has_key?(opt)
|
sum[opt] = options.delete(opt) if options.has_key?(opt)
|
||||||
sum
|
sum
|
||||||
end
|
end
|
||||||
|
|
||||||
renderer.new(render_options)
|
renderer.new(render_options)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def evaluate(scope, locals, &block)
|
||||||
|
if @engine.renderer.respond_to? :middleman_app=
|
||||||
|
@engine.renderer.middleman_app = scope
|
||||||
|
end
|
||||||
|
super
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# Custom Redcarpet renderer that uses our helpers for images and links
|
||||||
|
class MiddlemanRedcarpetHTML < ::Redcarpet::Render::HTML
|
||||||
|
attr_accessor :middleman_app
|
||||||
|
|
||||||
|
def image(link, title, alt_text)
|
||||||
|
middleman_app.image_tag(link, :title => title, :alt => alt_text)
|
||||||
|
end
|
||||||
|
|
||||||
|
def link(link, title, content)
|
||||||
|
middleman_app.link_to(content, link, :title => title)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
::Tilt.register RedcarpetTemplate, 'markdown', 'mkd', 'md'
|
::Tilt.register RedcarpetTemplate, 'markdown', 'mkd', 'md'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Reference in a new issue