/* * Copyright (C) 2009 Google Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. * * Neither the name of Google Inc. nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef WebKit_h #define WebKit_h #include "WebCommon.h" namespace v8 { class Extension; } namespace WebKit { class WebKitClient; class WebString; // Must be called on the thread that will be the main WebKit thread before // using any other WebKit APIs. The provided WebKitClient must be non-null // and must remain valid until the current thread calls shutdown. WEBKIT_API void initialize(WebKitClient*); // Once shutdown, the WebKitClient passed to initialize will no longer be // accessed. No other WebKit objects should be in use when this function // is called. Any background threads created by WebKit are promised to be // terminated by the time this function returns. WEBKIT_API void shutdown(); // Returns the WebKitClient instance passed to initialize. WEBKIT_API WebKitClient* webKitClient(); // Alters the rendering of content to conform to a fixed set of rules. WEBKIT_API void setLayoutTestMode(bool); WEBKIT_API bool layoutTestMode(); // Registers a URL scheme to be treated as a local scheme (i.e., with the // same security rules as those applied to "file" URLs). This means that // normal pages cannot link to or access URLs of this scheme. WEBKIT_API void registerURLSchemeAsLocal(const WebString&); // Registers a URL scheme to be treated as a noAccess scheme. This means // that pages loaded with this URL scheme cannot access pages loaded with // any other URL scheme. WEBKIT_API void registerURLSchemeAsNoAccess(const WebString&); // Registers a v8 extension to be available on webpages with a particular // scheme. If the scheme argument is empty, the extension is available on // all pages. Will only affect v8 contexts initialized after this call. // Takes ownership of the v8::Extension object passed. WEBKIT_API void registerExtension(v8::Extension*); WEBKIT_API void registerExtension(v8::Extension*, const WebString& schemeRestriction); // Enables HTML5 worker support. WEBKIT_API void enableWebWorkers(); // Purge the plugin list cache. WEBKIT_API void resetPluginCache(); } // namespace WebKit #endif