Skip to content
This repository has been archived by the owner on Nov 12, 2024. It is now read-only.

feat: add support for milestones #23

Draft
wants to merge 1 commit into
base: main
Choose a base branch
from
Draft
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 21 additions & 11 deletions gen-graph/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,16 +35,21 @@ type task struct {
func main() {
file, err := ioutil.ReadFile("output/roadmap.json")
checkErr(err)
var tasks []task
err = json.Unmarshal(file, &tasks)
var entries []task
err = json.Unmarshal(file, &entries)
checkErr(err)

roadmap := make(map[string]task)
for _, t := range tasks {
if t.Kind != 1 {
continue
var (
tasks = make(map[string]task)
milestones = make(map[string]task)
)
for _, t := range entries {
switch {
case t.Kind == 1: // issues
tasks[t.ID] = t
case t.Kind == 3: // milestones
milestones[t.ID] = t
}
roadmap[t.ID] = t
}

g := graphviz.New()
Expand All @@ -59,7 +64,12 @@ func main() {

nodes := make(map[string]*cgraph.Node)

for _, task := range roadmap {
for _, milestone := range milestones {
// TODO: group issues by milestone
_ = milestone
}

for _, task := range tasks {
node, err := graph.CreateNode(task.ID)
checkErr(err)
if task.ID == "https://github.com/gnolang/roadmap/issues/1" {
Expand All @@ -86,17 +96,17 @@ func main() {
nodes[task.ID] = node
}

for _, task := range roadmap {
for _, task := range tasks {
for _, dependentID := range task.IsBlocking {
dependent := roadmap[dependentID]
dependent := tasks[dependentID]
name := task.ID + dependent.ID
edge, err := graph.CreateEdge(name, nodes[task.ID], nodes[dependent.ID])
checkErr(err)
_ = edge
// edge.SetLabel("blocking")
}
for _, dependingID := range task.IsDependingOn {
depending := roadmap[dependingID]
depending := tasks[dependingID]
name := depending.ID + task.ID
edge, err := graph.CreateEdge(name, nodes[depending.ID], nodes[task.ID])
checkErr(err)
Expand Down