mirror of
https://github.com/golang/go
synced 2024-11-19 03:54:42 -07:00
f270e23f6a
This is the first step to surfacing potential fixes and suggestions to a user's go.mod file. Specifically, it will show a warning if you have a dependency that is not used, or if a dependency is declared as indirect when it should be direct and vice versa. This CL adds functionality for version of Go that are >= 1.14. Updates golang/go#31999 Change-Id: Id60fa0ee201dcd843f62e2659dda8e795bd671db Reviewed-on: https://go-review.googlesource.com/c/tools/+/211937 Run-TryBot: Rohan Challa <rohan@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Rebecca Stambler <rstambler@golang.org>
73 lines
1.7 KiB
Go
73 lines
1.7 KiB
Go
// Copyright 2019 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 cache
|
|
|
|
import (
|
|
"context"
|
|
|
|
"golang.org/x/mod/modfile"
|
|
"golang.org/x/tools/internal/lsp/source"
|
|
"golang.org/x/tools/internal/lsp/telemetry"
|
|
"golang.org/x/tools/internal/memoize"
|
|
"golang.org/x/tools/internal/telemetry/trace"
|
|
errors "golang.org/x/xerrors"
|
|
)
|
|
|
|
type parseModHandle struct {
|
|
handle *memoize.Handle
|
|
file source.FileHandle
|
|
}
|
|
|
|
type parseModData struct {
|
|
memoize.NoCopy
|
|
|
|
modfile *modfile.File
|
|
err error
|
|
}
|
|
|
|
func (c *cache) ParseModHandle(fh source.FileHandle) source.ParseModHandle {
|
|
h := c.store.Bind(fh.Identity(), func(ctx context.Context) interface{} {
|
|
data := &parseModData{}
|
|
data.modfile, data.err = parseMod(ctx, fh)
|
|
return data
|
|
})
|
|
return &parseModHandle{
|
|
handle: h,
|
|
file: fh,
|
|
}
|
|
}
|
|
|
|
func parseMod(ctx context.Context, fh source.FileHandle) (modifle *modfile.File, err error) {
|
|
ctx, done := trace.StartSpan(ctx, "cache.parseMod", telemetry.File.Of(fh.Identity().URI.Filename()))
|
|
defer done()
|
|
|
|
buf, _, err := fh.Read(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
f, err := modfile.Parse(fh.Identity().URI.Filename(), buf, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return f, nil
|
|
}
|
|
|
|
func (pgh *parseModHandle) String() string {
|
|
return pgh.File().Identity().URI.Filename()
|
|
}
|
|
|
|
func (pgh *parseModHandle) File() source.FileHandle {
|
|
return pgh.file
|
|
}
|
|
|
|
func (pgh *parseModHandle) Parse(ctx context.Context) (*modfile.File, error) {
|
|
v := pgh.handle.Get(ctx)
|
|
if v == nil {
|
|
return nil, errors.Errorf("no parsed file for %s", pgh.File().Identity().URI)
|
|
}
|
|
data := v.(*parseModData)
|
|
return data.modfile, data.err
|
|
}
|