2000-06-21 13:03:05 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
|
|
|
* 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/
|
|
|
|
*
|
|
|
|
* 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 the Mozilla browser.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape
|
|
|
|
* Communications, Inc. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1999, Mozilla. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Author:
|
|
|
|
* Adam Lock <adamlock@netscape.com>
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef NSEMBEDAPI_H
|
|
|
|
#define NSEMBEDAPI_H
|
|
|
|
|
2000-06-21 13:19:12 +00:00
|
|
|
#include "nsILocalFile.h"
|
2000-08-11 20:09:05 +00:00
|
|
|
#include "nsIDirectoryService.h"
|
2000-06-21 13:19:12 +00:00
|
|
|
|
2000-09-20 12:23:53 +00:00
|
|
|
|
2001-01-17 21:10:46 +00:00
|
|
|
/**
|
|
|
|
* Function to initialise the Gecko embedding APIs. You *must* call this
|
|
|
|
* method before any others!
|
|
|
|
*
|
|
|
|
* aPath -> the mozilla bin directory. If nsnull, the default is used
|
|
|
|
* aProvider -> the application directory service provider. If nsnull, the
|
|
|
|
* default (nsAppFileLocationProvider) is constructed and used.
|
|
|
|
*/
|
2000-08-11 20:09:05 +00:00
|
|
|
extern nsresult NS_InitEmbedding(nsILocalFile *mozBinDirectory,
|
|
|
|
nsIDirectoryServiceProvider *appFileLocProvider);
|
2001-01-17 21:10:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function to call to finish the Gecko embedding APIs.
|
|
|
|
*/
|
2000-06-21 13:03:05 +00:00
|
|
|
extern nsresult NS_TermEmbedding();
|
|
|
|
|
2001-01-17 21:10:46 +00:00
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
/* Event processing APIs. The native OS dependencies mean you must be */
|
|
|
|
/* building on a supported platform to get the functions below. */
|
|
|
|
/*---------------------------------------------------------------------------*/
|
2000-09-20 12:23:53 +00:00
|
|
|
|
2001-01-17 21:10:46 +00:00
|
|
|
#undef MOZ_SUPPORTS_EMBEDDING_EVENT_PROCESSING
|
|
|
|
|
|
|
|
/* Win32 specific stuff */
|
|
|
|
#ifdef WIN32
|
|
|
|
#include "windows.h"
|
|
|
|
typedef MSG nsEmbedNativeEvent;
|
|
|
|
#define MOZ_SUPPORTS_EMBEDDING_EVENT_PROCESSING
|
2000-06-27 20:54:15 +00:00
|
|
|
#endif
|
|
|
|
|
2001-01-17 21:10:46 +00:00
|
|
|
/* Mac specific stuff */
|
|
|
|
/* TODO implementation left as an exercise for the reader */
|
|
|
|
|
|
|
|
/* GTK specific stuff */
|
|
|
|
/* TODO implementation left as an exercise for the reader */
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef MOZ_SUPPORTS_EMBEDDING_EVENT_PROCESSING
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function to call during the idle time in your application and/or as each
|
|
|
|
* event is processed. This function ensures things such as timers are fired
|
|
|
|
* correctly.
|
|
|
|
*/
|
|
|
|
extern nsresult NS_DoIdleEmbeddingStuff();
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function to call before handling an event. It gives Gecko the chance to
|
|
|
|
* handle the event first.
|
|
|
|
*
|
|
|
|
* aEvent -> the native UI event
|
|
|
|
* aWasHandled -> returns with PR_TRUE if the event was handled by Gecko
|
|
|
|
*/
|
|
|
|
extern nsresult NS_HandleEmbeddingEvent(nsEmbedNativeEvent &aEvent, PRBool &aWasHandled);
|
|
|
|
|
|
|
|
#endif /* MOZ_SUPPORTS_EMBEDDING_EVENT_PROCESSING */
|
|
|
|
|
|
|
|
#endif /* NSEMBEDAPI_H */
|
|
|
|
|