Skip to content

upta/pubsub

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

#PubSub PCL Build status

An extremely light-weight, easy to use PCL 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

About

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

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages