// // Copyright (c) ZeroC, Inc. All rights reserved. // using System; namespace Ice { /// /// Class to support thread notification hooks. Applications using /// thread notification hooks instantiate a ThreadHookPlugin with a /// thread notification hook and return the instance from their /// PluginFactory implementation. /// public class ThreadHookPlugin : Plugin { /// /// Installs a thread hook for a communicator. /// /// The communicator using the thread notification hook. /// The thread notification hook for the communicator. [Obsolete("This constructor is deprecated. Use the constructur with threadStart and threadStop parameters instead.")] public ThreadHookPlugin(Communicator communicator, ThreadNotification threadHook) : this(communicator, threadHook.start, threadHook.stop) { } /// /// Installs thread hooks for a communicator. /// /// The communicator using the thread notification hook. /// The start thread notification hook for the communicator. /// The stop thread notification hook for the communicator. public ThreadHookPlugin(Communicator communicator, System.Action threadStart, System.Action threadStop) { if(communicator == null) { PluginInitializationException ex = new PluginInitializationException(); ex.reason = "Communicator cannot be null"; throw ex; } IceInternal.Instance instance = IceInternal.Util.getInstance(communicator); instance.setThreadHook(threadStart, threadStop); } /// /// Called by the Ice run time during communicator initialization. The derived class /// can override this method to perform any initialization that might be required /// by the thread notification hook. /// public void initialize() { } /// /// Called by the Ice run time when the communicator is destroyed. The derived class /// can override this method to perform any finalization that might be required /// by thread notification hook. /// public void destroy() { } } }