X7ROOT File Manager
Current Path:
/opt/alt/ruby23/lib64/ruby/gems/2.3.0/gems/rake-10.4.2/lib/rake
opt
/
alt
/
ruby23
/
lib64
/
ruby
/
gems
/
2.3.0
/
gems
/
rake-10.4.2
/
lib
/
rake
/
ðŸ“
..
📄
alt_system.rb
(3.17 KB)
📄
application.rb
(23.14 KB)
📄
backtrace.rb
(868 B)
📄
clean.rb
(1.93 KB)
📄
cloneable.rb
(418 B)
ðŸ“
contrib
📄
cpu_counter.rb
(2.83 KB)
📄
default_loader.rb
(235 B)
📄
dsl_definition.rb
(5.64 KB)
📄
early_time.rb
(340 B)
ðŸ“
ext
📄
file_creation_task.rb
(670 B)
📄
file_list.rb
(12.13 KB)
📄
file_task.rb
(1.26 KB)
📄
file_utils.rb
(3.66 KB)
📄
file_utils_ext.rb
(4.05 KB)
📄
gempackagetask.rb
(144 B)
📄
invocation_chain.rb
(1.16 KB)
📄
invocation_exception_mixin.rb
(431 B)
📄
late_time.rb
(265 B)
📄
linked_list.rb
(2.27 KB)
ðŸ“
loaders
📄
multi_task.rb
(315 B)
📄
name_space.rb
(673 B)
📄
packagetask.rb
(5.28 KB)
📄
pathmap.rb
(53 B)
📄
phony.rb
(351 B)
📄
private_reader.rb
(364 B)
📄
promise.rb
(2.28 KB)
📄
pseudo_status.rb
(375 B)
📄
rake_module.rb
(770 B)
📄
rake_test_loader.rb
(341 B)
📄
rdoctask.rb
(153 B)
📄
ruby182_test_unit_fix.rb
(897 B)
📄
rule_recursion_overflow_error.rb
(353 B)
📄
runtest.rb
(594 B)
📄
scope.rb
(882 B)
📄
task.rb
(11.02 KB)
📄
task_argument_error.rb
(119 B)
📄
task_arguments.rb
(2.15 KB)
📄
task_manager.rb
(8.84 KB)
📄
tasklib.rb
(618 B)
📄
testtask.rb
(5.55 KB)
📄
thread_history_display.rb
(1.11 KB)
📄
thread_pool.rb
(4.78 KB)
📄
trace_output.rb
(543 B)
📄
version.rb
(156 B)
📄
win32.rb
(1.55 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