2002-10-04 01:05:30 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
2004-04-19 02:01:16 +04:00
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
2002-10-04 01:05:30 +04:00
|
|
|
*
|
2004-04-19 02:01:16 +04:00
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
2002-10-04 01:05:30 +04:00
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is mozilla.org code.
|
|
|
|
*
|
2004-04-19 02:01:16 +04:00
|
|
|
* The Initial Developer of the Original Code is
|
2002-10-04 01:05:30 +04:00
|
|
|
* Netscape Communications Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 1998
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
2004-04-19 02:01:16 +04:00
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
2002-10-04 01:05:30 +04:00
|
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
2004-04-19 02:01:16 +04:00
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
2002-10-04 01:05:30 +04:00
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
2004-04-19 02:01:16 +04:00
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
2002-10-04 01:05:30 +04:00
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
#include "nsISupports.idl"
|
|
|
|
#include "nspluginroot.idl"
|
2009-12-27 23:26:00 +03:00
|
|
|
#include "nsIInputStream.idl"
|
2002-10-04 01:05:30 +04:00
|
|
|
|
|
|
|
interface nsIDocument;
|
|
|
|
|
2009-08-27 04:29:47 +04:00
|
|
|
%{C++
|
|
|
|
#include "npapi.h"
|
2011-05-18 05:48:34 +04:00
|
|
|
#include "nsNPAPIPluginInstance.h"
|
2009-08-27 04:29:47 +04:00
|
|
|
class nsPluginEvent;
|
|
|
|
%}
|
|
|
|
|
2011-05-18 05:48:34 +04:00
|
|
|
[ptr] native nsNPAPIPluginInstancePtr(nsNPAPIPluginInstance);
|
2002-10-04 01:05:30 +04:00
|
|
|
|
2012-02-10 14:04:45 +04:00
|
|
|
// Do not make this interface scriptable, because the virtual functions in C++
|
|
|
|
// blocks will make script call the wrong functions.
|
|
|
|
[uuid(23bd0a76-a5dc-4a1d-be76-13d7a0dfd9ff)]
|
2002-10-04 01:05:30 +04:00
|
|
|
interface nsIPluginInstanceOwner : nsISupports
|
|
|
|
{
|
|
|
|
/**
|
2009-02-25 03:28:35 +03:00
|
|
|
* Let the owner know what its instance is
|
2002-10-04 01:05:30 +04:00
|
|
|
*/
|
2011-05-18 05:48:34 +04:00
|
|
|
void setInstance(in nsNPAPIPluginInstancePtr aInstance);
|
2002-10-04 01:05:30 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the instance associated with this owner.
|
|
|
|
*/
|
2011-05-18 05:48:34 +04:00
|
|
|
nsNPAPIPluginInstancePtr getInstance();
|
2010-02-24 05:58:27 +03:00
|
|
|
|
2002-10-04 01:05:30 +04:00
|
|
|
/**
|
|
|
|
* Get a handle to the window structure of the owner.
|
2005-11-26 00:57:13 +03:00
|
|
|
* This pointer cannot be made persistent by the caller.
|
2002-10-04 01:05:30 +04:00
|
|
|
*/
|
2009-09-17 05:30:26 +04:00
|
|
|
void getWindow(in NPWindowStarRef aWindow);
|
2002-10-04 01:05:30 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the display mode for the plugin instance.
|
|
|
|
*/
|
2009-09-17 05:30:26 +04:00
|
|
|
readonly attribute PRInt32 mode;
|
2002-10-04 01:05:30 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a place for the plugin to live in the owner's
|
|
|
|
* environment. this may or may not create a window
|
|
|
|
* depending on the windowless state of the plugin instance.
|
|
|
|
*/
|
|
|
|
void createWidget();
|
|
|
|
|
|
|
|
%{C++
|
|
|
|
/**
|
|
|
|
* Called when there is a valid target so that the proper
|
|
|
|
* frame can be updated with new content. will not be called
|
|
|
|
* with nsnull aTarget.
|
|
|
|
*/
|
|
|
|
NS_IMETHOD
|
|
|
|
GetURL(const char *aURL, const char *aTarget,
|
2009-12-27 23:26:00 +03:00
|
|
|
nsIInputStream *aPostStream,
|
|
|
|
void *aHeadersData, PRUint32 aHeadersDataLen) = 0;
|
2002-10-04 01:05:30 +04:00
|
|
|
%}
|
2009-08-27 04:29:47 +04:00
|
|
|
|
2002-10-04 01:05:30 +04:00
|
|
|
/**
|
|
|
|
* Show a status message in the host environment.
|
|
|
|
*/
|
|
|
|
void showStatus(in string aStatusMsg);
|
|
|
|
|
|
|
|
%{C++
|
2009-08-27 04:29:47 +04:00
|
|
|
NS_IMETHOD ShowStatus(const PRUnichar *aStatusMsg) = 0;
|
2002-10-04 01:05:30 +04:00
|
|
|
%}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the associated document.
|
|
|
|
*/
|
|
|
|
readonly attribute nsIDocument document;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Invalidate the rectangle
|
|
|
|
*/
|
2009-09-17 05:30:26 +04:00
|
|
|
void invalidateRect(in NPRectPtr aRect);
|
2002-10-04 01:05:30 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Invalidate the region
|
|
|
|
*/
|
2009-09-17 05:30:26 +04:00
|
|
|
void invalidateRegion(in NPRegion aRegion);
|
2002-10-04 01:05:30 +04:00
|
|
|
|
2012-02-16 07:30:22 +04:00
|
|
|
/**
|
|
|
|
* Have the plugin recomposited.
|
|
|
|
*/
|
|
|
|
void redrawPlugin();
|
|
|
|
|
2002-10-04 01:05:30 +04:00
|
|
|
/**
|
2009-06-29 22:53:52 +04:00
|
|
|
* Get NetscapeWindow, corresponds to NPNVnetscapeWindow
|
2002-10-04 01:05:30 +04:00
|
|
|
*/
|
2009-06-29 22:53:52 +04:00
|
|
|
void getNetscapeWindow(in voidPtr aValue);
|
2009-08-27 04:29:47 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Show native context menu
|
|
|
|
*/
|
|
|
|
%{C++
|
2009-09-17 05:30:26 +04:00
|
|
|
virtual NPError ShowNativeContextMenu(NPMenu* menu, void* event) = 0;
|
2009-08-27 04:29:47 +04:00
|
|
|
virtual NPBool ConvertPoint(double sourceX, double sourceY, NPCoordinateSpace sourceSpace,
|
|
|
|
double *destX, double *destY, NPCoordinateSpace destSpace) = 0;
|
2012-02-16 07:08:41 +04:00
|
|
|
virtual NPError InitAsyncSurface(NPSize *size, NPImageFormat format,
|
|
|
|
void *initData, NPAsyncSurface *surface) = 0;
|
|
|
|
virtual NPError FinalizeAsyncSurface(NPAsyncSurface *surface) = 0;
|
|
|
|
virtual void SetCurrentAsyncSurface(NPAsyncSurface *surface, NPRect *changed) = 0;
|
2009-08-27 04:29:47 +04:00
|
|
|
%}
|
2009-11-10 06:58:48 +03:00
|
|
|
|
|
|
|
void setEventModel(in PRInt32 eventModel);
|
2009-12-15 23:44:52 +03:00
|
|
|
|
|
|
|
%{C++
|
|
|
|
virtual void SendIdleEvent() = 0;
|
|
|
|
%}
|
2010-12-08 00:18:50 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Call NPP_SetWindow on the plugin.
|
|
|
|
*/
|
2012-02-01 01:55:54 +04:00
|
|
|
void callSetWindow();
|
2010-12-08 00:18:50 +03:00
|
|
|
};
|