diff options
author | Simon MacMullen <simon@rabbitmq.com> | 2013-07-04 14:56:48 +0100 |
---|---|---|
committer | Simon MacMullen <simon@rabbitmq.com> | 2013-07-04 14:56:48 +0100 |
commit | 3de186a95a8c81cd83b9b4c7e5a7aa5cfbc12f5f (patch) | |
tree | ce623b195def168fdbf165c873a4575cbd689324 /src/pmon.erl | |
parent | c70ac2c72afad9035bd7290208a5da6cb0595fb7 (diff) | |
download | rabbitmq-server-3de186a95a8c81cd83b9b4c7e5a7aa5cfbc12f5f.tar.gz |
Get amqqueu_process to montor via delegate too, tighten delegate specs, simplify pmon parameterisation.
Diffstat (limited to 'src/pmon.erl')
-rw-r--r-- | src/pmon.erl | 33 |
1 files changed, 11 insertions, 22 deletions
diff --git a/src/pmon.erl b/src/pmon.erl index 136f6b90..1e31eb60 100644 --- a/src/pmon.erl +++ b/src/pmon.erl @@ -16,12 +16,12 @@ -module(pmon). --export([new/0, new/1, new/3, monitor/2, monitor_all/2, demonitor/2, +-export([new/0, new/1, monitor/2, monitor_all/2, demonitor/2, is_monitored/2, erase/2, monitored/1, is_empty/1]). -compile({no_auto_import, [monitor/2]}). --record(state, {dict, monitor, demonitor1, demonitor2}). +-record(state, {dict, module}). -ifdef(use_specs). @@ -29,18 +29,13 @@ -export_type([?MODULE/0]). --opaque(?MODULE() :: #state{dict :: dict(), - monitor :: fun((atom(), any()) -> any()), - demonitor1 :: fun((any()) -> 'true'), - demonitor2 :: fun((any(), [any()]) -> 'true')}). +-opaque(?MODULE() :: #state{dict :: dict(), + module :: atom()}). -type(item() :: pid() | {atom(), node()}). -spec(new/0 :: () -> ?MODULE()). -spec(new/1 :: ('erlang' | 'delegate') -> ?MODULE()). --spec(new/3 :: (fun((atom(), any()) -> any()), - fun((any()) -> 'true'), - fun((any(), [any()]) -> 'true')) -> ?MODULE()). -spec(monitor/2 :: (item(), ?MODULE()) -> ?MODULE()). -spec(monitor_all/2 :: ([item()], ?MODULE()) -> ?MODULE()). -spec(demonitor/2 :: (item(), ?MODULE()) -> ?MODULE()). @@ -53,29 +48,23 @@ new() -> new(erlang). -new(erlang) -> new(fun erlang:monitor/2, - fun erlang:demonitor/1, fun erlang:demonitor/2); -new(delegate) -> new(fun delegate:monitor/2, - fun delegate:demonitor/1, fun delegate:demonitor/2). +new(Module) -> #state{dict = dict:new(), + module = Module}. -new(Monitor, Demonitor1, Demonitor2) -> #state{dict = dict:new(), - monitor = Monitor, - demonitor1 = Demonitor1, - demonitor2 = Demonitor2}. - -monitor(Item, S = #state{dict = M, monitor = Monitor}) -> +monitor(Item, S = #state{dict = M, module = Module}) -> case dict:is_key(Item, M) of true -> S; - false -> S#state{dict = dict:store(Item, Monitor(process, Item), M)} + false -> S#state{dict = dict:store( + Item, Module:monitor(process, Item), M)} end. monitor_all([], S) -> S; %% optimisation monitor_all([Item], S) -> monitor(Item, S); %% optimisation monitor_all(Items, S) -> lists:foldl(fun monitor/2, S, Items). -demonitor(Item, S = #state{dict = M, demonitor1 = Demonitor1}) -> +demonitor(Item, S = #state{dict = M, module = Module}) -> case dict:find(Item, M) of - {ok, MRef} -> Demonitor1(MRef), + {ok, MRef} -> Module:demonitor(MRef), S#state{dict = dict:erase(Item, M)}; error -> M end. |