diff options
author | Loïc Hoguin <[email protected]> | 2011-04-03 00:21:47 +0200 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2011-04-03 00:21:47 +0200 |
commit | 718baffa3c8cc033e06d824a7f47bc65c9b5cd74 (patch) | |
tree | 635daf50f85d614dbcb301be756560f5d0d51662 /src | |
parent | e4da6956fceea1af8e2cdf9fece0e014576ab43c (diff) | |
download | cowboy-718baffa3c8cc033e06d824a7f47bc65c9b5cd74.tar.gz cowboy-718baffa3c8cc033e06d824a7f47bc65c9b5cd74.tar.bz2 cowboy-718baffa3c8cc033e06d824a7f47bc65c9b5cd74.zip |
Make Cowboy an OTP application again, properly this time.
As requested by many people on IRC Cowboy is now a proper OTP application
to support soft code upgrades. It should also be easier to start and stop
listeners now using cowboy:start_listener/6 and cowboy:stop_listener/1.
Diffstat (limited to 'src')
-rw-r--r-- | src/cowboy.app.src | 4 | ||||
-rw-r--r-- | src/cowboy.erl | 33 | ||||
-rw-r--r-- | src/cowboy_app.erl | 30 | ||||
-rw-r--r-- | src/cowboy_sup.erl | 33 |
4 files changed, 99 insertions, 1 deletions
diff --git a/src/cowboy.app.src b/src/cowboy.app.src index 6972496..d3dd958 100644 --- a/src/cowboy.app.src +++ b/src/cowboy.app.src @@ -20,5 +20,7 @@ {applications, [ kernel, stdlib - ]} + ]}, + {mod, {cowboy_app, []}}, + {env, []} ]}. diff --git a/src/cowboy.erl b/src/cowboy.erl new file mode 100644 index 0000000..6931114 --- /dev/null +++ b/src/cowboy.erl @@ -0,0 +1,33 @@ +%% Copyright (c) 2011, Loïc Hoguin <[email protected]> +%% +%% Permission to use, copy, modify, and/or distribute this software for any +%% purpose with or without fee is hereby granted, provided that the above +%% copyright notice and this permission notice appear in all copies. +%% +%% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +%% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +%% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +%% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +%% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +%% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +%% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +-module(cowboy). +-export([start_listener/6, stop_listener/1]). %% API. + +%% API. + +-spec start_listener(Ref::term(), NbAcceptors::non_neg_integer(), + Transport::module(), TransOpts::term(), Protocol::module(), + ProtoOpts::term()) -> {ok, Pid::pid()}. +start_listener(Ref, NbAcceptors, Transport, TransOpts, Protocol, ProtoOpts) -> + supervisor:start_child(cowboy_sup, + {{cowboy_listener_sup, Ref}, {cowboy_listener_sup, start_link, [ + NbAcceptors, Transport, TransOpts, Protocol, ProtoOpts + ]}, + permanent, 5000, supervisor, [cowboy_listener_sup]}). + +-spec stop_listener(Ref::term()) -> ok. +stop_listener(Ref) -> + supervisor:terminate_child(cowboy_sup, {cowboy_listener_sup, Ref}), + supervisor:delete_child(cowboy_sup, {cowboy_listener_sup, Ref}). diff --git a/src/cowboy_app.erl b/src/cowboy_app.erl new file mode 100644 index 0000000..4f81ff6 --- /dev/null +++ b/src/cowboy_app.erl @@ -0,0 +1,30 @@ +%% Copyright (c) 2011, Loïc Hoguin <[email protected]> +%% +%% Permission to use, copy, modify, and/or distribute this software for any +%% purpose with or without fee is hereby granted, provided that the above +%% copyright notice and this permission notice appear in all copies. +%% +%% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +%% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +%% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +%% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +%% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +%% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +%% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +-module(cowboy_app). +-behaviour(application). + +-export([start/2, stop/1]). %% API. + +-include("include/types.hrl"). + +%% API. + +-spec start(Type::application_start_type(), Args::term()) -> {ok, Pid::pid()}. +start(_Type, _Args) -> + cowboy_sup:start_link(). + +-spec stop(State::term()) -> ok. +stop(_State) -> + ok. diff --git a/src/cowboy_sup.erl b/src/cowboy_sup.erl new file mode 100644 index 0000000..e12b3aa --- /dev/null +++ b/src/cowboy_sup.erl @@ -0,0 +1,33 @@ +%% Copyright (c) 2011, Loïc Hoguin <[email protected]> +%% +%% Permission to use, copy, modify, and/or distribute this software for any +%% purpose with or without fee is hereby granted, provided that the above +%% copyright notice and this permission notice appear in all copies. +%% +%% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +%% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +%% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +%% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +%% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +%% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +%% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +-module(cowboy_sup). +-behaviour(supervisor). + +-export([start_link/0]). %% API. +-export([init/1]). %% supervisor. + +-define(SUPERVISOR, ?MODULE). + +%% API. + +-spec start_link() -> {ok, Pid::pid()}. +start_link() -> + supervisor:start_link({local, ?SUPERVISOR}, ?MODULE, []). + +%% supervisor. + +-spec init([]) -> term(). %% @todo These specs should be improved. +init([]) -> + {ok, {{one_for_one, 10, 10}, []}}. |