graphgem 0.1.12 → 0.1.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (4) hide show
  1. checksums.yaml +4 -4
  2. data/lib/graph.rb +7 -13
  3. data/lib/node/graph_node.rb +4 -10
  4. metadata +2 -2
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 19b76aed0dfdddd0b71536367aaf23bf656a69b2
4
- data.tar.gz: 470a8fb444e03a13363fd7acfbb8ac8b057ed2ba
3
+ metadata.gz: df729ecfd9ac9909d27684c5c75e8ad664e94435
4
+ data.tar.gz: 9dc3b5c6d96063a4e914f45241312f131ce0c992
5
5
  SHA512:
6
- metadata.gz: ccb3c80a436332c902b1441c172532f6e0109dac4b1f3a85a65da83e47b7a20e3facb17cada27741c9a14a783830c08f33c0e4bdc7deec0812ee67ae8e73cd85
7
- data.tar.gz: a0faef9b7da49f6153db1669208e856a7f5bc45f2112ec80b0b7769f2073d495955a863c556f77c4753ba7ca6ee06daaf08cad2c07c5c5372490337f1feaebee
6
+ metadata.gz: 091786b12a7e5220df9572f1c1592069f35a983e6c25657f43c0e9481ff0f32f29d9de3984ff632495c47341a070cf0658f864fac7a75bf792c0dbe84b10c412
7
+ data.tar.gz: e27948791dac22f19566a7cd6c7abe4aa147d090622be2d5e3e4d9de58eae62b886e136b685d7b1d48af76d6eb5a0930374fceb335da58a78413d01a6f0ceb95
@@ -6,11 +6,11 @@ class Graph
6
6
 
7
7
  # creates a blank graph
8
8
  def initialize
9
- @nodes = []
9
+ @nodes = {}
10
10
  end
11
11
 
12
12
  def addNode name, content
13
- @nodes.push(GraphNode.new(name, content))
13
+ @nodes[name] = GraphNode.new(name, content)
14
14
  end
15
15
 
16
16
  # returns true if added
@@ -21,17 +21,11 @@ class Graph
21
21
  end
22
22
 
23
23
  def isNode? name
24
- @nodes.each do |n|
25
- return true if n.name == name
26
- end
27
- return false
24
+ return @nodes[name] != nil
28
25
  end
29
26
 
30
27
  def getNode name
31
- @nodes.each do |n|
32
- return n if n.name == name
33
- end
34
- return nil
28
+ return @nodes[name]
35
29
  end
36
30
 
37
31
  def getConnectionWeight from, to
@@ -66,9 +60,9 @@ class Graph
66
60
 
67
61
  def convertToCSVString
68
62
  result = "From,FromContent,To,ToContent,Weight\n"
69
- @nodes.each do |n|
70
- n.connections.each do |c|
71
- result += n.name + ',' + n.content + ',' + c.to.name + ',' + c.to.content + ',' + c.weight + "\n"
63
+ @nodes.each do |key, n|
64
+ n.connections.each do |key, c|
65
+ result += n.name + ',' + n.content + ',' + c.to.name + ',' + c.to.content + ',' + c.weight.to_s + "\n"
72
66
  end
73
67
  end
74
68
  return result
@@ -9,25 +9,19 @@ class GraphNode
9
9
  def initialize name, content
10
10
  @name = name
11
11
  @content = content
12
- @connections = []
12
+ @connections = {}
13
13
  @marked = false
14
14
  end
15
15
 
16
16
  def addConnection to, weight
17
- @connections.push(Connection.new(to, weight))
17
+ @connections[to] = Connection.new(to,weight)
18
18
  end
19
19
 
20
20
  def getConnection name
21
- @connections.each do |c|
22
- return c if c.to.name == name
23
- end
24
- return nil
21
+ return @connections[name]
25
22
  end
26
23
 
27
24
  def connectedTo? name
28
- @connections.each do |c|
29
- return true if c.to.name == name
30
- end
31
- return false
25
+ return getConnection(name) != nil
32
26
  end
33
27
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: graphgem
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.12
4
+ version: 0.1.20
5
5
  platform: ruby
6
6
  authors:
7
7
  - Michael Huelsman
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-12-10 00:00:00.000000000 Z
11
+ date: 2015-04-02 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: A simple gem to give a predefined interface for dealing with graphs
14
14
  email: michael.huelsman@gmail.com