|
|
// Copyright 2013 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.
package godoc
// ----------------------------------------------------------------------------
// SpotInfo
// A SpotInfo value describes a particular identifier spot in a given file;
// It encodes three values: the SpotKind (declaration or use), a line or
// snippet index "lori", and whether it's a line or index.
//
// The following encoding is used:
//
// bits 32 4 1 0
// value [lori|kind|isIndex]
//
type SpotInfo uint32
// SpotKind describes whether an identifier is declared (and what kind of
// declaration) or used.
type SpotKind uint32
const ( PackageClause SpotKind = iota ImportDecl ConstDecl TypeDecl VarDecl FuncDecl MethodDecl Use nKinds )
var ( // These must match the SpotKind values above.
name = []string{ "Packages", "Imports", "Constants", "Types", "Variables", "Functions", "Methods", "Uses", "Unknown", } )
func (x SpotKind) Name() string { return name[x] }
func init() { // sanity check: if nKinds is too large, the SpotInfo
// accessor functions may need to be updated
if nKinds > 8 { panic("internal error: nKinds > 8") } }
// makeSpotInfo makes a SpotInfo.
func makeSpotInfo(kind SpotKind, lori int, isIndex bool) SpotInfo { // encode lori: bits [4..32)
x := SpotInfo(lori) << 4 if int(x>>4) != lori { // lori value doesn't fit - since snippet indices are
// most certainly always smaller then 1<<28, this can
// only happen for line numbers; give it no line number (= 0)
x = 0 } // encode kind: bits [1..4)
x |= SpotInfo(kind) << 1 // encode isIndex: bit 0
if isIndex { x |= 1 } return x }
func (x SpotInfo) Kind() SpotKind { return SpotKind(x >> 1 & 7) } func (x SpotInfo) Lori() int { return int(x >> 4) } func (x SpotInfo) IsIndex() bool { return x&1 != 0 }
|