Skip to content

Latest commit

 

History

History
90 lines (71 loc) · 3.06 KB

README.md

File metadata and controls

90 lines (71 loc) · 3.06 KB

PubSub .Net Build status

An extremely light-weight, easy to use .Net pub/sub library

The idea

  • Provide the ability to do de-coupled communitcation without having to include some large (and often opinionated) framework when all you want is pubsub
  • It should be portable so it can be used pretty much wherever
  • Make it stupid simple to use with zero setup

When is it useful?

In general, the publish/subscribe pattern is great when you want to communicate between pieces of your app without having those pieces being tightly dependent on each other. You might find this article on the subject interesting (it talks specifically about javascript, but the concept applies)

A few cases where I have found this library useful (namely in mobile development):

  • Persisting user settings to disk asynchronously
  • Posting a message (i.e. Twitter) and using Subscribe to refresh lists, update counts, etc.
  • Providing a nice, de-coupled communication medium between Activities and their child Fragments in a Xamarin.Android application.

There are lots of good applications for the publish/subscribe patterns. Have a good one I didn't think of? Let me know

How to use it

First, add a using.

using PubSub;

Listen for stuff you might be interested in.

public class Page
{
	public Page()
	{
		this.Subscribe<Product>( product =>
		{
			// highly interesting things
		});
	}
}

Tell others that interesting things happened.

public class OtherPage
{
	public void ProductPurchased()
	{
		this.Publish( new Product() );
	}
}

Stop listening when you don't care anymore.

public class Page
{
	public void WereDoneHere()
	{
		this.Unsubscribe<Product>();
	}
}

Some explanation

To keep things simple, yet flexible, PubSub PCL is implemented using two core ideas:

  • Different kinds of messages are delineated by CLR type.
    • This avoids the need to have a list of string constants (or just magic strings), enums, whatever to define what you want to listen for/send.
    • This gives us nice strongly-typed data that can be passed from our Publish methods to our Subscribe handlers (i.e. Product above)
  • All interaction with the PubSub system is done through extention methods on System.Object (e.g. Publish, Subscribe and Unsubscribe)
    • This allows for a zero-setup system, you can simply Subscribe on any object and Publish away

Get it on Nuget

Install-Package PubSub

nuget dialog image for PubSub PCL

Currently supported platforms

  • .Net Framwork 4.5 / 4.5.1
  • Windows 8 / 8.1
  • Windows Phone Silverlight 8 / 8.1
  • Windows Phone 8.1 (WinRT)
  • Silverlight 5
  • Xamarin.Android
  • Xamarin.iOS

Questions? Thoughts?

Feel free to post stuff to the issues page or hit me up on Twitter @brianupta