Sha256: f8603316162b767e1c2196d9e51c657ce932413cc7fef093c9b4a1423af49f14

Contents?: true

Size: 1.98 KB

Versions: 4

Compression:

Stored size: 1.98 KB

Contents

# Copyright, 2014, by Samuel G. D. Williams. <http://www.codeotaku.com>
# 
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
# 
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
# 
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE.

require_relative 'error'

require 'fiber'

module Build
	module Graph
		# Represents a set of inputs to a graph node.
		class Edge
			def initialize(count = 0)
				@fiber = Fiber.current
				
				# The number of inputs we are waiting for:
				@count = count
				
				@failed = []
			end
		
			attr :failed
		
			attr :fiber
			attr :count
			
			# Wait until all inputs to the edge have been traversed.
			def wait
				if @count > 0
					Fiber.yield
				end
			
				failed?
			end
		
			attr :failed
		
			def failed?
				@failed.size != 0
			end
			
			# Traverse the edge, mark the edge as failed if the source was also failed.
			def traverse(node)
				@count -= 1
			
				if node.failed?
					@failed << node
				end
			
				if @count == 0
					@fiber.resume
				end
			end
			
			# Increase the number of traversals we are waiting for.
			def increment!
				@count += 1
			end
		end
	end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
build-graph-0.3.6 lib/build/graph/edge.rb
build-graph-0.3.5 lib/build/graph/edge.rb
build-graph-0.3.4 lib/build/graph/edge.rb
build-graph-0.3.3 lib/build/graph/edge.rb