package span
import "golang.org/x/tools/internal/span"
Package span contains support for representing with positions and ranges in text files.
Index ¶
- Variables
- func Compare(a, b Span) int
- func ComparePoint(a, b Point) int
- func CompareURI(a, b URI) int
- func ToUTF16Column(p Point, content []byte) (int, error)
- type Converter
- type FileConverter
- func (l *FileConverter) ToOffset(line, col int) (int, error)
- func (l *FileConverter) ToPosition(offset int) (int, int, error)
- type Point
- func FromUTF16Column(p Point, chr int, content []byte) (Point, error)
- func NewPoint(line, col, offset int) Point
- func (p Point) Column() int
- func (p Point) HasOffset() bool
- func (p Point) HasPosition() bool
- func (p Point) IsValid() bool
- func (p Point) Line() int
- func (p *Point) MarshalJSON() ([]byte, error)
- func (p Point) Offset() int
- func (p *Point) UnmarshalJSON(b []byte) error
- type Range
- func NewRange(fset *token.FileSet, start, end token.Pos) Range
- func (r Range) IsPoint() bool
- func (r Range) Span() (Span, error)
- type Span
- func FileSpan(tok *token.File, converter Converter, start, end token.Pos) (Span, error)
- func New(uri URI, start Point, end Point) Span
- func Parse(input string) Span
- func ParseInDir(input, wd string) Span
- func (s Span) End() Point
- func (s Span) Format(f fmt.State, c rune)
- func (s Span) HasOffset() bool
- func (s Span) HasPosition() bool
- func (s Span) IsPoint() bool
- func (s Span) IsValid() bool
- func (s *Span) MarshalJSON() ([]byte, error)
- func (s Span) Range(converter *TokenConverter) (Range, error)
- func (s Span) Start() Point
- func (s Span) URI() URI
- func (s *Span) UnmarshalJSON(b []byte) error
- func (s Span) WithAll(c Converter) (Span, error)
- func (s Span) WithOffset(c Converter) (Span, error)
- func (s Span) WithPosition(c Converter) (Span, error)
- type TokenConverter
- func NewContentConverter(filename string, content []byte) *TokenConverter
- func NewTokenConverter(fset *token.FileSet, f *token.File) *TokenConverter
- type URI
Variables ¶
var Invalid = Span{/* contains filtered or unexported fields */}
Invalid is a span that reports false from IsValid
Functions ¶
func Compare ¶
func ComparePoint ¶
func CompareURI ¶
func ToUTF16Column ¶
ToUTF16Column calculates the utf16 column expressed by the point given the supplied file contents. This is used to convert from the native (always in bytes) column representation and the utf16 counts used by some editors.
Types ¶
type Converter ¶
type Converter interface { //ToPosition converts from an offset to a line:column pair. ToPosition(offset int) (int, int, error) //ToOffset converts from a line:column pair to an offset. ToOffset(line, col int) (int, error) }
Converter is the interface to an object that can convert between line:column and offset forms for a single file.
type FileConverter ¶
type FileConverter struct {
// contains filtered or unexported fields
}
func (*FileConverter) ToOffset ¶
func (l *FileConverter) ToOffset(line, col int) (int, error)
func (*FileConverter) ToPosition ¶
func (l *FileConverter) ToPosition(offset int) (int, int, error)
type Point ¶
type Point struct {
// contains filtered or unexported fields
}
Point represents a single point within a file. In general this should only be used as part of a Span, as on its own it does not carry enough information.
func FromUTF16Column ¶
FromUTF16Column advances the point by the utf16 character offset given the supplied line contents. This is used to convert from the utf16 counts used by some editors to the native (always in bytes) column representation.
func NewPoint ¶
func (Point) Column ¶
func (Point) HasOffset ¶
func (Point) HasPosition ¶
func (Point) IsValid ¶
func (Point) Line ¶
func (*Point) MarshalJSON ¶
func (Point) Offset ¶
func (*Point) UnmarshalJSON ¶
type Range ¶
Range represents a source code range in token.Pos form. It also carries the FileSet that produced the positions, so that it is self contained.
func NewRange ¶
NewRange creates a new Range from a FileSet and two positions. To represent a point pass a 0 as the end pos.
func (Range) IsPoint ¶
IsPoint returns true if the range represents a single point.
func (Range) Span ¶
Span converts a Range to a Span that represents the Range. It will fill in all the members of the Span, calculating the line and column information.
type Span ¶
type Span struct {
// contains filtered or unexported fields
}
Span represents a source code range in standardized form.
func FileSpan ¶
FileSpan returns a span within tok, using converter to translate between offsets and positions.
func New ¶
func Parse ¶
Parse returns the location represented by the input. Only file paths are accepted, not URIs. The returned span will be normalized, and thus if printed may produce a different string.
func ParseInDir ¶
ParseInDir is like Parse, but interprets paths relative to wd.
func (Span) End ¶
func (Span) Format ¶
Format implements fmt.Formatter to print the Location in a standard form. The format produced is one that can be read back in using Parse.
func (Span) HasOffset ¶
func (Span) HasPosition ¶
func (Span) IsPoint ¶
func (Span) IsValid ¶
func (*Span) MarshalJSON ¶
func (Span) Range ¶
func (s Span) Range(converter *TokenConverter) (Range, error)
Range converts a Span to a Range that represents the Span for the supplied File.
func (Span) Start ¶
func (Span) URI ¶
func (*Span) UnmarshalJSON ¶
func (Span) WithAll ¶
func (Span) WithOffset ¶
func (Span) WithPosition ¶
type TokenConverter ¶
type TokenConverter struct { FileConverter // contains filtered or unexported fields }
TokenConverter is a Converter backed by a token file set and file. It uses the file set methods to work out the conversions, which makes it fast and does not require the file contents.
func NewContentConverter ¶
func NewContentConverter(filename string, content []byte) *TokenConverter
NewContentConverter returns an implementation of Converter for the given file content.
func NewTokenConverter ¶
func NewTokenConverter(fset *token.FileSet, f *token.File) *TokenConverter
NewTokenConverter returns an implementation of Converter backed by a token.File.
type URI ¶
type URI string
URI represents the full URI for a file.
func URIFromPath ¶
URIFromPath returns a span URI for the supplied file path. It will always have the file scheme.
func URIFromURI ¶
func (URI) Filename ¶
Filename returns the file path for the given URI. It is an error to call this on a URI that is not a valid filename.
func (URI) IsFile ¶
Source Files ¶
parse.go span.go token.go token112.go uri.go utf16.go
- Version
- v0.1.10
- Published
- Mar 15, 2022
- Platform
- js/wasm
- Imports
- 12 packages
- Last checked
- 6 hours ago –
Tools for package owners.