I am writing an Addin Framework in C# and I'm wondering how I can make Addin's unloadable without requiring a restart of the application.
I heard of AppDomains but how do these work? Can an Addin add extendability classes and be called in the Main AppDomain by Interfaces and still be unloadable and call cleanup code resulting in those classes being removed without that Assembly being in the Main AppDomain?
Or are there other methods of achieving unloadable addins, but IIRC other then AppDomain's you cannot unload an Assembly.
I also want the addin engine to be compatible with Mono if possible, so any answers try to stay compatible with Mono, if you can.
You might want to look at Mono.Addins. There are some good looking samples here, Here are some of the details:.
The following code is a basic example of an add-in host application. This application runs a set of commands which can be implemented by add-ins:
using System;
using Mono.Addins;
[assembly:AddinRoot ("HelloWorld", "1.0")]
class MainClass
{
public static void Main ()
{
AddinManager.Initialize ();
AddinManager.Registry.Update ();
foreach (ICommand cmd in AddinManager.GetExtensionObjects<ICommand> ())
cmd.Run ();
}
}
The extension point for the above example can be declared like this:
using Mono.Addins;
[TypeExtensionPoint]
public interface ICommand
{
void Run ();
}
An add-in extending the above extension point would look like this:
using System;
using Mono.Addins;
[assembly:Addin]
[assembly:AddinDependency ("HelloWorld", "1.0")]
[Extension]
public class HelloCommand: ICommand
{
public void Run ()
{
Console.WriteLine ("Hello World!");
}
}
You didn't explicitly ask how to dynamically load add-in or plug-ins, but you can see this question (and my answer) on StackOverflow.com on how to do so.
There is only one way that I am aware of to unload dynamically loaded plug-ins and add-ins: by loading the add-in in a separate AppDomain
and unloading the AppDomain
. For more information see this article on MSDN.
Why reinvent something that already exists? I know of two plug-in frameworks.
System.AddIn
namespace Some people talk about the Managed Extensibility Framework (MEF) as a plug-in or add-in framework, which it isn't. For more information see this StackOverflow.com question and this StackOverflow.com question.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With