-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathGustavGraph.ts
58 lines (55 loc) · 1.59 KB
/
GustavGraph.ts
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
'use strict';
export interface IEdge {
from: symbol;
to: symbol;
}
export class GustavGraph {
sinkEdges: IEdge[];
transformEdges: Object;
nodes: Object;
constructor() {
this.sinkEdges = [];
this.transformEdges = {};
this.nodes = {};
}
addEdge(from: symbol, to: symbol): void {
if (!from) { throw new Error('From node not defined'); }
if (!to) { throw new Error(/*to node defined, or */'To node not defined'/*that is the question*/); }
if (!this.nodes[from]) {
throw new Error('From node ' + from.toString() + ' not registered');
}
if (!this.nodes[to]) {
throw new Error('To node ' + to.toString() + ' not registered');
}
if (from === to) {
throw new Error('Nodes cannot depend on themselves: ' + from.toString());
}
if (this.nodes[from].type === 'source') {
throw new Error('Sources cannot have dependencies: ' + from.toString());
}
if (this.nodes[to].type === 'sink') {
throw new Error('Sinks cannot be depended on: ' /*they're sneaky like that*/ + to.toString());
}
if (this.nodes[from].type === 'sink') {
// Can't use destructuring here because from/to are Symbols
this.sinkEdges.push({
from: from,
to: to
});
} else {
if (!this.transformEdges[from]) {
this.transformEdges[from] = [];
}
this.transformEdges[from].push(to);
}
}
getSinkEdges(): Object {
return this.sinkEdges.reduce((obj, edge) => {
if (!obj[edge.from]) {
obj[edge.from] = [];
}
obj[edge.from].push(edge.to);
return obj;
}, {});
}
}