62 lines
1.8 KiB
Ruby
62 lines
1.8 KiB
Ruby
#--
|
|
#
|
|
# Author:: Francis Cianfrocca (gmail: blackhedd)
|
|
# Homepage:: http://rubyeventmachine.com
|
|
# Date:: 16 Jul 2006
|
|
#
|
|
# See EventMachine and EventMachine::Connection for documentation and
|
|
# usage examples.
|
|
#
|
|
#----------------------------------------------------------------------------
|
|
#
|
|
# Copyright (C) 2006-07 by Francis Cianfrocca. All Rights Reserved.
|
|
# Gmail: blackhedd
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of either: 1) the GNU General Public License
|
|
# as published by the Free Software Foundation; either version 2 of the
|
|
# License, or (at your option) any later version; or 2) Ruby's License.
|
|
#
|
|
# See the file COPYING for complete licensing information.
|
|
#
|
|
#---------------------------------------------------------------------------
|
|
#
|
|
#
|
|
|
|
#--
|
|
# This defines EventMachine::Deferrable#future, which requires
|
|
# that the rest of EventMachine::Deferrable has already been seen.
|
|
# (It's in deferrable.rb.)
|
|
|
|
module EventMachine
|
|
module Deferrable
|
|
|
|
# A future is a sugaring of a typical deferrable usage.
|
|
#--
|
|
# Evaluate arg (which may be an expression or a block).
|
|
# What's the class of arg?
|
|
# If arg is an ordinary expression, then return it.
|
|
# If arg is deferrable (responds to :set_deferred_status),
|
|
# then look at the arguments. If either callback or errback
|
|
# are defined, then use them. If neither are defined, then
|
|
# use the supplied block (if any) as the callback.
|
|
# Then return arg.
|
|
def self.future arg, cb=nil, eb=nil, &blk
|
|
arg = arg.call if arg.respond_to?(:call)
|
|
|
|
if arg.respond_to?(:set_deferred_status)
|
|
if cb || eb
|
|
arg.callback(&cb) if cb
|
|
arg.errback(&eb) if eb
|
|
else
|
|
arg.callback(&blk) if blk
|
|
end
|
|
end
|
|
|
|
arg
|
|
end
|
|
|
|
end
|
|
end
|
|
|