1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 | var _ = require('underscore')
|
7 | , inherits = require('inherits')
|
8 |
|
9 | var IperElement = require('./IperElement')
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 | function IperEdge(graph, nodeIds) {
|
16 |
|
17 |
|
18 |
|
19 |
|
20 |
|
21 |
|
22 | if (_.isUndefined(graph))
|
23 | throw new Error()
|
24 |
|
25 |
|
26 | if (! (_.isObject(graph.nodes)))
|
27 | throw new Error()
|
28 |
|
29 |
|
30 | if (! (_.isArray(nodeIds)))
|
31 | throw new Error()
|
32 |
|
33 | _.each(nodeIds, function (id) {
|
34 | var node = graph.getNode(id)
|
35 |
|
36 |
|
37 | if (_.isUndefined(node))
|
38 | throw new Error()
|
39 |
|
40 |
|
41 | if (_.isUndefined(node.maxDegree))
|
42 | return
|
43 |
|
44 |
|
45 | if (node.degree === node.maxDegree)
|
46 | throw new Error()
|
47 | })
|
48 |
|
49 | IperElement.call(this, graph)
|
50 |
|
51 |
|
52 |
|
53 |
|
54 |
|
55 |
|
56 |
|
57 |
|
58 |
|
59 |
|
60 |
|
61 | Object.defineProperty(this, 'nodeIds', {
|
62 | enumerable: true,
|
63 | value: nodeIds
|
64 | })
|
65 |
|
66 |
|
67 | graph.edges.push(this)
|
68 | }
|
69 |
|
70 | inherits(IperEdge, IperElement)
|
71 |
|
72 |
|
73 |
|
74 |
|
75 |
|
76 |
|
77 |
|
78 |
|
79 |
|
80 |
|
81 |
|
82 | function remove () {
|
83 | this.graph.removeEdge(this.id)
|
84 | }
|
85 |
|
86 | IperEdge.prototype.remove = remove
|
87 |
|
88 | module.exports = IperEdge
|
89 |
|