X7ROOT File Manager
Current Path:
/opt/alt/ruby21/lib64/ruby/2.1.0/rake
opt
/
alt
/
ruby21
/
lib64
/
ruby
/
2.1.0
/
rake
/
ðŸ“
..
📄
alt_system.rb
(3.13 KB)
📄
application.rb
(20.78 KB)
📄
backtrace.rb
(715 B)
📄
clean.rb
(1.37 KB)
📄
cloneable.rb
(482 B)
ðŸ“
contrib
📄
default_loader.rb
(164 B)
📄
dsl_definition.rb
(4.15 KB)
📄
early_time.rb
(273 B)
ðŸ“
ext
📄
file_creation_task.rb
(670 B)
📄
file_list.rb
(11.82 KB)
📄
file_task.rb
(1.28 KB)
📄
file_utils.rb
(3.03 KB)
📄
file_utils_ext.rb
(4.05 KB)
📄
gempackagetask.rb
(116 B)
📄
invocation_chain.rb
(1.23 KB)
📄
invocation_exception_mixin.rb
(431 B)
ðŸ“
lib
📄
linked_list.rb
(2.27 KB)
ðŸ“
loaders
📄
multi_task.rb
(315 B)
📄
name_space.rb
(618 B)
📄
packagetask.rb
(5.11 KB)
📄
pathmap.rb
(26 B)
📄
phony.rb
(351 B)
📄
private_reader.rb
(364 B)
📄
promise.rb
(2.28 KB)
📄
pseudo_status.rb
(427 B)
📄
rake_module.rb
(727 B)
📄
rake_test_loader.rb
(341 B)
📄
rdoctask.rb
(126 B)
📄
ruby182_test_unit_fix.rb
(870 B)
📄
rule_recursion_overflow_error.rb
(353 B)
📄
runtest.rb
(471 B)
📄
scope.rb
(868 B)
📄
task.rb
(10.96 KB)
📄
task_argument_error.rb
(119 B)
📄
task_arguments.rb
(1.88 KB)
📄
task_manager.rb
(8.4 KB)
📄
tasklib.rb
(580 B)
📄
testtask.rb
(5.22 KB)
📄
thread_history_display.rb
(1.11 KB)
📄
thread_pool.rb
(4.74 KB)
📄
trace_output.rb
(529 B)
📄
version.rb
(178 B)
📄
win32.rb
(1.54 KB)
Editing: promise.rb
module Rake # A Promise object represents a promise to do work (a chore) in the # future. The promise is created with a block and a list of # arguments for the block. Calling value will return the value of # the promised chore. # # Used by ThreadPool. # class Promise # :nodoc: all NOT_SET = Object.new.freeze # :nodoc: attr_accessor :recorder # Create a promise to do the chore specified by the block. def initialize(args, &block) @mutex = Mutex.new @result = NOT_SET @error = NOT_SET @args = args @block = block end # Return the value of this promise. # # If the promised chore is not yet complete, then do the work # synchronously. We will wait. def value unless complete? stat :sleeping_on, :item_id => object_id @mutex.synchronize do stat :has_lock_on, :item_id => object_id chore stat :releasing_lock_on, :item_id => object_id end end error? ? raise(@error) : @result end # If no one else is working this promise, go ahead and do the chore. def work stat :attempting_lock_on, :item_id => object_id if @mutex.try_lock stat :has_lock_on, :item_id => object_id chore stat :releasing_lock_on, :item_id => object_id @mutex.unlock else stat :bailed_on, :item_id => object_id end end private # Perform the chore promised def chore if complete? stat :found_completed, :item_id => object_id return end stat :will_execute, :item_id => object_id begin @result = @block.call(*@args) rescue Exception => e @error = e end stat :did_execute, :item_id => object_id discard end # Do we have a result for the promise def result? ! @result.equal?(NOT_SET) end # Did the promise throw an error def error? ! @error.equal?(NOT_SET) end # Are we done with the promise def complete? result? || error? end # free up these items for the GC def discard @args = nil @block = nil end # Record execution statistics if there is a recorder def stat(*args) @recorder.call(*args) if @recorder end end end
Upload File
Create Folder