summaryrefslogtreecommitdiff
path: root/internal/documentation/documentation.go
blob: af4b302411d4fb25830cbf39c41e5da13c376ee6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/*
 * This package isn't the actual termpicker app.
 * To avoid importing packages which aren't needed at runtime,
 * some auto-generation functionnalities is offloaded to here so
 * it can be done with access to the rest of the code-base but
 * without bloating the final binary. For example,
 * generating bash+zsh auto-completion scripts isn't needed in
 * the final binary if those script are generated before hand.
 * Same gose for manpages. This file is meant to be run automatically
 * to easily package new releases. Same goes for manpages which is the
 * only feature currently in here.
 */
package main

import (
	_ "embed"
	"log/slog"
	"os"
	"strings"

	"github.com/ChausseBenjamin/termpicker/internal/app"
	docs "github.com/urfave/cli-docs/v3"
)

func main() {
	a := app.Command()

	docs.MarkdownDocTemplate = strings.Join(
		[]string{
			docs.MarkdownDocTemplate,
			app.KeybindingDocs,
		},
		"\n",
	)

	man, err := docs.ToManWithSection(a, 1)
	if err != nil {
		slog.Error("failed to generate man page",
			slog.Any("error_message", err),
		)
		os.Exit(1)
	}
	os.Stdout.Write([]byte(man))
}