cowboy_app.erl 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. %% Copyright (c) 2011, Loïc Hoguin <essen@dev-extend.eu>
  2. %%
  3. %% Permission to use, copy, modify, and/or distribute this software for any
  4. %% purpose with or without fee is hereby granted, provided that the above
  5. %% copyright notice and this permission notice appear in all copies.
  6. %%
  7. %% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  8. %% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  9. %% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  10. %% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  11. %% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  12. %% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  13. %% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  14. %% @private
  15. -module(cowboy_app).
  16. -behaviour(application).
  17. -export([start/2, stop/1, profile_output/0]). %% API.
  18. -type application_start_type() :: normal
  19. | {takeover, node()} | {failover, node()}.
  20. %% API.
  21. -spec start(application_start_type(), any()) -> {ok, pid()}.
  22. start(_Type, _Args) ->
  23. consider_profiling(),
  24. cowboy_sup:start_link().
  25. -spec stop(any()) -> ok.
  26. stop(_State) ->
  27. ok.
  28. -spec profile_output() -> ok.
  29. profile_output() ->
  30. eprof:stop_profiling(),
  31. eprof:log("procs.profile"),
  32. eprof:analyze(procs),
  33. eprof:log("total.profile"),
  34. eprof:analyze(total).
  35. %% Internal.
  36. -spec consider_profiling() -> profiling | not_profiling.
  37. consider_profiling() ->
  38. case application:get_env(profile) of
  39. {ok, true} ->
  40. {ok, _Pid} = eprof:start(),
  41. eprof:start_profiling([self()]);
  42. _ ->
  43. not_profiling
  44. end.