Skip to content
This repository has been archived by the owner on Dec 20, 2022. It is now read-only.

cjbhaines/MemBroker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MemBroker

MemBroker is a lightweight in memory message broker for .NET. It can be used to reduce coupling and to communicate with different components in your system. Full credit must be given to the MVVM light team from whom I took the base concept of their Messenger class. MemBroker is a refactored, cleaner and extended version.

Build status

Features

  • Register for messages via base types, interfaces or concrete types
  • Register for messages with a filter func
  • Deliver sub types to base type registrations
  • Unregister entire receivers or specific registrations
  • WeakReferences are used to allow recipients to be garbage collected

Example

var messageBroker = new MessageBroker();

// Subscribe to messages
messageBroker.Register<TestMessage>(this, message =>
{
// Handle message
});

// Send message
messageBroker.Send(new TestMessage());

Interface

/// <summary>
/// Register to a given message type
/// </summary>
/// <typeparam name="TMessage">The type of the message to register to</typeparam>
/// <param name="recipient">The object to which the message will be delivered. This reference keeps the registration alive</param>
/// <param name="action">The callback to invoke upon receiving a message</param>
void Register<TMessage>(object recipient, Action<TMessage> action);

/// <summary>
/// Register to a given message type with an additional filter
/// </summary>
/// <typeparam name="TMessage">The type of the message to register to</typeparam>
/// <param name="recipient">The object to which the message will be delivered. This reference keeps the registration alive</param>
/// <param name="action">The callback to invoke upon receiving a message</param>
/// <param name="filter">A Func to filter messages</param>
void Register<TMessage>(object recipient, Action<TMessage> action, Func<TMessage, bool> filter);

/// <summary>
/// Send a message to all subscribers
/// </summary>
/// <typeparam name="TMessage">The type of the message to send</typeparam>
/// <param name="message">The message</param>
void Send<TMessage>(TMessage message);

/// <summary>
/// Send a collection of messages to all subscribers
/// </summary>
/// <typeparam name="TMessage">The type of the message to send</typeparam>
/// <param name="messages">The collection of messages</param>
void Send<TMessage>(IEnumerable<TMessage> messages);

/// <summary>
/// Unregister an entire recipient instance
/// </summary>
/// <param name="recipient">The recipient instance to unregister</param>
void Unregister(object recipient);

/// <summary>
/// Unregister a specific registration
/// </summary>
/// <typeparam name="TMessage">The message type to uregister</typeparam>
/// <param name="recipient">The recipient instance to unregister</param>
/// <param name="action">The callback reference</param>
void Unregister<TMessage>(object recipient, Action<TMessage> action);

/// <summary>
/// Remove any registrations for recipients that have been garbage collected
/// </summary>
void Cleanup();

/// <summary>
/// Remove all registrations
/// </summary>
void Clear();

About

MemBroker is a lightweight in-memory message broker for .NET

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages