mirror of
https://github.com/go-gitea/gitea
synced 2025-01-25 17:14:32 +00:00
d1353e1f7c
* update code.gitea.io/sdk/gitea v0.13.1 -> v0.13.2 * update github.com/go-swagger/go-swagger v0.25.0 -> v0.26.0 * update github.com/google/uuid v1.1.2 -> v1.2.0 * update github.com/klauspost/compress v1.11.3 -> v1.11.7 * update github.com/lib/pq 083382b7e6fc -> v1.9.0 * update github.com/markbates/goth v1.65.0 -> v1.66.1 * update github.com/mattn/go-sqlite3 v1.14.4 -> v1.14.6 * update github.com/mgechev/revive 246eac737dc7 -> v1.0.3 * update github.com/minio/minio-go/v7 v7.0.6 -> v7.0.7 * update github.com/niklasfasching/go-org v1.3.2 -> v1.4.0 * update github.com/olivere/elastic/v7 v7.0.21 -> v7.0.22 * update github.com/pquerna/otp v1.2.0 -> v1.3.0 * update github.com/xanzy/go-gitlab v0.39.0 -> v0.42.0 * update github.com/yuin/goldmark v1.2.1 -> v1.3.1
98 lines
2.5 KiB
Go
Vendored
98 lines
2.5 KiB
Go
Vendored
package org
|
|
|
|
import (
|
|
"regexp"
|
|
"strings"
|
|
)
|
|
|
|
type Drawer struct {
|
|
Name string
|
|
Children []Node
|
|
}
|
|
|
|
type PropertyDrawer struct {
|
|
Properties [][]string
|
|
}
|
|
|
|
var beginDrawerRegexp = regexp.MustCompile(`^(\s*):(\S+):\s*$`)
|
|
var endDrawerRegexp = regexp.MustCompile(`(?i)^(\s*):END:\s*$`)
|
|
var propertyRegexp = regexp.MustCompile(`^(\s*):(\S+):(\s+(.*)$|$)`)
|
|
|
|
func lexDrawer(line string) (token, bool) {
|
|
if m := endDrawerRegexp.FindStringSubmatch(line); m != nil {
|
|
return token{"endDrawer", len(m[1]), "", m}, true
|
|
} else if m := beginDrawerRegexp.FindStringSubmatch(line); m != nil {
|
|
return token{"beginDrawer", len(m[1]), strings.ToUpper(m[2]), m}, true
|
|
}
|
|
return nilToken, false
|
|
}
|
|
|
|
func (d *Document) parseDrawer(i int, parentStop stopFn) (int, Node) {
|
|
name := strings.ToUpper(d.tokens[i].content)
|
|
if name == "PROPERTIES" {
|
|
return d.parsePropertyDrawer(i, parentStop)
|
|
}
|
|
drawer, start := Drawer{Name: name}, i
|
|
i++
|
|
stop := func(d *Document, i int) bool {
|
|
if parentStop(d, i) {
|
|
return true
|
|
}
|
|
kind := d.tokens[i].kind
|
|
return kind == "beginDrawer" || kind == "endDrawer" || kind == "headline"
|
|
}
|
|
for {
|
|
consumed, nodes := d.parseMany(i, stop)
|
|
i += consumed
|
|
drawer.Children = append(drawer.Children, nodes...)
|
|
if i < len(d.tokens) && d.tokens[i].kind == "beginDrawer" {
|
|
p := Paragraph{[]Node{Text{":" + d.tokens[i].content + ":", false}}}
|
|
drawer.Children = append(drawer.Children, p)
|
|
i++
|
|
} else {
|
|
break
|
|
}
|
|
}
|
|
if i < len(d.tokens) && d.tokens[i].kind == "endDrawer" {
|
|
i++
|
|
}
|
|
return i - start, drawer
|
|
}
|
|
|
|
func (d *Document) parsePropertyDrawer(i int, parentStop stopFn) (int, Node) {
|
|
drawer, start := PropertyDrawer{}, i
|
|
i++
|
|
stop := func(d *Document, i int) bool {
|
|
return parentStop(d, i) || (d.tokens[i].kind != "text" && d.tokens[i].kind != "beginDrawer")
|
|
}
|
|
for ; !stop(d, i); i++ {
|
|
m := propertyRegexp.FindStringSubmatch(d.tokens[i].matches[0])
|
|
if m == nil {
|
|
return 0, nil
|
|
}
|
|
k, v := strings.ToUpper(m[2]), strings.TrimSpace(m[4])
|
|
drawer.Properties = append(drawer.Properties, []string{k, v})
|
|
}
|
|
if i < len(d.tokens) && d.tokens[i].kind == "endDrawer" {
|
|
i++
|
|
} else {
|
|
return 0, nil
|
|
}
|
|
return i - start, drawer
|
|
}
|
|
|
|
func (d *PropertyDrawer) Get(key string) (string, bool) {
|
|
if d == nil {
|
|
return "", false
|
|
}
|
|
for _, kvPair := range d.Properties {
|
|
if kvPair[0] == key {
|
|
return kvPair[1], true
|
|
}
|
|
}
|
|
return "", false
|
|
}
|
|
|
|
func (n Drawer) String() string { return orgWriter.WriteNodesAsString(n) }
|
|
func (n PropertyDrawer) String() string { return orgWriter.WriteNodesAsString(n) }
|