-
Notifications
You must be signed in to change notification settings - Fork 100
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
automatically link type names found in the doc comments #30
Comments
I can't think of a clean way of linking from parts of godoc comments without over-engineering. Such a smart detection might also be susceptible to issues like:
If we can live without, that'd be preferable. If you definitely want to do it, probably should be opt-in with an explicit syntax that doesn't break godoc too much. |
Yeh, I think you are right; this is more problematic the more you think about it. I poked at this using If we switch to something like There's no package context from Here's a super-naive implementation: diff --git main.go main.go
index 95193b8..6c7bb71 100644
--- main.go
+++ main.go
@@ -338,14 +338,25 @@ func isLocalType(t *types.Type, typePkgMap map[*types.Type]*apiPackage) bool {
return ok
}
-func renderComments(s []string, markdown bool) string {
+func renderComments(s []string, typePkgMap map[*types.Type]*apiPackage, markdown bool) string {
s = filterCommentTags(s)
doc := strings.Join(s, "\n")
if markdown {
+ var replacements []string
+
+ for t := range typePkgMap {
+ if lnk, err := linkForType(t, generatorConfig{}, typePkgMap); err == nil {
+ klog.Infof("type %q, link %q", t.Name.Name, lnk)
+ replacements = append(replacements, t.Name.Name, fmt.Sprintf("[%s](%s)", t.Name.Name, lnk))
+ }
+ }
+
+ r := strings.NewReplacer(replacements...)
+
// TODO(ahmetb): when a comment includes stuff like "http://<service>"
// we treat this as a HTML tag with markdown renderer below. solve this.
- return string(blackfriday.Run([]byte(doc)))
+ return string(blackfriday.Run([]byte(r.Replace(doc))))
}
return nl2br(doc)
}
@@ -649,7 +660,7 @@ func render(w io.Writer, pkgs []*apiPackage, config generatorConfig) error {
"typeIdentifier": func(t *types.Type) string { return typeIdentifier(t) },
"typeDisplayName": func(t *types.Type) string { return typeDisplayName(t, config, typePkgMap) },
"visibleTypes": func(t []*types.Type) []*types.Type { return visibleTypes(t, config) },
- "renderComments": func(s []string) string { return renderComments(s, !config.MarkdownDisabled) },
+ "renderComments": func(s []string) string { return renderComments(s, typePkgMap, !config.MarkdownDisabled) },
"packageDisplayName": func(p *apiPackage) string { return p.identifier() },
"apiGroup": func(t *types.Type) string { return apiGroupForType(t, typePkgMap) },
"packageAnchorID": func(p *apiPackage) string { |
It would be a great enhancement to automatically link any API type names that are found in the doc comments. Adding a markdown link works, but it doesn't render properly in godoc, so if we can add the link in the generator we can have best of both worlds.
The text was updated successfully, but these errors were encountered: