From 6780a23dd76e7bf3e7246a29cba4c8d872d4de54 Mon Sep 17 00:00:00 2001 From: k1LoW Date: Sat, 3 Oct 2020 11:40:22 +0900 Subject: [PATCH 1/7] git gsub network-tag tag --- cmd/doc.go | 8 ++++---- config/config.go | 2 +- output/md/md.go | 2 +- output/md/templates/diagram.md.tmpl | 2 +- output/md/templates/index.md.tmpl | 2 +- output/md/templates/node.md.tmpl | 2 +- output/md/templates/{network-tag.md.tmpl => tag.md.tmpl} | 4 ++-- 7 files changed, 11 insertions(+), 11 deletions(-) rename output/md/templates/{network-tag.md.tmpl => tag.md.tmpl} (71%) diff --git a/cmd/doc.go b/cmd/doc.go index ef8f8220..b4a3495b 100644 --- a/cmd/doc.go +++ b/cmd/doc.go @@ -184,7 +184,7 @@ var docCmd = &cobra.Command{ o := md.New(cfg) // generate md - mPath := filepath.Join(cfg.DocPath, config.MdPath("network-tag", []string{nw.Id()})) + mPath := filepath.Join(cfg.DocPath, config.MdPath("tag", []string{nw.Id()})) file, err := os.Create(mPath) if err != nil { printFatalln(cmd, err) @@ -195,7 +195,7 @@ var docCmd = &cobra.Command{ // draw diagram diag := gviz.New(cfg) - dPath := filepath.Join(cfg.DocPath, config.ImagePath("network-tag", []string{nw.Id()}, format)) + dPath := filepath.Join(cfg.DocPath, config.ImagePath("tag", []string{nw.Id()}, format)) dFile, err := os.OpenFile(dPath, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0644) // #nosec if err != nil { printFatalln(cmd, err) @@ -258,11 +258,11 @@ func diagExists(cfg *config.Config) error { // tags for _, nw := range cfg.Tags() { - mPath := filepath.Join(cfg.DocPath, config.ImagePath("network-tag", []string{nw.Id()}, format)) + mPath := filepath.Join(cfg.DocPath, config.ImagePath("tag", []string{nw.Id()}, format)) if _, err := os.Lstat(mPath); err == nil { return fmt.Errorf("%s already exist", mPath) } - dPath := filepath.Join(cfg.DocPath, config.MdPath("network-tag", []string{nw.Id()})) + dPath := filepath.Join(cfg.DocPath, config.MdPath("tag", []string{nw.Id()})) if _, err := os.Lstat(dPath); err == nil { return fmt.Errorf("%s already exist", dPath) } diff --git a/config/config.go b/config/config.go index 95ebf8b5..62df9b34 100644 --- a/config/config.go +++ b/config/config.go @@ -545,7 +545,7 @@ func (cfg *Config) buildDescriptions() error { if t.Desc != "" { continue } - desc, err := cfg.readDescFile(MdPath("_network-tag", []string{t.Id()})) + desc, err := cfg.readDescFile(MdPath("_tag", []string{t.Id()})) if err != nil { return err } diff --git a/output/md/md.go b/output/md/md.go index 5ec91641..d2a37eff 100644 --- a/output/md/md.go +++ b/output/md/md.go @@ -132,7 +132,7 @@ func (m *Md) OutputNode(wr io.Writer, n *config.Node) error { } func (m *Md) OutputTag(wr io.Writer, t *config.Tag) error { - ts, err := m.box.FindString("network-tag.md.tmpl") + ts, err := m.box.FindString("tag.md.tmpl") if err != nil { return err } diff --git a/output/md/templates/diagram.md.tmpl b/output/md/templates/diagram.md.tmpl index b3c4acae..44a55be8 100644 --- a/output/md/templates/diagram.md.tmpl +++ b/output/md/templates/diagram.md.tmpl @@ -28,7 +28,7 @@ | Name | Description | | --- | --- | {{- range $i, $t := .Tags }} -| [{{ $t | fullname }}]({{ mdpath "network-tag" ($t | id) }}) | {{ if ne $t.Desc "" }}{{ $t.Desc | summary }}{{ else }}:pencil2:{{ end }} | +| [{{ $t | fullname }}]({{ mdpath "tag" ($t | id) }}) | {{ if ne $t.Desc "" }}{{ $t.Desc | summary }}{{ else }}:pencil2:{{ end }} | {{- end }} --- diff --git a/output/md/templates/index.md.tmpl b/output/md/templates/index.md.tmpl index 5712048a..28e858e7 100644 --- a/output/md/templates/index.md.tmpl +++ b/output/md/templates/index.md.tmpl @@ -33,7 +33,7 @@ | Name | Description | | --- | --- | {{- range $i, $t := .Tags }} -| [{{ $t | fullname }}]({{ mdpath "network-tag" ($t | id) }}) | {{ if ne $t.Desc "" }}{{ $t.Desc | summary }}{{ else }}:pencil2:{{ end }} | +| [{{ $t | fullname }}]({{ mdpath "tag" ($t | id) }}) | {{ if ne $t.Desc "" }}{{ $t.Desc | summary }}{{ else }}:pencil2:{{ end }} | {{- end }} --- diff --git a/output/md/templates/node.md.tmpl b/output/md/templates/node.md.tmpl index fb176ceb..d67c33e0 100644 --- a/output/md/templates/node.md.tmpl +++ b/output/md/templates/node.md.tmpl @@ -20,7 +20,7 @@ | Name | Description | | --- | --- | {{- range $i, $t := .Tags }} -| [{{ $t | fullname }}]({{ mdpath "network-tag" ($t | id) }}) | {{ if ne $t.Desc "" }}{{ $t.Desc | summary }}{{ else }}:pencil2:{{ end }} | +| [{{ $t | fullname }}]({{ mdpath "tag" ($t | id) }}) | {{ if ne $t.Desc "" }}{{ $t.Desc | summary }}{{ else }}:pencil2:{{ end }} | {{- end }} ## Real nodes {{ range $i, $rn := .RealNodes }} diff --git a/output/md/templates/network-tag.md.tmpl b/output/md/templates/tag.md.tmpl similarity index 71% rename from output/md/templates/network-tag.md.tmpl rename to output/md/templates/tag.md.tmpl index 920bef99..52144312 100644 --- a/output/md/templates/network-tag.md.tmpl +++ b/output/md/templates/tag.md.tmpl @@ -1,11 +1,11 @@ # {{ .Tag | fullname }} -![diagram]({{ imgpath "network-tag" (.Tag | id) .DiagFormat }}) +![diagram]({{ imgpath "tag" (.Tag | id) .DiagFormat }}) {{ .Tag.Desc }}

- [ :pencil2: Edit description ] + [ :pencil2: Edit description ]

## Route From 601c2861ef37767fa9cf0ee1eb10156beeaf6223 Mon Sep 17 00:00:00 2001 From: k1LoW Date: Sat, 3 Oct 2020 11:57:35 +0900 Subject: [PATCH 2/7] Rename network to relation --- cmd/doc.go | 16 ++--- config/config.go | 70 +++++++++---------- config/config_test.go | 6 +- config/{network.go => relation.go} | 34 ++++----- config/yaml.go | 38 +++++----- output/dot/dot.go | 10 +-- output/gviz/gviz.go | 4 +- output/md/md.go | 42 +++++------ output/md/templates/diagram.md.tmpl | 2 +- output/md/templates/index.md.tmpl | 2 +- output/md/templates/node.md.tmpl | 4 +- .../{network.md.tmpl => relation.md.tmpl} | 10 +-- output/md/templates/tag.md.tmpl | 4 +- output/output.go | 8 +-- 14 files changed, 125 insertions(+), 125 deletions(-) rename config/{network.go => relation.go} (75%) rename output/md/templates/{network.md.tmpl => relation.md.tmpl} (54%) diff --git a/cmd/doc.go b/cmd/doc.go index b4a3495b..96a30598 100644 --- a/cmd/doc.go +++ b/cmd/doc.go @@ -176,7 +176,7 @@ var docCmd = &cobra.Command{ } // tags - for _, nw := range cfg.Tags() { + for _, rel := range cfg.Tags() { cfg, err := newConfig() if err != nil { printFatalln(cmd, err) @@ -184,23 +184,23 @@ var docCmd = &cobra.Command{ o := md.New(cfg) // generate md - mPath := filepath.Join(cfg.DocPath, config.MdPath("tag", []string{nw.Id()})) + mPath := filepath.Join(cfg.DocPath, config.MdPath("tag", []string{rel.Id()})) file, err := os.Create(mPath) if err != nil { printFatalln(cmd, err) } - if err := o.OutputTag(file, nw); err != nil { + if err := o.OutputTag(file, rel); err != nil { printFatalln(cmd, err) } // draw diagram diag := gviz.New(cfg) - dPath := filepath.Join(cfg.DocPath, config.ImagePath("tag", []string{nw.Id()}, format)) + dPath := filepath.Join(cfg.DocPath, config.ImagePath("tag", []string{rel.Id()}, format)) dFile, err := os.OpenFile(dPath, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0644) // #nosec if err != nil { printFatalln(cmd, err) } - if err := diag.OutputTag(dFile, nw); err != nil { + if err := diag.OutputTag(dFile, rel); err != nil { printFatalln(cmd, err) } } @@ -257,12 +257,12 @@ func diagExists(cfg *config.Config) error { } // tags - for _, nw := range cfg.Tags() { - mPath := filepath.Join(cfg.DocPath, config.ImagePath("tag", []string{nw.Id()}, format)) + for _, rel := range cfg.Tags() { + mPath := filepath.Join(cfg.DocPath, config.ImagePath("tag", []string{rel.Id()}, format)) if _, err := os.Lstat(mPath); err == nil { return fmt.Errorf("%s already exist", mPath) } - dPath := filepath.Join(cfg.DocPath, config.MdPath("tag", []string{nw.Id()})) + dPath := filepath.Join(cfg.DocPath, config.MdPath("tag", []string{rel.Id()})) if _, err := os.Lstat(dPath); err == nil { return fmt.Errorf("%s already exist", dPath) } diff --git a/config/config.go b/config/config.go index 62df9b34..89027b17 100644 --- a/config/config.go +++ b/config/config.go @@ -37,11 +37,11 @@ type Attr struct { } type NEdge struct { - Src *Component - Dst *Component - Desc string - Network *Network - Attrs []*Attr + Src *Component + Dst *Component + Desc string + Relation *Relation + Attrs []*Attr } type Layer struct { @@ -50,14 +50,14 @@ type Layer struct { } type Config struct { - Name string `yaml:"name"` - Desc string `yaml:"desc,omitempty"` - DocPath string `yaml:"docPath"` - DescPath string `yaml:"descPath"` - Diagrams []*Diagram `yaml:"diagrams"` - Nodes []*Node `yaml:"nodes"` - Networks []*Network `yaml:"networks"` - rawNetworks []*rawNetwork + Name string `yaml:"name"` + Desc string `yaml:"desc,omitempty"` + DocPath string `yaml:"docPath"` + DescPath string `yaml:"descPath"` + Diagrams []*Diagram `yaml:"diagrams"` + Nodes []*Node `yaml:"nodes"` + Relations []*Relation `yaml:"relations"` + rawRelations []*rawRelation realNodes []*RealNode layers []*Layer clusters Clusters @@ -175,7 +175,7 @@ func (cfg *Config) Build() error { if err := cfg.buildComponents(); err != nil { return err } - if err := cfg.buildNetworks(); err != nil { + if err := cfg.buildRelations(); err != nil { return err } if err := cfg.checkUnique(); err != nil { @@ -293,8 +293,8 @@ func (cfg *Config) buildComponents() error { gc := orderedmap.NewOrderedMap() nc := orderedmap.NewOrderedMap() cc := orderedmap.NewOrderedMap() - for _, nw := range cfg.rawNetworks { - for _, r := range nw.Route { + for _, rel := range cfg.rawRelations { + for _, r := range rel.Route { switch sepCount(r) { case 2: // cluster components cc.Set(r, struct{}{}) @@ -308,7 +308,7 @@ func (cfg *Config) buildComponents() error { // global components for _, c := range gc.Keys() { - // create global component from network route + // create global component from relations cfg.globalComponents = append(cfg.globalComponents, &Component{ Name: c.(string), }) @@ -335,7 +335,7 @@ func (cfg *Config) buildComponents() error { } } if !belongTo { - // create node component from network route + // create node component from relations component := &Component{ Name: comName, Node: n, @@ -353,7 +353,7 @@ func (cfg *Config) buildComponents() error { belongTo := false for _, cl := range cfg.Clusters() { if strings.EqualFold(cl.FullName(), clName) { - // create cluster component from network route + // create cluster component from relations com := &Component{ Cluster: cl, Name: comName, @@ -410,41 +410,41 @@ func (cfg *Config) parseClusterLabel(label string) (*Cluster, error) { return newC, nil } -func (cfg *Config) buildNetworks() error { - nwTags := orderedmap.NewOrderedMap() - for _, nw := range cfg.rawNetworks { - nnw := &Network{ - NetworkId: nw.Id, - Tags: nw.Tags, +func (cfg *Config) buildRelations() error { + relTags := orderedmap.NewOrderedMap() + for _, rel := range cfg.rawRelations { + nrel := &Relation{ + RelationId: rel.Id, + Tags: rel.Tags, } - for _, r := range nw.Route { + for _, r := range rel.Route { c, err := cfg.FindComponent(r) if err != nil { return err } - nnw.Route = append(nnw.Route, c) + nrel.Route = append(nrel.Route, c) } - cfg.Networks = append(cfg.Networks, nnw) + cfg.Relations = append(cfg.Relations, nrel) // tags - for _, t := range nw.Tags { + for _, t := range rel.Tags { var nt *Tag - nti, ok := nwTags.Get(t) + nti, ok := relTags.Get(t) if ok { nt = nti.(*Tag) } else { nt = &Tag{ Name: t, } - nwTags.Set(t, nt) + relTags.Set(t, nt) } - nt.Networks = append(nt.Networks, nnw) + nt.Relations = append(nt.Relations, nrel) } } - cfg.nEdges = SplitNetworks(cfg.Networks) + cfg.nEdges = SplitRelations(cfg.Relations) - for _, k := range nwTags.Keys() { - nt, _ := nwTags.Get(k) + for _, k := range relTags.Keys() { + nt, _ := relTags.Get(k) cfg.tags = append(cfg.tags, nt.(*Tag)) } diff --git a/config/config_test.go b/config/config_test.go index d5cccb01..7c446b65 100644 --- a/config/config_test.go +++ b/config/config_test.go @@ -89,7 +89,7 @@ func TestBuildNestedCluster(t *testing.T) { cGlobalComponentLen := len(d.GlobalComponents()) cClusterComponentLen := len(d.ClusterComponents()) cNodeComponentLen := len(d.NodeComponents()) - cNetworkLen := len(d.Networks) + cRelationLen := len(d.Relations) gotClusters, gotNodes, gotNEdges, err := d.BuildNestedClusters(tt.layers) if err != nil { @@ -126,8 +126,8 @@ func TestBuildNestedCluster(t *testing.T) { if got := len(d.NodeComponents()); got != cNodeComponentLen { t.Errorf("TestBuildNestedCluster(%d) got %v want %v", i, got, cNodeComponentLen) } - if got := len(d.Networks); got != cNetworkLen { - t.Errorf("TestBuildNestedCluster(%d) got %v want %v", i, got, cNetworkLen) + if got := len(d.Relations); got != cRelationLen { + t.Errorf("TestBuildNestedCluster(%d) got %v want %v", i, got, cRelationLen) } } } diff --git a/config/network.go b/config/relation.go similarity index 75% rename from config/network.go rename to config/relation.go index 724cf70e..6b4eb6b2 100644 --- a/config/network.go +++ b/config/relation.go @@ -7,30 +7,30 @@ import ( "github.com/elliotchance/orderedmap" ) -type Network struct { - NetworkId string - Route []*Component - Tags []string +type Relation struct { + RelationId string + Route []*Component + Tags []string } -func (n *Network) FullName() string { - return fmt.Sprintf(n.NetworkId) +func (n *Relation) FullName() string { + return fmt.Sprintf(n.RelationId) } -func (n *Network) Id() string { +func (n *Relation) Id() string { return strings.ToLower(n.FullName()) } -type rawNetwork struct { +type rawRelation struct { Id string Route []string Tags []string } type Tag struct { - Name string - Desc string - Networks []*Network + Name string + Desc string + Relations []*Relation } func (t *Tag) FullName() string { @@ -41,17 +41,17 @@ func (t *Tag) Id() string { return strings.ToLower(t.FullName()) } -func SplitNetworks(networks []*Network) []*NEdge { +func SplitRelations(relations []*Relation) []*NEdge { var prev *Component edges := []*NEdge{} - for _, nw := range networks { + for _, rel := range relations { prev = nil - for _, r := range nw.Route { + for _, r := range rel.Route { if prev != nil { edge := &NEdge{ - Src: prev, - Dst: r, - Network: nw, + Src: prev, + Dst: r, + Relation: rel, } prev.NEdges = append(prev.NEdges, edge) r.NEdges = append(r.NEdges, edge) diff --git a/config/yaml.go b/config/yaml.go index c801b9b2..f56e522a 100644 --- a/config/yaml.go +++ b/config/yaml.go @@ -12,12 +12,12 @@ import ( func (d *Config) UnmarshalYAML(data []byte) error { raw := struct { - Name string `yaml:"name"` - Desc string `yaml:"desc,omitempty"` - DocPath string `yaml:"docPath"` - Diagrams []*Diagram `yaml:"diagrams"` - Nodes []*Node `yaml:"nodes"` - Networks []interface{} `yaml:"networks"` + Name string `yaml:"name"` + Desc string `yaml:"desc,omitempty"` + DocPath string `yaml:"docPath"` + Diagrams []*Diagram `yaml:"diagrams"` + Nodes []*Node `yaml:"nodes"` + Relations []interface{} `yaml:"relations"` }{} if err := yaml.Unmarshal(data, &raw); err != nil { @@ -29,28 +29,28 @@ func (d *Config) UnmarshalYAML(data []byte) error { d.Diagrams = raw.Diagrams d.Nodes = raw.Nodes - for _, nw := range raw.Networks { + for _, rel := range raw.Relations { route := []string{} tags := []string{} - switch v := nw.(type) { + switch v := rel.(type) { case []interface{}: for _, r := range v { route = append(route, r.(string)) } if len(route) < 2 { - return fmt.Errorf("invalid network format: %s", v) + return fmt.Errorf("invalid relation format: %s", v) } - id, err := genNetworkId(route) + id, err := genRelationId(route) if err != nil { return err } tags = []string{id} - rnw := &rawNetwork{ + rrel := &rawRelation{ Id: id, Route: route, Tags: tags, } - d.rawNetworks = append(d.rawNetworks, rnw) + d.rawRelations = append(d.rawRelations, rrel) case map[string]interface{}: var ( id string @@ -60,20 +60,20 @@ func (d *Config) UnmarshalYAML(data []byte) error { if ok { id = idi.(string) } else { - id, err = genNetworkId(route) + id, err = genRelationId(route) if err != nil { return err } } ri, ok := v["route"] if !ok { - return fmt.Errorf("invalid network format: %s", v) + return fmt.Errorf("invalid relation format: %s", v) } for _, r := range ri.([]interface{}) { route = append(route, r.(string)) } if len(route) < 2 { - return fmt.Errorf("invalid network format: %s", v) + return fmt.Errorf("invalid relation format: %s", v) } ti, ok := v["tags"] if ok { @@ -84,12 +84,12 @@ func (d *Config) UnmarshalYAML(data []byte) error { if len(tags) == 0 { tags = []string{id} } - rnw := &rawNetwork{ + rrel := &rawRelation{ Id: id, Route: route, Tags: tags, } - d.rawNetworks = append(d.rawNetworks, rnw) + d.rawRelations = append(d.rawRelations, rrel) } } return nil @@ -124,11 +124,11 @@ func (n *Node) UnmarshalYAML(data []byte) error { return nil } -func genNetworkId(route []string) (string, error) { +func genRelationId(route []string) (string, error) { h := sha256.New() if _, err := io.WriteString(h, fmt.Sprintf("%s", route)); err != nil { return "", err } s := fmt.Sprintf("%x", h.Sum(nil)) - return fmt.Sprintf("nw-%s", s[:12]), nil + return fmt.Sprintf("rel-%s", s[:12]), nil } diff --git a/output/dot/dot.go b/output/dot/dot.go index 329c8c14..8f049070 100644 --- a/output/dot/dot.go +++ b/output/dot/dot.go @@ -62,7 +62,7 @@ func (d *Dot) OutputLayer(wr io.Writer, l *config.Layer) error { L: for _, e := range nEdges { for _, n := range remain { - // remove nw with global nodes + // remove rel with global nodes if strings.HasPrefix(e.Src.Id(), fmt.Sprintf("%s:", n.Id())) { continue L } @@ -70,7 +70,7 @@ L: continue L } } - // remove nw with global components + // remove rel with global components if (e.Src.Node == nil && e.Src.Cluster == nil) || (e.Dst.Node == nil && e.Dst.Cluster == nil) { continue L } @@ -167,7 +167,7 @@ func (d *Dot) OutputTag(wr io.Writer, t *config.Tag) error { nIds := orderedmap.NewOrderedMap() globalComponents := []*config.Component{} gIds := orderedmap.NewOrderedMap() - edges := config.SplitNetworks(t.Networks) + edges := config.SplitRelations(t.Relations) for _, e := range edges { switch { @@ -214,7 +214,7 @@ func (d *Dot) OutputTag(wr io.Writer, t *config.Tag) error { return nil } -func (d *Dot) OutputNetwork(wr io.Writer, nw *config.Network) error { +func (d *Dot) OutputRelation(wr io.Writer, rel *config.Relation) error { ts, err := d.box.FindString("diagram.dot.tmpl") if err != nil { return err @@ -230,7 +230,7 @@ func (d *Dot) OutputNetwork(wr io.Writer, nw *config.Network) error { edges := []*config.NEdge{} for _, e := range d.config.NEdges() { - if e.Network.Id() != nw.Id() { + if e.Relation.Id() != rel.Id() { continue } switch { diff --git a/output/gviz/gviz.go b/output/gviz/gviz.go index 4713b992..7d9d7251 100644 --- a/output/gviz/gviz.go +++ b/output/gviz/gviz.go @@ -53,9 +53,9 @@ func (g *Gviz) OutputTag(wr io.Writer, t *config.Tag) error { return g.render(wr, buf.Bytes()) } -func (g *Gviz) OutputNetwork(wr io.Writer, nw *config.Network) error { +func (g *Gviz) OutputRelation(wr io.Writer, rel *config.Relation) error { buf := &bytes.Buffer{} - if err := g.dot.OutputNetwork(buf, nw); err != nil { + if err := g.dot.OutputRelation(buf, rel); err != nil { return err } return g.render(wr, buf.Bytes()) diff --git a/output/md/md.go b/output/md/md.go index d2a37eff..b19610b9 100644 --- a/output/md/md.go +++ b/output/md/md.go @@ -29,7 +29,7 @@ func (m *Md) OutputDiagram(wr io.Writer, d *config.Diagram) error { return err } - rel, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) + relPath, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) if err != nil { return err } @@ -47,7 +47,7 @@ func (m *Md) OutputDiagram(wr io.Writer, d *config.Diagram) error { tmplData := map[string]interface{}{ "Diagram": d, "DiagFormat": m.config.DiagFormat(), - "DescPath": rel, + "DescPath": relPath, "Layers": layers, "Nodes": m.config.Nodes, "Tags": m.config.Tags(), @@ -64,7 +64,7 @@ func (m *Md) OutputLayer(wr io.Writer, l *config.Layer) error { return err } - rel, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) + relPath, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) if err != nil { return err } @@ -78,7 +78,7 @@ func (m *Md) OutputLayer(wr io.Writer, l *config.Layer) error { tmplData := map[string]interface{}{ "Layer": l, "DiagFormat": m.config.DiagFormat(), - "DescPath": rel, + "DescPath": relPath, "Clusters": clusters, } if err := tmpl.Execute(wr, tmplData); err != nil { @@ -93,26 +93,26 @@ func (m *Md) OutputNode(wr io.Writer, n *config.Node) error { return err } - rel, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) + relPath, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) if err != nil { return err } tags := []*config.Tag{} - nwTags := orderedmap.NewOrderedMap() + relTags := orderedmap.NewOrderedMap() for _, c := range n.Components { for _, e := range c.NEdges { - for _, ts := range e.Network.Tags { + for _, ts := range e.Relation.Tags { for _, t := range m.config.Tags() { if ts == t.Name { - nwTags.Set(ts, t) + relTags.Set(ts, t) } } } } } - for _, k := range nwTags.Keys() { - t, _ := nwTags.Get(k) + for _, k := range relTags.Keys() { + t, _ := relTags.Get(k) tags = append(tags, t.(*config.Tag)) } @@ -120,7 +120,7 @@ func (m *Md) OutputNode(wr io.Writer, n *config.Node) error { tmplData := map[string]interface{}{ "Node": n, "DiagFormat": m.config.DiagFormat(), - "DescPath": rel, + "DescPath": relPath, "Components": n.Components, "RealNodes": n.RealNodes, "Tags": tags, @@ -137,7 +137,7 @@ func (m *Md) OutputTag(wr io.Writer, t *config.Tag) error { return err } - rel, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) + relPath, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) if err != nil { return err } @@ -146,7 +146,7 @@ func (m *Md) OutputTag(wr io.Writer, t *config.Tag) error { tmplData := map[string]interface{}{ "Tag": t, "DiagFormat": m.config.DiagFormat(), - "DescPath": rel, + "DescPath": relPath, } if err := tmpl.Execute(wr, tmplData); err != nil { @@ -156,22 +156,22 @@ func (m *Md) OutputTag(wr io.Writer, t *config.Tag) error { return nil } -func (m *Md) OutputNetwork(wr io.Writer, nw *config.Network) error { - ts, err := m.box.FindString("network.md.tmpl") +func (m *Md) OutputRelation(wr io.Writer, rel *config.Relation) error { + ts, err := m.box.FindString("relation.md.tmpl") if err != nil { return err } - rel, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) + relPath, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) if err != nil { return err } - tmpl := template.Must(template.New(nw.Id()).Funcs(output.FuncMap).Parse(ts)) + tmpl := template.Must(template.New(rel.Id()).Funcs(output.FuncMap).Parse(ts)) tmplData := map[string]interface{}{ - "Network": nw, + "Relation": rel, "DiagFormat": m.config.DiagFormat(), - "DescPath": rel, + "DescPath": relPath, } if err := tmpl.Execute(wr, tmplData); err != nil { @@ -187,7 +187,7 @@ func (m *Md) OutputIndex(wr io.Writer) error { return err } - rel, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) + relPath, err := filepath.Rel(filepath.Join("root", m.config.DocPath), filepath.Join("root", m.config.DescPath)) if err != nil { return err } @@ -197,7 +197,7 @@ func (m *Md) OutputIndex(wr io.Writer) error { "Config": m.config, "Diagram": m.config.PrimaryDiagram(), "DiagFormat": m.config.DiagFormat(), - "DescPath": rel, + "DescPath": relPath, "Diagrams": m.config.Diagrams, "Layers": m.config.Layers(), "Nodes": m.config.Nodes, diff --git a/output/md/templates/diagram.md.tmpl b/output/md/templates/diagram.md.tmpl index 44a55be8..a5aa77bf 100644 --- a/output/md/templates/diagram.md.tmpl +++ b/output/md/templates/diagram.md.tmpl @@ -23,7 +23,7 @@ {{- range $i, $n := .Nodes }} | [{{ $n | fullname }}]({{ mdpath "node" ($n | id) }}) ({{ len $n.RealNodes }}) | {{ if ne $n.Desc "" }}{{ $n.Desc | summary }}{{ else }}:pencil2:{{ end }} | {{- end }} -## Network tag groups +## Tag groups | Name | Description | | --- | --- | diff --git a/output/md/templates/index.md.tmpl b/output/md/templates/index.md.tmpl index 28e858e7..d4906e94 100644 --- a/output/md/templates/index.md.tmpl +++ b/output/md/templates/index.md.tmpl @@ -28,7 +28,7 @@ | [{{ $n | fullname }}]({{ mdpath "node" ($n | id) }}) ({{ len $n.RealNodes }}) | {{ if ne $n.Desc "" }}{{ $n.Desc | summary }}{{ else }}:pencil2:{{ end }} | {{- end }} -## Network tag groups +## Tag groups | Name | Description | | --- | --- | diff --git a/output/md/templates/node.md.tmpl b/output/md/templates/node.md.tmpl index d67c33e0..d2507a45 100644 --- a/output/md/templates/node.md.tmpl +++ b/output/md/templates/node.md.tmpl @@ -10,12 +10,12 @@ ## Components -| Name | Description | From (Network) | To (Network) | +| Name | Description | From (Relation) | To (Relation) | | --- | --- | --- | --- | {{- range $i, $c := .Components }} | {{ $c | id }} | {{ $c.Desc | trim | nl2br }} :pencil2: | {{ fromlinks $c.NEdges $c }} | {{ tolinks $c.NEdges $c }} | {{- end }} -## Network tag groups +## Tag groups | Name | Description | | --- | --- | diff --git a/output/md/templates/network.md.tmpl b/output/md/templates/relation.md.tmpl similarity index 54% rename from output/md/templates/network.md.tmpl rename to output/md/templates/relation.md.tmpl index 9c28c7f8..f7949f74 100644 --- a/output/md/templates/network.md.tmpl +++ b/output/md/templates/relation.md.tmpl @@ -1,18 +1,18 @@ -# {{ .Network | fullname }} +# {{ .Relation | fullname }} -![diagram]({{ imgpath "network" (.Network | id) .DiagFormat }}) +![diagram]({{ imgpath "relation" (.Relation | id) .DiagFormat }}) -{{ .Network.Desc }} +{{ .Relation.Desc }}

- [ :pencil2: Edit description ] + [ :pencil2: Edit description ]

## Route | # | Component | Component Description | | --- | --- | --- | -{{- range $i, $c := .Network.Route }} +{{- range $i, $c := .Relation.Route }} | {{ $i }} | {{ $c | id }} | {{ $c.Desc | trim | nl2br }} :pencil2: | {{- end }} diff --git a/output/md/templates/tag.md.tmpl b/output/md/templates/tag.md.tmpl index 52144312..2754ff3f 100644 --- a/output/md/templates/tag.md.tmpl +++ b/output/md/templates/tag.md.tmpl @@ -10,10 +10,10 @@ ## Route -{{- range $j, $nw := .Tag.Networks }} +{{- range $j, $rel := .Tag.Relations }} | # | Component | Component Description | | --- | --- | --- | -{{- range $i, $c := $nw.Route }} +{{- range $i, $c := $rel.Route }} | {{ $i }} | {{ $c | id }} | {{ $c.Desc | trim | nl2br }} :pencil2: | {{- end }} {{ end }} diff --git a/output/output.go b/output/output.go index 3133bdc4..696619c3 100644 --- a/output/output.go +++ b/output/output.go @@ -69,7 +69,7 @@ var FuncMap = template.FuncMap{ return config.MdPath(prefix, strs) }, "componentlink": componentLink, - "nwlink": nwLink, + "rellink": relLink, "fromlinks": func(edges []*config.NEdge, base *config.Component) string { links := []string{} for _, e := range edges { @@ -129,12 +129,12 @@ func componentLink(c *config.Component) string { } } -func nwLink(nw *config.Network) string { +func relLink(rel *config.Relation) string { cIds := []string{} - for _, r := range nw.Route { + for _, r := range rel.Route { cIds = append(cIds, r.FullName()) } - return fmt.Sprintf("[%s](%s)", strings.Join(cIds, " -> "), config.MdPath("network", []string{nw.Id()})) + return fmt.Sprintf("[%s](%s)", strings.Join(cIds, " -> "), config.MdPath("relation", []string{rel.Id()})) } func unique(in []string) []string { From bdeb0c44e3edc74f17d619da239251f013922ad8 Mon Sep 17 00:00:00 2001 From: k1LoW Date: Sat, 3 Oct 2020 12:13:58 +0900 Subject: [PATCH 3/7] Rename route to components --- config/config.go | 6 +++--- config/relation.go | 6 +++--- config/yaml.go | 24 ++++++++++++------------ output/md/templates/relation.md.tmpl | 4 ++-- output/md/templates/tag.md.tmpl | 4 ++-- output/output.go | 2 +- 6 files changed, 23 insertions(+), 23 deletions(-) diff --git a/config/config.go b/config/config.go index 89027b17..a8369195 100644 --- a/config/config.go +++ b/config/config.go @@ -294,7 +294,7 @@ func (cfg *Config) buildComponents() error { nc := orderedmap.NewOrderedMap() cc := orderedmap.NewOrderedMap() for _, rel := range cfg.rawRelations { - for _, r := range rel.Route { + for _, r := range rel.Components { switch sepCount(r) { case 2: // cluster components cc.Set(r, struct{}{}) @@ -417,12 +417,12 @@ func (cfg *Config) buildRelations() error { RelationId: rel.Id, Tags: rel.Tags, } - for _, r := range rel.Route { + for _, r := range rel.Components { c, err := cfg.FindComponent(r) if err != nil { return err } - nrel.Route = append(nrel.Route, c) + nrel.Components = append(nrel.Components, c) } cfg.Relations = append(cfg.Relations, nrel) diff --git a/config/relation.go b/config/relation.go index 6b4eb6b2..10236950 100644 --- a/config/relation.go +++ b/config/relation.go @@ -9,7 +9,7 @@ import ( type Relation struct { RelationId string - Route []*Component + Components []*Component Tags []string } @@ -23,7 +23,7 @@ func (n *Relation) Id() string { type rawRelation struct { Id string - Route []string + Components []string Tags []string } @@ -46,7 +46,7 @@ func SplitRelations(relations []*Relation) []*NEdge { edges := []*NEdge{} for _, rel := range relations { prev = nil - for _, r := range rel.Route { + for _, r := range rel.Components { if prev != nil { edge := &NEdge{ Src: prev, diff --git a/config/yaml.go b/config/yaml.go index f56e522a..9fd4d4de 100644 --- a/config/yaml.go +++ b/config/yaml.go @@ -30,24 +30,24 @@ func (d *Config) UnmarshalYAML(data []byte) error { d.Nodes = raw.Nodes for _, rel := range raw.Relations { - route := []string{} + components := []string{} tags := []string{} switch v := rel.(type) { case []interface{}: for _, r := range v { - route = append(route, r.(string)) + components = append(components, r.(string)) } - if len(route) < 2 { + if len(components) < 2 { return fmt.Errorf("invalid relation format: %s", v) } - id, err := genRelationId(route) + id, err := genRelationId(components) if err != nil { return err } tags = []string{id} rrel := &rawRelation{ Id: id, - Route: route, + Components: components, Tags: tags, } d.rawRelations = append(d.rawRelations, rrel) @@ -60,19 +60,19 @@ func (d *Config) UnmarshalYAML(data []byte) error { if ok { id = idi.(string) } else { - id, err = genRelationId(route) + id, err = genRelationId(components) if err != nil { return err } } - ri, ok := v["route"] + ri, ok := v["components"] if !ok { return fmt.Errorf("invalid relation format: %s", v) } for _, r := range ri.([]interface{}) { - route = append(route, r.(string)) + components = append(components, r.(string)) } - if len(route) < 2 { + if len(components) < 2 { return fmt.Errorf("invalid relation format: %s", v) } ti, ok := v["tags"] @@ -86,7 +86,7 @@ func (d *Config) UnmarshalYAML(data []byte) error { } rrel := &rawRelation{ Id: id, - Route: route, + Components: components, Tags: tags, } d.rawRelations = append(d.rawRelations, rrel) @@ -124,9 +124,9 @@ func (n *Node) UnmarshalYAML(data []byte) error { return nil } -func genRelationId(route []string) (string, error) { +func genRelationId(components []string) (string, error) { h := sha256.New() - if _, err := io.WriteString(h, fmt.Sprintf("%s", route)); err != nil { + if _, err := io.WriteString(h, fmt.Sprintf("%s", components)); err != nil { return "", err } s := fmt.Sprintf("%x", h.Sum(nil)) diff --git a/output/md/templates/relation.md.tmpl b/output/md/templates/relation.md.tmpl index f7949f74..838c6cac 100644 --- a/output/md/templates/relation.md.tmpl +++ b/output/md/templates/relation.md.tmpl @@ -8,11 +8,11 @@ [ :pencil2: Edit description ]

-## Route +## Components | # | Component | Component Description | | --- | --- | --- | -{{- range $i, $c := .Relation.Route }} +{{- range $i, $c := .Relation.Components }} | {{ $i }} | {{ $c | id }} | {{ $c.Desc | trim | nl2br }} :pencil2: | {{- end }} diff --git a/output/md/templates/tag.md.tmpl b/output/md/templates/tag.md.tmpl index 2754ff3f..4b9a3c25 100644 --- a/output/md/templates/tag.md.tmpl +++ b/output/md/templates/tag.md.tmpl @@ -8,12 +8,12 @@ [ :pencil2: Edit description ]

-## Route +## Components {{- range $j, $rel := .Tag.Relations }} | # | Component | Component Description | | --- | --- | --- | -{{- range $i, $c := $rel.Route }} +{{- range $i, $c := $rel.Components }} | {{ $i }} | {{ $c | id }} | {{ $c.Desc | trim | nl2br }} :pencil2: | {{- end }} {{ end }} diff --git a/output/output.go b/output/output.go index 696619c3..d9093a94 100644 --- a/output/output.go +++ b/output/output.go @@ -131,7 +131,7 @@ func componentLink(c *config.Component) string { func relLink(rel *config.Relation) string { cIds := []string{} - for _, r := range rel.Route { + for _, r := range rel.Components { cIds = append(cIds, r.FullName()) } return fmt.Sprintf("[%s](%s)", strings.Join(cIds, " -> "), config.MdPath("relation", []string{rel.Id()})) From cc614ba64d6b57853d6d21d7e51514f6a44a8b86 Mon Sep 17 00:00:00 2001 From: k1LoW Date: Sat, 3 Oct 2020 16:34:23 +0900 Subject: [PATCH 4/7] Add block delimiter --- output/output.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/output/output.go b/output/output.go index d9093a94..d68dc3c3 100644 --- a/output/output.go +++ b/output/output.go @@ -69,7 +69,7 @@ var FuncMap = template.FuncMap{ return config.MdPath(prefix, strs) }, "componentlink": componentLink, - "rellink": relLink, + "rellink": relLink, "fromlinks": func(edges []*config.NEdge, base *config.Component) string { links := []string{} for _, e := range edges { @@ -94,7 +94,7 @@ var FuncMap = template.FuncMap{ } var out string for _, a := range attrs { - out = fmt.Sprintf("%s, %s=%s", out, a.Key, a.Value) + out = fmt.Sprintf("%s, %s=\"%s\"", out, a.Key, a.Value) } return out }, From a876ad6a99226b8610b447c77c598af026773886 Mon Sep 17 00:00:00 2001 From: k1LoW Date: Sat, 3 Oct 2020 16:36:27 +0900 Subject: [PATCH 5/7] Support `networks:` --- config/config.go | 1 + config/relation.go | 39 ++++++- config/yaml.go | 158 ++++++++++++++++---------- output/dot/templates/diagram.dot.tmpl | 2 +- output/dot/templates/node.dot.tmpl | 2 +- 5 files changed, 137 insertions(+), 65 deletions(-) diff --git a/config/config.go b/config/config.go index a8369195..ad3ec70a 100644 --- a/config/config.go +++ b/config/config.go @@ -416,6 +416,7 @@ func (cfg *Config) buildRelations() error { nrel := &Relation{ RelationId: rel.Id, Tags: rel.Tags, + Attrs: rel.Attrs, } for _, r := range rel.Components { c, err := cfg.FindComponent(r) diff --git a/config/relation.go b/config/relation.go index 10236950..099eb906 100644 --- a/config/relation.go +++ b/config/relation.go @@ -7,10 +7,41 @@ import ( "github.com/elliotchance/orderedmap" ) +var defaultNetworkAttrs = []*Attr{ + &Attr{ + Key: "arrowhead", + Value: "normal", + }, + &Attr{ + Key: "arrowhead", + Value: "normal", + }, + &Attr{ + Key: "style", + Value: "bold", + }, +} + +var defaultRelationAttrs = []*Attr{ + &Attr{ + Key: "arrowhead", + Value: "dot", + }, + &Attr{ + Key: "arrowhead", + Value: "dot", + }, + &Attr{ + Key: "style", + Value: "dashed", + }, +} + type Relation struct { RelationId string - Components []*Component + Components []*Component Tags []string + Attrs []*Attr } func (n *Relation) FullName() string { @@ -22,9 +53,10 @@ func (n *Relation) Id() string { } type rawRelation struct { - Id string + Id string Components []string - Tags []string + Tags []string + Attrs []*Attr } type Tag struct { @@ -52,6 +84,7 @@ func SplitRelations(relations []*Relation) []*NEdge { Src: prev, Dst: r, Relation: rel, + Attrs: rel.Attrs, } prev.NEdges = append(prev.NEdges, edge) r.NEdges = append(r.NEdges, edge) diff --git a/config/yaml.go b/config/yaml.go index 9fd4d4de..76544fa7 100644 --- a/config/yaml.go +++ b/config/yaml.go @@ -5,6 +5,7 @@ import ( "fmt" "io" "regexp" + "sort" "strings" "github.com/goccy/go-yaml" @@ -17,6 +18,7 @@ func (d *Config) UnmarshalYAML(data []byte) error { DocPath string `yaml:"docPath"` Diagrams []*Diagram `yaml:"diagrams"` Nodes []*Node `yaml:"nodes"` + Networks []interface{} `yaml:"networks"` Relations []interface{} `yaml:"relations"` }{} @@ -29,68 +31,22 @@ func (d *Config) UnmarshalYAML(data []byte) error { d.Diagrams = raw.Diagrams d.Nodes = raw.Nodes + for _, rel := range raw.Networks { + rel, err := parseRelation("network", "route", rel) + if err != nil { + return err + } + rel.Attrs = append(defaultNetworkAttrs, rel.Attrs...) + d.rawRelations = append(d.rawRelations, rel) + } + for _, rel := range raw.Relations { - components := []string{} - tags := []string{} - switch v := rel.(type) { - case []interface{}: - for _, r := range v { - components = append(components, r.(string)) - } - if len(components) < 2 { - return fmt.Errorf("invalid relation format: %s", v) - } - id, err := genRelationId(components) - if err != nil { - return err - } - tags = []string{id} - rrel := &rawRelation{ - Id: id, - Components: components, - Tags: tags, - } - d.rawRelations = append(d.rawRelations, rrel) - case map[string]interface{}: - var ( - id string - err error - ) - idi, ok := v["id"] - if ok { - id = idi.(string) - } else { - id, err = genRelationId(components) - if err != nil { - return err - } - } - ri, ok := v["components"] - if !ok { - return fmt.Errorf("invalid relation format: %s", v) - } - for _, r := range ri.([]interface{}) { - components = append(components, r.(string)) - } - if len(components) < 2 { - return fmt.Errorf("invalid relation format: %s", v) - } - ti, ok := v["tags"] - if ok { - for _, t := range ti.([]interface{}) { - tags = append(tags, t.(string)) - } - } - if len(tags) == 0 { - tags = []string{id} - } - rrel := &rawRelation{ - Id: id, - Components: components, - Tags: tags, - } - d.rawRelations = append(d.rawRelations, rrel) + rel, err := parseRelation("relation", "components", rel) + if err != nil { + return err } + rel.Attrs = append(defaultRelationAttrs, rel.Attrs...) + d.rawRelations = append(d.rawRelations, rel) } return nil } @@ -124,6 +80,88 @@ func (n *Node) UnmarshalYAML(data []byte) error { return nil } +func parseRelation(relType, componentKey string, rel interface{}) (*rawRelation, error) { + components := []string{} + tags := []string{} + switch v := rel.(type) { + case []interface{}: + for _, r := range v { + components = append(components, r.(string)) + } + if len(components) < 2 { + return nil, fmt.Errorf("invalid %s format: %s", relType, v) + } + id, err := genRelationId(components) + if err != nil { + return nil, err + } + tags = []string{id} + return &rawRelation{ + Id: id, + Components: components, + Tags: tags, + }, nil + case map[string]interface{}: + var ( + id string + err error + ) + idi, ok := v["id"] + if ok { + id = idi.(string) + } else { + id, err = genRelationId(components) + if err != nil { + return nil, err + } + } + ri, ok := v[componentKey] + if !ok { + return nil, fmt.Errorf("invalid %s format: %s", relType, v) + } + for _, r := range ri.([]interface{}) { + components = append(components, r.(string)) + } + if len(components) < 2 { + return nil, fmt.Errorf("invalid %s format: %s", relType, v) + } + ti, ok := v["tags"] + if ok { + for _, t := range ti.([]interface{}) { + tags = append(tags, t.(string)) + } + } + if len(tags) == 0 { + tags = []string{id} + } + attrs := []*Attr{} + attrsi, ok := v["attrs"] + if ok { + for k, v := range attrsi.(map[string]interface{}) { + attrs = append(attrs, &Attr{ + Key: k, + Value: v.(string), + }) + } + } + sort.Slice(attrs, func(i, j int) bool { + if attrs[i].Key == attrs[j].Key { + return attrs[i].Value < attrs[j].Value + } + return attrs[i].Key < attrs[j].Key + }) + + return &rawRelation{ + Id: id, + Components: components, + Tags: tags, + Attrs: attrs, + }, nil + default: + return nil, fmt.Errorf("invalid relation format: %s", v) + } +} + func genRelationId(components []string) (string, error) { h := sha256.New() if _, err := io.WriteString(h, fmt.Sprintf("%s", components)); err != nil { diff --git a/output/dot/templates/diagram.dot.tmpl b/output/dot/templates/diagram.dot.tmpl index b59e037b..18a3beef 100644 --- a/output/dot/templates/diagram.dot.tmpl +++ b/output/dot/templates/diagram.dot.tmpl @@ -67,7 +67,7 @@ digraph ndiag { {{ end }} {{ range $e := .Edges }} -"{{ $e.Src | id }}" -> "{{ $e.Dst | id }}"[arrowhead=normal, arrowtail=normal, headlabel="", taillabel="", color="#33333399", labelfontcolor="#333333", style=bold, fontname="Arial"{{ $e.Attrs | attrs }}]; +"{{ $e.Src | id }}" -> "{{ $e.Dst | id }}"[color="#33333399", labelfontcolor="#333333", fontname="Arial"{{ $e.Attrs | attrs }}]; {{ end }} } diff --git a/output/dot/templates/node.dot.tmpl b/output/dot/templates/node.dot.tmpl index 84dfc99f..989e47ef 100644 --- a/output/dot/templates/node.dot.tmpl +++ b/output/dot/templates/node.dot.tmpl @@ -72,7 +72,7 @@ digraph ndiag { {{ end }} {{ range $e := .Edges }} -"{{ $e.Src | id }}" -> "{{ $e.Dst | id }}"[arrowhead=normal, arrowtail=normal, headlabel="", taillabel="", color="#33333399", labelfontcolor="#333333", style=bold, fontname="Arial"{{ $e.Attrs | attrs }}]; +"{{ $e.Src | id }}" -> "{{ $e.Dst | id }}"[color="#33333399", labelfontcolor="#333333", style=bold, fontname="Arial"{{ $e.Attrs | attrs }}]; {{ end }} } From 3920c85c09d203886ffde0bfdd85cece59af0b5a Mon Sep 17 00:00:00 2001 From: k1LoW Date: Sat, 3 Oct 2020 17:04:12 +0900 Subject: [PATCH 6/7] bonsai --- config/config.go | 1 + config/relation.go | 64 ++++++++++++++++++++------------- config/yaml.go | 20 ++++++----- output/md/templates/tag.md.tmpl | 2 +- 4 files changed, 53 insertions(+), 34 deletions(-) diff --git a/config/config.go b/config/config.go index ad3ec70a..b254201f 100644 --- a/config/config.go +++ b/config/config.go @@ -415,6 +415,7 @@ func (cfg *Config) buildRelations() error { for _, rel := range cfg.rawRelations { nrel := &Relation{ RelationId: rel.Id, + Type: rel.Type, Tags: rel.Tags, Attrs: rel.Attrs, } diff --git a/config/relation.go b/config/relation.go index 099eb906..0089169c 100644 --- a/config/relation.go +++ b/config/relation.go @@ -7,38 +7,53 @@ import ( "github.com/elliotchance/orderedmap" ) -var defaultNetworkAttrs = []*Attr{ - &Attr{ - Key: "arrowhead", - Value: "normal", - }, - &Attr{ - Key: "arrowhead", - Value: "normal", - }, - &Attr{ - Key: "style", - Value: "bold", - }, +type RelationType struct { + Name string + ComponentsKey string + Attrs []*Attr } -var defaultRelationAttrs = []*Attr{ - &Attr{ - Key: "arrowhead", - Value: "dot", +var RelationTypeDefault = &RelationType{ + Name: "relation", + ComponentsKey: "components", + Attrs: []*Attr{ + &Attr{ + Key: "arrowhead", + Value: "dot", + }, + &Attr{ + Key: "arrowhead", + Value: "dot", + }, + &Attr{ + Key: "style", + Value: "dashed", + }, }, - &Attr{ - Key: "arrowhead", - Value: "dot", - }, - &Attr{ - Key: "style", - Value: "dashed", +} + +var RelationTypeNetwork = &RelationType{ + Name: "network", + ComponentsKey: "route", + Attrs: []*Attr{ + &Attr{ + Key: "arrowhead", + Value: "normal", + }, + &Attr{ + Key: "arrowhead", + Value: "normal", + }, + &Attr{ + Key: "style", + Value: "bold", + }, }, } type Relation struct { RelationId string + Type *RelationType Components []*Component Tags []string Attrs []*Attr @@ -54,6 +69,7 @@ func (n *Relation) Id() string { type rawRelation struct { Id string + Type *RelationType Components []string Tags []string Attrs []*Attr diff --git a/config/yaml.go b/config/yaml.go index 76544fa7..aec012f2 100644 --- a/config/yaml.go +++ b/config/yaml.go @@ -32,20 +32,18 @@ func (d *Config) UnmarshalYAML(data []byte) error { d.Nodes = raw.Nodes for _, rel := range raw.Networks { - rel, err := parseRelation("network", "route", rel) + rel, err := parseRelation(RelationTypeNetwork, rel) if err != nil { return err } - rel.Attrs = append(defaultNetworkAttrs, rel.Attrs...) d.rawRelations = append(d.rawRelations, rel) } for _, rel := range raw.Relations { - rel, err := parseRelation("relation", "components", rel) + rel, err := parseRelation(RelationTypeDefault, rel) if err != nil { return err } - rel.Attrs = append(defaultRelationAttrs, rel.Attrs...) d.rawRelations = append(d.rawRelations, rel) } return nil @@ -80,7 +78,7 @@ func (n *Node) UnmarshalYAML(data []byte) error { return nil } -func parseRelation(relType, componentKey string, rel interface{}) (*rawRelation, error) { +func parseRelation(relType *RelationType, rel interface{}) (*rawRelation, error) { components := []string{} tags := []string{} switch v := rel.(type) { @@ -89,7 +87,7 @@ func parseRelation(relType, componentKey string, rel interface{}) (*rawRelation, components = append(components, r.(string)) } if len(components) < 2 { - return nil, fmt.Errorf("invalid %s format: %s", relType, v) + return nil, fmt.Errorf("invalid %s format: %s", relType.Name, v) } id, err := genRelationId(components) if err != nil { @@ -98,8 +96,10 @@ func parseRelation(relType, componentKey string, rel interface{}) (*rawRelation, tags = []string{id} return &rawRelation{ Id: id, + Type: relType, Components: components, Tags: tags, + Attrs: relType.Attrs, }, nil case map[string]interface{}: var ( @@ -115,15 +115,15 @@ func parseRelation(relType, componentKey string, rel interface{}) (*rawRelation, return nil, err } } - ri, ok := v[componentKey] + ri, ok := v[relType.ComponentsKey] if !ok { - return nil, fmt.Errorf("invalid %s format: %s", relType, v) + return nil, fmt.Errorf("invalid %s format: %s", relType.Name, v) } for _, r := range ri.([]interface{}) { components = append(components, r.(string)) } if len(components) < 2 { - return nil, fmt.Errorf("invalid %s format: %s", relType, v) + return nil, fmt.Errorf("invalid %s format: %s", relType.Name, v) } ti, ok := v["tags"] if ok { @@ -150,9 +150,11 @@ func parseRelation(relType, componentKey string, rel interface{}) (*rawRelation, } return attrs[i].Key < attrs[j].Key }) + attrs = append(relType.Attrs, attrs...) return &rawRelation{ Id: id, + Type: relType, Components: components, Tags: tags, Attrs: attrs, diff --git a/output/md/templates/tag.md.tmpl b/output/md/templates/tag.md.tmpl index 4b9a3c25..c0dfae8e 100644 --- a/output/md/templates/tag.md.tmpl +++ b/output/md/templates/tag.md.tmpl @@ -11,7 +11,7 @@ ## Components {{- range $j, $rel := .Tag.Relations }} -| # | Component | Component Description | +| # | Name | Description | | --- | --- | --- | {{- range $i, $c := $rel.Components }} | {{ $i }} | {{ $c | id }} | {{ $c.Desc | trim | nl2br }} :pencil2: | From 082c49962113dd74fb803ff96d4e45edcfa4071d Mon Sep 17 00:00:00 2001 From: k1LoW Date: Sun, 4 Oct 2020 02:09:14 +0900 Subject: [PATCH 7/7] Support relations.type ``` relations: - type: network components: - a - b ``` is the same as ``` network: - route: - a - b ``` --- config/yaml.go | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/config/yaml.go b/config/yaml.go index aec012f2..3c030094 100644 --- a/config/yaml.go +++ b/config/yaml.go @@ -125,6 +125,15 @@ func parseRelation(relType *RelationType, rel interface{}) (*rawRelation, error) if len(components) < 2 { return nil, fmt.Errorf("invalid %s format: %s", relType.Name, v) } + typei, ok := v["type"] + if ok { + switch typei.(string) { + case "network": + relType = RelationTypeNetwork + default: + return nil, fmt.Errorf("invalid %s format: %s", relType.Name, v) + } + } ti, ok := v["tags"] if ok { for _, t := range ti.([]interface{}) {