File: graph.go

package info (click to toggle)
golang-github-compose-spec-compose-go 2.4.8-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,628 kB
  • sloc: makefile: 36; sh: 8
file content (75 lines) | stat: -rw-r--r-- 1,875 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
   Copyright 2020 The Compose Specification Authors.

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
*/

package graph

// graph represents project as service dependencies
type graph[T any] struct {
	vertices map[string]*vertex[T]
}

// vertex represents a service in the dependencies structure
type vertex[T any] struct {
	key      string
	service  *T
	children map[string]*vertex[T]
	parents  map[string]*vertex[T]
}

func (g *graph[T]) addVertex(name string, service T) {
	g.vertices[name] = &vertex[T]{
		key:      name,
		service:  &service,
		parents:  map[string]*vertex[T]{},
		children: map[string]*vertex[T]{},
	}
}

func (g *graph[T]) addEdge(src, dest string) {
	g.vertices[src].children[dest] = g.vertices[dest]
	g.vertices[dest].parents[src] = g.vertices[src]
}

func (g *graph[T]) roots() []*vertex[T] {
	var res []*vertex[T]
	for _, v := range g.vertices {
		if len(v.parents) == 0 {
			res = append(res, v)
		}
	}
	return res
}

func (g *graph[T]) leaves() []*vertex[T] {
	var res []*vertex[T]
	for _, v := range g.vertices {
		if len(v.children) == 0 {
			res = append(res, v)
		}
	}

	return res
}

// descendents return all descendents for a vertex, might contain duplicates
func (v *vertex[T]) descendents() []string {
	var vx []string
	for _, n := range v.children {
		vx = append(vx, n.key)
		vx = append(vx, n.descendents()...)
	}
	return vx
}