mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-07 11:56:51 +00:00
791 lines
21 KiB
C
791 lines
21 KiB
C
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
*
|
|
* The contents of this file are subject to the Netscape 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/NPL/
|
|
*
|
|
* 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.
|
|
*
|
|
* The Initial Developer of the Original Code is Netscape
|
|
* Communications Corporation. Portions created by Netscape are
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All
|
|
* Rights Reserved.
|
|
*
|
|
* Contributor(s):
|
|
*/
|
|
|
|
/*
|
|
* Header file for event passing between the mozilla thread and
|
|
* the mocha thread
|
|
*/
|
|
|
|
#ifndef libevent_h___
|
|
#define libevent_h___
|
|
|
|
#include "libmocha.h"
|
|
#include "prtypes.h"
|
|
#include "plevent.h"
|
|
#include "shist.h"
|
|
#include "fe_proto.h"
|
|
#include "lo_ele.h"
|
|
#include "jscookie.h"
|
|
|
|
NSPR_BEGIN_EXTERN_C
|
|
|
|
extern PREventQueue * mozilla_event_queue;
|
|
|
|
typedef struct WindowGroup LMWindowGroup;
|
|
|
|
/*
|
|
* XXX - should we use the same event values as layer events?
|
|
*/
|
|
|
|
/* Event bits stored in the low end of decoder->event_mask. */
|
|
#define EVENT_MOUSEDOWN 0x00000001
|
|
#define EVENT_MOUSEUP 0x00000002
|
|
#define EVENT_MOUSEOVER 0x00000004 /* user is mousing over a link */
|
|
#define EVENT_MOUSEOUT 0x00000008 /* user is mousing out of a link */
|
|
#define EVENT_MOUSEMOVE 0x00000010
|
|
#define EVENT_MOUSEDRAG 0x00000020
|
|
#define EVENT_CLICK 0x00000040 /* input element click in progress */
|
|
#define EVENT_DBLCLICK 0x00000080
|
|
#define EVENT_KEYDOWN 0x00000100
|
|
#define EVENT_KEYUP 0x00000200
|
|
#define EVENT_KEYPRESS 0x00000400
|
|
#define EVENT_DRAGDROP 0x00000800 /* not yet implemented */
|
|
#define EVENT_FOCUS 0x00001000 /* input focus event in progress */
|
|
#define EVENT_BLUR 0x00002000 /* loss of focus event in progress */
|
|
#define EVENT_SELECT 0x00004000 /* input field selection in progress */
|
|
#define EVENT_CHANGE 0x00008000 /* field value change in progress */
|
|
#define EVENT_RESET 0x00010000 /* form submit in progress */
|
|
#define EVENT_SUBMIT 0x00020000 /* form submit in progress */
|
|
#define EVENT_SCROLL 0x00040000 /* window is being scrolled */
|
|
#define EVENT_LOAD 0x00080000 /* layout parsed a loaded document */
|
|
#define EVENT_UNLOAD 0x00100000
|
|
#define EVENT_XFER_DONE 0x00200000 /* document has loaded */
|
|
#define EVENT_ABORT 0x00400000
|
|
#define EVENT_ERROR 0x00800000
|
|
#define EVENT_LOCATE 0x01000000
|
|
#define EVENT_MOVE 0x02000000
|
|
#define EVENT_RESIZE 0x04000000
|
|
#define EVENT_FORWARD 0x08000000
|
|
#define EVENT_HELP 0x10000000 /* for handling of help events */
|
|
#define EVENT_BACK 0x20000000
|
|
|
|
/* #define EVENT_PRINT 0x20000000 *//* To be removed per joki */
|
|
|
|
#define STATUS_STOP 0x00000001 /* stop processing */
|
|
#define STATUS_IGNORE 0x00000002 /* no new messages */
|
|
|
|
#define EVENT_ALT_MASK 0x00000001
|
|
#define EVENT_CONTROL_MASK 0x00000002
|
|
#define EVENT_SHIFT_MASK 0x00000004
|
|
#define EVENT_META_MASK 0x00000008
|
|
|
|
#define ARGTYPE_NULL 0x00000001
|
|
#define ARGTYPE_INT32 0x00000002
|
|
#define ARGTYPE_BOOL 0x00000004
|
|
#define ARGTYPE_STRING 0x00000008
|
|
|
|
/*
|
|
* When the event has been processed by the backend, there will be
|
|
* a front-end callback that gets called. If the event processed
|
|
* successfully, the callback will be passed EVENT_OK. If the
|
|
* event wasn't successful (i.e. the user canceled it) the return
|
|
* status will be EVENT_CANCEL. If something radical happened
|
|
* and the front-end should do nothing (i.e. mocha changed the
|
|
* underlying context) the status will be EVENT_PANIC and the
|
|
* front end should treat the context and element passed to the
|
|
* exit routine as bogus
|
|
*/
|
|
typedef enum {
|
|
EVENT_OK,
|
|
EVENT_CANCEL,
|
|
EVENT_PANIC
|
|
} ETEventStatus;
|
|
|
|
/*
|
|
* When a given event gets processed we may need to tell the front
|
|
* end about it so that they can update the UI / continue the
|
|
* operation. The context, lo_element, lType and whatever
|
|
* field are all supplied by the original ET_SendEvent() call.
|
|
* See ET_SendEvent() for a description of the values for
|
|
* the status parameter
|
|
*/
|
|
typedef void
|
|
(*ETClosureFunc)(MWContext * pContext, LO_Element * lo_element,
|
|
int32 lType, void * whatever, ETEventStatus status);
|
|
|
|
/*
|
|
* Someone has initiated a call to LM_EvaluateBuffer(). This function
|
|
* gets called back with the result
|
|
*/
|
|
typedef void
|
|
(*ETEvalAckFunc)(void * data, char * result_string, size_t result_length,
|
|
char * wysiwyg_url, char * base_href, Bool valid);
|
|
|
|
/*
|
|
* This function is called back after a layer's state has been restored
|
|
* in a resize_relayout.
|
|
*/
|
|
typedef void
|
|
(*ETRestoreAckFunc)(void * data, void *param);
|
|
|
|
/*
|
|
* Typedef for a function taking a void pointer and
|
|
* returning nothing
|
|
*/
|
|
typedef void
|
|
(*ETVoidPtrFunc)(void * data);
|
|
|
|
/*
|
|
* Typedef for a function taking a void pointer and
|
|
* returning a bool
|
|
*/
|
|
typedef PRBool
|
|
(*ETBoolPtrFunc)(void * data);
|
|
|
|
/*
|
|
* Typedef for a function taking a void pointer and
|
|
* returning a int32
|
|
*/
|
|
typedef int32
|
|
(*ETIntPtrFunc)(void * data);
|
|
|
|
/*
|
|
* Typedef for a function taking a void pointer and
|
|
* returning a char *
|
|
*/
|
|
typedef char *
|
|
(*ETStringPtrFunc)(void * data);
|
|
|
|
/*
|
|
* Struct for passing JS typed variable info through C interface calls
|
|
*/
|
|
typedef union ArgVal {
|
|
int32 intArg;
|
|
XP_Bool boolArg;
|
|
char * stringArg;
|
|
} ArgVal;
|
|
|
|
typedef struct {
|
|
uint8 type; /* arg type as defined at top of file */
|
|
ArgVal value;
|
|
} JSCompArg;
|
|
|
|
/*
|
|
* Typedef for a function used to verify installed components and
|
|
* get back components utility functions.
|
|
*/
|
|
typedef PRBool
|
|
(*ETVerifyComponentFunc)(void **active_callback, void **startup_callback);
|
|
|
|
/*
|
|
* Generic function for JS setting values with native calls.
|
|
*/
|
|
typedef void
|
|
(*ETCompPropSetterFunc)(char *name, void *value);
|
|
|
|
/*
|
|
* Generic function for JS getting values from native calls.
|
|
*/
|
|
typedef void*
|
|
(*ETCompPropGetterFunc)(char *name);
|
|
|
|
/*
|
|
* Generic function for JS calling native methods.
|
|
*/
|
|
typedef void*
|
|
(*ETCompMethodFunc)(int32 argc, JSCompArg *argv);
|
|
|
|
/* --------------------------------------------------------------------------
|
|
* Common prologue for talking between the mocha thread and the mozilla
|
|
* thread
|
|
*/
|
|
typedef struct {
|
|
PREvent event; /* the PREvent structure */
|
|
MWContext* context; /* context */
|
|
int32 doc_id; /* doc id of context when event launched */
|
|
PRPackedBool handle_eagerly;
|
|
} ETEvent;
|
|
|
|
/*
|
|
* Struct to send back from front end in order to get additional
|
|
* event information without having to initialize event object
|
|
* until necessary. Yow, there is a lot of junk in here now
|
|
* can we make a union out of some of these or are they always
|
|
* needed?
|
|
*/
|
|
typedef struct {
|
|
ETEvent ce;
|
|
MochaDecoder * decoder;
|
|
JSObject * object;
|
|
int32 type;
|
|
int32 layer_id;
|
|
int32 id;
|
|
LO_Element * lo_element;
|
|
ETClosureFunc fnClosure; /* event sender closure */
|
|
void * whatever; /* anything other state */
|
|
int32 x,y;
|
|
int32 docx,docy;
|
|
int32 screenx,screeny;
|
|
uint32 which;
|
|
uint32 modifiers;
|
|
void * data;
|
|
uint32 dataSize;
|
|
PRPackedBool saved;
|
|
PRPackedBool event_handled;
|
|
} JSEvent;
|
|
|
|
/*
|
|
* Tell the backend about a new event.
|
|
* The event is placed onto an event queue, it is not processed
|
|
* immediately. If the event is the type that can be cancelled
|
|
* by the backend (i.e. a button click or a submit) the front
|
|
* end must wait until the callback routine gets called before
|
|
* continuing with the operation. The ETEventStatus will be
|
|
* EVENT_OK if the operation is to continue or EVENT_CANCEL
|
|
* if it got cancelled.
|
|
*
|
|
* The processing of the event may cause the document to change
|
|
* or even the whole window to close. In those cases the callback
|
|
* will still get called in case there is any front-end cleanup
|
|
* to do but the ETEventStatus will be set to EVENT_PANIC
|
|
*
|
|
*/
|
|
|
|
extern JSBool
|
|
ET_SendEvent(MWContext * pContext, LO_Element *pElement, JSEvent *pEvent,
|
|
ETClosureFunc fnClosure, void * whatever);
|
|
|
|
/*
|
|
* Tell the backend about a new document load event. We need a
|
|
* closure so that libparse/layout knows when its safe to discard
|
|
* the old document when they were waiting for onunload events to
|
|
* finish processing
|
|
*/
|
|
extern void
|
|
ET_SendLoadEvent(MWContext * pContext, int32 type, ETVoidPtrFunc fnClosure,
|
|
NET_StreamClass *stream, int32 layer_id, Bool resize_reload);
|
|
|
|
/*
|
|
* Tell the backend about a new image event. Async. No closure
|
|
*/
|
|
extern void
|
|
ET_SendImageEvent(MWContext * pContext, LO_ImageStruct *image_data,
|
|
LM_ImageEvent event);
|
|
|
|
/*
|
|
* Send an interrupt event to the current context
|
|
* Remove all pending events for the event queue of the given context.
|
|
*/
|
|
extern void
|
|
ET_InterruptContext(MWContext * pContext);
|
|
|
|
extern JSBool
|
|
ET_ContinueProcessing(MWContext * pContext);
|
|
|
|
/*
|
|
* Tell mocha to destroy the given context's data. The callback
|
|
* function gets called when mocha is done with all of its data
|
|
* that was associated with the context
|
|
*/
|
|
extern void
|
|
ET_RemoveWindowContext(MWContext * context, ETVoidPtrFunc fn,
|
|
void * data);
|
|
|
|
typedef struct {
|
|
uint len, line_no;
|
|
char * scope_to;
|
|
void * data;
|
|
JSVersion version;
|
|
JSPrincipals * principals;
|
|
JSBool want_result;
|
|
JSBool unicode;
|
|
} ETEvalStuff;
|
|
|
|
/*
|
|
* Evaluate the mocha code in the given buffer
|
|
*/
|
|
extern void
|
|
ET_EvaluateBuffer(MWContext * context, char * buffer, uint buflen,
|
|
uint line_no, char * scope_to, JSBool want_result,
|
|
ETEvalAckFunc fn, void * data,
|
|
JSVersion ver, struct JSPrincipals *);
|
|
|
|
extern void
|
|
ET_EvaluateScript(MWContext * context, char * buffer, ETEvalStuff * stuff,
|
|
ETEvalAckFunc fn);
|
|
|
|
/*
|
|
* Ask Mocha to reflect the given object into JavaScript
|
|
*/
|
|
extern void
|
|
ET_ReflectObject(MWContext * pContext, void * lo_ele, void * tag,
|
|
int32 layer_id, uint index, ReflectedObject type);
|
|
|
|
void
|
|
ET_ReflectFormElement(MWContext * pContext, void * form,
|
|
LO_FormElementStruct * form_element, PA_Tag * tag);
|
|
|
|
extern void
|
|
ET_ReflectWindow(MWContext * pContext,
|
|
PA_Block onLoad, PA_Block onUnload,
|
|
PA_Block onFocus, PA_Block onBlur, PA_Block onHelp,
|
|
PA_Block onMouseOver, PA_Block onMouseOut, PA_Block onDragDrop,
|
|
PA_Block onMove, PA_Block onResize,
|
|
PA_Block id, char *all,
|
|
Bool bDelete, int newline_count);
|
|
|
|
/*
|
|
* Tell mocha we are processing a form
|
|
*/
|
|
extern void
|
|
ET_SetActiveForm(MWContext * pContext, struct lo_FormData_struct * loElement);
|
|
|
|
/*
|
|
* Tell mocha which layer we are processing
|
|
*/
|
|
void
|
|
ET_SetActiveLayer(MWContext * pContext, int32 layer_id);
|
|
|
|
/*
|
|
** Tell mocha where to send its output
|
|
*/
|
|
extern void
|
|
ET_ClearDecoderStream(MWContext * context, NET_StreamClass * old_stream);
|
|
|
|
extern void
|
|
ET_SetDecoderStream(MWContext * context, NET_StreamClass *stream,
|
|
URL_Struct *url_struct, JSBool free_stream_on_close);
|
|
|
|
/*
|
|
** Remember the current nesting URL in the MochaDecoder
|
|
*/
|
|
extern void
|
|
ET_SetNestingUrl(MWContext * context, char * szUrl);
|
|
|
|
/*
|
|
** Set up the principals for an upcoming softupdate script.
|
|
*/
|
|
extern void
|
|
ET_StartSoftUpdate(MWContext * pContext, char *codebase);
|
|
|
|
/*
|
|
** Remember the current language version in the MochaDecoder
|
|
*/
|
|
extern void
|
|
ET_SetVersion(MWContext * context, JSVersion version);
|
|
|
|
/*
|
|
* Tell mocha to trash the current document. around and around...
|
|
*/
|
|
extern void
|
|
ET_ReleaseDocument(MWContext * pContext, JSBool resize_reload);
|
|
|
|
/*
|
|
* Tell mocha to trash the layer's document.
|
|
*/
|
|
extern void
|
|
ET_DestroyLayer(MWContext * pContext, JSObject *layer_obj);
|
|
|
|
extern void
|
|
ET_MochaStreamComplete(MWContext * context, void * buf, int len,
|
|
char * content_type, Bool isUnicode);
|
|
|
|
extern void
|
|
ET_MochaStreamAbort(MWContext * context, int status);
|
|
|
|
/*
|
|
* Called when a layer's contents are changing and we want to create
|
|
* a new layer document.
|
|
*/
|
|
extern void
|
|
ET_NewLayerDocument(MWContext *pContext, int32 layer_id);
|
|
|
|
extern void
|
|
ET_DocWriteAck(MWContext *pContext, int status);
|
|
|
|
extern void
|
|
ET_RegisterComponent(char *name, void *active_callback, void *startup_callback);
|
|
|
|
extern void
|
|
ET_RegisterComponentProp(char *comp, char *name, uint8 retType, void *setter,
|
|
void *getter);
|
|
|
|
extern void
|
|
ET_RegisterComponentMethod(char *comp, char *name, uint8 retType, void *method,
|
|
int32 argc);
|
|
|
|
/* =============================================================== */
|
|
|
|
/*
|
|
* This event can be sent to both the mozilla thread and the moacha thread
|
|
*/
|
|
typedef struct {
|
|
ETEvent ce;
|
|
TimeoutCallbackFunction fnCallback;
|
|
void* pClosure;
|
|
uint32 ulTime;
|
|
void* pTimerId;
|
|
} MozillaEvent_Timeout;
|
|
|
|
|
|
/* =============================================================== */
|
|
|
|
/*
|
|
* Busy loop waiting for events to come along
|
|
*/
|
|
extern void PR_CALLBACK
|
|
lm_wait_for_events(void *);
|
|
|
|
/*
|
|
* global mocha event queues. It would be nice to not have these
|
|
* exported this globally
|
|
*/
|
|
extern PREventQueue *lm_InterpretQueue;
|
|
extern PREventQueue *lm_PriorityQueue;
|
|
|
|
/*
|
|
* Ways to send events to the front end
|
|
*/
|
|
extern JSBool
|
|
ET_PostMessageBox(MWContext* context, char* szMessage,
|
|
JSBool bConfirm);
|
|
|
|
JSBool
|
|
ET_PostCheckConfirmBox(MWContext* context,
|
|
char* szMainMessage, char* szCheckMessage,
|
|
char* szOKMessage, char* szCancelMessage,
|
|
XP_Bool *bChecked);
|
|
|
|
extern void
|
|
ET_PostProgress(MWContext* context, const char* szMessage);
|
|
|
|
/* --- timeout routines --- */
|
|
|
|
/*
|
|
* Set (or clear) a timeout to go off. The timeout will go off in the
|
|
* mozilla thread so we will use the routine ET_FireTimeoutCallBack()
|
|
* to get back into our thread to actually run the closure
|
|
*/
|
|
extern void *
|
|
ET_PostSetTimeout(TimeoutCallbackFunction fnCallback,
|
|
void * pClosure, uint32 ulTime, int32 doc_id);
|
|
|
|
extern void
|
|
ET_PostClearTimeout(void * stuff);
|
|
|
|
extern void
|
|
ET_FireTimeoutCallBack(void *);
|
|
|
|
/* --- end of timeout routines --- */
|
|
|
|
extern void
|
|
ET_PostDestroyWindow(MWContext * context);
|
|
|
|
extern void
|
|
ET_PostManipulateForm(MWContext * context, LO_Element * pForm, int32 action);
|
|
|
|
extern void
|
|
ET_PostClearView(MWContext * context);
|
|
|
|
extern void
|
|
ET_PostFreeImageElement(MWContext * context, void * stuff);
|
|
|
|
extern void
|
|
ET_PostFreeImageContext(MWContext *context, IL_GroupContext *img_cx);
|
|
|
|
extern void
|
|
ET_PostFreeAnonImages(MWContext *context, IL_GroupContext *img_cx);
|
|
|
|
extern void
|
|
ET_PostDisplayImage(MWContext *, int, LO_ImageStruct *);
|
|
|
|
extern void
|
|
ET_PostGetUrl(MWContext *, URL_Struct * pUrl);
|
|
|
|
extern char *
|
|
ET_PostPrompt(MWContext* context, const char* szMessage,
|
|
const char * szDefault);
|
|
|
|
extern MWContext *
|
|
ET_PostNewWindow(MWContext* context, URL_Struct * pUrl,
|
|
char * szName, Chrome * pChrome, LMWindowGroup *grp);
|
|
|
|
extern void
|
|
ET_PostUpdateChrome(MWContext* context, Chrome * pChrome);
|
|
|
|
extern void
|
|
ET_PostQueryChrome(MWContext* context, Chrome * pChrome);
|
|
|
|
extern void
|
|
ET_PostGetScreenSize(MWContext* context, int32 *pX, int32 *pY);
|
|
|
|
extern void
|
|
ET_PostGetAvailScreenRect(MWContext* context, int32 *pX, int32 *pY,
|
|
int32 *pLeft, int32 *pTop);
|
|
|
|
extern void
|
|
ET_PostGetColorDepth(MWContext* context, int32 *pPixel, int32 *pPallette);
|
|
|
|
extern char *
|
|
ET_PostGetSelectedText(MWContext* context);
|
|
|
|
extern void
|
|
ET_PostScrollDocTo(MWContext* context, int loc, int32 x, int32 y);
|
|
|
|
extern void
|
|
ET_PostScrollDocBy(MWContext* context, int loc, int32 x, int32 y);
|
|
|
|
extern void
|
|
ET_PostBackCommand(MWContext* context);
|
|
|
|
extern void
|
|
ET_PostForwardCommand(MWContext* context);
|
|
|
|
extern void
|
|
ET_PostHomeCommand(MWContext* context);
|
|
|
|
extern JSBool
|
|
ET_PostFindCommand(MWContext* context, char * szName, JSBool matchCase,
|
|
JSBool searchBackward);
|
|
extern void
|
|
ET_PostPrintCommand(MWContext* context);
|
|
|
|
extern void
|
|
ET_PostOpenFileCommand(MWContext* context);
|
|
|
|
extern void
|
|
ET_MakeHTMLAlert(MWContext * context, const char * szString);
|
|
|
|
/* respond to events sent to the mocha thread by the mozilla thread */
|
|
|
|
extern void
|
|
ET_PostJsEventAck(MWContext* context, LO_Element * pEle, int type,
|
|
ETClosureFunc fnClosure, void * pStuff,
|
|
ETEventStatus status);
|
|
|
|
|
|
|
|
extern void
|
|
ET_PostEvalAck(MWContext * context, int doc_id, void * data,
|
|
char * str, size_t len, char * wysiwyg_url,
|
|
char * base_href, Bool valid, ETEvalAckFunc fn);
|
|
|
|
extern void
|
|
ET_PostRestoreAck(void *data, void *param,
|
|
ETRestoreAckFunc fn);
|
|
|
|
/* netlib events */
|
|
|
|
extern char *
|
|
ET_net_GetCookie(MWContext* context, int32 doc_id);
|
|
|
|
extern char *
|
|
ET_net_SetCookieString(MWContext* context, char * szCookie, int32 doc_id);
|
|
|
|
extern NET_StreamClass *
|
|
ET_net_CacheConverter(FO_Present_Types format, void * obj,
|
|
URL_Struct *pUrl, MWContext * pContext);
|
|
|
|
extern void
|
|
ET_net_FindURLInCache(URL_Struct * pUrl, MWContext * pContext);
|
|
|
|
extern NET_StreamClass *
|
|
ET_net_StreamBuilder(FO_Present_Types format, URL_Struct *pUrl,
|
|
MWContext * pContext);
|
|
|
|
/* layout events */
|
|
|
|
extern void
|
|
ET_lo_ResetForm(MWContext * pContext, LO_Element * ele);
|
|
|
|
void
|
|
ET_fe_SubmitInputElement(MWContext * pContext, LO_Element * ele);
|
|
|
|
/*
|
|
* Synchronously shove the given text down the parser's processing
|
|
* queue. If the currently loaded document is not equal to
|
|
* doc_id, this message should be ignored since it arrived too
|
|
* late for the intended document
|
|
*/
|
|
extern int
|
|
ET_lo_DoDocWrite(JSContext *cx, MWContext * context, NET_StreamClass * stream,
|
|
char * str, size_t len, int32 doc_id);
|
|
|
|
|
|
extern void
|
|
ET_il_GetImage(const char * str, MWContext * pContext, IL_GroupContext *img_cx,
|
|
LO_ImageStruct * image_data, NET_ReloadMethod how);
|
|
|
|
extern void
|
|
ET_il_SetGroupObserver(MWContext * pContext, IL_GroupContext *pImgCX, void *pDpyCX,
|
|
JSBool bAddObserver);
|
|
|
|
extern void
|
|
ET_InterruptImgCX(MWContext * pContext);
|
|
|
|
/*
|
|
* Tell layout to trash the current document.
|
|
*/
|
|
extern void
|
|
ET_lo_DiscardDocument(MWContext * pContext);
|
|
|
|
/*
|
|
* Tell layout to prepare a layer for writing.
|
|
*/
|
|
extern Bool
|
|
ET_lo_PrepareLayerForWriting(MWContext *context, int32 layer_id,
|
|
const char *referer);
|
|
|
|
/*
|
|
* Return a copy of the current history element. Caller must free
|
|
*/
|
|
extern History_entry *
|
|
ET_shist_GetCurrent(MWContext * pContext);
|
|
|
|
/*
|
|
* Return the current security status.
|
|
*/
|
|
extern int
|
|
ET_GetSecurityStatus(MWContext * pContext);
|
|
|
|
/*
|
|
* Make sure Mocha/Java glue is ready. Returns the same return code as
|
|
* LM_InitMoja.
|
|
*/
|
|
extern int
|
|
ET_InitMoja(MWContext * pContext);
|
|
|
|
/*
|
|
* Pack up toys and go home
|
|
*/
|
|
extern void
|
|
ET_FinishMocha(void);
|
|
|
|
/*
|
|
* Used to call a stream completion function in the mozilla
|
|
* thread
|
|
*/
|
|
extern void
|
|
ET_moz_CallFunction(ETVoidPtrFunc fn, void * data);
|
|
|
|
extern void
|
|
ET_moz_CallFunctionAsync(ETVoidPtrFunc fn, void * data);
|
|
|
|
extern PRBool
|
|
ET_moz_CallFunctionBool(ETBoolPtrFunc fn, void * data);
|
|
|
|
extern int32
|
|
ET_moz_CallFunctionInt(ETIntPtrFunc fn, void * data);
|
|
|
|
extern char *
|
|
ET_moz_CallFunctionString(ETStringPtrFunc fn, void * data);
|
|
|
|
extern void
|
|
ET_moz_CallAsyncAndSubEventLoop(ETVoidPtrFunc fn, void *data,
|
|
MWContext *context);
|
|
|
|
extern void
|
|
ET_moz_Abort(MKStreamAbortFunc fn, void * data, int status);
|
|
|
|
extern void
|
|
ET_moz_SetMochaWriteStream(MochaDecoder * decoder);
|
|
|
|
extern NET_StreamClass *
|
|
ET_moz_DocCacheConverter(MWContext * context, URL_Struct * pUrl,
|
|
char * wysiwyg_url, int32 layer_id);
|
|
|
|
extern PRBool
|
|
ET_moz_VerifyComponentFunction(ETVerifyComponentFunc fn, ETBoolPtrFunc *pActive_callback,
|
|
ETVoidPtrFunc *pStartup_callback);
|
|
|
|
extern void
|
|
ET_moz_CompSetterFunction(ETCompPropSetterFunc fn, char *name, void *data);
|
|
|
|
extern void *
|
|
ET_moz_CompGetterFunction(ETCompPropGetterFunc fn, char *name);
|
|
|
|
extern void *
|
|
ET_moz_CompMethodFunction(ETCompMethodFunc fn, int32 argc, JSCompArg *argv);
|
|
|
|
typedef enum {
|
|
CL_Move,
|
|
CL_MoveX,
|
|
CL_MoveY,
|
|
CL_Offset,
|
|
CL_Resize,
|
|
CL_SetBboxWidth,
|
|
CL_SetBboxHeight,
|
|
CL_SetBboxTop,
|
|
CL_SetBboxLeft,
|
|
CL_SetBboxBottom,
|
|
CL_SetBboxRight,
|
|
CL_SetHidden,
|
|
CL_MoveInZ,
|
|
CL_SetSrc,
|
|
CL_SetSrcWidth,
|
|
CL_SetZ,
|
|
CL_SetBgColor,
|
|
CL_SetBackdrop
|
|
} ETLayerOp;
|
|
|
|
extern int
|
|
ET_TweakLayer(MWContext * context, void * layer, int32 x, int32 y,
|
|
void *param_ptr, int32 param_val, ETLayerOp op,
|
|
const char *referer, int32 doc_id);
|
|
|
|
extern void
|
|
ET_RestoreLayerState(MWContext *context, int32 layer_id,
|
|
void *param, ETRestoreAckFunc fn,
|
|
void *data);
|
|
|
|
extern int32
|
|
ET_npl_RefreshPluginList(MWContext* context, XP_Bool refreshInstances);
|
|
|
|
extern JSCFResult
|
|
ET_JSCFExecute(MWContext *context, const char *script_name,
|
|
JSCFCookieData *data, Bool *data_changed);
|
|
|
|
extern JSBool
|
|
ET_HandlePref(JSContext * cx, uint argc, jsval * argv, jsval * rval);
|
|
|
|
extern void
|
|
ET_SetPluginWindow(MWContext * pContext, void * app);
|
|
|
|
#ifdef DOM
|
|
typedef enum {
|
|
SP_SetColor,
|
|
SP_SetBackground,
|
|
SP_SetFontWeight,
|
|
SP_SetFontFamily,
|
|
SP_SetFontSize,
|
|
SP_SetFontSlant
|
|
} ETSpanOp;
|
|
|
|
extern int
|
|
ET_TweakSpan(MWContext * context, void *name_rec, void *param_ptr,
|
|
int32 param_val, ETSpanOp op, int32 doc_id);
|
|
|
|
typedef enum {
|
|
TR_SetHref,
|
|
TR_SetVisibility,
|
|
TR_SetData
|
|
} ETTransclusionOp;
|
|
|
|
extern int
|
|
ET_TweakTransclusion(MWContext * context, void *xmlFile, void *param_ptr,
|
|
int32 param_val, ETTransclusionOp op, int32 doc_id);
|
|
#endif
|
|
|
|
NSPR_END_EXTERN_C
|
|
|
|
#endif /* libevent_h___ */
|