mirror of
https://github.com/kovetskiy/mark.git
synced 2025-04-24 05:42:40 +08:00
move CompileMarkdown to package
This commit is contained in:
parent
ada6f828ff
commit
5f582e51e6
@ -1,19 +1 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import "fmt"
|
|
||||||
|
|
||||||
type MacroCode struct {
|
|
||||||
lang string
|
|
||||||
code []byte
|
|
||||||
}
|
|
||||||
|
|
||||||
func (code MacroCode) Render() string {
|
|
||||||
return fmt.Sprintf(
|
|
||||||
`<ac:structured-macro ac:name="code">`+
|
|
||||||
`<ac:parameter ac:name="language">%s</ac:parameter>`+
|
|
||||||
`<ac:parameter ac:name="collapse">false</ac:parameter>`+
|
|
||||||
`<ac:plain-text-body><![CDATA[%s]]></ac:plain-text-body>`+
|
|
||||||
`</ac:structured-macro>`,
|
|
||||||
code.lang, code.code,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
49
main.go
49
main.go
@ -5,7 +5,6 @@ import (
|
|||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"regexp"
|
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/BurntSushi/toml"
|
"github.com/BurntSushi/toml"
|
||||||
@ -15,7 +14,6 @@ import (
|
|||||||
"github.com/kovetskiy/mark/pkg/mark"
|
"github.com/kovetskiy/mark/pkg/mark"
|
||||||
"github.com/reconquest/colorgful"
|
"github.com/reconquest/colorgful"
|
||||||
"github.com/reconquest/karma-go"
|
"github.com/reconquest/karma-go"
|
||||||
"github.com/russross/blackfriday"
|
|
||||||
"github.com/zazab/zhash"
|
"github.com/zazab/zhash"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -140,7 +138,7 @@ func main() {
|
|||||||
logger.Fatal(err)
|
logger.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
htmlData := compileMarkdown(markdownData)
|
htmlData := mark.CompileMarkdown(markdownData)
|
||||||
|
|
||||||
if dryRun {
|
if dryRun {
|
||||||
fmt.Println(string(htmlData))
|
fmt.Println(string(htmlData))
|
||||||
@ -227,51 +225,6 @@ func main() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// compileMarkdown will replace tags like <ac:rich-tech-body> with escaped
|
|
||||||
// equivalent, because blackfriday markdown parser replaces that tags with
|
|
||||||
// <a href="ac:rich-text-body">ac:rich-text-body</a> for whatever reason.
|
|
||||||
func compileMarkdown(markdown []byte) []byte {
|
|
||||||
colon := regexp.MustCompile(`---BLACKFRIDAY-COLON---`)
|
|
||||||
|
|
||||||
tags := regexp.MustCompile(`<(/?\S+):(\S+)>`)
|
|
||||||
|
|
||||||
markdown = tags.ReplaceAll(
|
|
||||||
markdown,
|
|
||||||
[]byte(`<$1`+colon.String()+`$2>`),
|
|
||||||
)
|
|
||||||
|
|
||||||
renderer := ConfluenceRenderer{
|
|
||||||
blackfriday.HtmlRenderer(
|
|
||||||
blackfriday.HTML_USE_XHTML|
|
|
||||||
blackfriday.HTML_USE_SMARTYPANTS|
|
|
||||||
blackfriday.HTML_SMARTYPANTS_FRACTIONS|
|
|
||||||
blackfriday.HTML_SMARTYPANTS_DASHES|
|
|
||||||
blackfriday.HTML_SMARTYPANTS_LATEX_DASHES,
|
|
||||||
"", "",
|
|
||||||
),
|
|
||||||
}
|
|
||||||
|
|
||||||
html := blackfriday.MarkdownOptions(
|
|
||||||
markdown,
|
|
||||||
renderer,
|
|
||||||
blackfriday.Options{
|
|
||||||
Extensions: blackfriday.EXTENSION_NO_INTRA_EMPHASIS |
|
|
||||||
blackfriday.EXTENSION_TABLES |
|
|
||||||
blackfriday.EXTENSION_FENCED_CODE |
|
|
||||||
blackfriday.EXTENSION_AUTOLINK |
|
|
||||||
blackfriday.EXTENSION_STRIKETHROUGH |
|
|
||||||
blackfriday.EXTENSION_SPACE_HEADERS |
|
|
||||||
blackfriday.EXTENSION_HEADER_IDS |
|
|
||||||
blackfriday.EXTENSION_BACKSLASH_LINE_BREAK |
|
|
||||||
blackfriday.EXTENSION_DEFINITION_LISTS,
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
html = colon.ReplaceAll(html, []byte(`:`))
|
|
||||||
|
|
||||||
return html
|
|
||||||
}
|
|
||||||
|
|
||||||
func resolvePage(
|
func resolvePage(
|
||||||
api *confluence.API,
|
api *confluence.API,
|
||||||
meta *mark.Meta,
|
meta *mark.Meta,
|
||||||
|
82
pkg/mark/markdown.go
Normal file
82
pkg/mark/markdown.go
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
package mark
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
"regexp"
|
||||||
|
|
||||||
|
"github.com/russross/blackfriday"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ConfluenceRenderer struct {
|
||||||
|
blackfriday.Renderer
|
||||||
|
}
|
||||||
|
|
||||||
|
func (renderer ConfluenceRenderer) BlockCode(
|
||||||
|
out *bytes.Buffer,
|
||||||
|
text []byte,
|
||||||
|
lang string,
|
||||||
|
) {
|
||||||
|
out.WriteString(MacroCode{lang, text}.Render())
|
||||||
|
}
|
||||||
|
|
||||||
|
type MacroCode struct {
|
||||||
|
lang string
|
||||||
|
code []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (code MacroCode) Render() string {
|
||||||
|
return fmt.Sprintf(
|
||||||
|
`<ac:structured-macro ac:name="code">`+
|
||||||
|
`<ac:parameter ac:name="language">%s</ac:parameter>`+
|
||||||
|
`<ac:parameter ac:name="collapse">false</ac:parameter>`+
|
||||||
|
`<ac:plain-text-body><![CDATA[%s]]></ac:plain-text-body>`+
|
||||||
|
`</ac:structured-macro>`,
|
||||||
|
code.lang, code.code,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
// compileMarkdown will replace tags like <ac:rich-tech-body> with escaped
|
||||||
|
// equivalent, because blackfriday markdown parser replaces that tags with
|
||||||
|
// <a href="ac:rich-text-body">ac:rich-text-body</a> for whatever reason.
|
||||||
|
func CompileMarkdown(markdown []byte) []byte {
|
||||||
|
colon := regexp.MustCompile(`---BLACKFRIDAY-COLON---`)
|
||||||
|
|
||||||
|
tags := regexp.MustCompile(`<(/?\S+):(\S+)>`)
|
||||||
|
|
||||||
|
markdown = tags.ReplaceAll(
|
||||||
|
markdown,
|
||||||
|
[]byte(`<$1`+colon.String()+`$2>`),
|
||||||
|
)
|
||||||
|
|
||||||
|
renderer := ConfluenceRenderer{
|
||||||
|
blackfriday.HtmlRenderer(
|
||||||
|
blackfriday.HTML_USE_XHTML|
|
||||||
|
blackfriday.HTML_USE_SMARTYPANTS|
|
||||||
|
blackfriday.HTML_SMARTYPANTS_FRACTIONS|
|
||||||
|
blackfriday.HTML_SMARTYPANTS_DASHES|
|
||||||
|
blackfriday.HTML_SMARTYPANTS_LATEX_DASHES,
|
||||||
|
"", "",
|
||||||
|
),
|
||||||
|
}
|
||||||
|
|
||||||
|
html := blackfriday.MarkdownOptions(
|
||||||
|
markdown,
|
||||||
|
renderer,
|
||||||
|
blackfriday.Options{
|
||||||
|
Extensions: blackfriday.EXTENSION_NO_INTRA_EMPHASIS |
|
||||||
|
blackfriday.EXTENSION_TABLES |
|
||||||
|
blackfriday.EXTENSION_FENCED_CODE |
|
||||||
|
blackfriday.EXTENSION_AUTOLINK |
|
||||||
|
blackfriday.EXTENSION_STRIKETHROUGH |
|
||||||
|
blackfriday.EXTENSION_SPACE_HEADERS |
|
||||||
|
blackfriday.EXTENSION_HEADER_IDS |
|
||||||
|
blackfriday.EXTENSION_BACKSLASH_LINE_BREAK |
|
||||||
|
blackfriday.EXTENSION_DEFINITION_LISTS,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
html = colon.ReplaceAll(html, []byte(`:`))
|
||||||
|
|
||||||
|
return html
|
||||||
|
}
|
18
renderer.go
18
renderer.go
@ -1,19 +1 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
|
|
||||||
"github.com/russross/blackfriday"
|
|
||||||
)
|
|
||||||
|
|
||||||
type ConfluenceRenderer struct {
|
|
||||||
blackfriday.Renderer
|
|
||||||
}
|
|
||||||
|
|
||||||
func (renderer ConfluenceRenderer) BlockCode(
|
|
||||||
out *bytes.Buffer,
|
|
||||||
text []byte,
|
|
||||||
lang string,
|
|
||||||
) {
|
|
||||||
out.WriteString(MacroCode{lang, text}.Render())
|
|
||||||
}
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user