Skip to content

Instantly share code, notes, and snippets.

@Vaysman
Forked from Arakade/build.gradle
Last active August 29, 2015 14:16
Show Gist options
  • Save Vaysman/bc0564b66498c0efbb47 to your computer and use it in GitHub Desktop.
Save Vaysman/bc0564b66498c0efbb47 to your computer and use it in GitHub Desktop.
import com.petebevin.markdown.MarkdownProcessor
import org.xhtmlrenderer.pdf.ITextRenderer
import org.ccil.cowan.tagsoup.Parser
import org.apache.xalan.xsltc.trax.SAX2DOM
import org.xml.sax.InputSource
buildscript{
repositories {
mavenCentral() // i.e. http://repo1.maven.org/maven2
maven { url "https://oss.sonatype.org/content/groups/scala-tools" }
maven { url "https://oss.sonatype.org/content/repositories/snapshots/org/markdownj/markdownj" }
maven { url "http://download.java.net/maven/2/" }
}
dependencies {
classpath "org.markdownj:markdownj:0.3.0-1.0.2b4"
classpath "org.ccil.cowan.tagsoup:tagsoup:1.2"
classpath "org.xhtmlrenderer:core-renderer:R8"
classpath "xalan:xalan:2.7.1"
}
}
task run <<{
def source = "resume.markdown"
def target = "resume.pdf"
//Convert from markdown to html
def mp = new MarkdownProcessor()
def html = "<html><body>${mp.markdown((new File(source).text))}</body></html>"
//Convert from html to w3c document
def parser = new Parser()
def sax2dom = new SAX2DOM()
parser.setContentHandler(sax2dom);
parser.setFeature(Parser.namespacesFeature, false);
parser.parse(new InputSource(new ByteArrayInputStream(html.getBytes())));
//Use Document to create pdf
ITextRenderer renderer = new ITextRenderer();
renderer.setDocument(sax2dom.getDOM(), null);
renderer.layout();
renderer.createPDF((new File(target).newOutputStream()))
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment