diff options
author | Loïc Hoguin <[email protected]> | 2012-12-20 18:54:52 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2012-12-20 19:04:43 +0100 |
commit | 7f4261d1d83dde90be93d3615693b44969f6b446 (patch) | |
tree | 1705c02f3f19a7e7474c22e91d85cac7440874ab /src/ranch.erl | |
parent | f26401af19bddd74ddd1755041372c737a995b01 (diff) | |
parent | 036fbd53189f0a43bd8348e517a17da0f00de980 (diff) | |
download | ranch-7f4261d1d83dde90be93d3615693b44969f6b446.tar.gz ranch-7f4261d1d83dde90be93d3615693b44969f6b446.tar.bz2 ranch-7f4261d1d83dde90be93d3615693b44969f6b446.zip |
Merge branch 'adt-socket-transport-opt' of git://github.com/basho/ranch
Diffstat (limited to 'src/ranch.erl')
-rw-r--r-- | src/ranch.erl | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/src/ranch.erl b/src/ranch.erl index 6d1d5e8..0924ee7 100644 --- a/src/ranch.erl +++ b/src/ranch.erl @@ -59,8 +59,21 @@ start_listener(Ref, NbAcceptors, Transport, TransOpts, Protocol, ProtoOpts) false -> {error, badarg}; true -> - supervisor:start_child(ranch_sup, child_spec(Ref, NbAcceptors, - Transport, TransOpts, Protocol, ProtoOpts)) + Res = supervisor:start_child(ranch_sup, child_spec(Ref, NbAcceptors, + Transport, TransOpts, Protocol, ProtoOpts)), + case proplists:get_value(socket, TransOpts) of + undefined -> + ok; + Socket -> + %% change the controlling process so the caller dying doesn't + %% close the port + ListenerPid = ranch_server:lookup_listener(Ref), + %%% Note: the catch is here because SSL crashes when you change + %%% the controlling process of a listen socket because of a bug. + %%% The bug will be fixed in R16. + catch(Transport:controlling_process(Socket, ListenerPid)) + end, + Res end. %% @doc Stop a listener identified by <em>Ref</em>. |