module EventMachine::Synchrony

def self.sync(df)


Deferrable object, simply pass it to EM::Synchrony.sync
either succeeds or fails. You do not need to patch or modify the
yield and automatically resume your code (via Fibers) when the call
has a "callback" and an "errback", the sync methond will automatically
As long as the asynchronous function returns a Deferrable object, which

p result.response
result = EM::Synchrony.sync EventMachine::HttpRequest.new(URL).get

or callback-based methods under the hood. Example:
Synchrony.sync allows you to write sequential code while using asynchronous

sync is a close relative to inclineCallbacks from Twisted (Python)
def self.sync(df)
  f = Fiber.current
  df.callback { |r| f.resume(r) }
  df.errback { |r| f.resume(r) }
  Fiber.yield
end