// Copyright © 2016 The CefSharp Authors. All rights reserved. // // Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. using System; using System.Collections.Generic; namespace CefSharp { /// /// Implement this interface to handle events related to browser process callbacks. /// The methods of this class will be called on the CEF UI thread unless otherwise indicated. . /// public interface IBrowserProcessHandler : IDisposable { /// /// Called on the CEF UI thread immediately after the CEF context has been initialized. /// You can now access the Global RequestContext through Cef.GetGlobalRequestContext() - this is the /// first place you can set Preferences (e.g. proxy settings, spell check dictionaries). /// void OnContextInitialized(); /// /// Called from any thread when work has been scheduled for the browser process /// main (UI) thread. This callback is used in combination with CefSettings. /// ExternalMessagePump and Cef.DoMessageLoopWork() in cases where the CEF /// message loop must be integrated into an existing application message loop /// (see additional comments and warnings on Cef.DoMessageLoopWork). This /// callback should schedule a Cef.DoMessageLoopWork() call to happen on the /// main (UI) thread. /// /// is the requested delay in milliseconds. If /// delay is less than or equal to 0 then the call should happen reasonably soon. If /// delay is greater than 0 then the call should be scheduled to happen after the /// specified delay and any currently pending scheduled call should be /// cancelled. void OnScheduleMessagePumpWork(long delay); /// /// Implement this method to provide app-specific behavior when an already /// running app is relaunched with the same CefSettings.RootCachePath value. /// For example, activate an existing app window or create a new app window. /// /// To avoid cache corruption only a single app instance is allowed to run for /// a given CefSettings.RootCachePath value. On relaunch the app checks a /// process singleton lock and then forwards the new launch arguments to the /// already running app process before exiting early. Client apps should /// therefore check the Cef.Initialize() return value for early exit before /// proceeding. /// /// It's important to note that this method will be called on a CEF UI thread, /// which by default is not the same as your application UI thread. /// /// /// Readonly command line args /// current directory (optional) /// /// Return true if the relaunch is handled or false for default relaunch /// behavior. Default behavior will create a new default styled Chrome window. /// /// /// The dictionary may contain keys that have empty string values /// (arugments). /// bool OnAlreadyRunningAppRelaunch(IReadOnlyDictionary commandLine, string currentDirectory); } }