mirror of
https://github.com/processone/ejabberd.git
synced 2024-11-28 16:34:13 +01:00
Avoid using broad p1_queue:queue() type wherever possible
This commit is contained in:
parent
6011135d24
commit
a2a061c1c8
@ -24,7 +24,7 @@
|
|||||||
|
|
||||||
-record(lqueue,
|
-record(lqueue,
|
||||||
{
|
{
|
||||||
queue = p1_queue:new() :: p1_queue:queue(),
|
queue = p1_queue:new() :: p1_queue:queue(lqueue_elem()),
|
||||||
max = 0 :: integer()
|
max = 0 :: integer()
|
||||||
}).
|
}).
|
||||||
|
|
||||||
@ -118,7 +118,7 @@
|
|||||||
just_created = erlang:system_time(microsecond) :: true | integer(),
|
just_created = erlang:system_time(microsecond) :: true | integer(),
|
||||||
activity = treap:empty() :: treap:treap(),
|
activity = treap:empty() :: treap:treap(),
|
||||||
room_shaper = none :: ejabberd_shaper:shaper(),
|
room_shaper = none :: ejabberd_shaper:shaper(),
|
||||||
room_queue :: p1_queue:queue() | undefined
|
room_queue :: p1_queue:queue({message | presence, jid()}) | undefined
|
||||||
}).
|
}).
|
||||||
|
|
||||||
-type users() :: #{ljid() => #user{}}.
|
-type users() :: #{ljid() => #user{}}.
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
%%%----------------------------------------------------------------------
|
%%%----------------------------------------------------------------------
|
||||||
|
|
||||||
{deps, [{lager, ".*", {git, "https://github.com/erlang-lager/lager", "3.6.10"}},
|
{deps, [{lager, ".*", {git, "https://github.com/erlang-lager/lager", "3.6.10"}},
|
||||||
{p1_utils, ".*", {git, "https://github.com/processone/p1_utils", {tag, "1.0.15"}}},
|
{p1_utils, ".*", {git, "https://github.com/processone/p1_utils", "2887223"}},
|
||||||
{cache_tab, ".*", {git, "https://github.com/processone/cache_tab", {tag, "1.0.19"}}},
|
{cache_tab, ".*", {git, "https://github.com/processone/cache_tab", {tag, "1.0.19"}}},
|
||||||
{fast_tls, ".*", {git, "https://github.com/processone/fast_tls", {tag, "1.1.1"}}},
|
{fast_tls, ".*", {git, "https://github.com/processone/fast_tls", {tag, "1.1.1"}}},
|
||||||
{stringprep, ".*", {git, "https://github.com/processone/stringprep", {tag, "1.0.16"}}},
|
{stringprep, ".*", {git, "https://github.com/processone/stringprep", {tag, "1.0.16"}}},
|
||||||
|
@ -55,8 +55,9 @@
|
|||||||
-record(state, {connection :: pid() | undefined,
|
-record(state, {connection :: pid() | undefined,
|
||||||
num :: pos_integer(),
|
num :: pos_integer(),
|
||||||
subscriptions = #{} :: subscriptions(),
|
subscriptions = #{} :: subscriptions(),
|
||||||
pending_q :: p1_queue:queue()}).
|
pending_q :: queue()}).
|
||||||
|
|
||||||
|
-type queue() :: p1_queue:queue({{pid(), term()}, integer()}).
|
||||||
-type subscriptions() :: #{binary() => [pid()]}.
|
-type subscriptions() :: #{binary() => [pid()]}.
|
||||||
-type error_reason() :: binary() | timeout | disconnected | overloaded.
|
-type error_reason() :: binary() | timeout | disconnected | overloaded.
|
||||||
-type redis_error() :: {error, error_reason()}.
|
-type redis_error() :: {error, error_reason()}.
|
||||||
@ -592,7 +593,7 @@ fsm_limit_opts() ->
|
|||||||
get_queue_type() ->
|
get_queue_type() ->
|
||||||
ejabberd_option:redis_queue_type().
|
ejabberd_option:redis_queue_type().
|
||||||
|
|
||||||
-spec flush_queue(p1_queue:queue()) -> p1_queue:queue().
|
-spec flush_queue(queue()) -> queue().
|
||||||
flush_queue(Q) ->
|
flush_queue(Q) ->
|
||||||
CurrTime = erlang:monotonic_time(millisecond),
|
CurrTime = erlang:monotonic_time(millisecond),
|
||||||
p1_queue:dropwhile(
|
p1_queue:dropwhile(
|
||||||
@ -605,7 +606,7 @@ flush_queue(Q) ->
|
|||||||
true
|
true
|
||||||
end, Q).
|
end, Q).
|
||||||
|
|
||||||
-spec clean_queue(p1_queue:queue(), integer()) -> p1_queue:queue().
|
-spec clean_queue(queue(), integer()) -> queue().
|
||||||
clean_queue(Q, CurrTime) ->
|
clean_queue(Q, CurrTime) ->
|
||||||
Q1 = p1_queue:dropwhile(
|
Q1 = p1_queue:dropwhile(
|
||||||
fun({_From, Time}) ->
|
fun({_From, Time}) ->
|
||||||
|
@ -46,7 +46,7 @@
|
|||||||
id = 0 :: non_neg_integer(),
|
id = 0 :: non_neg_integer(),
|
||||||
in_flight :: undefined | publish() | pubrel(),
|
in_flight :: undefined | publish() | pubrel(),
|
||||||
codec :: mqtt_codec:state(),
|
codec :: mqtt_codec:state(),
|
||||||
queue :: undefined | p1_queue:queue(),
|
queue :: undefined | p1_queue:queue(publish()),
|
||||||
tls :: boolean()}).
|
tls :: boolean()}).
|
||||||
|
|
||||||
-type acks() :: #{non_neg_integer() => pubrec()}.
|
-type acks() :: #{non_neg_integer() => pubrec()}.
|
||||||
|
@ -1540,7 +1540,7 @@ get_service_max_users(StateData) ->
|
|||||||
get_max_users_admin_threshold(StateData) ->
|
get_max_users_admin_threshold(StateData) ->
|
||||||
mod_muc_opt:max_users_admin_threshold(StateData#state.server_host).
|
mod_muc_opt:max_users_admin_threshold(StateData#state.server_host).
|
||||||
|
|
||||||
-spec room_queue_new(binary(), ejabberd_shaper:shaper(), _) -> p1_queue:queue().
|
-spec room_queue_new(binary(), ejabberd_shaper:shaper(), _) -> p1_queue:queue({message | presence, jid()}) | undefined.
|
||||||
room_queue_new(ServerHost, Shaper, QueueType) ->
|
room_queue_new(ServerHost, Shaper, QueueType) ->
|
||||||
HaveRoomShaper = Shaper /= none,
|
HaveRoomShaper = Shaper /= none,
|
||||||
HaveMessageShaper = mod_muc_opt:user_message_shaper(ServerHost) /= none,
|
HaveMessageShaper = mod_muc_opt:user_message_shaper(ServerHost) /= none,
|
||||||
@ -2121,7 +2121,7 @@ get_history(Nick, Packet, #state{history = History}) ->
|
|||||||
p1_queue:to_list(History#lqueue.queue)
|
p1_queue:to_list(History#lqueue.queue)
|
||||||
end.
|
end.
|
||||||
|
|
||||||
-spec filter_history(p1_queue:queue(), erlang:timestamp(),
|
-spec filter_history(p1_queue:queue(lqueue_elem()), erlang:timestamp(),
|
||||||
binary(), muc_history()) -> [lqueue_elem()].
|
binary(), muc_history()) -> [lqueue_elem()].
|
||||||
filter_history(Queue, Now, Nick,
|
filter_history(Queue, Now, Nick,
|
||||||
#muc_history{since = Since,
|
#muc_history{since = Since,
|
||||||
@ -2516,7 +2516,7 @@ lqueue_in(Item, #lqueue{queue = Q1, max = Max}) ->
|
|||||||
true -> #lqueue{queue = Q2, max = Max}
|
true -> #lqueue{queue = Q2, max = Max}
|
||||||
end.
|
end.
|
||||||
|
|
||||||
-spec lqueue_cut(p1_queue:queue(), non_neg_integer()) -> p1_queue:queue().
|
-spec lqueue_cut(p1_queue:queue(lqueue_elem()), non_neg_integer()) -> p1_queue:queue(lqueue_elem()).
|
||||||
lqueue_cut(Q, 0) -> Q;
|
lqueue_cut(Q, 0) -> Q;
|
||||||
lqueue_cut(Q, N) ->
|
lqueue_cut(Q, N) ->
|
||||||
{_, Q1} = p1_queue:out(Q),
|
{_, Q1} = p1_queue:out(Q),
|
||||||
|
@ -50,6 +50,7 @@
|
|||||||
is_record(Pkt, sm_r)).
|
is_record(Pkt, sm_r)).
|
||||||
|
|
||||||
-type state() :: ejabberd_c2s:state().
|
-type state() :: ejabberd_c2s:state().
|
||||||
|
-type queue() :: p1_queue:queue({non_neg_integer(), erlang:timestamp(), xmpp_element() | xmlel()}).
|
||||||
-type error_reason() :: session_not_found | session_timed_out |
|
-type error_reason() :: session_not_found | session_timed_out |
|
||||||
session_is_dead | session_has_exited |
|
session_is_dead | session_has_exited |
|
||||||
session_was_killed | session_copy_timed_out |
|
session_was_killed | session_copy_timed_out |
|
||||||
@ -298,7 +299,7 @@ set_resume_timeout(State, Timeout) ->
|
|||||||
State1 = restart_pending_timer(State, Timeout),
|
State1 = restart_pending_timer(State, Timeout),
|
||||||
State1#{mgmt_timeout => Timeout}.
|
State1#{mgmt_timeout => Timeout}.
|
||||||
|
|
||||||
-spec queue_find(fun((stanza()) -> boolean()), p1_queue:queue())
|
-spec queue_find(fun((stanza()) -> boolean()), queue())
|
||||||
-> stanza() | none.
|
-> stanza() | none.
|
||||||
queue_find(Pred, Queue) ->
|
queue_find(Pred, Queue) ->
|
||||||
case p1_queue:out(Queue) of
|
case p1_queue:out(Queue) of
|
||||||
|
Loading…
Reference in New Issue
Block a user