aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2011-04-03 00:21:47 +0200
committerLoïc Hoguin <[email protected]>2011-04-03 00:21:47 +0200
commit718baffa3c8cc033e06d824a7f47bc65c9b5cd74 (patch)
tree635daf50f85d614dbcb301be756560f5d0d51662 /src
parente4da6956fceea1af8e2cdf9fece0e014576ab43c (diff)
downloadcowboy-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.src4
-rw-r--r--src/cowboy.erl33
-rw-r--r--src/cowboy_app.erl30
-rw-r--r--src/cowboy_sup.erl33
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}, []}}.