2009-09-09 15:00:14 -07:00
|
|
|
/* -*- Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil; tab-width: 8 -*- */
|
2009-08-18 12:05:15 -07:00
|
|
|
/* vim: set sw=4 ts=8 et tw=80 ft=cpp : */
|
|
|
|
|
2012-05-21 04:12:37 -07:00
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
2009-08-25 16:07:22 -07:00
|
|
|
|
2012-08-01 23:02:29 -07:00
|
|
|
include protocol PBlob;
|
2014-02-23 12:19:43 -08:00
|
|
|
include protocol PColorPicker;
|
2010-07-19 11:33:33 -07:00
|
|
|
include protocol PContent;
|
2014-06-10 22:44:13 -07:00
|
|
|
include protocol PContentBridge;
|
2010-04-27 00:12:38 -07:00
|
|
|
include protocol PDocumentRenderer;
|
2010-09-09 22:00:08 -07:00
|
|
|
include protocol PContentPermissionRequest;
|
2014-02-17 16:30:06 -08:00
|
|
|
include protocol PFilePicker;
|
2014-09-26 16:21:57 -07:00
|
|
|
include protocol PIndexedDBPermissionRequest;
|
2010-08-20 16:24:41 -07:00
|
|
|
include protocol PRenderFrame;
|
2014-11-12 12:59:18 -08:00
|
|
|
include protocol PPluginWidget;
|
2012-08-23 12:33:46 -07:00
|
|
|
include DOMTypes;
|
2013-07-10 15:05:39 -07:00
|
|
|
include JavaScriptTypes;
|
2012-08-23 12:33:46 -07:00
|
|
|
include URIParams;
|
2014-02-09 12:34:40 -08:00
|
|
|
include PContentPermission;
|
2015-02-06 15:31:33 -08:00
|
|
|
include ServiceWorkerRegistrarTypes;
|
2009-09-09 15:00:14 -07:00
|
|
|
|
2012-08-01 23:02:29 -07:00
|
|
|
|
2013-10-01 12:25:07 -07:00
|
|
|
using class IPC::Principal from "mozilla/dom/PermissionMessageUtils.h";
|
2014-06-18 17:57:51 -07:00
|
|
|
using class mozilla::gfx::Matrix from "mozilla/gfx/Matrix.h";
|
2013-10-01 12:25:07 -07:00
|
|
|
using struct gfxSize from "gfxPoint.h";
|
|
|
|
using CSSRect from "Units.h";
|
2015-02-04 12:21:03 -08:00
|
|
|
using LayoutDeviceIntRect from "Units.h";
|
2013-10-01 12:25:07 -07:00
|
|
|
using struct mozilla::layers::FrameMetrics from "FrameMetrics.h";
|
2013-11-13 10:20:31 -08:00
|
|
|
using struct mozilla::layers::ScrollableLayerGuid from "FrameMetrics.h";
|
2014-01-06 10:26:44 -08:00
|
|
|
using struct mozilla::layers::ZoomConstraints from "FrameMetrics.h";
|
2013-10-01 12:25:07 -07:00
|
|
|
using FrameMetrics::ViewID from "FrameMetrics.h";
|
|
|
|
using mozilla::layout::ScrollingBehavior from "mozilla/layout/RenderFrameUtils.h";
|
|
|
|
using struct mozilla::void_t from "ipc/IPCMessageUtils.h";
|
|
|
|
using mozilla::WindowsHandle from "ipc/IPCMessageUtils.h";
|
|
|
|
using nscolor from "nsColor.h";
|
|
|
|
using class mozilla::WidgetCompositionEvent from "ipc/nsGUIEventIPC.h";
|
2014-09-11 06:46:17 -07:00
|
|
|
using struct mozilla::widget::IMENotification from "nsIWidget.h";
|
2013-10-01 12:25:07 -07:00
|
|
|
using struct nsIMEUpdatePreference from "nsIWidget.h";
|
|
|
|
using struct nsIntPoint from "nsPoint.h";
|
|
|
|
using struct nsIntRect from "nsRect.h";
|
|
|
|
using struct nsIntSize from "nsSize.h";
|
|
|
|
using class mozilla::WidgetKeyboardEvent from "ipc/nsGUIEventIPC.h";
|
|
|
|
using class mozilla::WidgetMouseEvent from "ipc/nsGUIEventIPC.h";
|
|
|
|
using class mozilla::WidgetWheelEvent from "ipc/nsGUIEventIPC.h";
|
|
|
|
using struct nsRect from "nsRect.h";
|
|
|
|
using class mozilla::WidgetSelectionEvent from "ipc/nsGUIEventIPC.h";
|
|
|
|
using class mozilla::WidgetTouchEvent from "ipc/nsGUIEventIPC.h";
|
|
|
|
using struct mozilla::dom::RemoteDOMEvent from "mozilla/dom/TabMessageUtils.h";
|
|
|
|
using mozilla::dom::ScreenOrientation from "mozilla/dom/ScreenOrientation.h";
|
|
|
|
using struct mozilla::layers::TextureFactoryIdentifier from "mozilla/layers/CompositorTypes.h";
|
2014-03-12 12:27:45 -07:00
|
|
|
using mozilla::CSSPoint from "Units.h";
|
2013-10-01 12:25:07 -07:00
|
|
|
using mozilla::CSSToScreenScale from "Units.h";
|
2014-03-20 08:46:29 -07:00
|
|
|
using mozilla::CommandInt from "mozilla/EventForwards.h";
|
2014-04-15 10:39:20 -07:00
|
|
|
using mozilla::layers::GeckoContentController::APZStateChange from "mozilla/layers/GeckoContentController.h";
|
2014-12-04 18:15:43 -08:00
|
|
|
using mozilla::WritingMode from "WritingModes.h";
|
2013-10-01 12:25:07 -07:00
|
|
|
|
2009-08-25 16:07:22 -07:00
|
|
|
namespace mozilla {
|
2009-09-09 15:00:14 -07:00
|
|
|
namespace dom {
|
2009-08-25 16:07:22 -07:00
|
|
|
|
2014-03-20 08:46:29 -07:00
|
|
|
struct NativeKeyBinding
|
|
|
|
{
|
|
|
|
CommandInt[] singleLineCommands;
|
|
|
|
CommandInt[] multiLineCommands;
|
|
|
|
CommandInt[] richTextCommands;
|
|
|
|
};
|
|
|
|
|
2015-02-06 15:31:33 -08:00
|
|
|
struct BrowserConfiguration
|
|
|
|
{
|
|
|
|
ServiceWorkerRegistrationData[] serviceWorkerRegistrations;
|
|
|
|
};
|
|
|
|
|
2014-03-20 08:46:29 -07:00
|
|
|
union MaybeNativeKeyBinding
|
|
|
|
{
|
|
|
|
NativeKeyBinding;
|
|
|
|
void_t;
|
|
|
|
};
|
|
|
|
|
2014-11-24 11:05:35 -08:00
|
|
|
struct ShowInfo
|
|
|
|
{
|
|
|
|
nsString name;
|
|
|
|
bool fullscreenAllowed;
|
|
|
|
bool isPrivate;
|
2014-12-12 09:50:46 -08:00
|
|
|
float dpi;
|
|
|
|
double defaultScale;
|
2014-11-24 11:05:35 -08:00
|
|
|
};
|
|
|
|
|
2015-01-16 10:07:50 -08:00
|
|
|
struct FrameScriptInfo
|
|
|
|
{
|
|
|
|
nsString url;
|
|
|
|
bool runInGlobalScope;
|
|
|
|
};
|
|
|
|
|
2015-01-28 11:53:46 -08:00
|
|
|
prio(normal upto urgent) sync protocol PBrowser
|
2009-08-25 16:07:22 -07:00
|
|
|
{
|
2014-06-10 22:44:13 -07:00
|
|
|
manager PContent or PContentBridge;
|
2010-07-19 11:33:33 -07:00
|
|
|
|
2014-02-23 12:19:43 -08:00
|
|
|
manages PColorPicker;
|
2009-10-29 10:58:31 -07:00
|
|
|
manages PDocumentRenderer;
|
2010-09-09 22:00:08 -07:00
|
|
|
manages PContentPermissionRequest;
|
2014-02-17 16:30:06 -08:00
|
|
|
manages PFilePicker;
|
2014-09-26 16:21:57 -07:00
|
|
|
manages PIndexedDBPermissionRequest;
|
2010-08-20 16:24:41 -07:00
|
|
|
manages PRenderFrame;
|
2014-11-12 12:59:18 -08:00
|
|
|
manages PPluginWidget;
|
2010-07-19 11:33:33 -07:00
|
|
|
|
|
|
|
both:
|
2013-11-06 09:21:15 -08:00
|
|
|
AsyncMessage(nsString aMessage, ClonedMessageData aData, CpowEntry[] aCpows,
|
|
|
|
Principal aPrincipal);
|
2009-09-09 15:00:14 -07:00
|
|
|
|
2014-11-16 10:23:22 -08:00
|
|
|
/**
|
|
|
|
* Create a layout frame (encapsulating a remote layer tree) for
|
|
|
|
* the page that is currently loaded in the <browser>.
|
|
|
|
*/
|
|
|
|
PRenderFrame();
|
|
|
|
|
2009-11-05 10:14:22 -08:00
|
|
|
parent:
|
2014-11-12 12:59:18 -08:00
|
|
|
/*
|
|
|
|
* Creates a new remoted nsIWidget connection for windowed plugins
|
|
|
|
* in e10s mode. This is always initiated from the child in response
|
|
|
|
* to windowed plugin creation.
|
|
|
|
*/
|
|
|
|
sync PPluginWidget();
|
|
|
|
|
2015-01-23 02:10:52 -08:00
|
|
|
/**
|
|
|
|
* Return native data of root widget
|
|
|
|
*/
|
|
|
|
sync GetWidgetNativeData() returns (WindowsHandle value);
|
|
|
|
|
|
|
|
parent:
|
2009-11-05 10:14:22 -08:00
|
|
|
/**
|
|
|
|
* When child sends this message, parent should move focus to
|
|
|
|
* the next or previous focusable element.
|
|
|
|
*/
|
2010-07-19 11:33:33 -07:00
|
|
|
MoveFocus(bool forward);
|
2009-11-05 10:14:22 -08:00
|
|
|
|
2010-07-19 11:33:33 -07:00
|
|
|
Event(RemoteDOMEvent aEvent);
|
2009-12-31 17:35:55 -08:00
|
|
|
|
2015-01-16 10:07:50 -08:00
|
|
|
sync CreateWindow(PBrowser aNewTab,
|
|
|
|
uint32_t aChromeFlags,
|
2014-06-20 11:07:47 -07:00
|
|
|
bool aCalledFromJS,
|
|
|
|
bool aPositionSpecified,
|
|
|
|
bool aSizeSpecified,
|
|
|
|
nsString aURI,
|
|
|
|
nsString aName,
|
|
|
|
nsString aFeatures,
|
|
|
|
nsString aBaseURI)
|
2015-01-22 20:00:18 -08:00
|
|
|
returns (bool windowOpened, FrameScriptInfo[] frameScripts, nsCString urlToLoad);
|
2010-02-20 09:05:20 -08:00
|
|
|
|
2013-11-06 09:21:15 -08:00
|
|
|
sync SyncMessage(nsString aMessage, ClonedMessageData aData,
|
|
|
|
CpowEntry[] aCpows, Principal aPrincipal)
|
2010-03-29 13:29:45 -07:00
|
|
|
returns (nsString[] retval);
|
|
|
|
|
2014-10-07 21:32:45 -07:00
|
|
|
prio(high) sync RpcMessage(nsString aMessage, ClonedMessageData aData,
|
|
|
|
CpowEntry[] aCpows, Principal aPrincipal)
|
2013-10-01 09:15:06 -07:00
|
|
|
returns (nsString[] retval);
|
|
|
|
|
2010-10-01 07:17:37 -07:00
|
|
|
/**
|
|
|
|
* The IME sequence number (seqno) parameter is used to make sure
|
|
|
|
* that a notification is discarded if it arrives at the chrome process
|
|
|
|
* too late. If the notification is late and we accept it, we will have
|
|
|
|
* an out-of-date view of the content process, which means events that we
|
|
|
|
* dispatch based on this out-of-date view will be wrong also.
|
|
|
|
* (see Bug 599550 and Bug 591047 comments 44, 50, and 54)
|
|
|
|
*
|
|
|
|
* Chrome increments seqno and includes it in each IME event sent to
|
|
|
|
* content, and content sends its current seqno back to chrome with each
|
|
|
|
* notification. A notification is up-to-date only if the content
|
|
|
|
* seqno is the same as the current chrome seqno, meaning no additional
|
|
|
|
* event was sent to content before the notification was received
|
|
|
|
*
|
|
|
|
* On blur, chrome returns the current seqno to content, and content
|
|
|
|
* uses it to discard subsequent events until the content seqno and
|
|
|
|
* chrome seqno-on-blur match again. These events, meant for the blurred
|
|
|
|
* textfield, are discarded to prevent events going to the wrong target
|
|
|
|
*/
|
|
|
|
|
2010-09-23 20:28:15 -07:00
|
|
|
/**
|
|
|
|
* Notifies chrome that there is a focus change involving an editable
|
|
|
|
* object (input, textarea, document, contentEditable. etc.)
|
|
|
|
*
|
2012-10-25 09:32:24 -07:00
|
|
|
* focus PR_TRUE if editable object is receiving focus
|
|
|
|
* PR_FALSE if losing focus
|
2010-09-23 20:28:15 -07:00
|
|
|
* preference Native widget preference for IME updates
|
2010-10-01 07:17:37 -07:00
|
|
|
* seqno Current seqno value on the chrome side
|
2010-09-23 20:28:15 -07:00
|
|
|
*/
|
2014-10-30 15:51:39 -07:00
|
|
|
prio(urgent) sync NotifyIMEFocus(bool focus)
|
2012-08-22 08:56:38 -07:00
|
|
|
returns (nsIMEUpdatePreference preference, uint32_t seqno);
|
2010-09-23 20:28:15 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Notifies chrome that there has been a change in text content
|
|
|
|
* One call can encompass both a delete and an insert operation
|
2012-10-25 09:32:24 -07:00
|
|
|
* Only called when NotifyIMEFocus returns PR_TRUE for mWantUpdates
|
2010-09-23 20:28:15 -07:00
|
|
|
*
|
|
|
|
* offset Starting offset of the change
|
|
|
|
* end Ending offset of the range deleted
|
|
|
|
* newEnd New ending offset after insertion
|
2014-02-25 16:48:02 -08:00
|
|
|
* causedByComposition true if the change is caused by composition
|
2010-09-23 20:28:15 -07:00
|
|
|
*
|
|
|
|
* for insertion, offset == end
|
|
|
|
* for deletion, offset == newEnd
|
|
|
|
*/
|
2014-10-30 15:51:39 -07:00
|
|
|
prio(urgent) async NotifyIMETextChange(uint32_t offset, uint32_t end,
|
|
|
|
uint32_t newEnd,
|
|
|
|
bool causedByComposition);
|
2010-09-23 20:28:15 -07:00
|
|
|
|
2013-11-06 16:11:11 -08:00
|
|
|
/**
|
|
|
|
* Notifies chrome that there is a IME compostion rect updated
|
|
|
|
*
|
|
|
|
* offset The starting offset of this rect
|
|
|
|
* rect The rect of first character of selected IME composition
|
2014-09-15 00:11:08 -07:00
|
|
|
* caretOffset The offset of caret position
|
2014-01-16 02:04:39 -08:00
|
|
|
* caretRect The rect of IME caret
|
2013-11-06 16:11:11 -08:00
|
|
|
*/
|
2014-10-30 15:51:39 -07:00
|
|
|
prio(urgent) async NotifyIMESelectedCompositionRect(uint32_t offset,
|
2015-02-04 12:21:03 -08:00
|
|
|
LayoutDeviceIntRect[] rect,
|
2014-10-30 15:51:39 -07:00
|
|
|
uint32_t caretOffset,
|
2015-02-04 12:21:03 -08:00
|
|
|
LayoutDeviceIntRect caretRect);
|
2013-11-06 16:11:11 -08:00
|
|
|
|
2010-09-23 20:28:15 -07:00
|
|
|
/**
|
|
|
|
* Notifies chrome that there has been a change in selection
|
2012-10-25 09:32:24 -07:00
|
|
|
* Only called when NotifyIMEFocus returns PR_TRUE for mWantUpdates
|
2010-09-23 20:28:15 -07:00
|
|
|
*
|
2010-10-01 07:17:37 -07:00
|
|
|
* seqno Current seqno value on the content side
|
2010-09-23 20:28:15 -07:00
|
|
|
* anchor Offset where the selection started
|
|
|
|
* focus Offset where the caret is
|
2014-12-04 18:15:43 -08:00
|
|
|
* writingMode CSS writing-mode in effect at the focus
|
2014-02-25 16:48:02 -08:00
|
|
|
* causedByComposition true if the change is caused by composition
|
2010-09-23 20:28:15 -07:00
|
|
|
*/
|
2014-10-30 15:51:39 -07:00
|
|
|
prio(urgent) async NotifyIMESelection(uint32_t seqno, uint32_t anchor,
|
2014-12-04 18:15:43 -08:00
|
|
|
uint32_t focus,
|
|
|
|
WritingMode writingMode,
|
|
|
|
bool causedByComposition);
|
2010-09-23 20:28:15 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Notifies chrome to refresh its text cache
|
|
|
|
*
|
|
|
|
* text The entire content of the text field
|
|
|
|
*/
|
2014-10-30 15:51:39 -07:00
|
|
|
prio(urgent) async NotifyIMETextHint(nsString text);
|
2010-09-23 20:28:15 -07:00
|
|
|
|
2014-09-11 06:46:17 -07:00
|
|
|
/**
|
|
|
|
* Notifies IME of mouse button event on a character in focused editor.
|
|
|
|
*
|
|
|
|
* Returns true if the mouse button event is consumd by IME.
|
|
|
|
*/
|
2014-10-30 15:51:39 -07:00
|
|
|
prio(urgent) sync NotifyIMEMouseButtonEvent(IMENotification notification)
|
2014-09-11 06:46:17 -07:00
|
|
|
returns (bool consumedByIME);
|
|
|
|
|
2014-12-15 01:21:20 -08:00
|
|
|
/**
|
|
|
|
* Notifies chrome to currect editor rect
|
|
|
|
*
|
|
|
|
* rect Rect of current focused editor
|
|
|
|
*/
|
2015-02-04 12:21:03 -08:00
|
|
|
prio(urgent) async NotifyIMEEditorRect(LayoutDeviceIntRect rect);
|
2014-12-15 01:21:20 -08:00
|
|
|
|
2014-12-15 01:37:00 -08:00
|
|
|
/**
|
|
|
|
* Notifies chrome to position change
|
|
|
|
*
|
|
|
|
* editorRect Rect of current focused editor
|
|
|
|
* compositionRects Rects of current composition string
|
|
|
|
*/
|
2015-02-04 12:21:03 -08:00
|
|
|
prio(urgent) async NotifyIMEPositionChange(LayoutDeviceIntRect editorRect,
|
|
|
|
LayoutDeviceIntRect[] compositionRects,
|
|
|
|
LayoutDeviceIntRect caretRect);
|
2014-12-15 01:37:00 -08:00
|
|
|
|
2010-09-23 20:28:15 -07:00
|
|
|
/**
|
|
|
|
* Instructs chrome to end any pending composition
|
|
|
|
*
|
2012-10-25 09:32:24 -07:00
|
|
|
* cancel PR_TRUE if composition should be cancelled
|
2010-09-23 20:28:15 -07:00
|
|
|
* composition Text to commit before ending the composition
|
|
|
|
*
|
2012-10-25 09:32:24 -07:00
|
|
|
* if cancel is PR_TRUE,
|
2010-09-23 20:28:15 -07:00
|
|
|
* widget should return empty string for composition
|
2012-10-25 09:32:24 -07:00
|
|
|
* if cancel is PR_FALSE,
|
2010-09-23 20:28:15 -07:00
|
|
|
* widget should return the current composition text
|
|
|
|
*/
|
2014-10-30 15:51:39 -07:00
|
|
|
prio(urgent) sync EndIMEComposition(bool cancel) returns (nsString composition);
|
2010-09-23 20:28:15 -07:00
|
|
|
|
2013-09-20 15:07:51 -07:00
|
|
|
/**
|
|
|
|
* Request that the parent process move focus to the browser's frame. If
|
|
|
|
* canRaise is true, the window can be raised if it is inactive.
|
|
|
|
*/
|
|
|
|
RequestFocus(bool canRaise);
|
|
|
|
|
2014-12-09 07:48:27 -08:00
|
|
|
/**
|
|
|
|
* Indicate, based on the current state, that some commands are enabled and
|
|
|
|
* some are disabled.
|
|
|
|
*/
|
|
|
|
EnableDisableCommands(nsString action,
|
|
|
|
nsCString[] enabledCommands,
|
|
|
|
nsCString[] disabledCommands);
|
|
|
|
|
2014-10-30 15:51:39 -07:00
|
|
|
prio(urgent) sync GetInputContext() returns (int32_t IMEEnabled,
|
|
|
|
int32_t IMEOpen,
|
|
|
|
intptr_t NativeIMEContext);
|
|
|
|
|
2015-01-20 14:01:24 -08:00
|
|
|
prio(urgent) async SetInputContext(int32_t IMEEnabled,
|
|
|
|
int32_t IMEOpen,
|
|
|
|
nsString type,
|
|
|
|
nsString inputmode,
|
|
|
|
nsString actionHint,
|
|
|
|
int32_t cause,
|
|
|
|
int32_t focusChange);
|
2010-09-23 20:28:15 -07:00
|
|
|
|
2014-04-04 14:50:42 -07:00
|
|
|
sync IsParentWindowMainWidgetVisible() returns (bool visible);
|
|
|
|
|
2010-12-02 17:24:04 -08:00
|
|
|
/**
|
|
|
|
* Gets the DPI of the screen corresponding to this browser.
|
|
|
|
*/
|
|
|
|
sync GetDPI() returns (float value);
|
|
|
|
|
2013-05-01 16:06:19 -07:00
|
|
|
/**
|
|
|
|
* Gets the default scaling factor of the screen corresponding to this browser.
|
|
|
|
*/
|
|
|
|
sync GetDefaultScale() returns (double value);
|
|
|
|
|
2014-05-27 18:12:29 -07:00
|
|
|
/**
|
|
|
|
* Set the native cursor.
|
|
|
|
* @param value
|
|
|
|
* The widget cursor to set.
|
|
|
|
* @param force
|
|
|
|
* Invalidate any locally cached cursor settings and force an
|
|
|
|
* update.
|
|
|
|
*/
|
|
|
|
SetCursor(uint32_t value, bool force);
|
|
|
|
|
2011-10-20 15:17:09 -07:00
|
|
|
SetBackgroundColor(nscolor color);
|
2011-06-21 17:32:43 -07:00
|
|
|
|
2013-07-25 12:45:31 -07:00
|
|
|
/**
|
|
|
|
* Used to set the current text of the status tooltip.
|
|
|
|
* Nowadays this is mainly used for link locations on hover.
|
|
|
|
*/
|
|
|
|
SetStatus(uint32_t type, nsString status);
|
|
|
|
|
2014-01-22 12:27:23 -08:00
|
|
|
/**
|
|
|
|
* Show/hide a tooltip when the mouse hovers over an element in the content
|
|
|
|
* document.
|
|
|
|
*/
|
|
|
|
ShowTooltip(uint32_t x, uint32_t y, nsString tooltip);
|
|
|
|
HideTooltip();
|
|
|
|
|
2014-02-23 12:19:43 -08:00
|
|
|
/**
|
|
|
|
* Create an asynchronous color picker on the parent side,
|
|
|
|
* but don't open it yet.
|
|
|
|
*/
|
|
|
|
PColorPicker(nsString title, nsString initialColor);
|
|
|
|
|
2012-07-30 07:58:26 -07:00
|
|
|
/**
|
|
|
|
* Initiates an asynchronous request for permission for the
|
|
|
|
* provided principal.
|
|
|
|
*
|
2014-02-09 12:34:40 -08:00
|
|
|
* @param aRequests
|
|
|
|
* The array of permissions to request.
|
2012-07-30 07:58:26 -07:00
|
|
|
* @param aPrincipal
|
|
|
|
* The principal of the request.
|
|
|
|
*
|
|
|
|
* NOTE: The principal is untrusted in the parent process. Only
|
|
|
|
* principals that can live in the content process should
|
|
|
|
* provided.
|
|
|
|
*/
|
2014-02-09 12:34:40 -08:00
|
|
|
PContentPermissionRequest(PermissionRequest[] aRequests, Principal aPrincipal);
|
2010-05-13 10:44:51 -07:00
|
|
|
|
2014-02-17 16:30:06 -08:00
|
|
|
PFilePicker(nsString aTitle, int16_t aMode);
|
|
|
|
|
2014-09-26 16:21:57 -07:00
|
|
|
/**
|
|
|
|
* Initiates an asynchronous request for one of the special indexedDB
|
|
|
|
* permissions for the provided principal.
|
|
|
|
*
|
|
|
|
* @param principal
|
|
|
|
* The principal of the request.
|
|
|
|
*
|
|
|
|
* NOTE: The principal is untrusted in the parent process. Only
|
|
|
|
* principals that can live in the content process should
|
|
|
|
* provided.
|
|
|
|
*/
|
|
|
|
PIndexedDBPermissionRequest(Principal principal);
|
|
|
|
|
2012-06-12 15:01:25 -07:00
|
|
|
/**
|
|
|
|
* window.open from inside <iframe mozbrowser> is special. When the child
|
|
|
|
* process calls window.open, it creates a new PBrowser (in its own
|
|
|
|
* process), then calls BrowserFrameOpenWindow on it.
|
|
|
|
*
|
|
|
|
* The parent process gets a chance to accept or reject the window.open
|
|
|
|
* call, and windowOpened is set to true if we ended up going through with
|
|
|
|
* the window.open.
|
|
|
|
*
|
|
|
|
* @param opener the PBrowser whose content called window.open.
|
|
|
|
*/
|
|
|
|
sync BrowserFrameOpenWindow(PBrowser opener, nsString aURL,
|
|
|
|
nsString aName, nsString aFeatures)
|
|
|
|
returns (bool windowOpened);
|
|
|
|
|
2012-08-08 21:39:02 -07:00
|
|
|
/**
|
|
|
|
* Instructs the TabParent to forward a request to zoom to a rect given in
|
|
|
|
* CSS pixels. This rect is relative to the document.
|
|
|
|
*/
|
2013-11-13 10:20:30 -08:00
|
|
|
ZoomToRect(uint32_t aPresShellId, ViewID aViewId, CSSRect aRect);
|
2012-08-08 21:39:02 -07:00
|
|
|
|
2012-08-21 21:37:06 -07:00
|
|
|
/**
|
|
|
|
* We know for sure that content has either preventDefaulted or not
|
|
|
|
* preventDefaulted. This applies to an entire batch of touch events. It is
|
|
|
|
* expected that, if there are any DOM touch listeners, touch events will be
|
|
|
|
* batched and only processed for panning and zooming if content does not
|
|
|
|
* preventDefault.
|
|
|
|
*/
|
2014-12-09 02:35:12 -08:00
|
|
|
ContentReceivedInputBlock(ScrollableLayerGuid aGuid, uint64_t aInputBlockId, bool aPreventDefault);
|
2012-08-21 21:37:06 -07:00
|
|
|
|
2014-11-21 18:36:25 -08:00
|
|
|
/**
|
|
|
|
* Notifies the APZ code of the results of the gecko hit-test for a
|
|
|
|
* particular input block. Each target corresponds to one touch point in the
|
|
|
|
* touch event.
|
|
|
|
*/
|
|
|
|
SetTargetAPZC(uint64_t aInputBlockId, ScrollableLayerGuid[] aTargets);
|
|
|
|
|
2012-09-28 19:18:18 -07:00
|
|
|
/**
|
2013-11-14 09:35:41 -08:00
|
|
|
* Updates the zoom constraints for a scrollable frame in this tab.
|
|
|
|
* The zoom controller code lives on the parent side and so this allows it to
|
|
|
|
* have up-to-date zoom constraints.
|
2012-09-28 19:18:18 -07:00
|
|
|
*/
|
2013-11-08 16:07:00 -08:00
|
|
|
UpdateZoomConstraints(uint32_t aPresShellId, ViewID aViewId, bool aIsRoot,
|
2014-01-06 10:26:44 -08:00
|
|
|
ZoomConstraints aConstraints);
|
2012-09-28 19:18:18 -07:00
|
|
|
|
2014-06-10 22:44:36 -07:00
|
|
|
/**
|
|
|
|
* Brings up the auth prompt dialog.
|
|
|
|
* Called when this is the PBrowserParent for a nested remote iframe.
|
|
|
|
* aCallbackId corresponds to an nsIAuthPromptCallback that lives in the
|
|
|
|
* root process. It will be passed back to the root process with either the
|
|
|
|
* OnAuthAvailable or OnAuthCancelled message.
|
|
|
|
*/
|
|
|
|
AsyncAuthPrompt(nsCString uri, nsString realm, uint64_t aCallbackId);
|
|
|
|
|
2010-08-05 15:11:23 -07:00
|
|
|
__delete__();
|
|
|
|
|
2014-03-18 08:16:47 -07:00
|
|
|
ReplyKeyEvent(WidgetKeyboardEvent event);
|
|
|
|
|
2014-11-02 23:05:38 -08:00
|
|
|
DispatchAfterKeyboardEvent(WidgetKeyboardEvent event);
|
|
|
|
|
2014-04-21 13:40:09 -07:00
|
|
|
sync RequestNativeKeyBindings(WidgetKeyboardEvent event)
|
|
|
|
returns (MaybeNativeKeyBinding bindings);
|
|
|
|
|
2014-05-23 11:19:00 -07:00
|
|
|
/**
|
|
|
|
* Child informs the parent that the graphics objects are ready for
|
|
|
|
* compositing. This is sent when all pending changes have been
|
|
|
|
* sent to the compositor and are ready to be shown on the next composite.
|
|
|
|
* @see PCompositor
|
|
|
|
* @see RequestNotifyAfterRemotePaint
|
|
|
|
*/
|
|
|
|
async RemotePaintIsReady();
|
|
|
|
|
2014-11-16 10:23:22 -08:00
|
|
|
sync GetRenderFrameInfo(PRenderFrame aRenderFrame)
|
|
|
|
returns (ScrollingBehavior scrolling,
|
|
|
|
TextureFactoryIdentifier textureFactoryIdentifier,
|
|
|
|
uint64_t layersId);
|
|
|
|
|
2015-01-12 16:41:53 -08:00
|
|
|
/**
|
|
|
|
* Sent by the child to the parent to inform it that an update to the
|
|
|
|
* dimensions has been requested, likely through win.moveTo or resizeTo
|
|
|
|
*/
|
|
|
|
async SetDimensions(uint32_t aFlags, int32_t aX, int32_t aY, int32_t aCx, int32_t aCy);
|
|
|
|
|
2009-09-09 15:00:14 -07:00
|
|
|
child:
|
2010-08-20 16:24:40 -07:00
|
|
|
/**
|
|
|
|
* Notify the remote browser that it has been Show()n on this
|
|
|
|
* side, with the given |visibleRect|. This message is expected
|
|
|
|
* to trigger creation of the remote browser's "widget".
|
|
|
|
*
|
|
|
|
* |Show()| and |Move()| take IntSizes rather than Rects because
|
|
|
|
* content processes always render to a virtual <0, 0> top-left
|
|
|
|
* point.
|
|
|
|
*/
|
2014-11-16 10:23:22 -08:00
|
|
|
Show(nsIntSize size,
|
2014-11-24 11:05:35 -08:00
|
|
|
ShowInfo info,
|
2014-11-16 10:23:22 -08:00
|
|
|
ScrollingBehavior scrolling,
|
|
|
|
TextureFactoryIdentifier textureFactoryIdentifier,
|
|
|
|
uint64_t layersId,
|
|
|
|
nullable PRenderFrame renderFrame);
|
2009-10-28 13:41:46 -07:00
|
|
|
|
2015-02-06 15:31:33 -08:00
|
|
|
LoadURL(nsCString uri, BrowserConfiguration config);
|
2009-09-09 15:00:14 -07:00
|
|
|
|
2013-02-15 14:27:21 -08:00
|
|
|
CacheFileDescriptor(nsString path, FileDescriptor fd);
|
|
|
|
|
2014-12-11 06:44:07 -08:00
|
|
|
UpdateDimensions(nsIntRect rect, nsIntSize size, ScreenOrientation orientation,
|
|
|
|
nsIntPoint chromeDisp) compress;
|
2009-10-29 10:58:31 -07:00
|
|
|
|
2014-03-20 14:34:41 -07:00
|
|
|
UpdateFrame(FrameMetrics frame);
|
2012-08-08 21:39:02 -07:00
|
|
|
|
2014-07-16 05:33:50 -07:00
|
|
|
// The following methods correspond to functions on the GeckoContentController
|
|
|
|
// interface in gfx/layers/apz/public/GeckoContentController.h. Refer to documentation
|
|
|
|
// in that file for these functions.
|
2014-02-05 14:43:20 -08:00
|
|
|
AcknowledgeScrollUpdate(ViewID aScrollId, uint32_t aScrollGeneration);
|
2014-03-12 12:27:45 -07:00
|
|
|
HandleDoubleTap(CSSPoint point, ScrollableLayerGuid aGuid);
|
|
|
|
HandleSingleTap(CSSPoint point, ScrollableLayerGuid aGuid);
|
2014-10-24 10:29:30 -07:00
|
|
|
HandleLongTap(CSSPoint point, ScrollableLayerGuid aGuid, uint64_t aInputBlockId);
|
2014-03-12 12:27:45 -07:00
|
|
|
HandleLongTapUp(CSSPoint point, ScrollableLayerGuid aGuid);
|
2014-04-15 10:39:20 -07:00
|
|
|
NotifyAPZStateChange(ViewID aViewId, APZStateChange aChange, int aArg);
|
2013-12-09 19:14:55 -08:00
|
|
|
|
2014-07-16 05:33:50 -07:00
|
|
|
|
2009-11-05 10:14:22 -08:00
|
|
|
/**
|
|
|
|
* Sending an activate message moves focus to the child.
|
|
|
|
*/
|
2010-07-19 11:33:33 -07:00
|
|
|
Activate();
|
2010-03-18 23:52:18 -07:00
|
|
|
|
2011-06-17 17:08:32 -07:00
|
|
|
Deactivate();
|
|
|
|
|
2014-11-27 05:28:26 -08:00
|
|
|
ParentActivated(bool aActivated);
|
|
|
|
|
2009-11-17 06:22:23 -08:00
|
|
|
/**
|
2010-07-19 11:33:33 -07:00
|
|
|
* @see nsIDOMWindowUtils sendMouseEvent.
|
|
|
|
*/
|
|
|
|
MouseEvent(nsString aType,
|
|
|
|
float aX,
|
|
|
|
float aY,
|
2012-08-22 08:56:38 -07:00
|
|
|
int32_t aButton,
|
|
|
|
int32_t aClickCount,
|
|
|
|
int32_t aModifiers,
|
2010-07-19 11:33:33 -07:00
|
|
|
bool aIgnoreRootScrollFrame);
|
|
|
|
|
2013-10-01 23:38:27 -07:00
|
|
|
RealMouseEvent(WidgetMouseEvent event);
|
2014-03-20 08:46:29 -07:00
|
|
|
RealKeyEvent(WidgetKeyboardEvent event, MaybeNativeKeyBinding keyBinding);
|
2014-12-09 02:40:26 -08:00
|
|
|
MouseWheelEvent(WidgetWheelEvent event, ScrollableLayerGuid aGuid, uint64_t aInputBlockId);
|
2014-10-24 10:29:30 -07:00
|
|
|
RealTouchEvent(WidgetTouchEvent aEvent, ScrollableLayerGuid aGuid, uint64_t aInputBlockId);
|
2014-11-07 14:21:08 -08:00
|
|
|
RealTouchMoveEvent(WidgetTouchEvent aEvent, ScrollableLayerGuid aGuid, uint64_t aInputBlockId);
|
2011-06-21 17:32:43 -07:00
|
|
|
|
2010-07-19 11:33:33 -07:00
|
|
|
/**
|
|
|
|
* @see nsIDOMWindowUtils sendKeyEvent.
|
2009-11-17 06:22:23 -08:00
|
|
|
*/
|
2010-07-19 11:33:33 -07:00
|
|
|
KeyEvent(nsString aType,
|
2012-08-22 08:56:38 -07:00
|
|
|
int32_t aKeyCode,
|
|
|
|
int32_t aCharCode,
|
|
|
|
int32_t aModifiers,
|
2010-07-19 11:33:33 -07:00
|
|
|
bool aPreventDefault);
|
2009-11-17 06:22:23 -08:00
|
|
|
|
2013-10-01 00:23:00 -07:00
|
|
|
CompositionEvent(WidgetCompositionEvent event);
|
2010-08-17 01:07:42 -07:00
|
|
|
|
2013-10-01 00:23:01 -07:00
|
|
|
SelectionEvent(WidgetSelectionEvent event);
|
2010-08-17 01:07:42 -07:00
|
|
|
|
2010-07-19 11:33:33 -07:00
|
|
|
/**
|
|
|
|
* Activate event forwarding from client to parent.
|
|
|
|
*/
|
|
|
|
ActivateFrameEvent(nsString aType, bool capture);
|
2010-02-20 09:05:20 -08:00
|
|
|
|
2013-11-23 21:32:45 -08:00
|
|
|
LoadRemoteScript(nsString aURL, bool aRunInGlobalScope);
|
2010-02-20 09:05:20 -08:00
|
|
|
|
2010-10-26 15:20:53 -07:00
|
|
|
/**
|
|
|
|
* Create a asynchronous request to render whatever document is
|
|
|
|
* loaded in the child when this message arrives. When the
|
|
|
|
* request finishes, PDocumentRenderer:__delete__ is sent back to
|
|
|
|
* this side to notify completion.
|
|
|
|
*
|
2010-10-26 15:20:53 -07:00
|
|
|
* |documentRect| is the area of the remote document to draw,
|
|
|
|
* transformed by |transform|. The rendered area will have the
|
|
|
|
* default background color |bgcolor|. |renderFlags| are the
|
|
|
|
* nsIPresShell::RenderDocument() flags to use on the remote side,
|
|
|
|
* and if true, |flushLayout| will do just that before rendering
|
2010-10-26 15:20:53 -07:00
|
|
|
* the document. The rendered image will be of size |renderSize|.
|
2010-10-26 15:20:53 -07:00
|
|
|
*/
|
2013-12-26 10:06:53 -08:00
|
|
|
PDocumentRenderer(nsRect documentRect, Matrix transform,
|
2010-10-26 15:20:53 -07:00
|
|
|
nsString bgcolor,
|
2012-08-22 08:56:38 -07:00
|
|
|
uint32_t renderFlags, bool flushLayout,
|
2010-10-26 15:20:53 -07:00
|
|
|
nsIntSize renderSize);
|
2010-03-24 03:47:18 -07:00
|
|
|
|
2010-08-05 15:11:23 -07:00
|
|
|
/**
|
|
|
|
* Sent by the chrome process when it no longer wants this remote
|
|
|
|
* <browser>. The child side cleans up in response, then
|
|
|
|
* finalizing its death by sending back __delete__() to the
|
|
|
|
* parent.
|
|
|
|
*/
|
|
|
|
Destroy();
|
|
|
|
|
2013-08-13 00:56:57 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Tell the child side if it has to update it's touchable region
|
|
|
|
* to the parent.
|
|
|
|
*/
|
|
|
|
SetUpdateHitRegion(bool aEnabled);
|
|
|
|
|
2014-02-20 03:26:13 -08:00
|
|
|
/**
|
|
|
|
* Tell the child to update its docShell's active state.
|
|
|
|
*/
|
|
|
|
SetIsDocShellActive(bool aIsActive);
|
|
|
|
|
2014-05-23 11:19:00 -07:00
|
|
|
/**
|
|
|
|
* The parent (chrome thread) requests that the child inform it when
|
|
|
|
* the graphics objects are ready to display.
|
|
|
|
* @see PCompositor
|
|
|
|
* @see RemotePaintIsReady
|
|
|
|
*/
|
|
|
|
async RequestNotifyAfterRemotePaint();
|
|
|
|
|
2014-05-23 07:36:50 -07:00
|
|
|
/**
|
|
|
|
* Tell the child that the UI resolution changed for the containing
|
|
|
|
* window.
|
|
|
|
*/
|
|
|
|
UIResolutionChanged();
|
|
|
|
|
2014-08-22 16:17:18 -07:00
|
|
|
/**
|
|
|
|
* Tell the child of an app's offline status
|
|
|
|
*/
|
|
|
|
AppOfflineStatus(uint32_t id, bool offline);
|
|
|
|
|
2010-08-05 15:11:23 -07:00
|
|
|
/*
|
|
|
|
* FIXME: write protocol!
|
|
|
|
|
|
|
|
state LIVE:
|
|
|
|
send LoadURL goto LIVE;
|
|
|
|
//etc.
|
|
|
|
send Destroy goto DYING;
|
|
|
|
|
|
|
|
state DYING:
|
|
|
|
discard send blah;
|
|
|
|
// etc.
|
|
|
|
recv __delete__;
|
|
|
|
*/
|
2009-08-25 16:07:22 -07:00
|
|
|
};
|
|
|
|
|
2009-09-09 15:00:14 -07:00
|
|
|
}
|
2012-07-30 07:58:26 -07:00
|
|
|
}
|