/scalate-pegdown/src/main/scala/org/fusesource/scalate/filter/PegDownFilter.scala
http://github.com/scalate/scalate · Scala · 57 lines · 26 code · 5 blank · 26 comment · 0 complexity · 863d97a8951c79dbbc4bc70425b1d7b2 MD5 · raw file
- /*
- * Copyright (C) 2009-2011 the original author or authors.
- * See the notice.md file distributed with this work for additional
- * information regarding copyright ownership.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package org.fusesource.scalate.filter
- import org.fusesource.scalate.{TemplateEngineAddOn, RenderContext, TemplateEngine}
- import org.fusesource.scalate.filter.Filter
- import org.pegdown.{Extensions, PegDownProcessor}
- /**
- * Renders markdown syntax with multi-markdown like extras.
- *
- * @author <a href="mailto:stuart.roebuck@gmail.com">Stuart Roebuck</a>
- */
- object PegDownFilter extends Filter with TemplateEngineAddOn {
- private val pegDownProcessor = new PegDownProcessor(
- Extensions.ABBREVIATIONS |
- Extensions.AUTOLINKS |
- Extensions.DEFINITIONS |
- Extensions.FENCED_CODE_BLOCKS |
- Extensions.QUOTES |
- Extensions.SMARTS |
- Extensions.TABLES |
- Extensions.WIKILINKS
- )
- def filter(context: RenderContext, content: String) = {
- synchronized {
- // This code block is synchronized as the PegDownProcessor is not thread safe.
- pegDownProcessor.markdownToHtml(content).stripLineEnd
- }
- }
- /**
- * Add the markdown filter to the template engine.
- */
- def apply(te: TemplateEngine) = {
- te.filters += "multimarkdown" -> PegDownFilter
- te.pipelines += "mmd" -> List(PegDownFilter)
- te.pipelines += "multimarkdown" -> List(PegDownFilter)
- }
- }