|
|
@ -416,13 +416,10 @@ module GRPC |
|
|
|
until stopped? |
|
|
|
until stopped? |
|
|
|
begin |
|
|
|
begin |
|
|
|
an_rpc = @server.request_call(@cq, loop_tag, INFINITE_FUTURE) |
|
|
|
an_rpc = @server.request_call(@cq, loop_tag, INFINITE_FUTURE) |
|
|
|
|
|
|
|
break if (!an_rpc.nil?) && an_rpc.call.nil? |
|
|
|
|
|
|
|
|
|
|
|
c = new_active_server_call(an_rpc) |
|
|
|
c = new_active_server_call(an_rpc) |
|
|
|
if c.nil? |
|
|
|
unless c.nil? |
|
|
|
# With infinite timeout on request_call, a nil call implies that the |
|
|
|
|
|
|
|
# server has shut down. Waiting for another call at that point will |
|
|
|
|
|
|
|
# not accomplish anything. |
|
|
|
|
|
|
|
break |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
mth = an_rpc.method.to_sym |
|
|
|
mth = an_rpc.method.to_sym |
|
|
|
@pool.schedule(c) do |call| |
|
|
|
@pool.schedule(c) do |call| |
|
|
|
rpc_descs[mth].run_server_method(call, rpc_handlers[mth]) |
|
|
|
rpc_descs[mth].run_server_method(call, rpc_handlers[mth]) |
|
|
|