mirror of
https://github.com/go-sylixos/elvish.git
synced 2024-12-13 18:07:51 +08:00
go vet cleanup
Most of the code uses keyed fields in composite literals; i.e., struct literals. However, running `go vet ./...` reports a few places that use anonymous fields. This modifies those composite literals to use keyed fields. This does make the code a bit more verbose without reducing the likelihood of a bug. But it does make the code more consistent, use best practices, and make it easier to notice if a potential problem is introduced when running `go vet ./...` since that command now produces no diagnostic output. I considered adding a `make vet` target that explicitly ran go vet -composites=false ./... I decided not to do that since consistently using keyed composite literals is preferable to having a mix of keyed and unkeyed composite literals. This also removes the unused `ExampleLoop` function which causes this `go vet` warning: pkg/cli/loop_test.go:130:1: ExampleLoop refers to unknown identifier: Loop
This commit is contained in:
parent
e28a7d766b
commit
b5b3a0d607
|
@ -284,9 +284,9 @@ func (a *app) ReadCode() (string, error) {
|
||||||
} else if err == term.ErrStopped {
|
} else if err == term.ErrStopped {
|
||||||
return
|
return
|
||||||
} else if term.IsReadErrorRecoverable(err) {
|
} else if term.IsReadErrorRecoverable(err) {
|
||||||
a.loop.Input(term.NonfatalErrorEvent{err})
|
a.loop.Input(term.NonfatalErrorEvent{Err: err})
|
||||||
} else {
|
} else {
|
||||||
a.loop.Input(term.FatalErrorEvent{err})
|
a.loop.Input(term.FatalErrorEvent{Err: err})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -127,7 +127,9 @@ func quitOn(lp *loop, retTrigger event, ret string, err error) handleCb {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func ExampleLoop() {
|
// This will be run by `go test` and compare the output to that in the comment
|
||||||
|
// at the end of the function. See https://golang.org/pkg/testing/#pkg-examples.
|
||||||
|
func Example_loop() {
|
||||||
buffer := ""
|
buffer := ""
|
||||||
firstDrawerCall := true
|
firstDrawerCall := true
|
||||||
drawer := func(flag redrawFlag) {
|
drawer := func(flag redrawFlag) {
|
||||||
|
|
|
@ -117,90 +117,90 @@ func (c *client) NextCmdSeq() (int, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) AddCmd(text string) (int, error) {
|
func (c *client) AddCmd(text string) (int, error) {
|
||||||
req := &api.AddCmdRequest{text}
|
req := &api.AddCmdRequest{Text: text}
|
||||||
res := &api.AddCmdResponse{}
|
res := &api.AddCmdResponse{}
|
||||||
err := c.call("AddCmd", req, res)
|
err := c.call("AddCmd", req, res)
|
||||||
return res.Seq, err
|
return res.Seq, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) DelCmd(seq int) error {
|
func (c *client) DelCmd(seq int) error {
|
||||||
req := &api.DelCmdRequest{seq}
|
req := &api.DelCmdRequest{Seq: seq}
|
||||||
res := &api.DelCmdResponse{}
|
res := &api.DelCmdResponse{}
|
||||||
err := c.call("DelCmd", req, res)
|
err := c.call("DelCmd", req, res)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) Cmd(seq int) (string, error) {
|
func (c *client) Cmd(seq int) (string, error) {
|
||||||
req := &api.CmdRequest{seq}
|
req := &api.CmdRequest{Seq: seq}
|
||||||
res := &api.CmdResponse{}
|
res := &api.CmdResponse{}
|
||||||
err := c.call("Cmd", req, res)
|
err := c.call("Cmd", req, res)
|
||||||
return res.Text, err
|
return res.Text, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) Cmds(from, upto int) ([]string, error) {
|
func (c *client) Cmds(from, upto int) ([]string, error) {
|
||||||
req := &api.CmdsRequest{from, upto}
|
req := &api.CmdsRequest{From: from, Upto: upto}
|
||||||
res := &api.CmdsResponse{}
|
res := &api.CmdsResponse{}
|
||||||
err := c.call("Cmds", req, res)
|
err := c.call("Cmds", req, res)
|
||||||
return res.Cmds, err
|
return res.Cmds, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) CmdsWithSeq(from, upto int) ([]store.Cmd, error) {
|
func (c *client) CmdsWithSeq(from, upto int) ([]store.Cmd, error) {
|
||||||
req := &api.CmdsWithSeqRequest{from, upto}
|
req := &api.CmdsWithSeqRequest{From: from, Upto: upto}
|
||||||
res := &api.CmdsWithSeqResponse{}
|
res := &api.CmdsWithSeqResponse{}
|
||||||
err := c.call("CmdsWithSeq", req, res)
|
err := c.call("CmdsWithSeq", req, res)
|
||||||
return res.Cmds, err
|
return res.Cmds, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) NextCmd(from int, prefix string) (store.Cmd, error) {
|
func (c *client) NextCmd(from int, prefix string) (store.Cmd, error) {
|
||||||
req := &api.NextCmdRequest{from, prefix}
|
req := &api.NextCmdRequest{From: from, Prefix: prefix}
|
||||||
res := &api.NextCmdResponse{}
|
res := &api.NextCmdResponse{}
|
||||||
err := c.call("NextCmd", req, res)
|
err := c.call("NextCmd", req, res)
|
||||||
return store.Cmd{Text: res.Text, Seq: res.Seq}, err
|
return store.Cmd{Text: res.Text, Seq: res.Seq}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) PrevCmd(upto int, prefix string) (store.Cmd, error) {
|
func (c *client) PrevCmd(upto int, prefix string) (store.Cmd, error) {
|
||||||
req := &api.PrevCmdRequest{upto, prefix}
|
req := &api.PrevCmdRequest{Upto: upto, Prefix: prefix}
|
||||||
res := &api.PrevCmdResponse{}
|
res := &api.PrevCmdResponse{}
|
||||||
err := c.call("PrevCmd", req, res)
|
err := c.call("PrevCmd", req, res)
|
||||||
return store.Cmd{Text: res.Text, Seq: res.Seq}, err
|
return store.Cmd{Text: res.Text, Seq: res.Seq}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) AddDir(dir string, incFactor float64) error {
|
func (c *client) AddDir(dir string, incFactor float64) error {
|
||||||
req := &api.AddDirRequest{dir, incFactor}
|
req := &api.AddDirRequest{Dir: dir, IncFactor: incFactor}
|
||||||
res := &api.AddDirResponse{}
|
res := &api.AddDirResponse{}
|
||||||
err := c.call("AddDir", req, res)
|
err := c.call("AddDir", req, res)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) DelDir(dir string) error {
|
func (c *client) DelDir(dir string) error {
|
||||||
req := &api.DelDirRequest{dir}
|
req := &api.DelDirRequest{Dir: dir}
|
||||||
res := &api.DelDirResponse{}
|
res := &api.DelDirResponse{}
|
||||||
err := c.call("DelDir", req, res)
|
err := c.call("DelDir", req, res)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) Dirs(blacklist map[string]struct{}) ([]store.Dir, error) {
|
func (c *client) Dirs(blacklist map[string]struct{}) ([]store.Dir, error) {
|
||||||
req := &api.DirsRequest{blacklist}
|
req := &api.DirsRequest{Blacklist: blacklist}
|
||||||
res := &api.DirsResponse{}
|
res := &api.DirsResponse{}
|
||||||
err := c.call("Dirs", req, res)
|
err := c.call("Dirs", req, res)
|
||||||
return res.Dirs, err
|
return res.Dirs, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) SharedVar(name string) (string, error) {
|
func (c *client) SharedVar(name string) (string, error) {
|
||||||
req := &api.SharedVarRequest{name}
|
req := &api.SharedVarRequest{Name: name}
|
||||||
res := &api.SharedVarResponse{}
|
res := &api.SharedVarResponse{}
|
||||||
err := c.call("SharedVar", req, res)
|
err := c.call("SharedVar", req, res)
|
||||||
return res.Value, err
|
return res.Value, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) SetSharedVar(name, value string) error {
|
func (c *client) SetSharedVar(name, value string) error {
|
||||||
req := &api.SetSharedVarRequest{name, value}
|
req := &api.SetSharedVarRequest{Name: name, Value: value}
|
||||||
res := &api.SetSharedVarResponse{}
|
res := &api.SetSharedVarResponse{}
|
||||||
return c.call("SetSharedVar", req, res)
|
return c.call("SetSharedVar", req, res)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) DelSharedVar(name string) error {
|
func (c *client) DelSharedVar(name string) error {
|
||||||
req := &api.DelSharedVarRequest{name}
|
req := &api.DelSharedVarRequest{Name: name}
|
||||||
res := &api.DelSharedVarResponse{}
|
res := &api.DelSharedVarResponse{}
|
||||||
return c.call("DelSharedVar", req, res)
|
return c.call("DelSharedVar", req, res)
|
||||||
}
|
}
|
||||||
|
|
|
@ -274,8 +274,8 @@ func (cp *compiler) primaryOp(n *parse.Primary) valuesOp {
|
||||||
cp.errorpf(n, "%s", err)
|
cp.errorpf(n, "%s", err)
|
||||||
}
|
}
|
||||||
vs := []interface{}{
|
vs := []interface{}{
|
||||||
GlobPattern{Pattern: glob.Pattern{[]glob.Segment{seg}, ""}, Flags: 0,
|
GlobPattern{Pattern: glob.Pattern{Segments: []glob.Segment{seg}, DirOverride: ""},
|
||||||
Buts: nil, TypeCb: nil}}
|
Flags: 0, Buts: nil, TypeCb: nil}}
|
||||||
return literalValues(n, vs...)
|
return literalValues(n, vs...)
|
||||||
case parse.Tilde:
|
case parse.Tilde:
|
||||||
cp.errorpf(n, "compiler bug: Tilde not handled in .compound")
|
cp.errorpf(n, "compiler bug: Tilde not handled in .compound")
|
||||||
|
|
|
@ -82,7 +82,7 @@ func (gp GlobPattern) Index(k interface{}) (interface{}, error) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
gp.Segments[len(gp.Segments)-1] = glob.Wild{
|
gp.Segments[len(gp.Segments)-1] = glob.Wild{
|
||||||
lastSeg.Type, true, lastSeg.Matchers,
|
Type: lastSeg.Type, MatchHidden: true, Matchers: lastSeg.Matchers,
|
||||||
}
|
}
|
||||||
case strings.HasPrefix(modifier, "type:"):
|
case strings.HasPrefix(modifier, "type:"):
|
||||||
if gp.TypeCb != nil {
|
if gp.TypeCb != nil {
|
||||||
|
@ -184,8 +184,8 @@ func (gp *GlobPattern) addMatcher(matcher func(rune) bool) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
gp.Segments[len(gp.Segments)-1] = glob.Wild{
|
gp.Segments[len(gp.Segments)-1] = glob.Wild{
|
||||||
lastSeg.Type, lastSeg.MatchHidden,
|
Type: lastSeg.Type, MatchHidden: lastSeg.MatchHidden,
|
||||||
append(lastSeg.Matchers, matcher),
|
Matchers: append(lastSeg.Matchers, matcher),
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -197,11 +197,11 @@ func (gp *GlobPattern) append(segs ...glob.Segment) {
|
||||||
func wildcardToSegment(s string) (glob.Segment, error) {
|
func wildcardToSegment(s string) (glob.Segment, error) {
|
||||||
switch s {
|
switch s {
|
||||||
case "*":
|
case "*":
|
||||||
return glob.Wild{glob.Star, false, nil}, nil
|
return glob.Wild{Type: glob.Star, MatchHidden: false, Matchers: nil}, nil
|
||||||
case "**":
|
case "**":
|
||||||
return glob.Wild{glob.StarStar, false, nil}, nil
|
return glob.Wild{Type: glob.StarStar, MatchHidden: false, Matchers: nil}, nil
|
||||||
case "?":
|
case "?":
|
||||||
return glob.Wild{glob.Question, false, nil}, nil
|
return glob.Wild{Type: glob.Question, MatchHidden: false, Matchers: nil}, nil
|
||||||
default:
|
default:
|
||||||
return nil, fmt.Errorf("bad wildcard: %q", s)
|
return nil, fmt.Errorf("bad wildcard: %q", s)
|
||||||
}
|
}
|
||||||
|
@ -214,7 +214,7 @@ func stringToSegments(s string) []glob.Segment {
|
||||||
for ; j < len(s) && s[j] != '/'; j++ {
|
for ; j < len(s) && s[j] != '/'; j++ {
|
||||||
}
|
}
|
||||||
if j > i {
|
if j > i {
|
||||||
segs = append(segs, glob.Literal{s[i:j]})
|
segs = append(segs, glob.Literal{Data: s[i:j]})
|
||||||
}
|
}
|
||||||
if j < len(s) {
|
if j < len(s) {
|
||||||
for ; j < len(s) && s[j] == '/'; j++ {
|
for ; j < len(s) && s[j] == '/'; j++ {
|
||||||
|
|
|
@ -39,11 +39,11 @@ var stringToSegmentsTests = []struct {
|
||||||
want []glob.Segment
|
want []glob.Segment
|
||||||
}{
|
}{
|
||||||
{"", []glob.Segment{}},
|
{"", []glob.Segment{}},
|
||||||
{"a", []glob.Segment{glob.Literal{"a"}}},
|
{"a", []glob.Segment{glob.Literal{Data: "a"}}},
|
||||||
{"/a", []glob.Segment{glob.Slash{}, glob.Literal{"a"}}},
|
{"/a", []glob.Segment{glob.Slash{}, glob.Literal{Data: "a"}}},
|
||||||
{"a/", []glob.Segment{glob.Literal{"a"}, glob.Slash{}}},
|
{"a/", []glob.Segment{glob.Literal{Data: "a"}, glob.Slash{}}},
|
||||||
{"/a/", []glob.Segment{glob.Slash{}, glob.Literal{"a"}, glob.Slash{}}},
|
{"/a/", []glob.Segment{glob.Slash{}, glob.Literal{Data: "a"}, glob.Slash{}}},
|
||||||
{"a//b", []glob.Segment{glob.Literal{"a"}, glob.Slash{}, glob.Literal{"b"}}},
|
{"a//b", []glob.Segment{glob.Literal{Data: "a"}, glob.Slash{}, glob.Literal{Data: "b"}}},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestStringToSegments(t *testing.T) {
|
func TestStringToSegments(t *testing.T) {
|
||||||
|
|
|
@ -405,7 +405,8 @@ func (cn *Compound) parse(ps *parser) {
|
||||||
func (cn *Compound) tilde(ps *parser) {
|
func (cn *Compound) tilde(ps *parser) {
|
||||||
if ps.peek() == '~' {
|
if ps.peek() == '~' {
|
||||||
ps.next()
|
ps.next()
|
||||||
base := node{diag.Ranging{ps.pos - 1, ps.pos}, "~", nil, nil}
|
base := node{Ranging: diag.Ranging{From: ps.pos - 1, To: ps.pos},
|
||||||
|
sourceText: "~", parent: nil, children: nil}
|
||||||
pn := &Primary{node: base, Type: Tilde, Value: "~"}
|
pn := &Primary{node: base, Type: Tilde, Value: "~"}
|
||||||
in := &Indexing{node: base}
|
in := &Indexing{node: base}
|
||||||
parsed{pn}.addAs(&in.Head, in)
|
parsed{pn}.addAs(&in.Head, in)
|
||||||
|
@ -900,7 +901,7 @@ type Sep struct {
|
||||||
|
|
||||||
// NewSep makes a new Sep.
|
// NewSep makes a new Sep.
|
||||||
func NewSep(src string, begin, end int) *Sep {
|
func NewSep(src string, begin, end int) *Sep {
|
||||||
return &Sep{node{diag.Ranging{begin, end}, src[begin:end], nil, nil}}
|
return &Sep{node: node{diag.Ranging{From: begin, To: end}, src[begin:end], nil, nil}}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (*Sep) parse(*parser) {
|
func (*Sep) parse(*parser) {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user