Separate leafs and HEAD

This commit is contained in:
Quentin 2021-04-22 11:20:52 +02:00
parent 9fd13f759a
commit 68795d1f38
Signed by: quentin
GPG key ID: A98E9B769E4FF428

View file

@ -16,8 +16,9 @@ type RepoCommits struct {
Config configCollect Config configCollect
CommitDesc map[string]string CommitDesc map[string]string
CommitContent map[string]*CommitNode CommitContent map[string]*CommitNode
Head *CommitNode
Root *CommitNode Root *CommitNode
Leafs map[*CommitNode]Empty
Head *CommitNode
} }
type CommitNode struct { type CommitNode struct {
@ -58,12 +59,15 @@ func cmdCommit(config configCollect) {
rc := NewRepoCommits(config) rc := NewRepoCommits(config)
rc.CollectDescs() rc.CollectDescs()
rc.PrintDescs() log.Println("Repo contains", len(rc.CommitDesc), "commits")
rc.CollectContent() rc.CollectContent()
rc.BuildGraph() rc.BuildGraph()
rc.FindHead() rc.FindLeafs()
rc.PrintHead() log.Println("Repo has", len(rc.Leafs), "leafs")
rc.ChooseHead()
log.Println("Proposing following HEAD:\n"+rc.Head.Content.String())
} }
func NewRepoCommits (config configCollect) *RepoCommits { func NewRepoCommits (config configCollect) *RepoCommits {
@ -71,6 +75,7 @@ func NewRepoCommits (config configCollect) *RepoCommits {
rc.Config = config rc.Config = config
rc.CommitDesc = make(map[string]string) rc.CommitDesc = make(map[string]string)
rc.CommitContent = make(map[string]*CommitNode) rc.CommitContent = make(map[string]*CommitNode)
rc.Leafs = make(map[*CommitNode]Empty)
return rc return rc
} }
@ -90,19 +95,6 @@ func (rc* RepoCommits) CollectDescs() {
} }
} }
func (rc* RepoCommits) PrintDescs() {
/*limit := 10
for id, path := range rc.CommitDesc {
log.Println(id, path)
limit = limit - 1
if limit < 0 {
log.Println("Too many commits, output has been truncated")
break
}
}*/
log.Println("Repo", rc.Config.RepoId, "contains", len(rc.CommitDesc), "commits")
}
func NewCommitNode(c Commit) *CommitNode { func NewCommitNode(c Commit) *CommitNode {
cn := new(CommitNode) cn := new(CommitNode)
cn.Content = c cn.Content = c
@ -153,7 +145,7 @@ func (rc* RepoCommits) BuildGraph() *CommitNode {
return rc.Root return rc.Root
} }
func (rc* RepoCommits) FindHead() *CommitNode { func (rc* RepoCommits) FindLeafs() map[*CommitNode]Empty {
toProcess := make(map[*CommitNode]Empty) toProcess := make(map[*CommitNode]Empty)
toProcess[rc.Root] = empty toProcess[rc.Root] = empty
@ -164,21 +156,25 @@ func (rc* RepoCommits) FindHead() *CommitNode {
nextToProcess[ccn] = empty nextToProcess[ccn] = empty
} }
if len(cn.Children) == 0 { if len(cn.Children) == 0 {
if rc.Head == nil { rc.Leafs[cn] = empty
rc.Head = cn
} else {
log.Fatal("More than one HEAD has been found")
}
} }
} }
toProcess = nextToProcess toProcess = nextToProcess
} }
if len(rc.Leafs) == 0 { log.Fatal("No leafs have been found") }
return rc.Leafs
}
func (rc* RepoCommits) ChooseHead() *CommitNode {
for cn, _ := range rc.Leafs {
if rc.Head == nil {
rc.Head = cn
} else if rc.Head.Content.Ctime < cn.Content.Ctime {
rc.Head = cn
}
}
if rc.Head == nil { log.Fatal("No HEAD has been found") } if rc.Head == nil { log.Fatal("No HEAD has been found") }
return rc.Head return rc.Head
} }
func (rc* RepoCommits) PrintHead() {
log.Println(rc.Head.Content.String())
}