adoc/element/styles.go

107 lines
1.8 KiB
Go

package element
import "ewintr.nl/adoc/token"
type Strong []Element
func (st Strong) Text() string {
var txt string
for _, e := range st {
txt += e.Text()
}
return txt
}
func (st Strong) Append(els []Element) Element {
return append(st, els...)
}
type Emphasis []Element
func (em Emphasis) Text() string {
var txt string
for _, e := range em {
txt += e.Text()
}
return txt
}
func (em Emphasis) Append(els []Element) Element {
return append(em, els...)
}
type Code []Element
func (c Code) Text() string {
var txt string
for _, e := range c {
txt += e.Text()
}
return txt
}
func (c Code) Append(els []Element) Element {
return append(c, els...)
}
func NewStyleFromTokens(tr ReadUnreader) (ParseResult, bool) {
toks, ok := tr.Read(2)
if !ok {
return ParseResult{}, false
}
markers := []token.Token{
{Type: token.TYPE_ASTERISK, Literal: "*"},
{Type: token.TYPE_UNDERSCORE, Literal: "_"},
{Type: token.TYPE_BACKTICK, Literal: "`"},
}
if !toks[0].Equal(markers...) {
tr.Unread(2)
return ParseResult{}, false
}
if toks[1].Type == token.TYPE_WHITESPACE {
tr.Unread(2)
return ParseResult{}, false
}
marker := toks[0]
toks = []token.Token{toks[1]}
for {
ntoks, ok := tr.Read(1)
if !ok {
tr.Unread(len(toks) + 1)
return ParseResult{}, false
}
tok := ntoks[0]
if tok.Equal(token.TOKEN_EOF, token.TOKEN_DOUBLE_NEWLINE) {
tr.Unread(len(toks) + 1)
return ParseResult{}, false
}
if tok.Equal(marker) {
break
}
toks = append(toks, tok)
}
if toks[len(toks)-1].Type == token.TYPE_WHITESPACE {
tr.Unread(len(toks) + 2)
return ParseResult{}, false
}
var s Element
switch marker.Type {
case token.TYPE_ASTERISK:
s = Strong{}
case token.TYPE_UNDERSCORE:
s = Emphasis{}
case token.TYPE_BACKTICK:
s = Code{}
}
return ParseResult{
Element: s,
Inner: toks,
}, true
}