tree: 78d67c334eb6c8150db7f02a011a6e40e09bebd0 [path history] [tgz]
  1. analysis/
  2. redirect/
  3. static/
  4. util/
  5. vfs/
  6. corpus.go
  7. dirtrees.go
  8. dirtrees_test.go
  9. format.go
  10. godoc.go
  11. godoc17_test.go
  12. godoc_test.go
  13. index.go
  14. index_test.go
  15. linkify.go
  16. markdown.go
  17. meta.go
  18. page.go
  19. parser.go
  20. pres.go
  21. README.md
  22. search.go
  23. server.go
  24. server_test.go
  25. snippet.go
  26. spec.go
  27. spec_test.go
  28. spot.go
  29. tab.go
  30. template.go
  31. tohtml_go119.go
  32. tohtml_other.go
  33. versions.go
  34. versions_test.go
godoc/README.md

godoc

This directory contains most of the code for running a godoc server. The executable lives at golang.org/x/tools/cmd/godoc.

Development mode

In production, CSS/JS/template assets need to be compiled into the godoc binary. It can be tedious to recompile assets every time, but you can pass a flag to load CSS/JS/templates from disk every time a page loads:

godoc -templates=$GOPATH/src/golang.org/x/tools/godoc/static -http=:6060

Recompiling static assets

The files that live at static/style.css, static/jquery.js and so on are not present in the final binary. They are placed into static/static.go by running go generate. So to compile a change and test it in your browser:

  1. Make changes to e.g. static/style.css.

  2. Run go generate golang.org/x/tools/godoc/static so static/static.go picks up the change.

  3. Run go install golang.org/x/tools/cmd/godoc so the compiled godoc binary picks up the change.

  4. Run godoc -http=:6060 and view your changes in the browser. You may need to disable your browser's cache to avoid reloading a stale file.