-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathIMessenger.cs
125 lines (111 loc) · 5.91 KB
/
IMessenger.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
using System;
using System.Collections.Generic;
namespace Messenger
{
public interface IMessenger
{
/// <summary>
/// Subscribe to a message type with the given destination and delivery action.
/// </summary>
/// <typeparam name="TMessage">Type of message</typeparam>
/// <param name="deliveryAction">Action to invoke when message is delivered</param>
/// <param name="reference">Use a strong or weak reference to the deliveryAction</param>
/// <param name="tag">An optional tag to include with this subscription</param>
/// <returns>MessageSubscription used to unsubscribing</returns>
MessengerSubscriptionToken Subscribe<TMessage>(Action<TMessage> deliveryAction, MessengerReference reference = MessengerReference.Weak, string tag = null)
where TMessage : MessengerMessage;
/// <summary>
/// Subscribe to a message type with the given destination and delivery action.
/// This subscription always invokes the delivery Action on the Main thread.
/// </summary>
/// <typeparam name="TMessage">Type of message</typeparam>
/// <param name="deliveryAction">Action to invoke when message is delivered</param>
/// <param name="reference">Use a strong or weak reference to the deliveryAction</param>
/// <param name="tag">An optional tag to include with this subscription</param>
/// <returns>MessageSubscription used to unsubscribing</returns>
MessengerSubscriptionToken SubscribeOnMainThread<TMessage>(Action<TMessage> deliveryAction, MessengerReference reference = MessengerReference.Weak, string tag = null)
where TMessage : MessengerMessage;
/// <summary>
/// Subscribe to a message type with the given destination and delivery action.
/// This subscription always invokes the delivery Action called on a threadpool thread.
/// </summary>
/// <typeparam name="TMessage">Type of message</typeparam>
/// <param name="deliveryAction">Action to invoke when message is delivered</param>
/// <param name="reference">Use a strong or weak reference to the deliveryAction</param>
/// <param name="tag">An optional tag to include with this subscription</param>
/// <returns>MessageSubscription used to unsubscribing</returns>
MessengerSubscriptionToken SubscribeOnThreadPoolThread<TMessage>(Action<TMessage> deliveryAction, MessengerReference reference = MessengerReference.Weak, string tag = null)
where TMessage : MessengerMessage;
/// <summary>
/// Unsubscribe from a particular message type.
/// </summary>
/// <typeparam name="TMessage">Type of message</typeparam>
/// <param name="mvxSubscriptionId">Subscription to remove</param>
void Unsubscribe<TMessage>(MessengerSubscriptionToken subscriptionId)
where TMessage : MessengerMessage;
/// <summary>
/// Has subscriptions for TMessage
/// </summary>
/// <typeparam name="TMessage"></typeparam>
/// <returns></returns>
bool HasSubscriptionsFor<TMessage>()
where TMessage : MessengerMessage;
/// <summary>
/// Number of subscriptions for TMessage
/// </summary>
/// <typeparam name="TMessage"></typeparam>
/// <returns></returns>
int CountSubscriptionsFor<TMessage>()
where TMessage : MessengerMessage;
/// <summary>
/// Has subscriptions for TMessage with a tag value of tag
/// </summary>
/// <typeparam name="TMessage"></typeparam>
/// <param name="tag">An optional tag to include with this subscription</param>
/// <returns></returns>
bool HasSubscriptionsForTag<TMessage>(string tag)
where TMessage : MessengerMessage;
/// <summary>
/// Number of subscriptions for TMessage with a tag value of tag
/// </summary>
/// <typeparam name="TMessage"></typeparam>
/// <param name="tag">An optional tag to include with this subscription</param>
/// <returns></returns>
int CountSubscriptionsForTag<TMessage>(string tag)
where TMessage : MessengerMessage;
/// <summary>
/// Get all the tags (including nulls) for subscriptions for TMessage
/// </summary>
/// <typeparam name="TMessage"></typeparam>
/// <returns></returns>
IList<string> GetSubscriptionTagsFor<TMessage>()
where TMessage : MessengerMessage;
/// <summary>
/// Publish a message to any subscribers
/// </summary>
/// <typeparam name="TMessage">Type of message</typeparam>
/// <param name="message">Message to deliver</param>
void Publish<TMessage>(TMessage message) where TMessage : MessengerMessage;
/// <summary>
/// Publish a message to any subscribers
/// - GetType() will be used to determine the message type
/// </summary>
/// <param name="message">Message to deliver</param>
void Publish(MessengerMessage message);
/// <summary>
/// Publish a message to any subscribers
/// </summary>
/// <param name="message">Message to deliver</param>
/// <param name="messageType">The type of the message to use for delivery - message should be of that class or a of a subclass</param>
void Publish(MessengerMessage message, Type messageType);
/// <summary>
/// Schedules a check on all subscribers for the specified messageType. If any are not alive, they will be removed
/// </summary>
/// <param name="messageType">The type of the message to check</param>
void RequestPurge(Type messageType);
/// <summary>
/// Schedules a check on all subscribers for all messageType. If any are not alive, they will be removed
/// </summary>
void RequestPurgeAll();
}
}