From d8f34de1641cb952cde2c95414458731750b3c18 Mon Sep 17 00:00:00 2001 From: Ajat Prabha Date: Thu, 6 Jul 2023 15:37:09 +0530 Subject: [PATCH] add excludeLinkAngularBrackets option for github markdown format --- cmd/gomarkdoc/command.go | 44 ++++++++++++++++++++++++---------------- format/github.go | 24 +++++++++++++++++++++- 2 files changed, 50 insertions(+), 18 deletions(-) diff --git a/cmd/gomarkdoc/command.go b/cmd/gomarkdoc/command.go index 77d73a0..21c4585 100644 --- a/cmd/gomarkdoc/command.go +++ b/cmd/gomarkdoc/command.go @@ -44,22 +44,23 @@ type PackageSpec struct { } type commandOptions struct { - repository lang.Repo - output string - header string - headerFile string - footer string - footerFile string - format string - tags []string - excludeDirs []string - templateOverrides map[string]string - templateFileOverrides map[string]string - verbosity int - includeUnexported bool - check bool - embed bool - version bool + repository lang.Repo + output string + header string + headerFile string + footer string + footerFile string + format string + tags []string + excludeDirs []string + excludeLinkAngularBrackets bool + templateOverrides map[string]string + templateFileOverrides map[string]string + verbosity int + includeUnexported bool + check bool + embed bool + version bool } // Flags populated by goreleaser @@ -98,6 +99,7 @@ func buildCommand() *cobra.Command { opts.footerFile = viper.GetString("footerFile") opts.tags = viper.GetStringSlice("tags") opts.excludeDirs = viper.GetStringSlice("excludeDirs") + opts.excludeLinkAngularBrackets = viper.GetBool("excludeLinkAngularBrackets") opts.repository.Remote = viper.GetString("repository.url") opts.repository.DefaultBranch = viper.GetString("repository.defaultBranch") opts.repository.PathFromRoot = viper.GetString("repository.path") @@ -205,6 +207,13 @@ func buildCommand() *cobra.Command { nil, "List of package directories to ignore when producing documentation.", ) + command.Flags().BoolVarP( + &opts.excludeLinkAngularBrackets, + "exclude-link-angular-brackets", + "", + false, + "Exclude the angular brackets [](<>) from links in the output. Works with the github format only.", + ) command.Flags().CountVarP( &opts.verbosity, "verbose", @@ -250,6 +259,7 @@ func buildCommand() *cobra.Command { _ = viper.BindPFlag("footerFile", command.Flags().Lookup("footer-file")) _ = viper.BindPFlag("tags", command.Flags().Lookup("tags")) _ = viper.BindPFlag("excludeDirs", command.Flags().Lookup("exclude-dirs")) + _ = viper.BindPFlag("excludeLinkAngularBrackets", command.Flags().Lookup("exclude-link-angular-brackets")) _ = viper.BindPFlag("repository.url", command.Flags().Lookup("repository.url")) _ = viper.BindPFlag("repository.defaultBranch", command.Flags().Lookup("repository.default-branch")) _ = viper.BindPFlag("repository.path", command.Flags().Lookup("repository.path")) @@ -367,7 +377,7 @@ func resolveOverrides(opts commandOptions) ([]gomarkdoc.RendererOption, error) { var f format.Format switch opts.format { case "github": - f = &format.GitHubFlavoredMarkdown{} + f = format.NewGitHubFlavoredMarkdown(opts.excludeLinkAngularBrackets) case "azure-devops": f = &format.AzureDevOpsMarkdown{} case "plain": diff --git a/format/github.go b/format/github.go index c630d72..a814af2 100644 --- a/format/github.go +++ b/format/github.go @@ -14,7 +14,14 @@ import ( // Flavored Markdown's syntax and semantics. See GitHub's documentation for // more details about their markdown format: // https://guides.github.com/features/mastering-markdown/ -type GitHubFlavoredMarkdown struct{} +type GitHubFlavoredMarkdown struct { + excludeHrefAngularBrackets bool +} + +// NewGitHubFlavoredMarkdown creates a new GitHubFlavoredMarkdown Format. +func NewGitHubFlavoredMarkdown(excludeLinkAngularBrackets bool) *GitHubFlavoredMarkdown { + return &GitHubFlavoredMarkdown{excludeHrefAngularBrackets: excludeLinkAngularBrackets} +} // Bold converts the provided text to bold func (f *GitHubFlavoredMarkdown) Bold(text string) (string, error) { @@ -82,6 +89,9 @@ func (f *GitHubFlavoredMarkdown) RawLocalHref(anchor string) string { // Link generates a link with the given text and href values. func (f *GitHubFlavoredMarkdown) Link(text, href string) (string, error) { + if f.excludeHrefAngularBrackets { + return f.link(text, href), nil + } return formatcore.Link(text, href), nil } @@ -162,3 +172,15 @@ func (f *GitHubFlavoredMarkdown) AccordionTerminator() (string, error) { func (f *GitHubFlavoredMarkdown) Escape(text string) string { return formatcore.Escape(text) } + +func (f *GitHubFlavoredMarkdown) link(text string, href string) string { + if text == "" { + return "" + } + + if href == "" { + return text + } + + return fmt.Sprintf("[%s](%s)", formatcore.Escape(text), href) +}