Commit adcf0a2a authored by David Symonds's avatar David Symonds

misc/vim: fix Drop for imports after the first group.

Previously, an import block such as
	import (
        	"net"

                "stack"
        )
would not permit ":Drop stack" to work because we were aborting
the scan early, which is only correct when Import is in operation.

R=golang-dev, franciscossouza
CC=golang-dev
https://golang.org/cl/6532053
parent 83601807
...@@ -96,7 +96,7 @@ function! s:SwitchImport(enabled, localname, path) ...@@ -96,7 +96,7 @@ function! s:SwitchImport(enabled, localname, path)
let linestr = getline(line) let linestr = getline(line)
let m = matchlist(getline(line), '^\()\|\(\s\+\)\(\S*\s*\)"\(.\+\)"\)') let m = matchlist(getline(line), '^\()\|\(\s\+\)\(\S*\s*\)"\(.\+\)"\)')
if empty(m) if empty(m)
if siteprefix == "" if siteprefix == "" && a:enabled
" must be in the first group " must be in the first group
break break
endif endif
......
...@@ -22,36 +22,53 @@ EOF ...@@ -22,36 +22,53 @@ EOF
fail=0 fail=0
# usage: test_one new_import pattern # usage: test_one command pattern
# Pattern is a PCRE expression that will match across lines. # Pattern is a PCRE expression that will match across lines.
test_one() { test_one() {
echo 2>&1 -n "Import $1: " echo 2>&1 -n "$1: "
vim -e -s -u /dev/null -U /dev/null --noplugin -c "source import.vim" \ vim -e -s -u /dev/null -U /dev/null --noplugin -c "source import.vim" \
-c "Import $1" -c 'wq! test.go' base.go -c "$1" -c 'wq! test.go' base.go
# ensure blank lines are treated correctly # ensure blank lines are treated correctly
if ! gofmt test.go | cmp test.go; then if ! gofmt test.go | cmp test.go; then
echo 2>&1 "gofmt conflict" echo 2>&1 "gofmt conflict"
gofmt test.go | diff -u test.go - | sed "s/^/\t/" 2>&1 gofmt test.go | diff -u test.go - | sed "s/^/ /" 2>&1
fail=1 fail=1
return return
fi fi
if ! grep -P -q "(?s)$2" test.go; then if ! grep -P -q "(?s)$2" test.go; then
echo 2>&1 "$2 did not match" echo 2>&1 "$2 did not match"
cat test.go | sed "s/^/\t/" 2>&1 cat test.go | sed "s/^/ /" 2>&1
fail=1 fail=1
return return
fi fi
echo 2>&1 "ok" echo 2>&1 "ok"
} }
test_one baz '"baz".*"bytes"' # Tests for Import
test_one io/ioutil '"io".*"io/ioutil".*"net"'
test_one myc '"io".*"myc".*"net"' # prefix of a site prefix test_one "Import baz" '"baz".*"bytes"'
test_one nat '"io".*"nat".*"net"' test_one "Import io/ioutil" '"io".*"io/ioutil".*"net"'
test_one net/http '"net".*"net/http".*"mycorp/foo"' test_one "Import myc" '"io".*"myc".*"net"' # prefix of a site prefix
test_one zoo '"net".*"zoo".*"mycorp/foo"' test_one "Import nat" '"io".*"nat".*"net"'
test_one mycorp/bar '"net".*"mycorp/bar".*"mycorp/foo"' test_one "Import net/http" '"net".*"net/http".*"mycorp/foo"'
test_one mycorp/goo '"net".*"mycorp/foo".*"mycorp/goo"' test_one "Import zoo" '"net".*"zoo".*"mycorp/foo"'
test_one "Import mycorp/bar" '"net".*"mycorp/bar".*"mycorp/foo"'
test_one "Import mycorp/goo" '"net".*"mycorp/foo".*"mycorp/goo"'
# Tests for Drop
cat > base.go <<EOF
package test
import (
"foo"
"something"
"zoo"
)
EOF
test_one "Drop something" '\([^"]*"foo"[^"]*"zoo"[^"]*\)'
rm -f base.go test.go rm -f base.go test.go
if [ $fail -gt 0 ]; then if [ $fail -gt 0 ]; then
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment