package git import ( "path" "strings" "shylinux.com/x/gogit" ice "shylinux.com/x/icebergs" "shylinux.com/x/icebergs/base/cli" "shylinux.com/x/icebergs/base/mdb" "shylinux.com/x/icebergs/base/nfs" kit "shylinux.com/x/toolkits" ) func _repos_path(name string) string { if strings.Contains(name, ":\\") { return name } return kit.Select(path.Join(ice.USR, name)+ice.PS, nfs.PWD, name == path.Base(kit.Pwd())) } func _repos_cmd(m *ice.Message, name string, arg ...string) *ice.Message { return m.Cmdy(cli.SYSTEM, GIT, arg, ice.Option{cli.CMD_DIR, _repos_path(name)}) } func _repos_insert(m *ice.Message, name string, dir string) { if s, e := nfs.StatFile(m, m.Option(cli.CMD_DIR, path.Join(dir, ".git"))); e == nil && s.IsDir() { ci, _ := gogit.OpenRepository(path.Join(dir, ".git")).GetCurrentCommit() mdb.HashCreate(m, mdb.NAME, name, nfs.PATH, dir, COMMIT, strings.TrimSpace(ci.CommitMessage), mdb.TIME, ci.Author.When.Format(ice.MOD_TIME), REMOTE, strings.SplitN(nfs.CatFile(m, path.Join(dir, ".git", "FETCH_HEAD")), ice.SP, 2)[1], BRANCH, path.Base(nfs.CatFile(m, path.Join(dir, ".git", "HEAD"))), ) } } const ( REMOTE = "remote" ORIGIN = "origin" BRANCH = "branch" MASTER = "master" CLONE = "clone" INIT = "init" ) const REPOS = "repos" func init() { Index.MergeCommands(ice.Commands{ REPOS: {Name: "repos repos path auto create", Help: "代码库", Actions: ice.MergeActions(ice.Actions{ ice.CTX_INIT: {Hand: func(m *ice.Message, arg ...string) { m.Cmd(nfs.DIR, ice.USR, "name,path", func(value ice.Maps) { _repos_insert(m, value[mdb.NAME], value[nfs.PATH]) }) _repos_insert(m, path.Base(kit.Pwd()), kit.Pwd()) cli.IsAlpine(m, GIT) cli.IsCentos(m, GIT) cli.IsUbuntu(m, GIT) }}, mdb.CREATE: {Name: "create repos branch name path", Hand: func(m *ice.Message, arg ...string) { m.OptionDefault(mdb.NAME, strings.TrimSuffix(path.Base(m.Option(REPOS)), ".git")) m.OptionDefault(nfs.PATH, path.Join(ice.USR, m.Option(mdb.NAME))) m.OptionDefault(REPOS, m.Config(REPOS)+m.Option(mdb.NAME)) _repos_insert(m, m.Option(mdb.NAME), m.Option(nfs.PATH)) if s, e := nfs.StatFile(m, path.Join(m.Option(nfs.PATH), ".git")); e == nil && s.IsDir() { return } if s, e := nfs.StatFile(m, m.Option(nfs.PATH)); e == nil && s.IsDir() { m.Option(cli.CMD_DIR, m.Option(nfs.PATH)) _git_cmd(m, INIT) _git_cmd(m, REMOTE, ADD, ORIGIN, m.Option(REPOS)) _git_cmd(m, PULL, ORIGIN, kit.Select(MASTER, m.Option(BRANCH))) } else { m.Option(cli.CMD_DIR, "") _git_cmd(m, CLONE, "-b", kit.Select(MASTER, m.Option(BRANCH)), m.Option(REPOS), m.Option(nfs.PATH)) } }}, }, mdb.HashAction(mdb.SHORT, mdb.NAME, mdb.FIELD, "time,name,branch,commit,remote", REPOS, "https://shylinux.com/x/"), mdb.ClearHashOnExitAction()), Hand: func(m *ice.Message, arg ...string) { if len(arg) == 0 { mdb.HashSelect(m, arg...).Sort(mdb.NAME).RenameAppend(mdb.NAME, REPOS) } else { m.Cmdy(nfs.DIR, kit.Select("", arg, 1), "time,line,path", kit.Dict(nfs.DIR_ROOT, _repos_path(arg[0]))) } }}, }) }