mirror of
https://github.com/golang/go
synced 2024-11-21 12:34:38 -07:00
godoc: initial support for showing popup information
for identifiers in Go source code - at the moment just show identifier kind (var, func, etc.) and name (eventually should show declaration, type, etc.) - JavaScript parts by adg R=rsc CC=adg, golang-dev https://golang.org/cl/578042
This commit is contained in:
parent
0b986316b8
commit
74fac99d05
24
doc/popups.js
Normal file
24
doc/popups.js
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
// Copyright 2009 The Go Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a BSD-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
function godocs_bindPopups(data) {
|
||||||
|
|
||||||
|
$('#content span').bind('mouseenter', function() {
|
||||||
|
var id = $(this).attr('id');
|
||||||
|
//var txt = $(this).text();
|
||||||
|
if (typeof data[id] == 'undefined')
|
||||||
|
return;
|
||||||
|
var content = data[id];
|
||||||
|
|
||||||
|
var $el = $('.popup', this);
|
||||||
|
if (!$el.length) { // create it
|
||||||
|
$el = $('<div class="popup"></div>');
|
||||||
|
$el.prependTo(this).css($(this).offset()).text(content);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$('#content span').bind('mouseleave', function() {
|
||||||
|
$('.popup', this).remove();
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
@ -211,6 +211,19 @@ span.highlight {
|
|||||||
border: 2px solid #ba9836;
|
border: 2px solid #ba9836;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* same color scheme as for gettingStarted */
|
||||||
|
#content .popup {
|
||||||
|
position: absolute;
|
||||||
|
border: 1px solid #ba9836;
|
||||||
|
background-color: #fffff0;
|
||||||
|
margin-top: 3em;
|
||||||
|
padding: 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#content .identifier,
|
||||||
|
#content .type {
|
||||||
|
color: #008;
|
||||||
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
/* Styles for the frontpage */
|
/* Styles for the frontpage */
|
||||||
|
23
lib/godoc/source.html
Normal file
23
lib/godoc/source.html
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
<!--
|
||||||
|
Copyright 2009 The Go Authors. All rights reserved.
|
||||||
|
Use of this source code is governed by a BSD-style
|
||||||
|
license that can be found in the LICENSE file.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<script src="http://www.google.com/jsapi"></script>
|
||||||
|
<script src="/doc/popups.js"></script>
|
||||||
|
<script>
|
||||||
|
var popup_data = [
|
||||||
|
{.repeated section Data}
|
||||||
|
'{@|popupInfo}',
|
||||||
|
{.end}
|
||||||
|
]
|
||||||
|
|
||||||
|
google.load("jquery", "1");
|
||||||
|
google.setOnLoadCallback(function() {.meta-left}
|
||||||
|
godocs_bindPopups(popup_data);
|
||||||
|
{.meta-right});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
{# Source is HTML-escaped elsewhere}
|
||||||
|
<pre>{Source}</pre>
|
@ -441,6 +441,36 @@ func (root *Directory) listing(skipRoot bool) *DirList {
|
|||||||
type Styler struct {
|
type Styler struct {
|
||||||
linetags bool
|
linetags bool
|
||||||
highlight string
|
highlight string
|
||||||
|
objmap map[*ast.Object]int
|
||||||
|
count int
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func newStyler(highlight string) *Styler {
|
||||||
|
return &Styler{true, highlight, make(map[*ast.Object]int), 0}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func (s *Styler) id(obj *ast.Object) int {
|
||||||
|
n, found := s.objmap[obj]
|
||||||
|
if !found {
|
||||||
|
n = s.count
|
||||||
|
s.objmap[obj] = n
|
||||||
|
s.count++
|
||||||
|
}
|
||||||
|
return n
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func (s *Styler) mapping() []*ast.Object {
|
||||||
|
if s.objmap == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
m := make([]*ast.Object, s.count)
|
||||||
|
for obj, i := range s.objmap {
|
||||||
|
m[i] = obj
|
||||||
|
}
|
||||||
|
return m
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -477,8 +507,15 @@ func (s *Styler) BasicLit(x *ast.BasicLit) (text []byte, tag printer.HTMLTag) {
|
|||||||
|
|
||||||
func (s *Styler) Ident(id *ast.Ident) (text []byte, tag printer.HTMLTag) {
|
func (s *Styler) Ident(id *ast.Ident) (text []byte, tag printer.HTMLTag) {
|
||||||
text = []byte(id.Name())
|
text = []byte(id.Name())
|
||||||
|
var str string
|
||||||
|
if s.objmap != nil {
|
||||||
|
str = fmt.Sprintf(` id="%d"`, s.id(id.Obj))
|
||||||
|
}
|
||||||
if s.highlight == id.Name() {
|
if s.highlight == id.Name() {
|
||||||
tag = printer.HTMLTag{"<span class=highlight>", "</span>"}
|
str += ` class="highlight"`
|
||||||
|
}
|
||||||
|
if str != "" {
|
||||||
|
tag = printer.HTMLTag{"<span" + str + ">", "</span>"}
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -761,6 +798,19 @@ func localnameFmt(w io.Writer, x interface{}, format string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Template formatter for "popupInfo" format.
|
||||||
|
func popupInfoFmt(w io.Writer, x interface{}, format string) {
|
||||||
|
obj := x.(*ast.Object)
|
||||||
|
// for now, show object kind and name; eventually
|
||||||
|
// do something more interesting (show declaration,
|
||||||
|
// for instance)
|
||||||
|
if obj.Kind != ast.Err {
|
||||||
|
fmt.Fprintf(w, "%s ", obj.Kind)
|
||||||
|
}
|
||||||
|
template.HTMLEscape(w, []byte(obj.Name))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
var fmap = template.FormatterMap{
|
var fmap = template.FormatterMap{
|
||||||
"": textFmt,
|
"": textFmt,
|
||||||
"html": htmlFmt,
|
"html": htmlFmt,
|
||||||
@ -776,6 +826,7 @@ var fmap = template.FormatterMap{
|
|||||||
"time": timeFmt,
|
"time": timeFmt,
|
||||||
"dir/": dirslashFmt,
|
"dir/": dirslashFmt,
|
||||||
"localname": localnameFmt,
|
"localname": localnameFmt,
|
||||||
|
"popupInfo": popupInfoFmt,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -799,7 +850,8 @@ var (
|
|||||||
godocHTML,
|
godocHTML,
|
||||||
packageHTML,
|
packageHTML,
|
||||||
packageText,
|
packageText,
|
||||||
searchHTML *template.Template
|
searchHTML,
|
||||||
|
sourceHTML *template.Template
|
||||||
)
|
)
|
||||||
|
|
||||||
func readTemplates() {
|
func readTemplates() {
|
||||||
@ -810,6 +862,7 @@ func readTemplates() {
|
|||||||
packageHTML = readTemplate("package.html")
|
packageHTML = readTemplate("package.html")
|
||||||
packageText = readTemplate("package.txt")
|
packageText = readTemplate("package.txt")
|
||||||
searchHTML = readTemplate("search.html")
|
searchHTML = readTemplate("search.html")
|
||||||
|
sourceHTML = readTemplate("source.html")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -913,11 +966,17 @@ func serveGoSource(c *http.Conn, r *http.Request, abspath, relpath string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var buf bytes.Buffer
|
var buf bytes.Buffer
|
||||||
fmt.Fprintln(&buf, "<pre>")
|
styler := newStyler(r.FormValue("h"))
|
||||||
writeNode(&buf, file, true, &Styler{linetags: true, highlight: r.FormValue("h")})
|
writeNode(&buf, file, true, styler)
|
||||||
fmt.Fprintln(&buf, "</pre>")
|
|
||||||
|
|
||||||
servePage(c, "Source file "+relpath, "", buf.Bytes())
|
type SourceInfo struct {
|
||||||
|
Source []byte
|
||||||
|
Data []*ast.Object
|
||||||
|
}
|
||||||
|
info := &SourceInfo{buf.Bytes(), styler.mapping()}
|
||||||
|
|
||||||
|
contents := applyTemplate(sourceHTML, "sourceHTML", info)
|
||||||
|
servePage(c, "Source file "+relpath, "", contents)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -19,6 +19,19 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
var objKindStrings = [...]string{
|
||||||
|
Err: "<unknown object kind>",
|
||||||
|
Pkg: "package",
|
||||||
|
Con: "const",
|
||||||
|
Typ: "type",
|
||||||
|
Var: "var",
|
||||||
|
Fun: "func",
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func (kind ObjKind) String() string { return objKindStrings[kind] }
|
||||||
|
|
||||||
|
|
||||||
// An Object describes a language entity such as a package,
|
// An Object describes a language entity such as a package,
|
||||||
// constant, type, variable, or function (incl. methods).
|
// constant, type, variable, or function (incl. methods).
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user