mirror of
https://github.com/kovetskiy/mark.git
synced 2025-04-23 21:32:41 +08:00
Space from config and title from h1 (#153)
* Add option to define Space. Add option to use H1 heading to define page title. * Update readme
This commit is contained in:
parent
851a8047f3
commit
8d58ff26a3
@ -438,7 +438,9 @@ mark -h | --help
|
||||
- `-c <path>` or `--config <path>` — Specify a path to the configuration file.
|
||||
- `-k` — Lock page editing to current user only to prevent accidental
|
||||
manual edits over Confluence Web UI.
|
||||
- `--space <space>` - Use specified space key. If not specified space ley must be set in a page metadata.
|
||||
- `--drop-h1` – Don't include H1 headings in Confluence output.
|
||||
- `--title-from-h1` - Extract page title from a leading H1 heading. If no H1 heading on a page then title must be set in a page metadata.
|
||||
- `--dry-run` — Show resulting HTML and don't update Confluence page content.
|
||||
- `--minor-edit` — Don't send notifications while updating Confluence page.
|
||||
- `--trace` — Enable trace logs.
|
||||
|
24
main.go
24
main.go
@ -24,6 +24,7 @@ type Flags struct {
|
||||
DryRun bool `docopt:"--dry-run"`
|
||||
EditLock bool `docopt:"-k"`
|
||||
DropH1 bool `docopt:"--drop-h1"`
|
||||
TitleFromH1 bool `docopt:"--title-from-h1"`
|
||||
MinorEdit bool `docopt:"--minor-edit"`
|
||||
Color string `docopt:"--color"`
|
||||
Debug bool `docopt:"--debug"`
|
||||
@ -34,6 +35,7 @@ type Flags struct {
|
||||
BaseURL string `docopt:"--base-url"`
|
||||
Config string `docopt:"--config"`
|
||||
Ci bool `docopt:"--ci"`
|
||||
Space string `docopt:"--space"`
|
||||
}
|
||||
|
||||
const (
|
||||
@ -61,7 +63,11 @@ Options:
|
||||
Supports file globbing patterns (needs to be quoted).
|
||||
-k Lock page editing to current user only to prevent accidental
|
||||
manual edits over Confluence Web UI.
|
||||
--space <space> Use specified space key. If not specified space ley must
|
||||
be set in a page metadata.
|
||||
--drop-h1 Don't include H1 headings in Confluence output.
|
||||
--title-from-h1 Extract page title from a leading H1 heading. If no H1 heading
|
||||
on a page then title must be set in a page metadata.
|
||||
--dry-run Resolve page and ancestry, show resulting HTML and exit.
|
||||
--compile-only Show resulting HTML and don't update Confluence page content.
|
||||
--minor-edit Don't send notifications while updating Confluence page.
|
||||
@ -170,6 +176,24 @@ func processFile(
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
switch {
|
||||
case meta.Space == "" && flags.Space == "":
|
||||
log.Fatal("space is not set ('Space' header is not set and '--space' option is not set)")
|
||||
case meta.Space == "" && flags.Space != "":
|
||||
meta.Space = flags.Space
|
||||
}
|
||||
|
||||
if meta.Title == "" && flags.TitleFromH1 {
|
||||
meta.Title = mark.ExtractDocumentLeadingH1(markdown)
|
||||
}
|
||||
|
||||
if meta.Title == "" {
|
||||
log.Fatal(
|
||||
`page title is not set ('Title' header is not set ` +
|
||||
`and '--title-from-h1' option is not set or there is no H1 in the file)`,
|
||||
)
|
||||
}
|
||||
|
||||
stdlib, err := stdlib.New(api)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
|
@ -147,3 +147,14 @@ func DropDocumentLeadingH1(
|
||||
markdown = h1.ReplaceAll(markdown, []byte(""))
|
||||
return markdown
|
||||
}
|
||||
|
||||
// ExtractDocumentLeadingH1 will extract leading H1 heading
|
||||
func ExtractDocumentLeadingH1(markdown []byte) string {
|
||||
h1 := regexp.MustCompile(`^#[^#]\s*(.*)\s*\n`)
|
||||
groups := h1.FindSubmatch(markdown)
|
||||
if groups == nil {
|
||||
return ""
|
||||
} else {
|
||||
return string(groups[1])
|
||||
}
|
||||
}
|
||||
|
@ -48,3 +48,16 @@ func TestCompileMarkdown(t *testing.T) {
|
||||
test.EqualValues(string(html), actual, filename+" vs "+htmlname)
|
||||
}
|
||||
}
|
||||
|
||||
func TestExtractDocumentLeadingH1(t *testing.T) {
|
||||
filename := "testdata/header.md"
|
||||
|
||||
markdown, err := ioutil.ReadFile(filename)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
actual := ExtractDocumentLeadingH1(markdown)
|
||||
|
||||
assert.Equal(t, "a", actual)
|
||||
}
|
||||
|
@ -128,19 +128,5 @@ func ExtractMeta(data []byte) (*Meta, []byte, error) {
|
||||
return nil, data, nil
|
||||
}
|
||||
|
||||
if meta.Space == "" {
|
||||
return nil, nil, fmt.Errorf(
|
||||
"space key is not set (%s header is not set)",
|
||||
HeaderSpace,
|
||||
)
|
||||
}
|
||||
|
||||
if meta.Title == "" {
|
||||
return nil, nil, fmt.Errorf(
|
||||
"page title is not set (%s header is not set)",
|
||||
HeaderTitle,
|
||||
)
|
||||
}
|
||||
|
||||
return meta, data[offset:], nil
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user