mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
Output from 'dep status': PROJECT CONSTRAINT VERSION REVISION LATEST PKGS USED cloud.google.com/go v0.23.0 v0.23.0 0fd7230 v0.23.0 1 github.com/briandowns/openweathermap ^0.11.0 0.11 1b87579 0.11 1 github.com/gdamore/encoding branch master branch master b23993c b23993c 1 github.com/gdamore/tcell ^1.0.0 v1.0.0 061d51a v1.0.0 2 github.com/go-test/deep ^1.0.1 v1.0.1 6592d9c v1.0.1 1 github.com/golang/protobuf v1.1.0 v1.1.0 b4deda0 v1.1.0 1 github.com/google/go-github branch master branch master 2ae5df7 2ae5df7 1 github.com/google/go-querystring branch master branch master 53e6ce1 53e6ce1 1 github.com/jessevdk/go-flags ^1.4.0 v1.4.0 c6ca198 v1.4.0 1 github.com/lucasb-eyer/go-colorful v1.0 v1.0 345fbb3 v1.0 1 github.com/mattn/go-runewidth v0.0.2 v0.0.2 9e777a8 v0.0.2 1 github.com/olebedev/config branch master branch master 9a10d05 9a10d05 1 github.com/radovskyb/watcher ^1.0.2 v1.0.2 6145e14 v1.0.2 1 github.com/rivo/tview branch master branch master 71ecf1f 71ecf1f 1 github.com/yfronto/newrelic branch master branch master f7fa0c6 f7fa0c6 1 golang.org/x/net branch master branch master 1e49130 1e49130 2 golang.org/x/oauth2 branch master branch master 1e0a3fa 1e0a3fa 5 golang.org/x/text v0.3.0 v0.3.0 f21a4df v0.3.0 5 google.golang.org/api branch master branch master 00e3bb8 00e3bb8 4 google.golang.org/appengine v1.0.0 v1.0.0 150dc57 v1.0.0 10 gopkg.in/yaml.v2 ^2.2.1 v2.2.1 5420a8b v2.2.1 1 See https://golang.github.io/dep/docs/daily-dep.html
60 lines
963 B
Go
60 lines
963 B
Go
package flags
|
|
|
|
func levenshtein(s string, t string) int {
|
|
if len(s) == 0 {
|
|
return len(t)
|
|
}
|
|
|
|
if len(t) == 0 {
|
|
return len(s)
|
|
}
|
|
|
|
dists := make([][]int, len(s)+1)
|
|
for i := range dists {
|
|
dists[i] = make([]int, len(t)+1)
|
|
dists[i][0] = i
|
|
}
|
|
|
|
for j := range t {
|
|
dists[0][j] = j
|
|
}
|
|
|
|
for i, sc := range s {
|
|
for j, tc := range t {
|
|
if sc == tc {
|
|
dists[i+1][j+1] = dists[i][j]
|
|
} else {
|
|
dists[i+1][j+1] = dists[i][j] + 1
|
|
if dists[i+1][j] < dists[i+1][j+1] {
|
|
dists[i+1][j+1] = dists[i+1][j] + 1
|
|
}
|
|
if dists[i][j+1] < dists[i+1][j+1] {
|
|
dists[i+1][j+1] = dists[i][j+1] + 1
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return dists[len(s)][len(t)]
|
|
}
|
|
|
|
func closestChoice(cmd string, choices []string) (string, int) {
|
|
if len(choices) == 0 {
|
|
return "", 0
|
|
}
|
|
|
|
mincmd := -1
|
|
mindist := -1
|
|
|
|
for i, c := range choices {
|
|
l := levenshtein(cmd, c)
|
|
|
|
if mincmd < 0 || l < mindist {
|
|
mindist = l
|
|
mincmd = i
|
|
}
|
|
}
|
|
|
|
return choices[mincmd], mindist
|
|
}
|