From 458b8a22338784aeb9682295c5e5e4dd426e7d21 Mon Sep 17 00:00:00 2001 From: Phil Prasek Date: Wed, 16 Oct 2024 16:59:31 -0700 Subject: [PATCH] encode JSON examples to avoid mdx acorn rendering error Signed-off-by: Phil Prasek --- temporalcli/commandsgen/docs.go | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/temporalcli/commandsgen/docs.go b/temporalcli/commandsgen/docs.go index 7e9480f7..c0ac28bc 100644 --- a/temporalcli/commandsgen/docs.go +++ b/temporalcli/commandsgen/docs.go @@ -3,6 +3,7 @@ package commandsgen import ( "bytes" "fmt" + "regexp" "sort" "strings" ) @@ -151,7 +152,7 @@ func (w *docWriter) writeCommandOptions() { if len(option.Usages) == 1 { usageDescription := option.Usages[0] usage := usageDescription.UsageSites[0] - w.fileMap[fileName].WriteString(usage.Option.Description + "\n\n") + w.fileMap[fileName].WriteString(encodeJSONExample(usage.Option.Description) + "\n\n") if usage.Option.Experimental { w.fileMap[fileName].WriteString(":::note" + "\n\n") @@ -164,7 +165,7 @@ func (w *docWriter) writeCommandOptions() { w.fileMap[fileName].WriteString("\n") } - w.fileMap[fileName].WriteString(usageDescription.OptionDescription + "\n\n") + w.fileMap[fileName].WriteString(encodeJSONExample(usageDescription.OptionDescription) + "\n\n") for _, usage := range usageDescription.UsageSites { experimentalDescr := "" @@ -213,3 +214,10 @@ func (w *docWriter) writeCommandOptions() { } */ } + +func encodeJSONExample(v string) string { + // example: `'YourKey={"your": "value"}'` + re := regexp.MustCompile(`('[a-zA-Z0-9]*={.*}')`) + v = re.ReplaceAllString(v, "`$1`") + return v +}