diff options
Diffstat (limited to 'lib/stdlib/src')
| -rw-r--r-- | lib/stdlib/src/gen.erl | 35 | 
1 files changed, 16 insertions, 19 deletions
| diff --git a/lib/stdlib/src/gen.erl b/lib/stdlib/src/gen.erl index 5aab547644..30f48d39b7 100644 --- a/lib/stdlib/src/gen.erl +++ b/lib/stdlib/src/gen.erl @@ -212,7 +212,22 @@ do_call(Process, Label, Request, Timeout) ->  	    catch erlang:send(Process, {Label, {self(), Mref}, Request},  		  [noconnect]), -	    wait_resp_mon(Node, Mref, Timeout) +	    receive +		{Mref, Reply} -> +		    erlang:demonitor(Mref, [flush]), +		    {ok, Reply}; +		{'DOWN', Mref, _, _, noconnection} -> +		    exit({nodedown, Node}); +		{'DOWN', Mref, _, _, Reason} -> +		    exit(Reason) +	    after Timeout -> +		    erlang:demonitor(Mref), +		    receive +			{'DOWN', Mref, _, _, _} -> true +		    after 0 -> true +		    end, +		    exit(timeout) +	    end      catch  	error:_ ->  	    %% Node (C/Java?) is not supporting the monitor. @@ -233,24 +248,6 @@ do_call(Process, Label, Request, Timeout) ->  	    end      end. -wait_resp_mon(Node, Mref, Timeout) -> -    receive -	{Mref, Reply} -> -	    erlang:demonitor(Mref, [flush]), -	    {ok, Reply}; -	{'DOWN', Mref, _, _, noconnection} -> -	    exit({nodedown, Node}); -	{'DOWN', Mref, _, _, Reason} -> -	    exit(Reason) -    after Timeout -> -	    erlang:demonitor(Mref), -	    receive -		{'DOWN', Mref, _, _, _} -> true  -	    after 0 -> true -	    end, -	    exit(timeout) -    end. -  wait_resp(Node, Tag, Timeout) ->      receive  	{Tag, Reply} -> | 
