
Changes < to < in autogenerated documentation for CLI commands so that markdown does not interpret them as HTML tags. Supersedes #3830 Fixes #3829
90 lines
2.2 KiB
Go
90 lines
2.2 KiB
Go
package terminal
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"strings"
|
|
)
|
|
|
|
func replaceDocPath(s string) string {
|
|
const docpath = "Documentation/"
|
|
|
|
i0 := 0
|
|
|
|
for {
|
|
start := strings.Index(s[i0:], docpath)
|
|
if start < 0 {
|
|
return s
|
|
}
|
|
start += i0
|
|
if start-1 >= 0 && s[start-1] != ' ' {
|
|
i0 = start + len(docpath) + 1
|
|
continue
|
|
}
|
|
var end int
|
|
for end = start + len(docpath); end < len(s); end++ {
|
|
if s[end] == ' ' {
|
|
break
|
|
}
|
|
}
|
|
// If we captured a trailing dot, backtrack.
|
|
if s[end-1] == '.' {
|
|
end--
|
|
}
|
|
|
|
text := s[start:end]
|
|
s = s[:start] + fmt.Sprintf("[%s](//github.com/go-delve/delve/tree/master/%s)", text, text) + s[end:]
|
|
i0 = end + 1
|
|
}
|
|
}
|
|
|
|
func fixLessThan(s string) string {
|
|
v := strings.Split(s, "\n")
|
|
for i := range v {
|
|
if len(v[i]) == 0 || v[i][0] != '\t' {
|
|
v[i] = strings.ReplaceAll(v[i], "<", "<")
|
|
}
|
|
}
|
|
return strings.Join(v, "\n")
|
|
}
|
|
|
|
func (c *Commands) WriteMarkdown(w io.Writer) {
|
|
fmt.Fprint(w, "# Configuration and Command History\n\n")
|
|
fmt.Fprint(w, "If `$XDG_CONFIG_HOME` is set, then configuration and command history files are located in `$XDG_CONFIG_HOME/dlv`. ")
|
|
fmt.Fprint(w, "Otherwise, they are located in `$HOME/.config/dlv` on Linux and `$HOME/.dlv` on other systems.\n\n")
|
|
fmt.Fprint(w, "The configuration file `config.yml` contains all the configurable options and their default values. ")
|
|
fmt.Fprint(w, "The command history is stored in `.dbg_history`.\n\n")
|
|
|
|
fmt.Fprint(w, "# Commands\n")
|
|
|
|
for _, cgd := range commandGroupDescriptions {
|
|
fmt.Fprintf(w, "\n## %s\n\n", cgd.description)
|
|
|
|
fmt.Fprint(w, "Command | Description\n")
|
|
fmt.Fprint(w, "--------|------------\n")
|
|
for _, cmd := range c.cmds {
|
|
if cmd.group != cgd.group {
|
|
continue
|
|
}
|
|
h := cmd.helpMsg
|
|
if idx := strings.Index(h, "\n"); idx >= 0 {
|
|
h = h[:idx]
|
|
}
|
|
fmt.Fprintf(w, "[%s](#%s) | %s\n", cmd.aliases[0], cmd.aliases[0], h)
|
|
}
|
|
fmt.Fprint(w, "\n")
|
|
}
|
|
|
|
for _, cmd := range c.cmds {
|
|
fmt.Fprintf(w, "## %s\n%s\n\n", cmd.aliases[0], fixLessThan(replaceDocPath(cmd.helpMsg)))
|
|
if len(cmd.aliases) > 1 {
|
|
fmt.Fprint(w, "Aliases:")
|
|
for _, alias := range cmd.aliases[1:] {
|
|
fmt.Fprintf(w, " %s", alias)
|
|
}
|
|
fmt.Fprint(w, "\n")
|
|
}
|
|
fmt.Fprint(w, "\n")
|
|
}
|
|
}
|