Documentation
¶
Overview ¶
Package mdtopdf implements a PDF document generator for markdown documents.
Introduction ¶
This package depends on two other packages:
* The BlackFriday v2 parser to read the markdown source
* The fpdf packace to generate the PDF
The tests included here are from the BlackFriday package. See the "testdata" folder. The tests create PDF files and thus while the tests may complete without errors, visual inspection of the created PDF is the only way to determine if the tests *really* pass!
The tests create log files that trace the BlackFriday parser callbacks. This is a valuable debug tool showing each callback and data provided in each while the AST is presented.
Installation ¶
To install the package:
go get github.com/mandolyte/mdtopdf
Quick start ¶
In the cmd folder is an example using the package. It demonstrates a number of features. The test PDF was created with this command:
go run convert.go -i test.md -o test.pdf
See README for limitations and known issues ¶
Package mdtopdf converts markdown to PDF.
Index ¶
- type Color
- type PdfRenderer
- func (r *PdfRenderer) Process(content []byte) error
- func (r *PdfRenderer) RenderFooter(w io.Writer, ast *bf.Node)
- func (r *PdfRenderer) RenderHeader(w io.Writer, ast *bf.Node)
- func (r *PdfRenderer) RenderNode(w io.Writer, node *bf.Node, entering bool) bf.WalkStatus
- func (r *PdfRenderer) Run(content []byte) error
- func (r *PdfRenderer) UpdateBlockquoteStyler()
- func (r *PdfRenderer) UpdateCodeStyler()
- func (r *PdfRenderer) UpdateParagraphStyler(defaultStyler Styler)
- type RenderOption
- type Styler
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Color ¶
type Color struct {
Red, Green, Blue int
}
Color is a RGB set of ints; for a nice picker see https://www.w3schools.com/colors/colors_picker.asp
type PdfRenderer ¶
type PdfRenderer struct { // Pdf can be used to access the underlying created fpdf object // prior to processing the markdown source Pdf *fpdf.Fpdf // normal text Normal Styler // link text Link Styler // backticked text Backtick Styler // blockquote text Blockquote Styler IndentValue float64 // Headings H1 Styler H2 Styler H3 Styler H4 Styler H5 Styler H6 Styler // Table styling THeader Styler TBody Styler // code styling Code Styler // update styling NeedCodeStyleUpdate bool NeedBlockquoteStyleUpdate bool // contains filtered or unexported fields }
PdfRenderer is the struct to manage conversion of a markdown object to PDF format.
func NewPdfRenderer ¶
func NewPdfRenderer(orient, papersz, pdfFile, tracerFile string, opts ...RenderOption) *PdfRenderer
NewPdfRenderer creates and configures an PdfRenderer object, which satisfies the Renderer interface.
func NewPdfRendererWithDefaultStyler ¶
func NewPdfRendererWithDefaultStyler(orient, papersz, pdfFile, tracerFile string, defaultStyler Styler, opts ...RenderOption) *PdfRenderer
NewPdfRendererWithDefaultStyler creates and configures an PdfRenderer object, which satisfies the Renderer interface. update default styler for normal
func (*PdfRenderer) Process ¶
func (r *PdfRenderer) Process(content []byte) error
Process takes the markdown content, parses it to generate the PDF
func (*PdfRenderer) RenderFooter ¶
func (r *PdfRenderer) RenderFooter(w io.Writer, ast *bf.Node)
RenderFooter is not supported.
func (*PdfRenderer) RenderHeader ¶
func (r *PdfRenderer) RenderHeader(w io.Writer, ast *bf.Node)
RenderHeader is not supported.
func (*PdfRenderer) RenderNode ¶
func (r *PdfRenderer) RenderNode(w io.Writer, node *bf.Node, entering bool) bf.WalkStatus
RenderNode is a default renderer of a single node of a syntax tree. For block nodes it will be called twice: first time with entering=true, second time with entering=false, so that it could know when it's working on an open tag and when on close. It writes the result to w.
The return value is a way to tell the calling walker to adjust its walk pattern: e.g. it can terminate the traversal by returning Terminate. Or it can ask the walker to skip a subtree of this node by returning SkipChildren. The typical behavior is to return GoToNext, which asks for the usual traversal to the next node. (above taken verbatim from the blackfriday v2 package)
func (*PdfRenderer) Run ¶
func (r *PdfRenderer) Run(content []byte) error
Run takes the markdown content, parses it but don't generate the PDF. you can access the PDF with youRenderer.Pdf
func (*PdfRenderer) UpdateBlockquoteStyler ¶
func (r *PdfRenderer) UpdateBlockquoteStyler()
UpdateBlockquoteStyler - update Blockquote fill styler
func (*PdfRenderer) UpdateCodeStyler ¶
func (r *PdfRenderer) UpdateCodeStyler()
UpdateCodeStyler - update code fill styler
func (*PdfRenderer) UpdateParagraphStyler ¶
func (r *PdfRenderer) UpdateParagraphStyler(defaultStyler Styler)
UpdateParagraphStyler - update with default styler
type RenderOption ¶
type RenderOption func(r *PdfRenderer)
RenderOption allows to define functions to configure the renderer
func WithUnicodeTranslator ¶
func WithUnicodeTranslator(cp string) RenderOption
WithUnicodeTranslator configures a unico translator to support characters for latin, russian, etc..