forked from x/icebergs
138 lines
4.4 KiB
Go
138 lines
4.4 KiB
Go
package git
|
|
|
|
import (
|
|
"path"
|
|
"strings"
|
|
"sync"
|
|
"time"
|
|
|
|
ice "shylinux.com/x/icebergs"
|
|
"shylinux.com/x/icebergs/base/cli"
|
|
"shylinux.com/x/icebergs/base/ctx"
|
|
"shylinux.com/x/icebergs/base/lex"
|
|
"shylinux.com/x/icebergs/base/mdb"
|
|
"shylinux.com/x/icebergs/base/nfs"
|
|
"shylinux.com/x/icebergs/base/web"
|
|
kit "shylinux.com/x/toolkits"
|
|
"shylinux.com/x/toolkits/logs"
|
|
"shylinux.com/x/toolkits/task"
|
|
)
|
|
|
|
const TOTAL = "total"
|
|
|
|
func init() {
|
|
const (
|
|
FROM = "from"
|
|
DAYS = "days"
|
|
COMMIT = "commit"
|
|
ADDS = "adds"
|
|
DELS = "dels"
|
|
REST = "rest"
|
|
)
|
|
Index.MergeCommands(ice.Commands{
|
|
TOTAL: {Name: "total repos auto pie", Help: "统计量", Actions: ice.Actions{
|
|
"pie": {Help: "饼图", Hand: func(m *ice.Message, arg ...string) {
|
|
defer ctx.DisplayStory(m, "pie.js")
|
|
m.Cmd("", func(value ice.Maps) {
|
|
kit.If(value[REPOS] != mdb.TOTAL, func() {
|
|
m.Push(REPOS, value[REPOS]).Push(mdb.VALUE, value[REST]).Push("", value, []string{FROM, DAYS, COMMIT, ADDS, DELS})
|
|
})
|
|
})
|
|
}},
|
|
}, Hand: func(m *ice.Message, arg ...string) {
|
|
if len(arg) > 0 {
|
|
ReposList(m.Spawn()).Table(func(value ice.Maps) {
|
|
kit.If(value[REPOS] == arg[0], func() { m.Cmdy("_sum", value[nfs.PATH], arg[1:]) })
|
|
})
|
|
m.StatusTimeCount(m.AppendSimple(FROM))
|
|
return
|
|
}
|
|
defer web.ToastProcess(m)()
|
|
from, days, commit, adds, dels, rest := "", 0, 0, 0, 0, 0
|
|
TableGo(ReposList(m.Spawn()), func(value ice.Maps, lock *task.Lock) {
|
|
if kit.IsIn(value[REPOS], "websocket", "go-qrcode", "go-git", "icons", "geoarea", "program", "node_modules") {
|
|
return
|
|
}
|
|
msg := m.Cmd("_sum", value[nfs.PATH], mdb.TOTAL, "10000")
|
|
defer lock.Lock()()
|
|
msg.Table(func(value ice.Maps) {
|
|
kit.If(kit.Int(value[DAYS]) > days, func() { from, days = value[FROM], kit.Int(value[DAYS]) })
|
|
commit += kit.Int(value[COMMIT])
|
|
adds += kit.Int(value[ADDS])
|
|
dels += kit.Int(value[DELS])
|
|
rest += kit.Int(value[REST])
|
|
})
|
|
m.Push(REPOS, value[REPOS]).Copy(msg)
|
|
})
|
|
m.Push(REPOS, mdb.TOTAL).Push(TAGS, "v5.0.0").Push(FROM, from).Push(DAYS, days).Push(COMMIT, commit).Push(ADDS, adds).Push(DELS, dels).Push(REST, rest).SortIntR(REST)
|
|
}},
|
|
"_sum": {Name: "_sum [path] [total] [count|date] args...", Help: "统计量", Hand: func(m *ice.Message, arg ...string) {
|
|
m.Options(nfs.DIR_ROOT, "", nfs.CAT_CONTENT, "")
|
|
if len(arg) > 0 {
|
|
if nfs.Exists(m, path.Join(arg[0], _GIT)) || nfs.Exists(m, path.Join(arg[0], "refs/heads/")) {
|
|
m.Option(cli.CMD_DIR, arg[0])
|
|
arg = arg[1:]
|
|
}
|
|
}
|
|
total := false
|
|
kit.If(len(arg) > 0 && arg[0] == mdb.TOTAL, func() { total, arg = true, arg[1:] })
|
|
args := []string{LOG, "--shortstat", "--pretty=commit: %H %ad %n%s", "--date=iso", "--reverse"}
|
|
if len(arg) > 0 {
|
|
arg[0] += kit.Select("", " 00:00:00", strings.Contains(arg[0], "-") && !strings.Contains(arg[0], nfs.DF))
|
|
args = append(args, kit.Select("-n", "--since", strings.Contains(arg[0], "-")))
|
|
args = append(args, arg...)
|
|
} else {
|
|
args = append(args, "-n", "30")
|
|
}
|
|
from, days, commit, adds, dels := "", 0, 0, 0, 0
|
|
kit.SplitKV(lex.NL, "commit:", _git_cmds(m, args...), func(text string, ls []string) {
|
|
add, del := "0", "0"
|
|
for _, v := range kit.Split(strings.TrimSpace(kit.Select("", ls, -1)), mdb.FS) {
|
|
switch {
|
|
case strings.Contains(v, "inser"):
|
|
add = kit.Split(v)[0]
|
|
case strings.Contains(v, "delet"):
|
|
del = kit.Split(v)[0]
|
|
}
|
|
}
|
|
hs := strings.Split(ls[0], lex.SP)
|
|
if total {
|
|
if commit++; from == "" {
|
|
if t, e := time.Parse("2006-01-02", hs[1]); e == nil {
|
|
from, days = hs[1], int(time.Now().Sub(t).Hours())/24
|
|
}
|
|
}
|
|
adds += kit.Int(add)
|
|
dels += kit.Int(del)
|
|
return
|
|
}
|
|
m.Push(FROM, hs[1]).Push(ADDS, add).Push(DELS, del).Push(REST, kit.Int(add)-kit.Int(del)).Push(COMMIT, ls[1]).Push(mdb.HASH, hs[0])
|
|
})
|
|
if total {
|
|
m.Push(TAGS, _git_cmds(m, "describe", "--tags"))
|
|
m.Push(FROM, from).Push(DAYS, days).Push(COMMIT, commit)
|
|
m.Push(ADDS, adds).Push(DELS, dels).Push(REST, adds-dels)
|
|
}
|
|
}},
|
|
})
|
|
}
|
|
func TableGo(m *ice.Message, cb ice.Any) *ice.Message {
|
|
wg, lock := sync.WaitGroup{}, &task.Lock{}
|
|
wg.Add(m.Length())
|
|
defer wg.Wait()
|
|
m.Table(func(value ice.Maps) {
|
|
task.Put(m.FormatTaskMeta(), logs.FileLine(cb), func(*task.Task) {
|
|
defer wg.Done()
|
|
switch cb := cb.(type) {
|
|
case func(ice.Maps, *task.Lock):
|
|
cb(value, lock)
|
|
case func(ice.Maps):
|
|
cb(value)
|
|
default:
|
|
m.ErrorNotImplement(cb)
|
|
}
|
|
})
|
|
})
|
|
return m
|
|
}
|