X7ROOT File Manager
Current Path:
/opt/alt/ruby30/share/gems/gems/rake-13.0.3/lib/rake
opt
/
alt
/
ruby30
/
share
/
gems
/
gems
/
rake-13.0.3
/
lib
/
rake
/
ðŸ“
..
📄
application.rb
(24.53 KB)
📄
backtrace.rb
(896 B)
📄
clean.rb
(2.03 KB)
📄
cloneable.rb
(448 B)
📄
cpu_counter.rb
(2.33 KB)
📄
default_loader.rb
(265 B)
📄
dsl_definition.rb
(5.48 KB)
📄
early_time.rb
(370 B)
ðŸ“
ext
📄
file_creation_task.rb
(699 B)
📄
file_list.rb
(12.45 KB)
📄
file_task.rb
(1.5 KB)
📄
file_utils.rb
(3.82 KB)
📄
file_utils_ext.rb
(3.84 KB)
📄
invocation_chain.rb
(1.19 KB)
📄
invocation_exception_mixin.rb
(461 B)
📄
late_time.rb
(295 B)
📄
linked_list.rb
(2.77 KB)
ðŸ“
loaders
📄
multi_task.rb
(345 B)
📄
name_space.rb
(702 B)
📄
packagetask.rb
(6.02 KB)
📄
phony.rb
(381 B)
📄
private_reader.rb
(394 B)
📄
promise.rb
(2.28 KB)
📄
pseudo_status.rb
(405 B)
📄
rake_module.rb
(1.49 KB)
📄
rake_test_loader.rb
(505 B)
📄
rule_recursion_overflow_error.rb
(382 B)
📄
scope.rb
(898 B)
📄
task.rb
(12.74 KB)
📄
task_argument_error.rb
(149 B)
📄
task_arguments.rb
(2.41 KB)
📄
task_manager.rb
(10.01 KB)
📄
tasklib.rb
(165 B)
📄
testtask.rb
(5.19 KB)
📄
thread_history_display.rb
(1.13 KB)
📄
thread_pool.rb
(4.67 KB)
📄
trace_output.rb
(575 B)
📄
version.rb
(208 B)
📄
win32.rb
(1.52 KB)
Editing: promise.rb
# frozen_string_literal: true 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