2004-01-12 08:25:18 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2001-09-28 20:14:13 +00:00
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
2004-04-18 22:01:16 +00:00
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
1998-04-13 20:24:54 +00:00
|
|
|
*
|
2004-04-18 22:01:16 +00: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/
|
1998-04-13 20:24:54 +00:00
|
|
|
*
|
2001-09-28 20:14:13 +00: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.
|
1998-04-13 20:24:54 +00:00
|
|
|
*
|
1999-11-06 03:40:37 +00:00
|
|
|
* The Original Code is mozilla.org code.
|
|
|
|
*
|
2004-04-18 22:01:16 +00:00
|
|
|
* The Initial Developer of the Original Code is
|
2001-09-28 20:14:13 +00:00
|
|
|
* Netscape Communications Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 1998
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
1999-11-06 03:40:37 +00:00
|
|
|
*
|
2001-09-28 20:14:13 +00:00
|
|
|
* Contributor(s):
|
2002-02-27 01:30:40 +00:00
|
|
|
* Dean Tessman <dean_tessman@hotmail.com>
|
|
|
|
* Ere Maijala <ere@atp.fi>
|
|
|
|
* Mark Hammond <markh@activestate.com>
|
2000-02-04 00:39:15 +00:00
|
|
|
* Michael Lowe <michael.lowe@bigfoot.com>
|
2000-12-19 03:01:31 +00:00
|
|
|
* Peter Bajusz <hyp-x@inf.bme.hu>
|
2000-12-20 01:43:38 +00:00
|
|
|
* Pierre Phaneuf <pp@ludusdesign.com>
|
2000-03-21 03:42:00 +00:00
|
|
|
* Robert O'Callahan <roc+moz@cs.cmu.edu>
|
2002-07-03 00:55:47 +00:00
|
|
|
* Roy Yokoyama <yokoyama@netscape.com>
|
2002-12-06 03:41:43 +00:00
|
|
|
* Makoto Kato <m_kato@ga2.so-net.ne.jp>
|
2001-09-28 20:14:13 +00:00
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
2004-04-18 22:01:16 +00:00
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
2001-09-28 20:14:13 +00: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-18 22:01:16 +00:00
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
2001-09-28 20:14:13 +00: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-18 22:01:16 +00:00
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
2001-09-28 20:14:13 +00:00
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
#if defined(DEBUG_ftang)
|
1999-11-15 20:57:41 +00:00
|
|
|
//#define KE_DEBUG
|
1999-12-01 22:10:13 +00:00
|
|
|
//#define DEBUG_IME
|
1999-11-30 22:09:28 +00:00
|
|
|
//#define DEBUG_IME2
|
1999-11-15 20:57:41 +00:00
|
|
|
//#define DEBUG_KBSTATE
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
#include "nsWindow.h"
|
2002-10-01 03:04:22 +00:00
|
|
|
#include "plevent.h"
|
1998-07-29 18:51:45 +00:00
|
|
|
#include "nsIAppShell.h"
|
1998-04-13 20:24:54 +00:00
|
|
|
#include "nsIFontMetrics.h"
|
2001-06-11 22:42:27 +00:00
|
|
|
#include "nsIFontEnumerator.h"
|
2002-02-16 01:39:56 +00:00
|
|
|
#include "nsIFontPackageService.h"
|
2004-04-01 22:51:46 +00:00
|
|
|
#include "nsIPrefBranch.h"
|
|
|
|
#include "nsIPrefService.h"
|
1998-09-28 22:32:48 +00:00
|
|
|
#include "nsFont.h"
|
1998-04-13 20:24:54 +00:00
|
|
|
#include "nsGUIEvent.h"
|
|
|
|
#include "nsIRenderingContext.h"
|
|
|
|
#include "nsIDeviceContext.h"
|
2002-01-09 01:30:06 +00:00
|
|
|
#include "nsIScreenManager.h"
|
1998-04-13 20:24:54 +00:00
|
|
|
#include "nsRect.h"
|
|
|
|
#include "nsTransform2D.h"
|
2002-09-28 15:04:47 +00:00
|
|
|
#include "nsIEventQueue.h"
|
1998-04-13 20:24:54 +00:00
|
|
|
#include <windows.h>
|
2001-05-11 21:11:38 +00:00
|
|
|
|
2002-10-17 06:47:01 +00:00
|
|
|
// unknwn.h is needed to build with WIN32_LEAN_AND_MEAN
|
|
|
|
#include <unknwn.h>
|
|
|
|
|
1999-03-05 15:34:53 +00:00
|
|
|
//#include <winuser.h>
|
|
|
|
#include <zmouse.h>
|
|
|
|
//#include "sysmets.h"
|
1998-04-13 20:24:54 +00:00
|
|
|
#include "nsGfxCIID.h"
|
|
|
|
#include "resource.h"
|
1998-04-17 00:16:11 +00:00
|
|
|
#include <commctrl.h>
|
1998-04-13 20:24:54 +00:00
|
|
|
#include "prtime.h"
|
1998-12-15 05:44:21 +00:00
|
|
|
#include "nsIRenderingContextWin.h"
|
2001-07-16 02:40:48 +00:00
|
|
|
#include "nsIImage.h"
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2001-08-17 03:13:07 +00:00
|
|
|
#ifdef ACCESSIBILITY
|
2003-04-01 20:02:51 +00:00
|
|
|
#include "OLEIDL.H"
|
|
|
|
#include "winable.h"
|
2001-04-01 01:38:35 +00:00
|
|
|
#include "nsIAccessible.h"
|
2003-04-01 20:02:51 +00:00
|
|
|
#include "nsIAccessibleDocument.h"
|
|
|
|
#include "nsIAccessNode.h"
|
|
|
|
#ifndef WM_GETOBJECT
|
|
|
|
#define WM_GETOBJECT 0x03d
|
|
|
|
#endif
|
2001-08-17 03:13:07 +00:00
|
|
|
#endif
|
2001-04-01 01:38:35 +00:00
|
|
|
|
1999-03-19 23:36:20 +00:00
|
|
|
#include <imm.h>
|
2000-01-07 00:34:34 +00:00
|
|
|
#include "aimm.h"
|
1999-02-17 14:30:47 +00:00
|
|
|
|
1999-04-06 20:23:55 +00:00
|
|
|
#include "nsNativeDragTarget.h"
|
1999-09-21 11:22:21 +00:00
|
|
|
#include "nsIRollupListener.h"
|
2000-04-13 20:15:40 +00:00
|
|
|
#include "nsIMenuRollup.h"
|
1999-11-20 22:33:42 +00:00
|
|
|
#include "nsIRegion.h"
|
1999-09-21 11:22:21 +00:00
|
|
|
|
1999-06-25 21:17:52 +00:00
|
|
|
//~~~ windowless plugin support
|
1999-06-11 22:48:50 +00:00
|
|
|
#include "nsplugindefs.h"
|
|
|
|
|
1999-03-23 21:26:20 +00:00
|
|
|
// For clipboard support
|
|
|
|
#include "nsIServiceManager.h"
|
|
|
|
#include "nsIClipboard.h"
|
|
|
|
#include "nsWidgetsCID.h"
|
1999-07-09 19:41:46 +00:00
|
|
|
|
2000-01-21 21:56:09 +00:00
|
|
|
#include "nsITimer.h"
|
|
|
|
|
2001-12-17 22:51:39 +00:00
|
|
|
#include "nsITheme.h"
|
|
|
|
|
2001-04-14 00:57:30 +00:00
|
|
|
// For SetIcon
|
2003-03-15 01:04:32 +00:00
|
|
|
#include "nsILocalFile.h"
|
|
|
|
#include "nsCRT.h"
|
2001-04-14 00:57:30 +00:00
|
|
|
#include "nsAppDirectoryServiceDefs.h"
|
|
|
|
#include "nsXPIDLString.h"
|
|
|
|
#include "nsIFile.h"
|
|
|
|
|
2002-02-27 02:18:12 +00:00
|
|
|
#include "prprf.h"
|
2002-10-01 02:47:41 +00:00
|
|
|
#include "prmem.h"
|
2002-02-27 02:18:12 +00:00
|
|
|
|
|
|
|
static const char *kMozHeapDumpMessageString = "MOZ_HeapDump";
|
|
|
|
|
2001-06-19 00:20:10 +00:00
|
|
|
#define kWindowPositionSlop 20
|
2000-08-04 14:48:33 +00:00
|
|
|
|
2000-11-02 05:15:34 +00:00
|
|
|
#ifndef SPI_GETWHEELSCROLLLINES
|
|
|
|
#define SPI_GETWHEELSCROLLLINES 104
|
|
|
|
#endif
|
|
|
|
|
2001-11-16 01:58:17 +00:00
|
|
|
// Pick some random timer ID. Is there a better way?
|
|
|
|
#define NS_FLASH_TIMER_ID 0x011231984
|
|
|
|
|
1999-07-09 19:41:46 +00:00
|
|
|
static NS_DEFINE_CID(kCClipboardCID, NS_CLIPBOARD_CID);
|
|
|
|
static NS_DEFINE_IID(kRenderingContextCID, NS_RENDERING_CONTEXT_CID);
|
1999-03-23 21:26:20 +00:00
|
|
|
|
2001-11-29 09:41:19 +00:00
|
|
|
// When we build we are currently (11/27/01) setting the WINVER to 0x0400
|
|
|
|
// Which means we do not compile in the system resource for the HAND cursor
|
|
|
|
// this enables us still define the resource and if it isn't there then we will
|
|
|
|
// get our own hand cursor.
|
|
|
|
// 32649 is the resource number as defined by WINUSER.H for this cursor
|
|
|
|
// if the resource is defined by the build env. then it will find it when asked
|
|
|
|
// if not, then we get our own cursor.
|
|
|
|
#ifndef IDC_HAND
|
|
|
|
#define IDC_HAND MAKEINTRESOURCE(32649)
|
|
|
|
#endif
|
|
|
|
|
2002-01-09 01:30:06 +00:00
|
|
|
static const char *sScreenManagerContractID = "@mozilla.org/gfx/screenmanager;1";
|
|
|
|
|
2000-05-11 13:39:17 +00:00
|
|
|
////////////////////////////////////////////////////
|
|
|
|
// Manager for Registering and unregistering OLE
|
|
|
|
// This is needed for drag & drop & Clipboard support
|
|
|
|
////////////////////////////////////////////////////
|
|
|
|
class OleRegisterMgr {
|
|
|
|
public:
|
|
|
|
~OleRegisterMgr();
|
|
|
|
protected:
|
|
|
|
OleRegisterMgr();
|
|
|
|
|
|
|
|
static OleRegisterMgr mSingleton;
|
|
|
|
};
|
|
|
|
OleRegisterMgr OleRegisterMgr::mSingleton;
|
|
|
|
|
|
|
|
OleRegisterMgr::OleRegisterMgr()
|
|
|
|
{
|
|
|
|
//DWORD dwVer = ::OleBuildVersion();
|
|
|
|
|
2000-05-12 14:01:17 +00:00
|
|
|
if (FAILED(::OleInitialize(NULL))) {
|
2000-05-11 13:39:17 +00:00
|
|
|
NS_ASSERTION(0, "***** OLE has not been initialized!\n");
|
|
|
|
} else {
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
//printf("***** OLE has been initialized!\n");
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
2000-05-11 13:39:17 +00:00
|
|
|
}
|
|
|
|
}
|
2000-12-19 20:11:11 +00:00
|
|
|
|
2000-05-11 13:39:17 +00:00
|
|
|
OleRegisterMgr::~OleRegisterMgr()
|
|
|
|
{
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
//printf("***** OLE has been Uninitialized!\n");
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
2000-05-11 13:39:17 +00:00
|
|
|
::OleUninitialize();
|
|
|
|
}
|
|
|
|
|
2000-04-28 20:27:18 +00:00
|
|
|
////////////////////////////////////////////////////
|
|
|
|
// nsWindow Class static variable defintions
|
|
|
|
////////////////////////////////////////////////////
|
|
|
|
BOOL nsWindow::sIsRegistered = FALSE;
|
2002-01-05 23:50:52 +00:00
|
|
|
BOOL nsWindow::sIsPopupClassRegistered = FALSE;
|
2000-04-28 20:27:18 +00:00
|
|
|
UINT nsWindow::uMSH_MOUSEWHEEL = 0;
|
2000-08-04 21:43:29 +00:00
|
|
|
UINT nsWindow::uWM_MSIME_RECONVERT = 0; // reconvert messge for MSIME
|
|
|
|
UINT nsWindow::uWM_MSIME_MOUSE = 0; // mouse messge for MSIME
|
|
|
|
UINT nsWindow::uWM_ATOK_RECONVERT = 0; // reconvert messge for ATOK
|
2002-02-27 02:18:12 +00:00
|
|
|
UINT nsWindow::uWM_HEAP_DUMP = 0; // Heap Dump to a file
|
2002-02-16 01:44:54 +00:00
|
|
|
|
2002-10-01 03:04:22 +00:00
|
|
|
|
2001-09-25 08:34:42 +00:00
|
|
|
#ifdef ACCESSIBILITY
|
|
|
|
BOOL nsWindow::gIsAccessibilityOn = FALSE;
|
|
|
|
#endif
|
2000-04-28 20:27:18 +00:00
|
|
|
nsWindow* nsWindow::gCurrentWindow = nsnull;
|
|
|
|
////////////////////////////////////////////////////
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
|
2000-04-28 20:27:18 +00:00
|
|
|
////////////////////////////////////////////////////
|
|
|
|
// Rollup Listener - static variable defintions
|
1999-09-21 11:22:21 +00:00
|
|
|
////////////////////////////////////////////////////
|
1999-09-30 14:36:17 +00:00
|
|
|
static nsIRollupListener * gRollupListener = nsnull;
|
|
|
|
static nsIWidget * gRollupWidget = nsnull;
|
|
|
|
static PRBool gRollupConsumeRollupEvent = PR_FALSE;
|
2001-05-25 10:53:32 +00:00
|
|
|
|
|
|
|
// Hook Data Memebers for Dropdowns
|
|
|
|
//
|
|
|
|
// gProcessHook Tells the hook methods whether they should be
|
|
|
|
// processing the hook messages
|
|
|
|
//
|
|
|
|
static HHOOK gMsgFilterHook = NULL;
|
|
|
|
static HHOOK gCallProcHook = NULL;
|
|
|
|
static HHOOK gCallMouseHook = NULL;
|
|
|
|
static PRPackedBool gProcessHook = PR_FALSE;
|
2001-06-14 02:08:39 +00:00
|
|
|
static UINT gRollupMsgId = 0;
|
|
|
|
static UINT gHookTimerId = 0;
|
2000-04-28 20:27:18 +00:00
|
|
|
////////////////////////////////////////////////////
|
1999-09-21 11:22:21 +00:00
|
|
|
|
2000-04-28 20:27:18 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////
|
|
|
|
// Mouse Clicks - static variable defintions
|
|
|
|
// for figuring out 1 - 3 Clicks
|
|
|
|
////////////////////////////////////////////////////
|
|
|
|
static POINT gLastMousePoint;
|
2001-12-06 02:55:06 +00:00
|
|
|
static POINT gLastMouseMovePoint;
|
2000-12-13 11:53:10 +00:00
|
|
|
static LONG gLastMouseDownTime = 0L;
|
|
|
|
static LONG gLastClickCount = 0L;
|
2000-04-28 20:27:18 +00:00
|
|
|
////////////////////////////////////////////////////
|
1998-05-29 22:44:13 +00:00
|
|
|
|
2002-10-01 03:04:22 +00:00
|
|
|
// The last user input event time in milliseconds. If there are any pending
|
|
|
|
// native toolkit input events it returns the current time. The value is
|
|
|
|
// compatible with PR_IntervalToMicroseconds(PR_IntervalNow()).
|
|
|
|
static PRUint32 gLastInputEventTime = 0;
|
|
|
|
|
2004-04-01 22:51:46 +00:00
|
|
|
static int gTrimOnMinimize = 2; // uninitialized, but still true
|
|
|
|
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
#if 0
|
|
|
|
static PRBool is_vk_down(int vk)
|
|
|
|
{
|
|
|
|
SHORT st = GetKeyState(vk);
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("is_vk_down vk=%x st=%x\n",vk, st);
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
2004-03-25 19:43:59 +00:00
|
|
|
return (st < 0);
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
}
|
|
|
|
#define IS_VK_DOWN is_vk_down
|
|
|
|
#else
|
2004-03-25 19:43:59 +00:00
|
|
|
#define IS_VK_DOWN(a) (GetKeyState(a) < 0)
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
#endif
|
|
|
|
|
1998-09-02 21:14:45 +00:00
|
|
|
|
1999-08-06 07:42:35 +00:00
|
|
|
//
|
|
|
|
// input method offsets
|
|
|
|
//
|
1999-11-11 22:28:52 +00:00
|
|
|
#define IME_X_OFFSET 0
|
|
|
|
#define IME_Y_OFFSET 0
|
1999-08-06 07:42:35 +00:00
|
|
|
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
|
|
|
|
|
1999-11-15 20:57:41 +00:00
|
|
|
#define IS_IME_CODEPAGE(cp) ((932==(cp))||(936==(cp))||(949==(cp))||(950==(cp)))
|
|
|
|
|
2000-01-07 00:34:34 +00:00
|
|
|
//
|
|
|
|
// Macro for Active Input Method Manager (AIMM) support.
|
|
|
|
// Use AIMM method instead of Win32 Imm APIs.
|
|
|
|
//
|
|
|
|
#define NS_IMM_GETCOMPOSITIONSTRING(hIMC, dwIndex, pBuf, dwBufLen, compStrLen) \
|
|
|
|
{ \
|
|
|
|
compStrLen = 0; \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->GetCompositionStringA(hIMC, dwIndex, dwBufLen, &(compStrLen), pBuf); \
|
2000-09-22 01:06:51 +00:00
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
compStrLen = theIMM.GetCompositionStringA(hIMC, dwIndex, pBuf, dwBufLen); \
|
|
|
|
} \
|
2000-01-07 00:34:34 +00:00
|
|
|
}
|
|
|
|
|
2000-04-13 22:23:04 +00:00
|
|
|
#define NS_IMM_GETCOMPOSITIONSTRINGW(hIMC, dwIndex, pBuf, dwBufLen, compStrLen) \
|
|
|
|
{ \
|
|
|
|
compStrLen = 0; \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->GetCompositionStringW(hIMC, dwIndex, dwBufLen, &(compStrLen), pBuf); \
|
2000-09-22 01:06:51 +00:00
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
compStrLen = theIMM.GetCompositionStringW(hIMC, dwIndex, pBuf, dwBufLen); \
|
|
|
|
} \
|
2000-04-13 22:23:04 +00:00
|
|
|
}
|
|
|
|
|
2000-01-07 00:34:34 +00:00
|
|
|
#define NS_IMM_GETCONTEXT(hWnd, hIMC) \
|
|
|
|
{ \
|
|
|
|
hIMC = NULL; \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->GetContext(hWnd, &(hIMC)); \
|
2000-09-22 01:06:51 +00:00
|
|
|
else { \
|
2001-04-01 01:38:35 +00:00
|
|
|
nsIMM& theIMM = nsIMM::LoadModule(); \
|
|
|
|
hIMC = (HIMC)theIMM.GetContext(hWnd); \
|
2000-09-22 01:06:51 +00:00
|
|
|
} \
|
2000-01-07 00:34:34 +00:00
|
|
|
}
|
|
|
|
|
2000-09-22 01:06:51 +00:00
|
|
|
#define NS_IMM_GETCONVERSIONSTATUS(hIMC, pfdwConversion, pfdwSentence, bRet) \
|
|
|
|
{ \
|
|
|
|
bRet = TRUE; \
|
|
|
|
if (nsToolkit::gAIMMApp) { \
|
|
|
|
bRet = (nsToolkit::gAIMMApp->GetConversionStatus(hIMC, pfdwConversion, pfdwSentence) == S_OK); \
|
|
|
|
} \
|
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
(theIMM.GetConversionStatus(hIMC, pfdwConversion, pfdwSentence)); \
|
|
|
|
}\
|
|
|
|
}
|
2000-01-07 00:34:34 +00:00
|
|
|
|
|
|
|
#define NS_IMM_RELEASECONTEXT(hWnd, hIMC) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->ReleaseContext(hWnd, hIMC); \
|
2000-09-22 01:06:51 +00:00
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.ReleaseContext(hWnd, hIMC); \
|
|
|
|
} \
|
2000-01-07 00:34:34 +00:00
|
|
|
}
|
|
|
|
|
2000-09-22 01:06:51 +00:00
|
|
|
#define NS_IMM_NOTIFYIME(hIMC, dwAction, dwIndex, dwValue, bRtn) \
|
|
|
|
{ \
|
|
|
|
bRtn = TRUE; \
|
|
|
|
if (nsToolkit::gAIMMApp) { \
|
|
|
|
bRtn = (nsToolkit::gAIMMApp->NotifyIME(hIMC, dwAction, dwIndex, dwValue) == S_OK); \
|
|
|
|
}\
|
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
(theIMM.NotifyIME(hIMC, dwAction, dwIndex, dwValue)); \
|
|
|
|
} \
|
|
|
|
}
|
2000-01-07 00:34:34 +00:00
|
|
|
|
|
|
|
#define NS_IMM_SETCANDIDATEWINDOW(hIMC, candForm) \
|
2000-09-22 01:06:51 +00:00
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
2002-05-23 22:03:49 +00:00
|
|
|
nsToolkit::gAIMMApp->SetCandidateWindow(hIMC, candForm); \
|
2000-09-22 01:06:51 +00:00
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.SetCandidateWindow(hIMC, candForm); \
|
|
|
|
} \
|
|
|
|
}
|
2000-01-07 00:34:34 +00:00
|
|
|
|
2002-05-23 22:03:49 +00:00
|
|
|
#define NS_IMM_SETCOMPOSITIONWINDOW(hIMC, compForm) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->SetCompositionWindow(hIMC, compForm); \
|
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.SetCompositionWindow(hIMC, compForm); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
2000-09-22 01:06:51 +00:00
|
|
|
#define NS_IMM_GETCOMPOSITIONWINDOW(hIMC, compForm) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
2002-05-23 22:03:49 +00:00
|
|
|
nsToolkit::gAIMMApp->GetCompositionWindow(hIMC, compForm); \
|
2000-09-22 01:06:51 +00:00
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.GetCompositionWindow(hIMC, compForm); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
2002-05-23 22:03:49 +00:00
|
|
|
#define NS_IMM_GETCOMPOSITIONFONT(hIMC, lf) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->GetCompositionFontA(hIMC, lf); \
|
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.GetCompositionFontA(hIMC, lf); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define NS_IMM_SETCOMPOSITIONFONT(hIMC, lf) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->SetCompositionFontA(hIMC, lf); \
|
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.SetCompositionFontA(hIMC, lf); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define NS_IMM_GETCOMPOSITIONFONTW(hIMC, lf) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->GetCompositionFontW(hIMC, lf); \
|
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.GetCompositionFontW(hIMC, lf); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define NS_IMM_SETCOMPOSITIONFONTW(hIMC, lf) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->SetCompositionFontW(hIMC, lf); \
|
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.SetCompositionFontW(hIMC, lf); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
2000-09-22 01:06:51 +00:00
|
|
|
#define NS_IMM_SETCONVERSIONSTATUS(hIMC, pfdwConversion, pfdwSentence, bRet) \
|
|
|
|
{ \
|
|
|
|
bRet = TRUE; \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
bRet = (nsToolkit::gAIMMApp->SetConversionStatus(hIMC, (pfdwConversion), (pfdwSentence)) == S_OK); \
|
|
|
|
else { \
|
|
|
|
nsIMM &theIMM = nsIMM::LoadModule(); \
|
|
|
|
theIMM.SetConversionStatus(hIMC, (pfdwConversion), (pfdwSentence)); \
|
|
|
|
} \
|
|
|
|
}
|
2000-01-07 00:34:34 +00:00
|
|
|
|
2002-05-08 20:24:55 +00:00
|
|
|
#define NS_IMM_GETPROPERTY(hKL, dwIndex, dwProp) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
nsToolkit::gAIMMApp->GetProperty(hKL, dwIndex, &(dwProp)); \
|
|
|
|
else { \
|
|
|
|
nsIMM& theIMM = nsIMM::LoadModule(); \
|
|
|
|
dwProp = (DWORD)theIMM.GetProperty(hKL, dwIndex); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
2002-10-01 02:47:41 +00:00
|
|
|
#define NS_IMM_GETDEFAULTIMEWND(hWnd, phDefWnd) \
|
|
|
|
{ \
|
|
|
|
if (nsToolkit::gAIMMApp) \
|
|
|
|
return nsToolkit::gAIMMApp->GetDefaultIMEWnd(hWnd, phDefWnd); \
|
|
|
|
else { \
|
|
|
|
nsIMM& theIMM = nsIMM::LoadModule(); \
|
|
|
|
*(phDefWnd) = (HWND)theIMM.GetDefaultIMEWnd(hWnd); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
//
|
|
|
|
// for reconversion define
|
|
|
|
//
|
|
|
|
|
|
|
|
// VC++5.0 header doesn't have reconvertion structure and message.
|
|
|
|
#ifndef WM_IME_REQUEST
|
|
|
|
typedef struct tagRECONVERTSTRING {
|
|
|
|
DWORD dwSize;
|
|
|
|
DWORD dwVersion;
|
|
|
|
DWORD dwStrLen;
|
|
|
|
DWORD dwStrOffset;
|
|
|
|
DWORD dwCompStrLen;
|
|
|
|
DWORD dwCompStrOffset;
|
|
|
|
DWORD dwTargetStrLen;
|
|
|
|
DWORD dwTargetStrOffset;
|
|
|
|
} RECONVERTSTRING, FAR * LPRECONVERTSTRING;
|
|
|
|
|
|
|
|
#define IMR_RECONVERTSTRING 0x0004
|
|
|
|
#define WM_IME_REQUEST 0x0288
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// from http://msdn.microsoft.com/library/specs/msime.h
|
|
|
|
#define RWM_RECONVERT TEXT("MSIMEReconvert")
|
|
|
|
#define RWM_MOUSE TEXT("MSIMEMouseOperation")
|
|
|
|
|
|
|
|
#define IMEMOUSE_NONE 0x00 // no mouse button was pushed
|
|
|
|
#define IMEMOUSE_LDOWN 0x01
|
|
|
|
#define IMEMOUSE_RDOWN 0x02
|
|
|
|
#define IMEMOUSE_MDOWN 0x04
|
|
|
|
#define IMEMOUSE_WUP 0x10 // wheel up
|
|
|
|
#define IMEMOUSE_WDOWN 0x20 // wheel down
|
|
|
|
|
|
|
|
// from http://www.justsystem.co.jp/tech/atok/api12_04.html#4_11
|
|
|
|
#define MSGNAME_ATOK_RECONVERT TEXT("Atok Message for ReconvertString")
|
|
|
|
|
2002-12-06 03:41:43 +00:00
|
|
|
//
|
|
|
|
// App Command messages for IntelliMouse and Natural Keyboard Pro
|
|
|
|
//
|
|
|
|
// These messages are not included in Visual C++ 6.0, but are in 7.0
|
|
|
|
//
|
|
|
|
#ifndef WM_APPCOMMAND
|
|
|
|
#define WM_APPCOMMAND 0x0319
|
|
|
|
|
|
|
|
#define APPCOMMAND_BROWSER_BACKWARD 1
|
|
|
|
#define APPCOMMAND_BROWSER_FORWARD 2
|
|
|
|
#define APPCOMMAND_BROWSER_REFRESH 3
|
|
|
|
#define APPCOMMAND_BROWSER_STOP 4
|
|
|
|
// keep these around in case we want them later
|
|
|
|
//#define APPCOMMAND_BROWSER_SEARCH 5
|
|
|
|
//#define APPCOMMAND_BROWSER_FAVORITES 6
|
|
|
|
//#define APPCOMMAND_BROWSER_HOME 7
|
|
|
|
//#define APPCOMMAND_VOLUME_MUTE 8
|
|
|
|
//#define APPCOMMAND_VOLUME_DOWN 9
|
|
|
|
//#define APPCOMMAND_VOLUME_UP 10
|
|
|
|
//#define APPCOMMAND_MEDIA_NEXTTRACK 11
|
|
|
|
//#define APPCOMMAND_MEDIA_PREVIOUSTRACK 12
|
|
|
|
//#define APPCOMMAND_MEDIA_STOP 13
|
|
|
|
//#define APPCOMMAND_MEDIA_PLAY_PAUSE 14
|
|
|
|
//#define APPCOMMAND_LAUNCH_MAIL 15
|
|
|
|
//#define APPCOMMAND_LAUNCH_MEDIA_SELECT 16
|
|
|
|
//#define APPCOMMAND_LAUNCH_APP1 17
|
|
|
|
//#define APPCOMMAND_LAUNCH_APP2 18
|
|
|
|
//#define APPCOMMAND_BASS_DOWN 19
|
|
|
|
//#define APPCOMMAND_BASS_BOOST 20
|
|
|
|
//#define APPCOMMAND_BASS_UP 21
|
|
|
|
//#define APPCOMMAND_TREBLE_DOWN 22
|
|
|
|
//#define APPCOMMAND_TREBLE_UP 23
|
|
|
|
|
|
|
|
//#define FAPPCOMMAND_MOUSE 0x8000
|
|
|
|
//#define FAPPCOMMAND_KEY 0
|
|
|
|
//#define FAPPCOMMAND_OEM 0x1000
|
|
|
|
#define FAPPCOMMAND_MASK 0xF000
|
|
|
|
|
|
|
|
#define GET_APPCOMMAND_LPARAM(lParam) ((short)(HIWORD(lParam) & ~FAPPCOMMAND_MASK))
|
|
|
|
//#define GET_DEVICE_LPARAM(lParam) ((WORD)(HIWORD(lParam) & FAPPCOMMAND_MASK))
|
|
|
|
//#define GET_MOUSEORKEY_LPARAM GET_DEVICE_LPARAM
|
|
|
|
//#define GET_FLAGS_LPARAM(lParam) (LOWORD(lParam))
|
|
|
|
//#define GET_KEYSTATE_LPARAM(lParam) GET_FLAGS_LPARAM(lParam)
|
|
|
|
|
|
|
|
#endif // #ifndef WM_APPCOMMAND
|
2000-01-07 00:34:34 +00:00
|
|
|
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
static PRBool LangIDToCP(WORD aLangID, UINT& oCP)
|
|
|
|
{
|
|
|
|
int localeid=MAKELCID(aLangID,SORT_DEFAULT);
|
|
|
|
int numchar=GetLocaleInfo(localeid,LOCALE_IDEFAULTANSICODEPAGE,NULL,0);
|
|
|
|
char cp_on_stack[32];
|
|
|
|
|
|
|
|
char* cp_name;
|
|
|
|
if(numchar > 32)
|
|
|
|
cp_name = new char[numchar];
|
|
|
|
else
|
|
|
|
cp_name = cp_on_stack;
|
|
|
|
if (cp_name) {
|
|
|
|
GetLocaleInfo(localeid,LOCALE_IDEFAULTANSICODEPAGE,cp_name,numchar);
|
|
|
|
oCP = atoi(cp_name);
|
|
|
|
if(cp_name != cp_on_stack)
|
|
|
|
delete [] cp_name;
|
|
|
|
return PR_TRUE;
|
|
|
|
} else {
|
|
|
|
oCP = CP_ACP;
|
|
|
|
return PR_FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-11-16 01:58:17 +00:00
|
|
|
/* This object maintains a correlation between attention timers and the
|
|
|
|
windows to which they belong. It's lighter than a hashtable (expected usage
|
|
|
|
is really just one at a time) and allows nsWindow::GetNSWindowPtr
|
|
|
|
to remain private. */
|
|
|
|
class nsAttentionTimerMonitor {
|
|
|
|
public:
|
|
|
|
nsAttentionTimerMonitor() : mHeadTimer(0) { }
|
|
|
|
~nsAttentionTimerMonitor() {
|
|
|
|
TimerInfo *current, *next;
|
|
|
|
for (current = mHeadTimer; current; current = next) {
|
|
|
|
next = current->next;
|
|
|
|
delete current;
|
|
|
|
}
|
|
|
|
}
|
2004-02-11 03:46:30 +00:00
|
|
|
void AddTimer(HWND timerWindow, HWND flashWindow, PRInt32 maxFlashCount, UINT timerID) {
|
2001-11-16 01:58:17 +00:00
|
|
|
TimerInfo *info;
|
|
|
|
PRBool newInfo = PR_FALSE;
|
|
|
|
info = FindInfo(timerWindow);
|
|
|
|
if (!info) {
|
|
|
|
info = new TimerInfo;
|
|
|
|
newInfo = PR_TRUE;
|
|
|
|
}
|
|
|
|
if (info) {
|
|
|
|
info->timerWindow = timerWindow;
|
|
|
|
info->flashWindow = flashWindow;
|
2004-02-11 03:46:30 +00:00
|
|
|
info->maxFlashCount = maxFlashCount;
|
|
|
|
info->flashCount = 0;
|
2001-11-16 01:58:17 +00:00
|
|
|
info->timerID = timerID;
|
2002-06-29 12:31:15 +00:00
|
|
|
info->hasFlashed = PR_FALSE;
|
2001-11-16 01:58:17 +00:00
|
|
|
info->next = 0;
|
|
|
|
if (newInfo)
|
|
|
|
AppendTimer(info);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
HWND GetFlashWindowFor(HWND timerWindow) {
|
|
|
|
TimerInfo *info = FindInfo(timerWindow);
|
|
|
|
return info ? info->flashWindow : 0;
|
|
|
|
}
|
2004-02-11 03:46:30 +00:00
|
|
|
PRInt32 GetMaxFlashCount(HWND timerWindow) {
|
|
|
|
TimerInfo *info = FindInfo(timerWindow);
|
|
|
|
return info ? info->maxFlashCount : -1;
|
|
|
|
}
|
|
|
|
PRInt32 GetFlashCount(HWND timerWindow) {
|
|
|
|
TimerInfo *info = FindInfo(timerWindow);
|
|
|
|
return info ? info->flashCount : -1;
|
|
|
|
}
|
|
|
|
void IncrementFlashCount(HWND timerWindow) {
|
|
|
|
TimerInfo *info = FindInfo(timerWindow);
|
|
|
|
++(info->flashCount);
|
|
|
|
}
|
2001-11-16 01:58:17 +00:00
|
|
|
void KillTimer(HWND timerWindow) {
|
|
|
|
TimerInfo *info = FindInfo(timerWindow);
|
|
|
|
if (info) {
|
|
|
|
// make sure it's unflashed and kill the timer
|
2002-06-29 12:31:15 +00:00
|
|
|
if (info->hasFlashed)
|
|
|
|
::FlashWindow(info->flashWindow, FALSE);
|
2001-11-16 01:58:17 +00:00
|
|
|
::KillTimer(info->timerWindow, info->timerID);
|
|
|
|
RemoveTimer(info);
|
|
|
|
delete info;
|
|
|
|
}
|
|
|
|
}
|
2002-06-29 12:31:15 +00:00
|
|
|
void SetFlashed(HWND timerWindow) {
|
|
|
|
TimerInfo *info = FindInfo(timerWindow);
|
|
|
|
if (info)
|
|
|
|
info->hasFlashed = PR_TRUE;
|
|
|
|
}
|
2001-11-16 01:58:17 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
struct TimerInfo {
|
|
|
|
HWND timerWindow,
|
|
|
|
flashWindow;
|
|
|
|
UINT timerID;
|
2004-02-11 03:46:30 +00:00
|
|
|
PRInt32 maxFlashCount;
|
|
|
|
PRInt32 flashCount;
|
2002-06-29 12:31:15 +00:00
|
|
|
PRBool hasFlashed;
|
2001-11-16 01:58:17 +00:00
|
|
|
TimerInfo *next;
|
|
|
|
};
|
|
|
|
TimerInfo *FindInfo(HWND timerWindow) {
|
|
|
|
TimerInfo *scan;
|
|
|
|
for (scan = mHeadTimer; scan; scan = scan->next)
|
|
|
|
if (scan->timerWindow == timerWindow)
|
|
|
|
break;
|
|
|
|
return scan;
|
|
|
|
}
|
|
|
|
void AppendTimer(TimerInfo *info) {
|
|
|
|
if (!mHeadTimer)
|
|
|
|
mHeadTimer = info;
|
|
|
|
else {
|
|
|
|
TimerInfo *scan, *last;
|
|
|
|
for (scan = mHeadTimer; scan; scan = scan->next)
|
|
|
|
last = scan;
|
|
|
|
last->next = info;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
void RemoveTimer(TimerInfo *info) {
|
|
|
|
TimerInfo *scan, *last = 0;
|
|
|
|
for (scan = mHeadTimer; scan && scan != info; scan = scan->next)
|
|
|
|
last = scan;
|
|
|
|
if (scan) {
|
|
|
|
if (last)
|
|
|
|
last->next = scan->next;
|
|
|
|
else
|
|
|
|
mHeadTimer = scan->next;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TimerInfo *mHeadTimer;
|
|
|
|
};
|
|
|
|
|
|
|
|
static nsAttentionTimerMonitor *gAttentionTimerMonitor = 0;
|
|
|
|
|
2002-06-04 17:47:54 +00:00
|
|
|
// Code to dispatch WM_SYSCOLORCHANGE message to all child windows.
|
|
|
|
// WM_SYSCOLORCHANGE is only sent to top-level windows, but the
|
|
|
|
// cross platform API requires that NS_SYSCOLORCHANGE message be sent to
|
|
|
|
// all child windows as well. When running in an embedded application
|
|
|
|
// we may not receive a WM_SYSCOLORCHANGE message because the top
|
|
|
|
// level window is owned by the embeddor. Note: this code can be used to
|
|
|
|
// dispatch other global messages (i.e messages that must be sent to all
|
|
|
|
// nsIWidget instances.
|
|
|
|
|
|
|
|
// Enumerate all child windows sending aMsg to each of them
|
|
|
|
|
|
|
|
BOOL CALLBACK nsWindow::BroadcastMsgToChildren(HWND aWnd, LPARAM aMsg)
|
|
|
|
{
|
2002-10-16 23:28:18 +00:00
|
|
|
LONG proc = nsToolkit::mGetWindowLong(aWnd, GWL_WNDPROC);
|
|
|
|
if (proc == (LONG)&nsWindow::WindowProc) {
|
|
|
|
// its one of our windows so go ahead and send a message to it
|
|
|
|
WNDPROC winProc = (WNDPROC)nsToolkit::mGetWindowLong(aWnd, GWL_WNDPROC);
|
|
|
|
nsToolkit::mCallWindowProc(winProc, aWnd, aMsg, 0, 0);
|
|
|
|
}
|
2002-06-04 17:47:54 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Enumerate all top level windows specifying that the children of each
|
|
|
|
// top level window should be enumerated. Do *not* send the message to
|
|
|
|
// each top level window since it is assumed that the toolkit will send
|
|
|
|
// aMsg to them directly.
|
|
|
|
|
|
|
|
BOOL CALLBACK nsWindow::BroadcastMsg(HWND aTopWindow, LPARAM aMsg)
|
|
|
|
{
|
|
|
|
// Iterate each of aTopWindows child windows sending the aMsg
|
|
|
|
// to each of them.
|
|
|
|
EnumChildWindows(aTopWindow, nsWindow::BroadcastMsgToChildren, aMsg);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// This method is called from nsToolkit::WindowProc to forward global
|
|
|
|
// messages which need to be dispatched to all child windows.
|
|
|
|
|
|
|
|
void nsWindow::GlobalMsgWindowProc(HWND hWnd, UINT msg,
|
|
|
|
WPARAM wParam, LPARAM lParam)
|
|
|
|
|
|
|
|
{
|
|
|
|
switch (msg) {
|
|
|
|
case WM_SYSCOLORCHANGE:
|
|
|
|
// System color changes are posted to top-level windows only.
|
|
|
|
// The NS_SYSCOLORCHANGE must be dispatched to all child
|
|
|
|
// windows as well.
|
|
|
|
::EnumThreadWindows(GetCurrentThreadId(), nsWindow::BroadcastMsg, msg);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// End of the methods to dispatch global messages
|
|
|
|
|
1999-11-15 20:57:41 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// nsISupport stuff
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
NS_IMPL_ADDREF(nsWindow)
|
|
|
|
NS_IMPL_RELEASE(nsWindow)
|
|
|
|
NS_IMETHODIMP nsWindow::QueryInterface(const nsIID& aIID, void** aInstancePtr)
|
|
|
|
{
|
|
|
|
if (NULL == aInstancePtr) {
|
|
|
|
return NS_ERROR_NULL_POINTER;
|
|
|
|
}
|
|
|
|
|
2000-02-04 00:39:15 +00:00
|
|
|
if (aIID.Equals(NS_GET_IID(nsIKBStateControl))) {
|
1999-11-15 20:57:41 +00:00
|
|
|
*aInstancePtr = (void*) ((nsIKBStateControl*)this);
|
|
|
|
NS_ADDREF((nsBaseWidget*)this);
|
|
|
|
// NS_ADDREF_THIS();
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
return nsBaseWidget::QueryInterface(aIID,aInstancePtr);
|
|
|
|
}
|
1998-11-04 21:43:47 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// nsWindow constructor
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2001-08-17 03:13:07 +00:00
|
|
|
#ifdef ACCESSIBILITY
|
2001-04-17 23:06:38 +00:00
|
|
|
nsWindow::nsWindow() : nsBaseWidget(), mRootAccessible(NULL)
|
2001-08-17 03:13:07 +00:00
|
|
|
#else
|
|
|
|
nsWindow::nsWindow() : nsBaseWidget()
|
|
|
|
#endif
|
1998-11-04 21:43:47 +00:00
|
|
|
{
|
|
|
|
mWnd = 0;
|
|
|
|
mPrevWndProc = NULL;
|
|
|
|
mBackground = ::GetSysColor(COLOR_BTNFACE);
|
|
|
|
mBrush = ::CreateSolidBrush(NSRGB_2_COLOREF(mBackground));
|
|
|
|
mForeground = ::GetSysColor(COLOR_WINDOWTEXT);
|
|
|
|
mIsShiftDown = PR_FALSE;
|
|
|
|
mIsControlDown = PR_FALSE;
|
|
|
|
mIsAltDown = PR_FALSE;
|
|
|
|
mIsDestroying = PR_FALSE;
|
|
|
|
mOnDestroyCalled = PR_FALSE;
|
|
|
|
mDeferredPositioner = NULL;
|
|
|
|
mLastPoint.x = 0;
|
|
|
|
mLastPoint.y = 0;
|
|
|
|
mPreferredWidth = 0;
|
|
|
|
mPreferredHeight = 0;
|
|
|
|
mFont = nsnull;
|
|
|
|
mIsVisible = PR_FALSE;
|
|
|
|
mHas3DBorder = PR_FALSE;
|
1999-07-27 04:27:17 +00:00
|
|
|
mWindowType = eWindowType_child;
|
|
|
|
mBorderStyle = eBorderStyle_default;
|
1999-05-27 21:09:49 +00:00
|
|
|
mBorderlessParent = 0;
|
2002-12-04 01:51:31 +00:00
|
|
|
mUnicodeWidget = PR_TRUE;
|
1999-08-05 14:56:21 +00:00
|
|
|
mIsInMouseCapture = PR_FALSE;
|
2001-09-29 00:05:58 +00:00
|
|
|
mIsInMouseWheelProcessing = PR_FALSE;
|
2000-05-11 22:59:20 +00:00
|
|
|
mLastSize.width = 0;
|
|
|
|
mLastSize.height = 0;
|
2002-02-20 03:33:52 +00:00
|
|
|
mOldStyle = 0;
|
|
|
|
mOldExStyle = 0;
|
1999-03-09 23:48:58 +00:00
|
|
|
|
2002-10-01 02:47:41 +00:00
|
|
|
mIMEProperty = 0;
|
|
|
|
mIMEIsComposing = PR_FALSE;
|
2000-10-11 21:50:50 +00:00
|
|
|
mIMEIsStatusChanged = PR_FALSE;
|
2002-10-01 02:47:41 +00:00
|
|
|
mIMECompString = NULL;
|
|
|
|
mIMECompUnicode = NULL;
|
|
|
|
mIMEAttributeString = NULL;
|
|
|
|
mIMEAttributeStringSize = 0;
|
|
|
|
mIMEAttributeStringLength = 0;
|
|
|
|
mIMECompClauseString = NULL;
|
|
|
|
mIMECompClauseStringSize = 0;
|
|
|
|
mIMECompClauseStringLength = 0;
|
2003-05-26 02:36:13 +00:00
|
|
|
mIMECursorPosition = 0;
|
2002-10-01 02:47:41 +00:00
|
|
|
mIMEReconvertUnicode = NULL;
|
|
|
|
mLeadByte = '\0';
|
2003-02-24 20:15:59 +00:00
|
|
|
mBlurEventSuppressionLevel = 0;
|
2002-10-01 02:47:41 +00:00
|
|
|
mIMECompCharPos = nsnull;
|
1999-11-29 21:14:43 +00:00
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
static BOOL gbInitGlobalValue = FALSE;
|
|
|
|
if(! gbInitGlobalValue) {
|
|
|
|
gbInitGlobalValue = TRUE;
|
|
|
|
gKeyboardLayout = GetKeyboardLayout(0);
|
|
|
|
LangIDToCP((WORD)(0x0FFFFL & (DWORD)gKeyboardLayout), gCurrentKeyboardCP);
|
2002-05-08 20:24:55 +00:00
|
|
|
|
|
|
|
if (nsToolkit::mW2KXP_CP936) {
|
|
|
|
DWORD imeProp = 0;
|
|
|
|
NS_IMM_GETPROPERTY(gKeyboardLayout, IGP_PROPERTY, imeProp);
|
|
|
|
nsToolkit::mUseImeApiW = (imeProp & IME_PROP_UNICODE) ? PR_TRUE : PR_FALSE;
|
|
|
|
}
|
2000-05-11 22:59:20 +00:00
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
//
|
|
|
|
// Reconvert message for Windows 95 / NT 4.0
|
|
|
|
//
|
|
|
|
|
|
|
|
// MS-IME98/2000
|
|
|
|
nsWindow::uWM_MSIME_RECONVERT = ::RegisterWindowMessage(RWM_RECONVERT);
|
|
|
|
|
|
|
|
// ATOK12/13
|
|
|
|
nsWindow::uWM_ATOK_RECONVERT = ::RegisterWindowMessage(MSGNAME_ATOK_RECONVERT);
|
|
|
|
|
|
|
|
// mouse message of MSIME98/2000
|
|
|
|
nsWindow::uWM_MSIME_MOUSE = ::RegisterWindowMessage(RWM_MOUSE);
|
2002-02-27 02:18:12 +00:00
|
|
|
|
|
|
|
// Heap dump
|
|
|
|
nsWindow::uWM_HEAP_DUMP = ::RegisterWindowMessage(kMozHeapDumpMessageString);
|
2000-08-04 21:43:29 +00:00
|
|
|
}
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-06-17 23:23:11 +00:00
|
|
|
mNativeDragTarget = nsnull;
|
1999-10-02 00:13:23 +00:00
|
|
|
mIsTopWidgetWindow = PR_FALSE;
|
2003-03-14 23:35:18 +00:00
|
|
|
|
|
|
|
#ifndef __MINGW32__
|
2000-03-18 00:57:23 +00:00
|
|
|
if (!nsWindow::uMSH_MOUSEWHEEL)
|
|
|
|
nsWindow::uMSH_MOUSEWHEEL = RegisterWindowMessage(MSH_MOUSEWHEEL);
|
2003-03-14 23:35:18 +00:00
|
|
|
#endif
|
1998-11-04 21:43:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
1999-12-01 22:10:13 +00:00
|
|
|
HKL nsWindow::gKeyboardLayout = 0;
|
|
|
|
UINT nsWindow::gCurrentKeyboardCP = 0;
|
|
|
|
|
1998-11-04 21:43:47 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// nsWindow destructor
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
nsWindow::~nsWindow()
|
|
|
|
{
|
2001-08-17 03:13:07 +00:00
|
|
|
#ifdef ACCESSIBILITY
|
2001-09-25 08:34:42 +00:00
|
|
|
if (mRootAccessible) {
|
2001-04-17 23:06:38 +00:00
|
|
|
mRootAccessible->Release();
|
2001-09-25 08:34:42 +00:00
|
|
|
mRootAccessible = nsnull;
|
|
|
|
}
|
2001-08-17 03:13:07 +00:00
|
|
|
#endif
|
2001-04-17 23:06:38 +00:00
|
|
|
|
1998-11-04 21:43:47 +00:00
|
|
|
mIsDestroying = PR_TRUE;
|
|
|
|
if (gCurrentWindow == this) {
|
|
|
|
gCurrentWindow = nsnull;
|
|
|
|
}
|
|
|
|
|
|
|
|
MouseTrailer * mouseTrailer = MouseTrailer::GetMouseTrailer(0);
|
|
|
|
if (mouseTrailer->GetMouseTrailerWindow() == this) {
|
|
|
|
mouseTrailer->DestroyTimer();
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the widget was released without calling Destroy() then the native
|
|
|
|
// window still exists, and we need to destroy it
|
|
|
|
if (NULL != mWnd) {
|
|
|
|
Destroy();
|
|
|
|
}
|
|
|
|
|
|
|
|
//XXX Temporary: Should not be caching the font
|
|
|
|
delete mFont;
|
1999-06-29 20:31:22 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// delete any of the IME structures that we allocated
|
|
|
|
//
|
1999-11-16 23:45:44 +00:00
|
|
|
if (mIMECompString!=NULL)
|
2001-02-23 02:03:02 +00:00
|
|
|
delete mIMECompString;
|
1999-11-16 23:45:44 +00:00
|
|
|
if (mIMECompUnicode!=NULL)
|
2001-02-23 02:03:02 +00:00
|
|
|
delete mIMECompUnicode;
|
1999-11-16 23:45:44 +00:00
|
|
|
if (mIMEAttributeString!=NULL)
|
|
|
|
delete [] mIMEAttributeString;
|
|
|
|
if (mIMECompClauseString!=NULL)
|
|
|
|
delete [] mIMECompClauseString;
|
2000-08-04 21:43:29 +00:00
|
|
|
if (mIMEReconvertUnicode)
|
|
|
|
nsMemory::Free(mIMEReconvertUnicode);
|
1999-11-01 21:53:06 +00:00
|
|
|
|
|
|
|
NS_IF_RELEASE(mNativeDragTarget);
|
1998-11-04 21:43:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
1999-06-21 20:37:50 +00:00
|
|
|
NS_METHOD nsWindow::CaptureMouse(PRBool aCapture)
|
|
|
|
{
|
|
|
|
if (PR_TRUE == aCapture) {
|
1999-09-09 13:38:30 +00:00
|
|
|
MouseTrailer::SetCaptureWindow(this);
|
|
|
|
::SetCapture(mWnd);
|
1999-06-21 20:37:50 +00:00
|
|
|
} else {
|
1999-09-09 13:38:30 +00:00
|
|
|
MouseTrailer::SetCaptureWindow(NULL);
|
|
|
|
::ReleaseCapture();
|
1999-06-21 20:37:50 +00:00
|
|
|
}
|
1999-08-05 14:56:21 +00:00
|
|
|
mIsInMouseCapture = aCapture;
|
1999-06-21 20:37:50 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
1998-05-14 21:34:08 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Default for height modification is to do nothing
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
|
|
|
|
PRInt32 nsWindow::GetHeight(PRInt32 aProposedHeight)
|
|
|
|
{
|
|
|
|
return(aProposedHeight);
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-05-13 03:39:08 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Deferred Window positioning
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-05-05 23:41:16 +00:00
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::BeginResizingChildren(void)
|
1998-05-13 03:39:08 +00:00
|
|
|
{
|
|
|
|
if (NULL == mDeferredPositioner)
|
|
|
|
mDeferredPositioner = ::BeginDeferWindowPos(1);
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-05-13 03:39:08 +00:00
|
|
|
}
|
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::EndResizingChildren(void)
|
1998-05-13 03:39:08 +00:00
|
|
|
{
|
|
|
|
if (NULL != mDeferredPositioner) {
|
|
|
|
::EndDeferWindowPos(mDeferredPositioner);
|
|
|
|
mDeferredPositioner = NULL;
|
|
|
|
}
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-05-13 03:39:08 +00:00
|
|
|
}
|
1998-05-05 23:41:16 +00:00
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::WidgetToScreen(const nsRect& aOldRect, nsRect& aNewRect)
|
1998-05-05 23:41:16 +00:00
|
|
|
{
|
|
|
|
POINT point;
|
|
|
|
point.x = aOldRect.x;
|
|
|
|
point.y = aOldRect.y;
|
|
|
|
::ClientToScreen((HWND)GetNativeData(NS_NATIVE_WINDOW), &point);
|
|
|
|
aNewRect.x = point.x;
|
|
|
|
aNewRect.y = point.y;
|
|
|
|
aNewRect.width = aOldRect.width;
|
|
|
|
aNewRect.height = aOldRect.height;
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-05-05 23:41:16 +00:00
|
|
|
}
|
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::ScreenToWidget(const nsRect& aOldRect, nsRect& aNewRect)
|
1998-05-05 23:41:16 +00:00
|
|
|
{
|
|
|
|
POINT point;
|
|
|
|
point.x = aOldRect.x;
|
|
|
|
point.y = aOldRect.y;
|
|
|
|
::ScreenToClient((HWND)GetNativeData(NS_NATIVE_WINDOW), &point);
|
|
|
|
aNewRect.x = point.x;
|
|
|
|
aNewRect.y = point.y;
|
|
|
|
aNewRect.width = aOldRect.width;
|
|
|
|
aNewRect.height = aOldRect.height;
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-05-04 19:25:25 +00:00
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Convert nsEventStatus value to a windows boolean
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
|
|
|
|
PRBool nsWindow::ConvertStatus(nsEventStatus aStatus)
|
|
|
|
{
|
|
|
|
switch(aStatus) {
|
1998-09-15 00:14:11 +00:00
|
|
|
case nsEventStatus_eIgnore:
|
|
|
|
return PR_FALSE;
|
|
|
|
case nsEventStatus_eConsumeNoDefault:
|
|
|
|
return PR_TRUE;
|
|
|
|
case nsEventStatus_eConsumeDoDefault:
|
|
|
|
return PR_FALSE;
|
|
|
|
default:
|
|
|
|
NS_ASSERTION(0, "Illegal nsEventStatus enumeration value");
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
}
|
1998-09-15 00:14:11 +00:00
|
|
|
return PR_FALSE;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
1998-04-24 23:09:11 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Initialize an event to dispatch
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2004-01-12 08:25:18 +00:00
|
|
|
void nsWindow::InitEvent(nsGUIEvent& event, nsPoint* aPoint)
|
1998-04-24 23:09:11 +00:00
|
|
|
{
|
1998-10-08 00:04:21 +00:00
|
|
|
NS_ADDREF(event.widget);
|
1998-04-24 23:09:11 +00:00
|
|
|
|
1998-05-29 22:44:13 +00:00
|
|
|
if (nsnull == aPoint) { // use the point from the event
|
|
|
|
// get the message position in client coordinates and in twips
|
|
|
|
DWORD pos = ::GetMessagePos();
|
|
|
|
POINT cpos;
|
1998-04-24 23:09:11 +00:00
|
|
|
|
2001-04-10 02:27:41 +00:00
|
|
|
cpos.x = (short)LOWORD(pos);
|
|
|
|
cpos.y = (short)HIWORD(pos);
|
1998-04-24 23:09:11 +00:00
|
|
|
|
1998-08-04 21:04:02 +00:00
|
|
|
if (mWnd != NULL) {
|
|
|
|
::ScreenToClient(mWnd, &cpos);
|
|
|
|
event.point.x = cpos.x;
|
|
|
|
event.point.y = cpos.y;
|
1998-08-04 21:06:35 +00:00
|
|
|
} else {
|
|
|
|
event.point.x = 0;
|
|
|
|
event.point.y = 0;
|
1998-08-04 21:04:02 +00:00
|
|
|
}
|
1998-05-29 22:44:13 +00:00
|
|
|
}
|
|
|
|
else { // use the point override if provided
|
|
|
|
event.point.x = aPoint->x;
|
|
|
|
event.point.y = aPoint->y;
|
|
|
|
}
|
1998-04-24 23:09:11 +00:00
|
|
|
|
|
|
|
event.time = ::GetMessageTime();
|
1998-05-29 22:44:13 +00:00
|
|
|
|
|
|
|
mLastPoint.x = event.point.x;
|
|
|
|
mLastPoint.y = event.point.y;
|
1998-04-24 23:09:11 +00:00
|
|
|
}
|
|
|
|
|
2003-02-24 20:15:59 +00:00
|
|
|
/* In some circumstances (opening dependent windows) it makes more sense
|
|
|
|
(and fixes a crash bug) to not blur the parent window. */
|
|
|
|
void nsWindow::SuppressBlurEvents(PRBool aSuppress)
|
|
|
|
{
|
|
|
|
if (aSuppress)
|
|
|
|
++mBlurEventSuppressionLevel; // for this widget
|
|
|
|
else {
|
|
|
|
NS_ASSERTION(mBlurEventSuppressionLevel > 0, "unbalanced blur event suppression");
|
|
|
|
if (mBlurEventSuppressionLevel > 0)
|
|
|
|
--mBlurEventSuppressionLevel;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
PRBool nsWindow::BlurEventsSuppressed()
|
|
|
|
{
|
|
|
|
// are they suppressed in this window?
|
|
|
|
if (mBlurEventSuppressionLevel > 0)
|
|
|
|
return PR_TRUE;
|
|
|
|
|
|
|
|
// are they suppressed by any container widget?
|
|
|
|
HWND parentWnd = ::GetParent(mWnd);
|
|
|
|
if (parentWnd) {
|
|
|
|
nsWindow *parent = GetNSWindowPtr(parentWnd);
|
|
|
|
if (parent)
|
|
|
|
return parent->BlurEventsSuppressed();
|
|
|
|
}
|
|
|
|
return PR_FALSE;
|
|
|
|
}
|
|
|
|
|
1998-04-24 23:09:11 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Invokes callback and ProcessEvent method on Event Listener object
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
|
1998-10-07 22:11:37 +00:00
|
|
|
NS_IMETHODIMP nsWindow::DispatchEvent(nsGUIEvent* event, nsEventStatus & aStatus)
|
1998-04-24 23:09:11 +00:00
|
|
|
{
|
1999-09-09 03:47:26 +00:00
|
|
|
#ifdef NS_DEBUG
|
|
|
|
debug_DumpEvent(stdout,
|
|
|
|
event->widget,
|
|
|
|
event,
|
2000-09-03 00:31:01 +00:00
|
|
|
nsCAutoString("something"),
|
1999-09-09 03:47:26 +00:00
|
|
|
(PRInt32) mWnd);
|
|
|
|
#endif // NS_DEBUG
|
|
|
|
|
1998-10-07 22:11:37 +00:00
|
|
|
aStatus = nsEventStatus_eIgnore;
|
2003-02-24 20:15:59 +00:00
|
|
|
|
|
|
|
// skip processing of suppressed blur events
|
|
|
|
if ((event->message == NS_DEACTIVATE || event->message == NS_LOSTFOCUS) &&
|
|
|
|
BlurEventsSuppressed())
|
|
|
|
return NS_OK;
|
|
|
|
|
1998-04-24 23:09:11 +00:00
|
|
|
if (nsnull != mEventCallback) {
|
1998-10-07 22:11:37 +00:00
|
|
|
aStatus = (*mEventCallback)(event);
|
1998-04-24 23:09:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Dispatch to event listener if event was not consumed
|
1998-10-07 22:11:37 +00:00
|
|
|
if ((aStatus != nsEventStatus_eIgnore) && (nsnull != mEventListener)) {
|
|
|
|
aStatus = mEventListener->ProcessEvent(*event);
|
1998-04-24 23:09:11 +00:00
|
|
|
}
|
1999-04-06 00:11:43 +00:00
|
|
|
|
|
|
|
// the window can be destroyed during processing of seemingly innocuous events like, say,
|
|
|
|
// mousedowns due to the magic of scripting. mousedowns will return nsEventStatus_eIgnore,
|
|
|
|
// which causes problems with the deleted window. therefore:
|
|
|
|
if (mOnDestroyCalled)
|
|
|
|
aStatus = nsEventStatus_eConsumeNoDefault;
|
1998-10-07 22:11:37 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
PRBool nsWindow::DispatchWindowEvent(nsGUIEvent* event)
|
|
|
|
{
|
|
|
|
nsEventStatus status;
|
|
|
|
DispatchEvent(event, status);
|
|
|
|
return ConvertStatus(status);
|
1998-04-24 23:09:11 +00:00
|
|
|
}
|
|
|
|
|
1999-11-12 02:06:52 +00:00
|
|
|
PRBool nsWindow::DispatchWindowEvent(nsGUIEvent*event, nsEventStatus &aStatus) {
|
|
|
|
DispatchEvent(event, aStatus);
|
|
|
|
return ConvertStatus(aStatus);
|
|
|
|
}
|
|
|
|
|
1998-05-04 19:25:25 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Dispatch standard event
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
|
|
|
|
PRBool nsWindow::DispatchStandardEvent(PRUint32 aMsg)
|
|
|
|
{
|
2004-01-12 08:25:18 +00:00
|
|
|
nsGUIEvent event(aMsg, this);
|
|
|
|
InitEvent(event);
|
1998-10-07 22:11:37 +00:00
|
|
|
|
1998-10-08 00:04:21 +00:00
|
|
|
PRBool result = DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
return result;
|
1998-05-04 19:25:25 +00:00
|
|
|
}
|
1998-04-24 23:09:11 +00:00
|
|
|
|
2002-12-06 03:41:43 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Dispatch app command event
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
PRBool nsWindow::DispatchAppCommandEvent(PRUint32 aEventCommand)
|
|
|
|
{
|
2004-01-12 08:25:18 +00:00
|
|
|
nsAppCommandEvent event(NS_APPCOMMAND_START, this);
|
2002-12-06 03:41:43 +00:00
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event);
|
2002-12-06 03:41:43 +00:00
|
|
|
event.appCommand = NS_APPCOMMAND_START + aEventCommand;
|
|
|
|
|
|
|
|
DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-09-21 11:22:21 +00:00
|
|
|
//-------------------------------------------------------------------------
|
1999-09-30 14:36:17 +00:00
|
|
|
NS_IMETHODIMP nsWindow::CaptureRollupEvents(nsIRollupListener * aListener,
|
|
|
|
PRBool aDoCapture,
|
|
|
|
PRBool aConsumeRollupEvent)
|
1999-09-21 11:22:21 +00:00
|
|
|
{
|
|
|
|
if (aDoCapture) {
|
1999-11-12 23:46:11 +00:00
|
|
|
/* we haven't bothered carrying a weak reference to gRollupWidget because
|
|
|
|
we believe lifespan is properly scoped. this next assertion helps
|
|
|
|
assure that remains true. */
|
|
|
|
NS_ASSERTION(!gRollupWidget, "rollup widget reassigned before release");
|
1999-09-30 14:36:17 +00:00
|
|
|
gRollupConsumeRollupEvent = aConsumeRollupEvent;
|
1999-09-21 11:22:21 +00:00
|
|
|
NS_IF_RELEASE(gRollupListener);
|
|
|
|
NS_IF_RELEASE(gRollupWidget);
|
|
|
|
gRollupListener = aListener;
|
|
|
|
NS_ADDREF(aListener);
|
|
|
|
gRollupWidget = this;
|
|
|
|
NS_ADDREF(this);
|
2001-05-25 10:53:32 +00:00
|
|
|
|
|
|
|
if (!gMsgFilterHook && !gCallProcHook && !gCallMouseHook) {
|
|
|
|
RegisterSpecialDropdownHooks();
|
|
|
|
}
|
|
|
|
gProcessHook = PR_TRUE;
|
|
|
|
|
1999-09-21 11:22:21 +00:00
|
|
|
} else {
|
|
|
|
NS_IF_RELEASE(gRollupListener);
|
|
|
|
NS_IF_RELEASE(gRollupWidget);
|
2001-05-25 10:53:32 +00:00
|
|
|
|
|
|
|
gProcessHook = PR_FALSE;
|
|
|
|
UnregisterSpecialDropdownHooks();
|
1999-09-21 11:22:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-10-02 00:13:23 +00:00
|
|
|
PRBool
|
2001-03-14 02:34:46 +00:00
|
|
|
nsWindow::EventIsInsideWindow(UINT Msg, nsWindow* aWindow)
|
1999-10-02 00:13:23 +00:00
|
|
|
{
|
|
|
|
RECT r;
|
2001-03-14 02:34:46 +00:00
|
|
|
|
|
|
|
if (Msg == WM_ACTIVATE)
|
|
|
|
// don't care about activation/deactivation
|
|
|
|
return PR_FALSE;
|
|
|
|
|
1999-10-02 00:13:23 +00:00
|
|
|
::GetWindowRect(aWindow->mWnd, &r);
|
|
|
|
DWORD pos = ::GetMessagePos();
|
|
|
|
POINT mp;
|
2001-04-10 02:27:41 +00:00
|
|
|
mp.x = (short)LOWORD(pos);
|
|
|
|
mp.y = (short)HIWORD(pos);
|
1999-10-02 00:13:23 +00:00
|
|
|
|
2001-03-14 02:34:46 +00:00
|
|
|
// was the event inside this window?
|
|
|
|
return (PRBool) PtInRect(&r, mp);
|
1999-10-02 00:13:23 +00:00
|
|
|
}
|
|
|
|
|
2000-04-27 00:23:18 +00:00
|
|
|
static LPCTSTR GetNSWindowPropName() {
|
|
|
|
static ATOM atom = 0;
|
|
|
|
|
|
|
|
// this is threadsafe, even without locking;
|
2001-05-25 10:53:32 +00:00
|
|
|
// even if there's a race, GlobalAddAtom("MozillaWindowPtr")
|
2000-04-27 00:23:18 +00:00
|
|
|
// will just return the same value
|
|
|
|
if (!atom) {
|
2001-05-25 10:53:32 +00:00
|
|
|
atom = ::GlobalAddAtom("MozillansIWidgetPtr");
|
2000-04-27 00:23:18 +00:00
|
|
|
}
|
|
|
|
return MAKEINTATOM(atom);
|
|
|
|
}
|
|
|
|
|
|
|
|
nsWindow * nsWindow::GetNSWindowPtr(HWND aWnd) {
|
|
|
|
return (nsWindow *) ::GetProp(aWnd, GetNSWindowPropName());
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL nsWindow::SetNSWindowPtr(HWND aWnd, nsWindow * ptr) {
|
|
|
|
if (ptr == NULL) {
|
|
|
|
::RemoveProp(aWnd, GetNSWindowPropName());
|
|
|
|
return TRUE;
|
|
|
|
} else {
|
|
|
|
return ::SetProp(aWnd, GetNSWindowPropName(), (HANDLE)ptr);
|
|
|
|
}
|
|
|
|
}
|
1999-10-02 00:13:23 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//
|
2000-04-13 20:15:40 +00:00
|
|
|
// DealWithPopups
|
1998-04-13 20:24:54 +00:00
|
|
|
//
|
2000-04-13 20:15:40 +00:00
|
|
|
// Handle events that may cause a popup (combobox, XPMenu, etc) to need to rollup.
|
|
|
|
//
|
|
|
|
BOOL
|
2001-03-14 02:34:46 +00:00
|
|
|
nsWindow :: DealWithPopups ( UINT inMsg, WPARAM inWParam, LPARAM inLParam, LRESULT* outResult )
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
2000-04-13 20:15:40 +00:00
|
|
|
if ( gRollupListener && gRollupWidget) {
|
|
|
|
|
2003-05-21 20:31:06 +00:00
|
|
|
if (inMsg == WM_ACTIVATE || inMsg == WM_NCLBUTTONDOWN || inMsg == WM_LBUTTONDOWN ||
|
2000-04-13 20:15:40 +00:00
|
|
|
inMsg == WM_RBUTTONDOWN || inMsg == WM_MBUTTONDOWN ||
|
2000-12-09 07:28:19 +00:00
|
|
|
inMsg == WM_NCMBUTTONDOWN || inMsg == WM_NCRBUTTONDOWN || inMsg == WM_MOUSEACTIVATE ||
|
2001-05-25 10:53:32 +00:00
|
|
|
inMsg == WM_MOUSEWHEEL || inMsg == uMSH_MOUSEWHEEL || inMsg == WM_ACTIVATEAPP ||
|
|
|
|
inMsg == WM_MENUSELECT || inMsg == WM_MOVING || inMsg == WM_SIZING || inMsg == WM_GETMINMAXINFO)
|
2000-12-09 07:28:19 +00:00
|
|
|
{
|
2000-04-13 20:15:40 +00:00
|
|
|
// Rollup if the event is outside the popup.
|
2001-03-14 02:34:46 +00:00
|
|
|
PRBool rollup = !nsWindow::EventIsInsideWindow(inMsg, (nsWindow*)gRollupWidget);
|
2000-12-09 07:28:19 +00:00
|
|
|
|
|
|
|
if (rollup && (inMsg == WM_MOUSEWHEEL || inMsg == uMSH_MOUSEWHEEL))
|
|
|
|
{
|
|
|
|
gRollupListener->ShouldRollupOnMouseWheelEvent(&rollup);
|
|
|
|
*outResult = PR_TRUE;
|
|
|
|
}
|
|
|
|
|
2000-04-13 20:15:40 +00:00
|
|
|
// If we're dealing with menus, we probably have submenus and we don't
|
|
|
|
// want to rollup if the click is in a parent menu of the current submenu.
|
|
|
|
if (rollup) {
|
|
|
|
nsCOMPtr<nsIMenuRollup> menuRollup ( do_QueryInterface(gRollupListener) );
|
|
|
|
if ( menuRollup ) {
|
|
|
|
nsCOMPtr<nsISupportsArray> widgetChain;
|
|
|
|
menuRollup->GetSubmenuWidgetChain ( getter_AddRefs(widgetChain) );
|
|
|
|
if ( widgetChain ) {
|
|
|
|
PRUint32 count = 0;
|
|
|
|
widgetChain->Count(&count);
|
|
|
|
for ( PRUint32 i = 0; i < count; ++i ) {
|
|
|
|
nsCOMPtr<nsISupports> genericWidget;
|
|
|
|
widgetChain->GetElementAt ( i, getter_AddRefs(genericWidget) );
|
|
|
|
nsCOMPtr<nsIWidget> widget ( do_QueryInterface(genericWidget) );
|
|
|
|
if ( widget ) {
|
|
|
|
nsIWidget* temp = widget.get();
|
2001-03-14 02:34:46 +00:00
|
|
|
if ( nsWindow::EventIsInsideWindow(inMsg, (nsWindow*)temp) ) {
|
2000-04-13 20:15:40 +00:00
|
|
|
rollup = PR_FALSE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} // foreach parent menu widget
|
|
|
|
}
|
|
|
|
} // if rollup listener knows about menus
|
1999-10-02 00:13:23 +00:00
|
|
|
}
|
|
|
|
|
2000-04-13 20:15:40 +00:00
|
|
|
if (inMsg == WM_MOUSEACTIVATE) {
|
1999-10-02 00:13:23 +00:00
|
|
|
// Prevent the click inside the popup from causing a change in window
|
2000-01-28 23:37:36 +00:00
|
|
|
// activation. Since the popup is shown non-activated, we need to eat
|
1999-10-02 00:13:23 +00:00
|
|
|
// any requests to activate the window while it is displayed. Windows
|
|
|
|
// will automatically activate the popup on the mousedown otherwise.
|
2000-04-13 20:15:40 +00:00
|
|
|
if (!rollup) {
|
|
|
|
*outResult = MA_NOACTIVATE;
|
|
|
|
return TRUE;
|
|
|
|
}
|
2001-03-14 02:34:46 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
UINT uMsg = HIWORD(inLParam);
|
|
|
|
if (uMsg == WM_MOUSEMOVE)
|
|
|
|
{
|
|
|
|
// WM_MOUSEACTIVATE cause by moving the mouse - X-mouse (eg. TweakUI)
|
|
|
|
// must be enabled in Windows.
|
2001-12-11 06:16:07 +00:00
|
|
|
gRollupListener->ShouldRollupOnMouseActivate(&rollup);
|
2001-03-14 02:34:46 +00:00
|
|
|
if (!rollup)
|
|
|
|
{
|
|
|
|
*outResult = MA_NOACTIVATE;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
1999-09-23 12:03:44 +00:00
|
|
|
}
|
2001-02-08 00:44:36 +00:00
|
|
|
|
|
|
|
// if we've still determined that we should still rollup everything, do it.
|
2001-02-08 21:06:43 +00:00
|
|
|
else if ( rollup ) {
|
2003-05-21 20:31:06 +00:00
|
|
|
gRollupListener->Rollup();
|
|
|
|
|
|
|
|
// Tell hook to stop processing messages
|
|
|
|
gProcessHook = PR_FALSE;
|
|
|
|
gRollupMsgId = 0;
|
|
|
|
|
|
|
|
// return TRUE tells Windows that the event is consumed,
|
|
|
|
// false allows the event to be dispatched
|
|
|
|
//
|
|
|
|
// So if we are NOT supposed to be consuming events, let it go through
|
|
|
|
if (gRollupConsumeRollupEvent && inMsg != WM_RBUTTONDOWN) {
|
|
|
|
*outResult = TRUE;
|
|
|
|
return TRUE;
|
|
|
|
}
|
2000-04-13 20:15:40 +00:00
|
|
|
}
|
|
|
|
} // if event that might trigger a popup to rollup
|
|
|
|
} // if rollup listeners registered
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
} // DealWithPopups
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// the nsWindow procedure for all nsWindows in this toolkit
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
LRESULT CALLBACK nsWindow::WindowProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
|
|
|
{
|
|
|
|
LRESULT popupHandlingResult;
|
2001-03-14 02:34:46 +00:00
|
|
|
if ( DealWithPopups(msg, wParam, lParam, &popupHandlingResult) )
|
2000-04-13 20:15:40 +00:00
|
|
|
return popupHandlingResult;
|
1999-09-21 11:22:21 +00:00
|
|
|
|
1999-02-09 18:20:18 +00:00
|
|
|
// Get the window which caused the event and ask it to process the message
|
2000-04-27 00:23:18 +00:00
|
|
|
nsWindow *someWindow = GetNSWindowPtr(hWnd);
|
1998-04-17 00:16:11 +00:00
|
|
|
|
2000-10-19 00:48:06 +00:00
|
|
|
// XXX This fixes 50208 and we are leaving 51174 open to further investigate
|
|
|
|
// why we are hitting this assert
|
|
|
|
if (nsnull == someWindow) {
|
|
|
|
NS_ASSERTION(someWindow, "someWindow is null, cannot call any CallWindowProc");
|
2002-09-09 23:58:39 +00:00
|
|
|
return nsToolkit::mDefWindowProc(hWnd, msg, wParam, lParam);
|
2000-10-19 00:48:06 +00:00
|
|
|
}
|
|
|
|
|
1999-07-03 01:17:44 +00:00
|
|
|
// hold on to the window for the life of this method, in case it gets
|
|
|
|
// deleted during processing. yes, it's a double hack, since someWindow
|
|
|
|
// is not really an interface.
|
|
|
|
nsCOMPtr<nsISupports> kungFuDeathGrip;
|
|
|
|
if (!someWindow->mIsDestroying) // not if we're in the destructor!
|
1999-11-15 20:57:41 +00:00
|
|
|
kungFuDeathGrip = do_QueryInterface((nsBaseWidget*)someWindow);
|
1999-07-03 01:17:44 +00:00
|
|
|
|
1999-04-06 00:11:43 +00:00
|
|
|
// Re-direct a tab change message destined for its parent window to the
|
1999-02-09 18:20:18 +00:00
|
|
|
// the actual window which generated the event.
|
1998-04-17 00:16:11 +00:00
|
|
|
if (msg == WM_NOTIFY) {
|
|
|
|
LPNMHDR pnmh = (LPNMHDR) lParam;
|
1999-07-03 01:17:44 +00:00
|
|
|
if (pnmh->code == TCN_SELCHANGE) {
|
2000-04-27 00:23:18 +00:00
|
|
|
someWindow = GetNSWindowPtr(pnmh->hwndFrom);
|
1998-04-17 00:16:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
if (nsnull != someWindow) {
|
|
|
|
LRESULT retValue;
|
|
|
|
if (PR_TRUE == someWindow->ProcessMessage(msg, wParam, lParam, &retValue)) {
|
|
|
|
return retValue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1998-08-29 06:21:50 +00:00
|
|
|
#if defined(STRICT)
|
2002-09-09 23:58:39 +00:00
|
|
|
return nsToolkit::mCallWindowProc((WNDPROC)someWindow->GetPrevWindowProc(), hWnd,
|
2002-07-03 00:55:47 +00:00
|
|
|
msg, wParam, lParam);
|
1998-08-29 06:21:50 +00:00
|
|
|
#else
|
2002-09-09 23:58:39 +00:00
|
|
|
return nsToolkit::mCallWindowProc((FARPROC)someWindow->GetPrevWindowProc(), hWnd,
|
2002-07-03 00:55:47 +00:00
|
|
|
msg, wParam, lParam);
|
1998-08-29 06:21:50 +00:00
|
|
|
#endif
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
2000-01-07 00:34:34 +00:00
|
|
|
//
|
|
|
|
// Default Window proceduer for AIMM support.
|
|
|
|
//
|
|
|
|
LRESULT CALLBACK nsWindow::DefaultWindowProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
|
|
|
{
|
|
|
|
if(nsToolkit::gAIMMApp)
|
|
|
|
{
|
|
|
|
LRESULT lResult;
|
|
|
|
if (nsToolkit::gAIMMApp->OnDefWindowProc(hWnd, msg, wParam, lParam, &lResult) == S_OK)
|
|
|
|
return lResult;
|
|
|
|
}
|
2002-09-09 23:58:39 +00:00
|
|
|
return nsToolkit::mDefWindowProc(hWnd, msg, wParam, lParam);
|
2000-01-07 00:34:34 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2000-04-27 00:23:18 +00:00
|
|
|
static BOOL CALLBACK DummyDialogProc(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) {
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
1999-03-09 23:48:58 +00:00
|
|
|
//WINOLEAPI oleStatus;
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
1998-09-29 21:34:58 +00:00
|
|
|
// Utility method for implementing both Create(nsIWidget ...) and
|
|
|
|
// Create(nsNativeWidget...)
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
Bug 109851, bug 108629, bug 109921, bug 109977, bug 109153, bug 109187, bug 109213, bug 109221. Check in latest XUL accessibility support - menus, <colorpicker>, <progressmeter>, <groupbox>, mixed states for checkboxes, buttons that can be 'checked' ie pressed down, fixes extra MSAA events being generated, couldn't see HTML content
2001-11-20 02:05:26 +00:00
|
|
|
|
1998-09-29 21:34:58 +00:00
|
|
|
nsresult nsWindow::StandardWindowCreate(nsIWidget *aParent,
|
1998-04-13 20:24:54 +00:00
|
|
|
const nsRect &aRect,
|
|
|
|
EVENT_CALLBACK aHandleEventFunction,
|
|
|
|
nsIDeviceContext *aContext,
|
1998-07-29 18:51:45 +00:00
|
|
|
nsIAppShell *aAppShell,
|
1998-04-24 21:37:30 +00:00
|
|
|
nsIToolkit *aToolkit,
|
1998-09-29 21:34:58 +00:00
|
|
|
nsWidgetInitData *aInitData,
|
|
|
|
nsNativeWidget aNativeParent)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1999-08-12 22:08:17 +00:00
|
|
|
nsIWidget *baseParent = aInitData &&
|
|
|
|
(aInitData->mWindowType == eWindowType_dialog ||
|
2003-07-25 14:54:39 +00:00
|
|
|
aInitData->mWindowType == eWindowType_toplevel ||
|
|
|
|
aInitData->mWindowType == eWindowType_invisible) ?
|
1999-08-12 22:08:17 +00:00
|
|
|
nsnull : aParent;
|
1999-10-02 00:13:23 +00:00
|
|
|
|
|
|
|
mIsTopWidgetWindow = (nsnull == baseParent);
|
|
|
|
|
1999-08-12 22:08:17 +00:00
|
|
|
BaseCreate(baseParent, aRect, aHandleEventFunction, aContext,
|
1998-09-23 19:19:23 +00:00
|
|
|
aAppShell, aToolkit, aInitData);
|
1998-07-29 18:51:45 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
// Switch to the "main gui thread" if necessary... This method must
|
|
|
|
// be executed on the "gui thread"...
|
1998-09-29 21:34:58 +00:00
|
|
|
|
1998-09-23 19:19:23 +00:00
|
|
|
nsToolkit* toolkit = (nsToolkit *)mToolkit;
|
1999-03-09 09:44:27 +00:00
|
|
|
if (toolkit) {
|
1999-02-09 18:20:18 +00:00
|
|
|
if (!toolkit->IsGuiThread()) {
|
|
|
|
DWORD args[7];
|
1998-04-13 20:24:54 +00:00
|
|
|
args[0] = (DWORD)aParent;
|
|
|
|
args[1] = (DWORD)&aRect;
|
|
|
|
args[2] = (DWORD)aHandleEventFunction;
|
|
|
|
args[3] = (DWORD)aContext;
|
1999-02-09 18:20:18 +00:00
|
|
|
args[4] = (DWORD)aAppShell;
|
|
|
|
args[5] = (DWORD)aToolkit;
|
|
|
|
args[6] = (DWORD)aInitData;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-09-29 21:34:58 +00:00
|
|
|
if (nsnull != aParent) {
|
|
|
|
// nsIWidget parent dispatch
|
1999-02-09 18:20:18 +00:00
|
|
|
MethodInfo info(this, nsWindow::CREATE, 7, args);
|
1998-09-29 21:34:58 +00:00
|
|
|
toolkit->CallMethod(&info);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// Native parent dispatch
|
|
|
|
MethodInfo info(this, nsWindow::CREATE_NATIVE, 5, args);
|
|
|
|
toolkit->CallMethod(&info);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
}
|
1999-03-09 09:44:27 +00:00
|
|
|
}
|
1998-09-29 21:34:58 +00:00
|
|
|
|
|
|
|
HWND parent;
|
1998-11-02 16:58:55 +00:00
|
|
|
if (nsnull != aParent) { // has a nsIWidget parent
|
1998-09-29 21:34:58 +00:00
|
|
|
parent = ((aParent) ? (HWND)aParent->GetNativeData(NS_NATIVE_WINDOW) : nsnull);
|
1998-11-02 16:58:55 +00:00
|
|
|
} else { // has a nsNative parent
|
1998-09-29 22:22:30 +00:00
|
|
|
parent = (HWND)aNativeParent;
|
1998-08-19 23:11:41 +00:00
|
|
|
}
|
|
|
|
|
1998-11-02 19:13:05 +00:00
|
|
|
if (nsnull != aInitData) {
|
1999-07-27 04:27:17 +00:00
|
|
|
SetWindowType(aInitData->mWindowType);
|
1999-05-27 21:09:49 +00:00
|
|
|
SetBorderStyle(aInitData->mBorderStyle);
|
2000-03-21 03:42:00 +00:00
|
|
|
}
|
1999-05-27 21:09:49 +00:00
|
|
|
|
2000-03-21 03:42:00 +00:00
|
|
|
DWORD style = WindowStyle();
|
|
|
|
DWORD extendedStyle = WindowExStyle();
|
1999-07-27 22:42:34 +00:00
|
|
|
|
2000-03-21 03:42:00 +00:00
|
|
|
if (mWindowType == eWindowType_popup) {
|
|
|
|
mBorderlessParent = parent;
|
2002-04-10 04:31:23 +00:00
|
|
|
// Don't set the parent of a popup window.
|
|
|
|
parent = NULL;
|
2000-03-21 03:42:00 +00:00
|
|
|
} else if (nsnull != aInitData) {
|
|
|
|
// See if the caller wants to explictly set clip children and clip siblings
|
|
|
|
if (aInitData->clipChildren) {
|
|
|
|
style |= WS_CLIPCHILDREN;
|
|
|
|
} else {
|
|
|
|
style &= ~WS_CLIPCHILDREN;
|
|
|
|
}
|
|
|
|
if (aInitData->clipSiblings) {
|
|
|
|
style |= WS_CLIPSIBLINGS;
|
1999-07-27 06:34:25 +00:00
|
|
|
}
|
1998-11-02 16:58:55 +00:00
|
|
|
}
|
|
|
|
|
1998-11-04 21:43:47 +00:00
|
|
|
mHas3DBorder = (extendedStyle & WS_EX_CLIENTEDGE) > 0;
|
|
|
|
|
2000-04-27 00:23:18 +00:00
|
|
|
if (mWindowType == eWindowType_dialog) {
|
|
|
|
struct {
|
|
|
|
DLGTEMPLATE t;
|
|
|
|
short noMenu;
|
|
|
|
short defaultClass;
|
|
|
|
short title;
|
|
|
|
} templ;
|
|
|
|
LONG units = GetDialogBaseUnits();
|
|
|
|
|
|
|
|
templ.t.style = style;
|
|
|
|
templ.t.dwExtendedStyle = extendedStyle;
|
|
|
|
templ.t.cdit = 0;
|
|
|
|
templ.t.x = (aRect.x*4)/LOWORD(units);
|
|
|
|
templ.t.y = (aRect.y*8)/HIWORD(units);
|
|
|
|
templ.t.cx = (aRect.width*4 + LOWORD(units) - 1)/LOWORD(units);
|
|
|
|
templ.t.cy = (GetHeight(aRect.height)*8 + HIWORD(units) - 1)/HIWORD(units);
|
|
|
|
templ.noMenu = 0;
|
|
|
|
templ.defaultClass = 0;
|
|
|
|
templ.title = 0;
|
|
|
|
|
|
|
|
mWnd = ::CreateDialogIndirectParam(nsToolkit::mDllInstance,
|
|
|
|
&templ.t,
|
|
|
|
parent,
|
2000-04-27 10:50:29 +00:00
|
|
|
(DLGPROC)DummyDialogProc,
|
2000-04-27 00:23:18 +00:00
|
|
|
NULL);
|
|
|
|
} else {
|
2002-09-09 23:58:39 +00:00
|
|
|
mWnd = nsToolkit::mCreateWindowEx(extendedStyle,
|
2002-07-03 00:55:47 +00:00
|
|
|
aInitData && aInitData->mDropShadow ?
|
|
|
|
WindowPopupClassW() : WindowClassW(),
|
|
|
|
L"",
|
|
|
|
style,
|
|
|
|
aRect.x,
|
|
|
|
aRect.y,
|
|
|
|
aRect.width,
|
|
|
|
GetHeight(aRect.height),
|
|
|
|
parent,
|
|
|
|
NULL,
|
|
|
|
nsToolkit::mDllInstance,
|
|
|
|
NULL);
|
2000-04-27 00:23:18 +00:00
|
|
|
}
|
1998-09-29 21:34:58 +00:00
|
|
|
|
1998-09-23 19:19:23 +00:00
|
|
|
VERIFY(mWnd);
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1999-06-17 23:23:11 +00:00
|
|
|
|
1999-08-26 14:41:17 +00:00
|
|
|
/*mNativeDragTarget = new nsNativeDragTarget(this);
|
1999-04-06 20:23:55 +00:00
|
|
|
if (NULL != mNativeDragTarget) {
|
|
|
|
mNativeDragTarget->AddRef();
|
|
|
|
if (S_OK == ::CoLockObjectExternal((LPUNKNOWN)mNativeDragTarget,TRUE,FALSE)) {
|
|
|
|
if (S_OK == ::RegisterDragDrop(mWnd, (LPDROPTARGET)mNativeDragTarget)) {
|
|
|
|
}
|
|
|
|
}
|
1999-08-26 14:41:17 +00:00
|
|
|
}*/
|
1999-06-17 23:23:11 +00:00
|
|
|
|
2003-03-06 23:07:00 +00:00
|
|
|
mContentType = aInitData? aInitData->mContentType: eContentTypeInherit;
|
|
|
|
SetWin32ContentType();
|
2002-08-01 23:12:38 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
// call the event callback to notify about creation
|
|
|
|
|
1998-05-04 19:25:25 +00:00
|
|
|
DispatchStandardEvent(NS_CREATE);
|
1998-04-13 20:24:54 +00:00
|
|
|
SubclassWindow(TRUE);
|
Bug 109851, bug 108629, bug 109921, bug 109977, bug 109153, bug 109187, bug 109213, bug 109221. Check in latest XUL accessibility support - menus, <colorpicker>, <progressmeter>, <groupbox>, mixed states for checkboxes, buttons that can be 'checked' ie pressed down, fixes extra MSAA events being generated, couldn't see HTML content
2001-11-20 02:05:26 +00:00
|
|
|
|
2004-04-01 22:51:46 +00:00
|
|
|
if (gTrimOnMinimize == 2 && mWindowType == eWindowType_invisible) {
|
|
|
|
/* not yet initialized, and this is the hidden window
|
|
|
|
(conveniently created before any visible windows and after
|
|
|
|
the profile has been initialized) */
|
|
|
|
gTrimOnMinimize = 1;
|
|
|
|
nsCOMPtr<nsIPrefService> prefs = do_GetService(NS_PREFSERVICE_CONTRACTID);
|
|
|
|
if (prefs) {
|
|
|
|
nsCOMPtr<nsIPrefBranch> prefBranch;
|
|
|
|
prefs->GetBranch(0, getter_AddRefs(prefBranch));
|
|
|
|
if (prefBranch) {
|
|
|
|
PRBool trimOnMinimize;
|
|
|
|
if (NS_SUCCEEDED(prefBranch->GetBoolPref("config.trim_on_minimize",
|
|
|
|
&trimOnMinimize))
|
|
|
|
&& !trimOnMinimize)
|
|
|
|
gTrimOnMinimize = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1998-09-29 21:34:58 +00:00
|
|
|
return(NS_OK);
|
|
|
|
}
|
|
|
|
|
2003-03-06 23:07:00 +00:00
|
|
|
PRBool nsWindow::SetWin32ContentType()
|
|
|
|
{
|
|
|
|
// Show mContentType in GWL_ID
|
|
|
|
// This way 3rd part apps can check if a window is UI (0) or content (1)
|
|
|
|
// Return true if control id changed
|
|
|
|
|
|
|
|
nsContentType newContentType = mContentType;
|
|
|
|
|
|
|
|
if (newContentType == eContentTypeInherit) {
|
|
|
|
HWND parentWnd = mWnd;
|
|
|
|
newContentType = eContentTypeUI; // default if we're the root
|
|
|
|
if ((parentWnd = ::GetParent(parentWnd)) != 0) {
|
|
|
|
newContentType = (nsContentType)nsToolkit::mGetWindowLong(parentWnd, GWL_ID);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
nsContentType oldContentType = (nsContentType)nsToolkit::mGetWindowLong(mWnd, GWL_ID);
|
|
|
|
nsToolkit::mSetWindowLong(mWnd, GWL_ID, (PRInt32)newContentType);
|
|
|
|
|
|
|
|
return oldContentType != newContentType;
|
|
|
|
}
|
|
|
|
|
1998-09-29 21:34:58 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Create the proper widget
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
NS_METHOD nsWindow::Create(nsIWidget *aParent,
|
|
|
|
const nsRect &aRect,
|
|
|
|
EVENT_CALLBACK aHandleEventFunction,
|
|
|
|
nsIDeviceContext *aContext,
|
|
|
|
nsIAppShell *aAppShell,
|
|
|
|
nsIToolkit *aToolkit,
|
|
|
|
nsWidgetInitData *aInitData)
|
|
|
|
{
|
2002-12-04 01:51:31 +00:00
|
|
|
if (aInitData)
|
|
|
|
mUnicodeWidget = aInitData->mUnicode;
|
1998-09-29 21:34:58 +00:00
|
|
|
return(StandardWindowCreate(aParent, aRect, aHandleEventFunction,
|
|
|
|
aContext, aAppShell, aToolkit, aInitData,
|
|
|
|
nsnull));
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// create with a native parent
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-29 21:34:58 +00:00
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::Create(nsNativeWidget aParent,
|
1998-04-13 20:24:54 +00:00
|
|
|
const nsRect &aRect,
|
|
|
|
EVENT_CALLBACK aHandleEventFunction,
|
|
|
|
nsIDeviceContext *aContext,
|
1998-07-29 18:51:45 +00:00
|
|
|
nsIAppShell *aAppShell,
|
1998-04-24 21:37:30 +00:00
|
|
|
nsIToolkit *aToolkit,
|
1998-05-14 21:34:08 +00:00
|
|
|
nsWidgetInitData *aInitData)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
2002-12-04 01:51:31 +00:00
|
|
|
if (aInitData)
|
|
|
|
mUnicodeWidget = aInitData->mUnicode;
|
1998-09-29 21:34:58 +00:00
|
|
|
return(StandardWindowCreate(nsnull, aRect, aHandleEventFunction,
|
|
|
|
aContext, aAppShell, aToolkit, aInitData,
|
|
|
|
aParent));
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
1998-09-29 21:34:58 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Close this nsWindow
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::Destroy()
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1998-08-09 01:37:30 +00:00
|
|
|
// Switch to the "main gui thread" if necessary... This method must
|
|
|
|
// be executed on the "gui thread"...
|
1998-09-23 19:19:23 +00:00
|
|
|
nsToolkit* toolkit = (nsToolkit *)mToolkit;
|
|
|
|
if (toolkit != nsnull && !toolkit->IsGuiThread()) {
|
1998-08-09 01:37:30 +00:00
|
|
|
MethodInfo info(this, nsWindow::DESTROY);
|
1998-09-23 19:19:23 +00:00
|
|
|
toolkit->CallMethod(&info);
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_ERROR_FAILURE;
|
1998-08-09 01:37:30 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-08-09 01:37:30 +00:00
|
|
|
// disconnect from the parent
|
|
|
|
if (!mIsDestroying) {
|
1998-09-23 19:19:23 +00:00
|
|
|
nsBaseWidget::Destroy();
|
1998-08-09 01:37:30 +00:00
|
|
|
}
|
1998-05-04 19:25:25 +00:00
|
|
|
|
2001-05-25 18:33:10 +00:00
|
|
|
// just to be safe. If we're going away and for some reason we're still
|
|
|
|
// the rollup widget, rollup and turn off capture.
|
|
|
|
if ( this == gRollupWidget ) {
|
|
|
|
if ( gRollupListener )
|
|
|
|
gRollupListener->Rollup();
|
|
|
|
CaptureRollupEvents(nsnull, PR_FALSE, PR_TRUE);
|
|
|
|
}
|
|
|
|
|
1999-08-26 14:41:17 +00:00
|
|
|
EnableDragDrop(PR_FALSE);
|
1999-04-06 20:23:55 +00:00
|
|
|
|
1998-08-09 01:37:30 +00:00
|
|
|
// destroy the HWND
|
|
|
|
if (mWnd) {
|
|
|
|
// prevent the widget from causing additional events
|
|
|
|
mEventCallback = nsnull;
|
2001-11-16 01:58:17 +00:00
|
|
|
if (gAttentionTimerMonitor)
|
|
|
|
gAttentionTimerMonitor->KillTimer(mWnd);
|
2002-05-03 18:52:04 +00:00
|
|
|
|
2003-10-30 01:35:14 +00:00
|
|
|
HICON icon;
|
|
|
|
icon = (HICON) nsToolkit::mSendMessage(mWnd, WM_SETICON, (WPARAM)ICON_BIG, (LPARAM) 0);
|
|
|
|
if (icon)
|
|
|
|
::DestroyIcon(icon);
|
|
|
|
|
|
|
|
icon = (HICON) nsToolkit::mSendMessage(mWnd, WM_SETICON, (WPARAM)ICON_SMALL, (LPARAM) 0);
|
|
|
|
if (icon)
|
|
|
|
::DestroyIcon(icon);
|
|
|
|
|
1998-08-09 01:37:30 +00:00
|
|
|
VERIFY(::DestroyWindow(mWnd));
|
2002-05-03 18:52:04 +00:00
|
|
|
|
1998-09-15 03:45:06 +00:00
|
|
|
mWnd = NULL;
|
|
|
|
//our windows can be subclassed by
|
|
|
|
//others and these namless, faceless others
|
|
|
|
//may not let us know about WM_DESTROY. so,
|
|
|
|
//if OnDestroy() didn't get called, just call
|
|
|
|
//it now. MMP
|
|
|
|
if (PR_FALSE == mOnDestroyCalled)
|
|
|
|
OnDestroy();
|
1998-08-09 01:37:30 +00:00
|
|
|
}
|
1999-04-06 20:23:55 +00:00
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
2002-09-12 03:59:15 +00:00
|
|
|
NS_IMETHODIMP nsWindow::SetParent(nsIWidget *aNewParent)
|
|
|
|
{
|
|
|
|
if (aNewParent) {
|
|
|
|
HWND newParent = (HWND)aNewParent->GetNativeData(NS_NATIVE_WINDOW);
|
|
|
|
NS_ASSERTION(newParent, "Parent widget has a null native window handle");
|
|
|
|
::SetParent(mWnd, newParent);
|
2003-03-06 23:07:00 +00:00
|
|
|
PRBool isChanged = mContentType == eContentTypeInherit && SetWin32ContentType();
|
|
|
|
NS_ASSERTION(!isChanged, "SetParent won't expose a new content type when decendents use eContentTypeInherit.");
|
|
|
|
|
2002-09-12 03:59:15 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
NS_WARNING("Null aNewParent passed to SetParent");
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Get this nsWindow parent
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
nsIWidget* nsWindow::GetParent(void)
|
|
|
|
{
|
1999-10-02 00:13:23 +00:00
|
|
|
if (mIsTopWidgetWindow) {
|
|
|
|
// Must use a flag instead of mWindowType to tell if the window is the
|
|
|
|
// owned by the topmost widget, because a child window can be embedded inside
|
|
|
|
// a HWND which is not associated with a nsIWidget.
|
|
|
|
return nsnull;
|
|
|
|
}
|
2001-08-02 00:19:24 +00:00
|
|
|
/* If this widget has already been destroyed, pretend we have no parent.
|
|
|
|
This corresponds to code in Destroy which removes the destroyed
|
|
|
|
widget from its parent's child list. */
|
|
|
|
if (mIsDestroying || mOnDestroyCalled)
|
|
|
|
return nsnull;
|
1999-10-02 00:13:23 +00:00
|
|
|
|
|
|
|
|
|
|
|
nsWindow* widget = nsnull;
|
1998-04-13 20:24:54 +00:00
|
|
|
if (mWnd) {
|
|
|
|
HWND parent = ::GetParent(mWnd);
|
|
|
|
if (parent) {
|
2000-04-27 00:23:18 +00:00
|
|
|
widget = GetNSWindowPtr(parent);
|
1998-08-09 01:37:30 +00:00
|
|
|
if (widget) {
|
|
|
|
// If the widget is in the process of being destroyed then
|
|
|
|
// do NOT return it
|
|
|
|
if (widget->mIsDestroying) {
|
1999-10-02 00:13:23 +00:00
|
|
|
widget = nsnull;
|
1998-08-09 01:37:30 +00:00
|
|
|
} else {
|
1998-09-17 20:02:04 +00:00
|
|
|
NS_ADDREF(widget);
|
1998-08-09 01:37:30 +00:00
|
|
|
}
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1998-08-09 01:37:30 +00:00
|
|
|
return (nsIWidget*)widget;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Hide or show this component
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::Show(PRBool bState)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
2000-12-20 01:43:38 +00:00
|
|
|
if (mWnd) {
|
|
|
|
if (bState) {
|
|
|
|
if (!mIsVisible && mWindowType == eWindowType_toplevel) {
|
|
|
|
int mode;
|
|
|
|
switch (mSizeMode) {
|
|
|
|
case nsSizeMode_Maximized :
|
|
|
|
mode = SW_SHOWMAXIMIZED;
|
|
|
|
break;
|
|
|
|
case nsSizeMode_Minimized :
|
|
|
|
mode = SW_SHOWMINIMIZED;
|
|
|
|
break;
|
|
|
|
default :
|
|
|
|
mode = SW_SHOWNORMAL;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
2000-12-20 01:43:38 +00:00
|
|
|
::ShowWindow(mWnd, mode);
|
|
|
|
} else {
|
|
|
|
DWORD flags = SWP_NOSIZE | SWP_NOMOVE | SWP_SHOWWINDOW;
|
2001-03-07 00:46:36 +00:00
|
|
|
if (mIsVisible)
|
2000-12-20 01:43:38 +00:00
|
|
|
flags |= SWP_NOZORDER;
|
|
|
|
|
|
|
|
if (mWindowType == eWindowType_popup) {
|
2001-03-07 00:46:36 +00:00
|
|
|
// ensure popups are the topmost of the TOPMOST layer. Remember
|
|
|
|
// not to set the SWP_NOZORDER flag as that might allow the taskbar
|
|
|
|
// to overlap the popup.
|
2000-12-20 01:43:38 +00:00
|
|
|
flags |= SWP_NOACTIVATE;
|
|
|
|
::SetWindowPos(mWnd, HWND_TOPMOST, 0, 0, 0, 0, flags);
|
|
|
|
} else {
|
|
|
|
::SetWindowPos(mWnd, HWND_TOP, 0, 0, 0, 0, flags);
|
|
|
|
}
|
|
|
|
}
|
2003-04-01 20:04:36 +00:00
|
|
|
} else {
|
|
|
|
if (mWindowType != eWindowType_dialog) {
|
|
|
|
::ShowWindow(mWnd, SW_HIDE);
|
|
|
|
} else {
|
|
|
|
::SetWindowPos(mWnd, 0, 0, 0, 0, 0, SWP_HIDEWINDOW | SWP_NOSIZE | SWP_NOMOVE |
|
|
|
|
SWP_NOZORDER | SWP_NOACTIVATE);
|
|
|
|
}
|
|
|
|
}
|
2000-12-20 01:43:38 +00:00
|
|
|
}
|
|
|
|
mIsVisible = bState;
|
2003-04-15 08:45:55 +00:00
|
|
|
|
2000-12-20 01:43:38 +00:00
|
|
|
return NS_OK;
|
1998-09-28 22:32:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Return PR_TRUE if the whether the component is visible, PR_FALSE otherwise
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
NS_METHOD nsWindow::IsVisible(PRBool & bState)
|
|
|
|
{
|
|
|
|
bState = mIsVisible;
|
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
2000-04-01 22:16:43 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Position the window behind the given window
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2003-10-07 01:19:59 +00:00
|
|
|
NS_METHOD nsWindow::PlaceBehind(nsTopLevelWidgetZPlacement aPlacement,
|
|
|
|
nsIWidget *aWidget, PRBool aActivate)
|
2000-04-01 22:16:43 +00:00
|
|
|
{
|
2003-10-07 01:19:59 +00:00
|
|
|
HWND behind = HWND_TOP;
|
|
|
|
if (aPlacement == eZPlacementBottom)
|
|
|
|
behind = HWND_BOTTOM;
|
|
|
|
else if (aPlacement == eZPlacementBelow && aWidget)
|
|
|
|
behind = (HWND)aWidget->GetNativeData(NS_NATIVE_WINDOW);
|
2000-08-30 21:21:39 +00:00
|
|
|
UINT flags = SWP_NOMOVE | SWP_NOREPOSITION | SWP_NOSIZE;
|
|
|
|
if (!aActivate)
|
|
|
|
flags |= SWP_NOACTIVATE;
|
|
|
|
|
|
|
|
::SetWindowPos(mWnd, behind, 0, 0, 0, 0, flags);
|
2000-04-01 22:16:43 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-12-14 22:37:08 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Maximize, minimize or restore the window.
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
NS_IMETHODIMP nsWindow::SetSizeMode(PRInt32 aMode) {
|
|
|
|
|
|
|
|
nsresult rv;
|
|
|
|
|
|
|
|
// save the requested state
|
|
|
|
rv = nsBaseWidget::SetSizeMode(aMode);
|
2000-12-20 01:43:38 +00:00
|
|
|
if (NS_SUCCEEDED(rv) && mIsVisible) {
|
|
|
|
int mode;
|
2000-12-14 22:37:08 +00:00
|
|
|
|
|
|
|
switch (aMode) {
|
|
|
|
case nsSizeMode_Maximized :
|
|
|
|
mode = SW_MAXIMIZE;
|
|
|
|
break;
|
|
|
|
case nsSizeMode_Minimized :
|
2004-04-01 22:51:46 +00:00
|
|
|
mode = gTrimOnMinimize ? SW_MINIMIZE : SW_SHOWMINIMIZED;
|
2000-12-14 22:37:08 +00:00
|
|
|
break;
|
|
|
|
default :
|
|
|
|
mode = SW_RESTORE;
|
|
|
|
}
|
|
|
|
::ShowWindow(mWnd, mode);
|
|
|
|
}
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
1999-11-12 23:46:11 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
// Return PR_TRUE in aForWindow if the given event should be processed
|
|
|
|
// assuming this is a modal window.
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
NS_METHOD nsWindow::ModalEventFilter(PRBool aRealEvent, void *aEvent,
|
|
|
|
PRBool *aForWindow)
|
|
|
|
{
|
|
|
|
if (!aRealEvent) {
|
2000-02-15 05:05:19 +00:00
|
|
|
*aForWindow = PR_FALSE;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
#if 0
|
|
|
|
// this version actually works, but turns out to be unnecessary
|
|
|
|
// if we use the OS properly.
|
|
|
|
MSG *msg = (MSG *) aEvent;
|
1999-11-12 23:46:11 +00:00
|
|
|
|
|
|
|
switch (msg->message) {
|
|
|
|
case WM_MOUSEMOVE:
|
|
|
|
case WM_LBUTTONDOWN:
|
|
|
|
case WM_LBUTTONUP:
|
|
|
|
case WM_LBUTTONDBLCLK:
|
|
|
|
case WM_MBUTTONDOWN:
|
|
|
|
case WM_MBUTTONUP:
|
|
|
|
case WM_MBUTTONDBLCLK:
|
|
|
|
case WM_RBUTTONDOWN:
|
|
|
|
case WM_RBUTTONUP:
|
2000-02-15 05:05:19 +00:00
|
|
|
case WM_RBUTTONDBLCLK: {
|
|
|
|
HWND msgWindow, ourWindow, rollupWindow;
|
|
|
|
PRBool acceptEvent;
|
|
|
|
|
|
|
|
// is the event within our window?
|
|
|
|
msgWindow = 0;
|
|
|
|
rollupWindow = 0;
|
|
|
|
ourWindow = msg->hwnd;
|
|
|
|
while (ourWindow) {
|
|
|
|
msgWindow = ourWindow;
|
|
|
|
ourWindow = ::GetParent(ourWindow);
|
|
|
|
}
|
|
|
|
ourWindow = (HWND)GetNativeData(NS_NATIVE_WINDOW);
|
|
|
|
if (gRollupWidget)
|
|
|
|
rollupWindow = (HWND)gRollupWidget->GetNativeData(NS_NATIVE_WINDOW);
|
|
|
|
acceptEvent = msgWindow && (msgWindow == ourWindow ||
|
|
|
|
msgWindow == rollupWindow) ?
|
|
|
|
PR_TRUE : PR_FALSE;
|
|
|
|
|
|
|
|
// if not, accept events for any window that hasn't been
|
|
|
|
// disabled.
|
|
|
|
if (!acceptEvent) {
|
2002-10-16 23:28:18 +00:00
|
|
|
LONG proc = nsToolkit::mGetWindowLong(msgWindow, GWL_WNDPROC);
|
2000-02-15 05:05:19 +00:00
|
|
|
if (proc == (LONG)&nsWindow::WindowProc) {
|
2000-04-27 00:23:18 +00:00
|
|
|
nsWindow *msgWin = GetNSWindowPtr(msgWindow);
|
2000-02-15 05:05:19 +00:00
|
|
|
msgWin->IsEnabled(&acceptEvent);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
*aForWindow = PR_TRUE;
|
1999-11-12 23:46:11 +00:00
|
|
|
}
|
2000-02-15 05:05:19 +00:00
|
|
|
#else
|
|
|
|
*aForWindow = PR_TRUE;
|
|
|
|
#endif
|
1999-11-12 23:46:11 +00:00
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2000-08-04 14:48:33 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Constrain a potential move to fit onscreen
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2002-01-09 01:30:06 +00:00
|
|
|
NS_METHOD nsWindow::ConstrainPosition(PRBool aAllowSlop,
|
|
|
|
PRInt32 *aX, PRInt32 *aY)
|
2000-08-04 14:48:33 +00:00
|
|
|
{
|
2002-01-09 01:30:06 +00:00
|
|
|
if (!mIsTopWidgetWindow) // only a problem for top-level windows
|
|
|
|
return NS_OK;
|
|
|
|
|
|
|
|
PRBool doConstrain = PR_FALSE; // whether we have enough info to do anything
|
|
|
|
|
|
|
|
/* get our playing field. use the current screen, or failing that
|
|
|
|
for any reason, use device caps for the default screen. */
|
|
|
|
RECT screenRect;
|
|
|
|
|
|
|
|
nsCOMPtr<nsIScreenManager> screenmgr = do_GetService(sScreenManagerContractID);
|
|
|
|
if (screenmgr) {
|
|
|
|
nsCOMPtr<nsIScreen> screen;
|
|
|
|
PRInt32 left, top, width, height;
|
|
|
|
|
|
|
|
// zero size rects confuse the screen manager
|
|
|
|
width = mBounds.width > 0 ? mBounds.width : 1;
|
|
|
|
height = mBounds.height > 0 ? mBounds.height : 1;
|
|
|
|
screenmgr->ScreenForRect(*aX, *aY, width, height,
|
|
|
|
getter_AddRefs(screen));
|
|
|
|
if (screen) {
|
|
|
|
screen->GetAvailRect(&left, &top, &width, &height);
|
|
|
|
screenRect.left = left;
|
|
|
|
screenRect.right = left+width;
|
|
|
|
screenRect.top = top;
|
|
|
|
screenRect.bottom = top+height;
|
|
|
|
doConstrain = PR_TRUE;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (mWnd) {
|
|
|
|
HDC dc = ::GetDC(mWnd);
|
|
|
|
if(dc) {
|
|
|
|
if (::GetDeviceCaps(dc, TECHNOLOGY) == DT_RASDISPLAY) {
|
|
|
|
::SystemParametersInfo(SPI_GETWORKAREA, 0, &screenRect, 0);
|
|
|
|
doConstrain = PR_TRUE;
|
|
|
|
}
|
|
|
|
::ReleaseDC(mWnd, dc);
|
2000-08-04 14:48:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2002-01-09 01:30:06 +00:00
|
|
|
|
|
|
|
if (aAllowSlop) {
|
|
|
|
if (*aX < screenRect.left - mBounds.width + kWindowPositionSlop)
|
|
|
|
*aX = screenRect.left - mBounds.width + kWindowPositionSlop;
|
|
|
|
else if (*aX >= screenRect.right - kWindowPositionSlop)
|
|
|
|
*aX = screenRect.right - kWindowPositionSlop;
|
|
|
|
|
|
|
|
if (*aY < screenRect.top - mBounds.height + kWindowPositionSlop)
|
|
|
|
*aY = screenRect.top - mBounds.height + kWindowPositionSlop;
|
|
|
|
else if (*aY >= screenRect.bottom - kWindowPositionSlop)
|
|
|
|
*aY = screenRect.bottom - kWindowPositionSlop;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
if (*aX < screenRect.left)
|
|
|
|
*aX = screenRect.left;
|
|
|
|
else if (*aX >= screenRect.right - mBounds.width)
|
|
|
|
*aX = screenRect.right - mBounds.width;
|
|
|
|
|
|
|
|
if (*aY < screenRect.top)
|
|
|
|
*aY = screenRect.top;
|
|
|
|
else if (*aY >= screenRect.bottom - mBounds.height)
|
|
|
|
*aY = screenRect.bottom - mBounds.height;
|
|
|
|
}
|
|
|
|
|
2000-08-04 14:48:33 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Move this component
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1999-07-27 23:26:36 +00:00
|
|
|
NS_METHOD nsWindow::Move(PRInt32 aX, PRInt32 aY)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
2003-03-06 10:38:30 +00:00
|
|
|
// Check to see if window needs to be moved first
|
|
|
|
// to avoid a costly call to SetWindowPos. This check
|
|
|
|
// can not be moved to the calling code in nsView, because
|
|
|
|
// some platforms do not position child windows correctly
|
|
|
|
|
|
|
|
// Only perform this check for non-popup windows, since the positioning can
|
|
|
|
// in fact change even when the x/y do not. We always need to perform the
|
|
|
|
// check. See bug #97805 for details.
|
|
|
|
if (mWindowType != eWindowType_popup && (mBounds.x == aX) && (mBounds.y == aY))
|
2000-03-15 01:17:29 +00:00
|
|
|
{
|
2003-03-06 10:38:30 +00:00
|
|
|
// Nothing to do, since it is already positioned correctly.
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
// When moving a borderless top-level window the window
|
|
|
|
// must be placed relative to its parent. WIN32 wants to
|
|
|
|
// place it relative to the screen, so we used the cached parent
|
|
|
|
// to calculate the parent's location then add the x,y passed to
|
|
|
|
// the move to get the screen coordinate for the borderless top-level
|
|
|
|
// window.
|
1999-07-27 04:27:17 +00:00
|
|
|
if (mWindowType == eWindowType_popup) {
|
1999-05-27 21:09:49 +00:00
|
|
|
HWND parent = mBorderlessParent;
|
|
|
|
if (parent) {
|
|
|
|
RECT pr;
|
|
|
|
VERIFY(::GetWindowRect(parent, &pr));
|
|
|
|
aX += pr.left;
|
|
|
|
aY += pr.top;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1998-11-24 14:57:09 +00:00
|
|
|
mBounds.x = aX;
|
|
|
|
mBounds.y = aY;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
if (mWnd) {
|
2000-08-04 14:48:33 +00:00
|
|
|
#ifdef DEBUG
|
|
|
|
// complain if a window is moved offscreen (legal, but potentially worrisome)
|
|
|
|
if (mIsTopWidgetWindow) { // only a problem for top-level windows
|
2000-03-14 11:44:04 +00:00
|
|
|
// Make sure this window is actually on the screen before we move it
|
|
|
|
// XXX: Needs multiple monitor support
|
|
|
|
HDC dc = ::GetDC(mWnd);
|
|
|
|
if(dc) {
|
2000-08-04 14:48:33 +00:00
|
|
|
if (::GetDeviceCaps(dc, TECHNOLOGY) == DT_RASDISPLAY) {
|
2000-03-08 04:41:12 +00:00
|
|
|
RECT workArea;
|
|
|
|
::SystemParametersInfo(SPI_GETWORKAREA, 0, &workArea, 0);
|
2000-08-04 14:48:33 +00:00
|
|
|
// no annoying assertions. just mention the issue.
|
|
|
|
if (aX < 0 || aX >= workArea.right || aY < 0 || aY >= workArea.bottom)
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("window moved to offscreen position\n");
|
2000-03-14 11:44:04 +00:00
|
|
|
}
|
|
|
|
::ReleaseDC(mWnd, dc);
|
|
|
|
}
|
|
|
|
}
|
2000-08-04 14:48:33 +00:00
|
|
|
#endif
|
2000-03-08 04:41:12 +00:00
|
|
|
|
1998-05-13 03:39:08 +00:00
|
|
|
nsIWidget *par = GetParent();
|
|
|
|
HDWP deferrer = NULL;
|
|
|
|
|
|
|
|
if (nsnull != par) {
|
|
|
|
deferrer = ((nsWindow *)par)->mDeferredPositioner;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NULL != deferrer) {
|
1998-06-16 17:16:59 +00:00
|
|
|
VERIFY(((nsWindow *)par)->mDeferredPositioner = ::DeferWindowPos(deferrer,
|
|
|
|
mWnd, NULL, aX, aY, 0, 0,
|
1998-05-13 03:39:08 +00:00
|
|
|
SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOSIZE));
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
VERIFY(::SetWindowPos(mWnd, NULL, aX, aY, 0, 0,
|
|
|
|
SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOSIZE));
|
|
|
|
}
|
1998-06-16 17:16:59 +00:00
|
|
|
|
|
|
|
NS_IF_RELEASE(par);
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Resize this component
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1999-07-27 23:26:36 +00:00
|
|
|
NS_METHOD nsWindow::Resize(PRInt32 aWidth, PRInt32 aHeight, PRBool aRepaint)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1999-07-27 23:26:36 +00:00
|
|
|
NS_ASSERTION((aWidth >=0 ) , "Negative width passed to nsWindow::Resize");
|
|
|
|
NS_ASSERTION((aHeight >=0 ), "Negative height passed to nsWindow::Resize");
|
1998-11-24 14:57:09 +00:00
|
|
|
// Set cached value for lightweight and printing
|
|
|
|
mBounds.width = aWidth;
|
|
|
|
mBounds.height = aHeight;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
if (mWnd) {
|
1998-05-13 03:39:08 +00:00
|
|
|
nsIWidget *par = GetParent();
|
|
|
|
HDWP deferrer = NULL;
|
|
|
|
|
|
|
|
if (nsnull != par) {
|
|
|
|
deferrer = ((nsWindow *)par)->mDeferredPositioner;
|
|
|
|
}
|
|
|
|
|
1998-06-01 20:26:50 +00:00
|
|
|
UINT flags = SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOMOVE;
|
|
|
|
if (!aRepaint) {
|
|
|
|
flags |= SWP_NOREDRAW;
|
|
|
|
}
|
|
|
|
|
1998-05-13 03:39:08 +00:00
|
|
|
if (NULL != deferrer) {
|
1998-06-16 17:16:59 +00:00
|
|
|
VERIFY(((nsWindow *)par)->mDeferredPositioner = ::DeferWindowPos(deferrer,
|
|
|
|
mWnd, NULL, 0, 0, aWidth, GetHeight(aHeight), flags));
|
1998-05-13 03:39:08 +00:00
|
|
|
}
|
|
|
|
else {
|
1998-05-14 21:34:08 +00:00
|
|
|
VERIFY(::SetWindowPos(mWnd, NULL, 0, 0, aWidth, GetHeight(aHeight),
|
1998-06-01 20:26:50 +00:00
|
|
|
flags));
|
1998-05-13 03:39:08 +00:00
|
|
|
}
|
1998-06-16 17:16:59 +00:00
|
|
|
|
|
|
|
NS_IF_RELEASE(par);
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
2000-02-15 21:40:31 +00:00
|
|
|
|
|
|
|
if (aRepaint)
|
|
|
|
Invalidate(PR_FALSE);
|
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Resize this component
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1999-07-27 23:26:36 +00:00
|
|
|
NS_METHOD nsWindow::Resize(PRInt32 aX,
|
|
|
|
PRInt32 aY,
|
|
|
|
PRInt32 aWidth,
|
|
|
|
PRInt32 aHeight,
|
1998-06-01 20:26:50 +00:00
|
|
|
PRBool aRepaint)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1999-07-27 23:26:36 +00:00
|
|
|
NS_ASSERTION((aWidth >=0 ), "Negative width passed to nsWindow::Resize");
|
|
|
|
NS_ASSERTION((aHeight >=0 ), "Negative height passed to nsWindow::Resize");
|
|
|
|
|
1998-11-24 14:57:09 +00:00
|
|
|
// Set cached value for lightweight and printing
|
|
|
|
mBounds.x = aX;
|
|
|
|
mBounds.y = aY;
|
|
|
|
mBounds.width = aWidth;
|
|
|
|
mBounds.height = aHeight;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
if (mWnd) {
|
1998-05-13 03:39:08 +00:00
|
|
|
nsIWidget *par = GetParent();
|
|
|
|
HDWP deferrer = NULL;
|
|
|
|
|
|
|
|
if (nsnull != par) {
|
|
|
|
deferrer = ((nsWindow *)par)->mDeferredPositioner;
|
|
|
|
}
|
|
|
|
|
1998-06-01 20:26:50 +00:00
|
|
|
UINT flags = SWP_NOZORDER | SWP_NOACTIVATE;
|
|
|
|
if (!aRepaint) {
|
|
|
|
flags |= SWP_NOREDRAW;
|
|
|
|
}
|
|
|
|
|
1998-05-13 03:39:08 +00:00
|
|
|
if (NULL != deferrer) {
|
1998-06-16 17:16:59 +00:00
|
|
|
VERIFY(((nsWindow *)par)->mDeferredPositioner = ::DeferWindowPos(deferrer,
|
|
|
|
mWnd, NULL, aX, aY, aWidth, GetHeight(aHeight),
|
1998-06-01 20:26:50 +00:00
|
|
|
flags));
|
1998-05-13 03:39:08 +00:00
|
|
|
}
|
|
|
|
else {
|
1998-05-14 21:34:08 +00:00
|
|
|
VERIFY(::SetWindowPos(mWnd, NULL, aX, aY, aWidth, GetHeight(aHeight),
|
1998-06-01 20:26:50 +00:00
|
|
|
flags));
|
1998-05-13 03:39:08 +00:00
|
|
|
}
|
1998-06-16 17:16:59 +00:00
|
|
|
|
|
|
|
NS_IF_RELEASE(par);
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
2000-02-15 21:40:31 +00:00
|
|
|
|
|
|
|
if (aRepaint)
|
|
|
|
Invalidate(PR_FALSE);
|
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Enable/disable this component
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::Enable(PRBool bState)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
|
|
|
if (mWnd) {
|
|
|
|
::EnableWindow(mWnd, bState);
|
|
|
|
}
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
2000-02-15 05:05:19 +00:00
|
|
|
|
2002-02-28 23:10:04 +00:00
|
|
|
NS_METHOD nsWindow::IsEnabled(PRBool *aState)
|
|
|
|
{
|
|
|
|
NS_ENSURE_ARG_POINTER(aState);
|
2002-03-04 22:50:11 +00:00
|
|
|
*aState = !mWnd || ::IsWindowEnabled(mWnd);
|
2002-02-28 23:10:04 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Give the focus to this component
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2001-03-19 17:56:04 +00:00
|
|
|
NS_METHOD nsWindow::SetFocus(PRBool aRaise)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
|
|
|
//
|
|
|
|
// Switch to the "main gui thread" if necessary... This method must
|
|
|
|
// be executed on the "gui thread"...
|
|
|
|
//
|
1998-09-23 19:19:23 +00:00
|
|
|
nsToolkit* toolkit = (nsToolkit *)mToolkit;
|
2000-10-19 00:48:06 +00:00
|
|
|
NS_ASSERTION(toolkit != nsnull, "This should never be null!"); // Bug 57044
|
|
|
|
if (toolkit != nsnull && !toolkit->IsGuiThread()) {
|
1998-04-13 20:24:54 +00:00
|
|
|
MethodInfo info(this, nsWindow::SET_FOCUS);
|
1998-09-23 19:19:23 +00:00
|
|
|
toolkit->CallMethod(&info);
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_ERROR_FAILURE;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (mWnd) {
|
2000-06-13 01:16:31 +00:00
|
|
|
// Uniconify, if necessary
|
|
|
|
HWND toplevelWnd = mWnd;
|
|
|
|
while (::GetParent(toplevelWnd))
|
|
|
|
toplevelWnd = ::GetParent(toplevelWnd);
|
|
|
|
if (::IsIconic(toplevelWnd))
|
|
|
|
::OpenIcon(toplevelWnd);
|
1998-04-13 20:24:54 +00:00
|
|
|
::SetFocus(mWnd);
|
|
|
|
}
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Get this component dimension
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::GetBounds(nsRect &aRect)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1998-11-04 21:43:47 +00:00
|
|
|
if (mWnd) {
|
|
|
|
RECT r;
|
|
|
|
VERIFY(::GetWindowRect(mWnd, &r));
|
|
|
|
|
|
|
|
// assign size
|
|
|
|
aRect.width = r.right - r.left;
|
|
|
|
aRect.height = r.bottom - r.top;
|
|
|
|
|
|
|
|
// convert coordinates if parent exists
|
|
|
|
HWND parent = ::GetParent(mWnd);
|
|
|
|
if (parent) {
|
|
|
|
RECT pr;
|
|
|
|
VERIFY(::GetWindowRect(parent, &pr));
|
|
|
|
r.left -= pr.left;
|
|
|
|
r.top -= pr.top;
|
|
|
|
}
|
|
|
|
aRect.x = r.left;
|
|
|
|
aRect.y = r.top;
|
|
|
|
} else {
|
1998-11-24 14:57:09 +00:00
|
|
|
aRect = mBounds;
|
1998-11-04 21:43:47 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-11-04 21:43:47 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-11-04 21:43:47 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Get this component dimension
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
NS_METHOD nsWindow::GetClientBounds(nsRect &aRect)
|
|
|
|
{
|
|
|
|
|
|
|
|
if (mWnd) {
|
|
|
|
RECT r;
|
|
|
|
VERIFY(::GetClientRect(mWnd, &r));
|
|
|
|
|
|
|
|
// assign size
|
|
|
|
aRect.x = 0;
|
|
|
|
aRect.y = 0;
|
|
|
|
aRect.width = r.right - r.left;
|
|
|
|
aRect.height = r.bottom - r.top;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
aRect.SetRect(0,0,0,0);
|
|
|
|
}
|
|
|
|
return NS_OK;
|
1998-06-16 17:16:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//get the bounds, but don't take into account the client size
|
|
|
|
|
|
|
|
void nsWindow::GetNonClientBounds(nsRect &aRect)
|
|
|
|
{
|
1998-11-04 21:43:47 +00:00
|
|
|
if (mWnd) {
|
|
|
|
RECT r;
|
|
|
|
VERIFY(::GetWindowRect(mWnd, &r));
|
|
|
|
|
|
|
|
// assign size
|
|
|
|
aRect.width = r.right - r.left;
|
|
|
|
aRect.height = r.bottom - r.top;
|
|
|
|
|
|
|
|
// convert coordinates if parent exists
|
|
|
|
HWND parent = ::GetParent(mWnd);
|
|
|
|
if (parent) {
|
|
|
|
RECT pr;
|
|
|
|
VERIFY(::GetWindowRect(parent, &pr));
|
|
|
|
r.left -= pr.left;
|
|
|
|
r.top -= pr.top;
|
|
|
|
}
|
|
|
|
aRect.x = r.left;
|
|
|
|
aRect.y = r.top;
|
|
|
|
} else {
|
|
|
|
aRect.SetRect(0,0,0,0);
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
2004-03-03 16:42:51 +00:00
|
|
|
// like GetBounds, but don't offset by the parent
|
|
|
|
NS_METHOD nsWindow::GetScreenBounds(nsRect &aRect)
|
|
|
|
{
|
|
|
|
if (mWnd) {
|
|
|
|
RECT r;
|
|
|
|
VERIFY(::GetWindowRect(mWnd, &r));
|
|
|
|
|
|
|
|
aRect.width = r.right - r.left;
|
|
|
|
aRect.height = r.bottom - r.top;
|
|
|
|
aRect.x = r.left;
|
|
|
|
aRect.y = r.top;
|
|
|
|
} else
|
|
|
|
aRect = mBounds;
|
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Set the background color
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::SetBackgroundColor(const nscolor &aColor)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1998-09-23 19:19:23 +00:00
|
|
|
nsBaseWidget::SetBackgroundColor(aColor);
|
|
|
|
|
1998-07-21 18:04:18 +00:00
|
|
|
if (mBrush)
|
|
|
|
::DeleteObject(mBrush);
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
mBrush = ::CreateSolidBrush(NSRGB_2_COLOREF(mBackground));
|
1998-07-21 18:04:18 +00:00
|
|
|
if (mWnd != NULL) {
|
|
|
|
SetClassLong(mWnd, GCL_HBRBACKGROUND, (LONG)mBrush);
|
|
|
|
}
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Get this component font
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
nsIFontMetrics* nsWindow::GetFont(void)
|
|
|
|
{
|
|
|
|
NS_NOTYETIMPLEMENTED("GetFont not yet implemented"); // to be implemented
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Set this component font
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::SetFont(const nsFont &aFont)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1998-11-24 14:57:09 +00:00
|
|
|
// Cache Font for owner draw
|
|
|
|
if (mFont == nsnull) {
|
|
|
|
mFont = new nsFont(aFont);
|
|
|
|
} else {
|
|
|
|
*mFont = aFont;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bail out if there is no context
|
|
|
|
if (nsnull == mContext) {
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
1998-11-16 22:18:30 +00:00
|
|
|
|
1998-11-24 14:57:09 +00:00
|
|
|
nsIFontMetrics* metrics;
|
|
|
|
mContext->GetMetricsFor(aFont, metrics);
|
|
|
|
nsFontHandle fontHandle;
|
|
|
|
metrics->GetFontHandle(fontHandle);
|
|
|
|
HFONT hfont = (HFONT)fontHandle;
|
|
|
|
|
|
|
|
// Draw in the new font
|
2002-09-09 23:58:39 +00:00
|
|
|
nsToolkit::mSendMessage(mWnd, WM_SETFONT, (WPARAM)hfont, (LPARAM)0);
|
1998-11-24 14:57:09 +00:00
|
|
|
NS_RELEASE(metrics);
|
|
|
|
|
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
1998-09-23 19:19:23 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Set this component cursor
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::SetCursor(nsCursor aCursor)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1998-09-23 19:19:23 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
// Only change cursor if it's changing
|
1998-11-18 05:25:26 +00:00
|
|
|
|
|
|
|
//XXX mCursor isn't always right. Scrollbars and others change it, too.
|
|
|
|
//XXX If we want this optimization we need a better way to do it.
|
|
|
|
//if (aCursor != mCursor) {
|
1998-04-13 20:24:54 +00:00
|
|
|
HCURSOR newCursor = NULL;
|
|
|
|
|
|
|
|
switch(aCursor) {
|
|
|
|
case eCursor_select:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_IBEAM);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_wait:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_WAIT);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_hyperlink: {
|
2001-11-29 09:41:19 +00:00
|
|
|
newCursor = ::LoadCursor(NULL, IDC_HAND);
|
|
|
|
if (!newCursor) {
|
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_SELECTANCHOR));
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case eCursor_standard:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_ARROW);
|
|
|
|
break;
|
|
|
|
|
1998-07-30 21:25:35 +00:00
|
|
|
case eCursor_sizeWE:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_SIZEWE);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_sizeNS:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_SIZENS);
|
|
|
|
break;
|
|
|
|
|
2000-04-30 15:29:32 +00:00
|
|
|
case eCursor_sizeNW:
|
|
|
|
case eCursor_sizeSE:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_SIZENWSE);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_sizeNE:
|
|
|
|
case eCursor_sizeSW:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_SIZENESW);
|
|
|
|
break;
|
|
|
|
|
1998-08-07 14:45:46 +00:00
|
|
|
case eCursor_arrow_north:
|
1998-10-27 18:57:18 +00:00
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ARROWNORTH));
|
1998-08-07 14:45:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_arrow_north_plus:
|
1998-10-27 18:57:18 +00:00
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ARROWNORTHPLUS));
|
1998-08-07 14:45:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_arrow_south:
|
1998-10-27 18:57:18 +00:00
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ARROWSOUTH));
|
1998-08-07 14:45:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_arrow_south_plus:
|
1998-10-27 18:57:18 +00:00
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ARROWSOUTHPLUS));
|
1998-08-07 14:45:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_arrow_east:
|
1998-10-27 18:57:18 +00:00
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ARROWEAST));
|
1998-08-07 14:45:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_arrow_east_plus:
|
1998-10-27 18:57:18 +00:00
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ARROWEASTPLUS));
|
1998-08-07 14:45:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_arrow_west:
|
1998-10-27 18:57:18 +00:00
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ARROWWEST));
|
1998-08-07 14:45:46 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_arrow_west_plus:
|
1998-10-27 18:57:18 +00:00
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ARROWWESTPLUS));
|
1998-08-07 14:45:46 +00:00
|
|
|
break;
|
|
|
|
|
2000-03-21 22:06:29 +00:00
|
|
|
case eCursor_crosshair:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_CROSS);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_move:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_SIZEALL);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_help:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_HELP);
|
|
|
|
break;
|
|
|
|
|
2000-05-07 05:14:43 +00:00
|
|
|
case eCursor_copy: // CSS3
|
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_COPY));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_alias:
|
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ALIAS));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_cell:
|
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_CELL));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_grab:
|
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_GRAB));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_grabbing:
|
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_GRABBING));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_spinning:
|
|
|
|
newCursor = ::LoadCursor(NULL, IDC_APPSTARTING);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_context_menu:
|
|
|
|
case eCursor_count_up:
|
|
|
|
case eCursor_count_down:
|
|
|
|
case eCursor_count_up_down:
|
|
|
|
break;
|
|
|
|
|
2003-05-02 22:23:55 +00:00
|
|
|
case eCursor_zoom_in:
|
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ZOOMIN));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eCursor_zoom_out:
|
|
|
|
newCursor = ::LoadCursor(nsToolkit::mDllInstance, MAKEINTRESOURCE(IDC_ZOOMOUT));
|
|
|
|
break;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
default:
|
|
|
|
NS_ASSERTION(0, "Invalid cursor type");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NULL != newCursor) {
|
|
|
|
mCursor = aCursor;
|
|
|
|
HCURSOR oldCursor = ::SetCursor(newCursor);
|
|
|
|
}
|
1998-11-18 05:25:26 +00:00
|
|
|
//}
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
2002-02-20 03:33:52 +00:00
|
|
|
|
|
|
|
NS_IMETHODIMP nsWindow::HideWindowChrome(PRBool aShouldHide)
|
|
|
|
{
|
|
|
|
HWND hwnd = (HWND)GetNativeData(NS_NATIVE_WINDOW);
|
|
|
|
|
|
|
|
HWND parentWnd = ::GetParent(hwnd);
|
|
|
|
while (parentWnd) {
|
|
|
|
hwnd = parentWnd;
|
|
|
|
parentWnd = ::GetParent(parentWnd);
|
|
|
|
if (!parentWnd) break;
|
|
|
|
}
|
|
|
|
|
|
|
|
DWORD style, exStyle;
|
|
|
|
if (aShouldHide) {
|
2002-10-16 23:28:18 +00:00
|
|
|
DWORD tempStyle = nsToolkit::mGetWindowLong(hwnd, GWL_STYLE);
|
|
|
|
DWORD tempExStyle = nsToolkit::mGetWindowLong(hwnd, GWL_EXSTYLE);
|
2002-02-20 03:33:52 +00:00
|
|
|
|
|
|
|
style = WS_SYSMENU | WS_MAXIMIZEBOX | WS_MINIMIZEBOX;
|
|
|
|
exStyle = 0;
|
|
|
|
|
|
|
|
mOldStyle = tempStyle;
|
|
|
|
mOldExStyle = tempExStyle;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (!mOldStyle || !mOldExStyle) {
|
2002-10-16 23:28:18 +00:00
|
|
|
mOldStyle = nsToolkit::mGetWindowLong(hwnd, GWL_STYLE);
|
|
|
|
mOldExStyle = nsToolkit::mGetWindowLong(hwnd, GWL_EXSTYLE);
|
2002-02-20 03:33:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
style = mOldStyle;
|
|
|
|
exStyle = mOldExStyle;
|
|
|
|
}
|
|
|
|
|
2002-09-09 23:58:39 +00:00
|
|
|
nsToolkit::mSetWindowLong(hwnd, GWL_STYLE, style);
|
|
|
|
nsToolkit::mSetWindowLong(hwnd, GWL_EXSTYLE, exStyle);
|
2002-02-20 03:33:52 +00:00
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2001-05-01 22:50:16 +00:00
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Validate a visible area of a widget.
|
|
|
|
//
|
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
|
|
|
|
NS_METHOD nsWindow::Validate()
|
|
|
|
{
|
|
|
|
if (mWnd)
|
|
|
|
VERIFY(::ValidateRect(mWnd, NULL));
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Invalidate this component visible area
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::Invalidate(PRBool aIsSynchronous)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1999-09-09 03:47:26 +00:00
|
|
|
if (mWnd)
|
|
|
|
{
|
|
|
|
#ifdef NS_DEBUG
|
|
|
|
debug_DumpInvalidate(stdout,
|
|
|
|
this,
|
|
|
|
nsnull,
|
|
|
|
aIsSynchronous,
|
2000-09-03 00:46:03 +00:00
|
|
|
nsCAutoString("noname"),
|
1999-09-09 03:47:26 +00:00
|
|
|
(PRInt32) mWnd);
|
|
|
|
#endif // NS_DEBUG
|
|
|
|
|
|
|
|
VERIFY(::InvalidateRect(mWnd, NULL, TRUE));
|
|
|
|
if (aIsSynchronous) {
|
1998-04-13 20:24:54 +00:00
|
|
|
VERIFY(::UpdateWindow(mWnd));
|
1999-09-09 03:47:26 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
1999-09-09 03:47:26 +00:00
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
1998-10-09 15:18:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Invalidate this component visible area
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
NS_METHOD nsWindow::Invalidate(const nsRect & aRect, PRBool aIsSynchronous)
|
|
|
|
{
|
|
|
|
RECT rect;
|
|
|
|
|
1999-09-09 03:47:26 +00:00
|
|
|
if (mWnd)
|
|
|
|
{
|
1998-10-09 15:18:54 +00:00
|
|
|
rect.left = aRect.x;
|
|
|
|
rect.top = aRect.y;
|
|
|
|
rect.right = aRect.x + aRect.width;
|
|
|
|
rect.bottom = aRect.y + aRect.height;
|
1999-09-09 03:47:26 +00:00
|
|
|
|
|
|
|
#ifdef NS_DEBUG
|
|
|
|
debug_DumpInvalidate(stdout,
|
|
|
|
this,
|
|
|
|
&aRect,
|
|
|
|
aIsSynchronous,
|
2000-09-03 00:46:03 +00:00
|
|
|
nsCAutoString("noname"),
|
1999-09-09 03:47:26 +00:00
|
|
|
(PRInt32) mWnd);
|
|
|
|
#endif // NS_DEBUG
|
|
|
|
|
1998-10-09 15:18:54 +00:00
|
|
|
VERIFY(::InvalidateRect(mWnd, &rect, TRUE));
|
|
|
|
if (aIsSynchronous) {
|
|
|
|
VERIFY(::UpdateWindow(mWnd));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1999-11-20 22:33:42 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsWindow::InvalidateRegion(const nsIRegion *aRegion, PRBool aIsSynchronous)
|
|
|
|
|
|
|
|
{
|
|
|
|
nsresult rv = NS_OK;
|
|
|
|
if (mWnd) {
|
|
|
|
HRGN nativeRegion;
|
|
|
|
rv = aRegion->GetNativeRegion((void *&)nativeRegion);
|
|
|
|
if (nativeRegion) {
|
|
|
|
if (NS_SUCCEEDED(rv)) {
|
|
|
|
VERIFY(::InvalidateRgn(mWnd, nativeRegion, TRUE));
|
|
|
|
|
|
|
|
if (aIsSynchronous) {
|
|
|
|
VERIFY(::UpdateWindow(mWnd));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
rv = NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
1998-10-27 00:16:59 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Force a synchronous repaint of the window
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
NS_IMETHODIMP nsWindow::Update()
|
|
|
|
{
|
1999-04-06 00:11:43 +00:00
|
|
|
// updates can come through for windows no longer holding an mWnd during
|
|
|
|
// deletes triggered by JavaScript in buttons with mouse feedback
|
|
|
|
if (mWnd)
|
|
|
|
VERIFY(::UpdateWindow(mWnd));
|
1998-10-27 00:16:59 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Return some native data according to aDataType
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
void* nsWindow::GetNativeData(PRUint32 aDataType)
|
|
|
|
{
|
|
|
|
switch(aDataType) {
|
1998-06-07 22:30:46 +00:00
|
|
|
case NS_NATIVE_WIDGET:
|
1998-04-13 20:24:54 +00:00
|
|
|
case NS_NATIVE_WINDOW:
|
1999-03-12 22:45:02 +00:00
|
|
|
case NS_NATIVE_PLUGIN_PORT:
|
1998-04-13 20:24:54 +00:00
|
|
|
return (void*)mWnd;
|
|
|
|
case NS_NATIVE_GRAPHIC:
|
1998-07-17 06:27:37 +00:00
|
|
|
// XXX: This is sleezy!! Remember to Release the DC after using it!
|
1998-04-13 20:24:54 +00:00
|
|
|
return (void*)::GetDC(mWnd);
|
|
|
|
case NS_NATIVE_COLORMAP:
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
1999-05-27 23:20:09 +00:00
|
|
|
//~~~
|
|
|
|
void nsWindow::FreeNativeData(void * data, PRUint32 aDataType)
|
|
|
|
{
|
|
|
|
switch(aDataType)
|
|
|
|
{
|
|
|
|
case NS_NATIVE_GRAPHIC:
|
|
|
|
::ReleaseDC(mWnd, (HDC)data);
|
|
|
|
case NS_NATIVE_WIDGET:
|
|
|
|
case NS_NATIVE_WINDOW:
|
|
|
|
case NS_NATIVE_PLUGIN_PORT:
|
|
|
|
case NS_NATIVE_COLORMAP:
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Set the colormap of the window
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::SetColorMap(nsColorMap *aColorMap)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
2001-08-09 20:22:39 +00:00
|
|
|
#if 0
|
1998-04-13 20:24:54 +00:00
|
|
|
if (mPalette != NULL) {
|
|
|
|
::DeleteObject(mPalette);
|
|
|
|
}
|
|
|
|
|
|
|
|
PRUint8 *map = aColorMap->Index;
|
|
|
|
LPLOGPALETTE pLogPal = (LPLOGPALETTE) new char[2 * sizeof(WORD) +
|
|
|
|
aColorMap->NumColors * sizeof(PALETTEENTRY)];
|
2001-08-09 20:22:39 +00:00
|
|
|
pLogPal->palVersion = 0x300;
|
|
|
|
pLogPal->palNumEntries = aColorMap->NumColors;
|
|
|
|
for(int i = 0; i < aColorMap->NumColors; i++)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
2001-08-09 20:22:39 +00:00
|
|
|
pLogPal->palPalEntry[i].peRed = *map++;
|
|
|
|
pLogPal->palPalEntry[i].peGreen = *map++;
|
|
|
|
pLogPal->palPalEntry[i].peBlue = *map++;
|
|
|
|
pLogPal->palPalEntry[i].peFlags = 0;
|
|
|
|
}
|
|
|
|
mPalette = ::CreatePalette(pLogPal);
|
|
|
|
delete pLogPal;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
NS_ASSERTION(mPalette != NULL, "Null palette");
|
|
|
|
if (mPalette != NULL) {
|
|
|
|
HDC hDC = ::GetDC(mWnd);
|
|
|
|
HPALETTE hOldPalette = ::SelectPalette(hDC, mPalette, TRUE);
|
|
|
|
::RealizePalette(hDC);
|
|
|
|
::SelectPalette(hDC, hOldPalette, TRUE);
|
|
|
|
::ReleaseDC(mWnd, hDC);
|
|
|
|
}
|
2001-08-09 20:22:39 +00:00
|
|
|
#endif
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Scroll the bits of a window
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2000-01-15 01:38:50 +00:00
|
|
|
//XXX Scroll is obsolete and should go away soon
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::Scroll(PRInt32 aDx, PRInt32 aDy, nsRect *aClipRect)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
|
|
|
RECT trect;
|
|
|
|
|
|
|
|
if (nsnull != aClipRect)
|
|
|
|
{
|
|
|
|
trect.left = aClipRect->x;
|
|
|
|
trect.top = aClipRect->y;
|
|
|
|
trect.right = aClipRect->XMost();
|
|
|
|
trect.bottom = aClipRect->YMost();
|
|
|
|
}
|
|
|
|
|
|
|
|
::ScrollWindowEx(mWnd, aDx, aDy, (nsnull != aClipRect) ? &trect : NULL, NULL,
|
1998-07-26 04:24:42 +00:00
|
|
|
NULL, NULL, SW_INVALIDATE | SW_SCROLLCHILDREN);
|
1998-04-13 20:24:54 +00:00
|
|
|
::UpdateWindow(mWnd);
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
2000-01-15 01:38:50 +00:00
|
|
|
NS_IMETHODIMP nsWindow::ScrollWidgets(PRInt32 aDx, PRInt32 aDy)
|
|
|
|
{
|
|
|
|
// Scroll the entire contents of the window + change the offset of any child windows
|
|
|
|
::ScrollWindowEx(mWnd, aDx, aDy, NULL, NULL, NULL,
|
|
|
|
NULL, SW_INVALIDATE | SW_SCROLLCHILDREN);
|
|
|
|
::UpdateWindow(mWnd); // Force synchronous generation of NS_PAINT
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP nsWindow::ScrollRect(nsRect &aRect, PRInt32 aDx, PRInt32 aDy)
|
|
|
|
{
|
|
|
|
RECT trect;
|
|
|
|
|
|
|
|
trect.left = aRect.x;
|
|
|
|
trect.top = aRect.y;
|
|
|
|
trect.right = aRect.XMost();
|
|
|
|
trect.bottom = aRect.YMost();
|
|
|
|
|
|
|
|
// Scroll the bits in the window defined by trect.
|
|
|
|
// Child windows are not scrolled.
|
|
|
|
::ScrollWindowEx(mWnd, aDx, aDy, &trect, NULL, NULL,
|
|
|
|
NULL, SW_INVALIDATE);
|
|
|
|
::UpdateWindow(mWnd); // Force synchronous generation of NS_PAINT
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-05-04 19:25:25 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Every function that needs a thread switch goes through this function
|
|
|
|
// by calling SendMessage (..WM_CALLMETHOD..) in nsToolkit::CallMethod.
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
BOOL nsWindow::CallMethod(MethodInfo *info)
|
|
|
|
{
|
|
|
|
BOOL bRet = TRUE;
|
|
|
|
|
|
|
|
switch (info->methodId) {
|
|
|
|
case nsWindow::CREATE:
|
1998-07-29 18:51:45 +00:00
|
|
|
NS_ASSERTION(info->nArgs == 7, "Wrong number of arguments to CallMethod");
|
1998-04-13 20:24:54 +00:00
|
|
|
Create((nsIWidget*)(info->args[0]),
|
|
|
|
(nsRect&)*(nsRect*)(info->args[1]),
|
|
|
|
(EVENT_CALLBACK)(info->args[2]),
|
|
|
|
(nsIDeviceContext*)(info->args[3]),
|
1998-07-29 18:51:45 +00:00
|
|
|
(nsIAppShell *)(info->args[4]),
|
|
|
|
(nsIToolkit*)(info->args[5]),
|
|
|
|
(nsWidgetInitData*)(info->args[6]));
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case nsWindow::CREATE_NATIVE:
|
1998-07-29 18:51:45 +00:00
|
|
|
NS_ASSERTION(info->nArgs == 7, "Wrong number of arguments to CallMethod");
|
1998-06-25 04:24:45 +00:00
|
|
|
Create((nsNativeWidget)(info->args[0]),
|
1998-04-13 20:24:54 +00:00
|
|
|
(nsRect&)*(nsRect*)(info->args[1]),
|
|
|
|
(EVENT_CALLBACK)(info->args[2]),
|
|
|
|
(nsIDeviceContext*)(info->args[3]),
|
1998-07-29 18:51:45 +00:00
|
|
|
(nsIAppShell *)(info->args[4]),
|
|
|
|
(nsIToolkit*)(info->args[5]),
|
|
|
|
(nsWidgetInitData*)(info->args[6]));
|
1998-04-13 20:24:54 +00:00
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
case nsWindow::DESTROY:
|
|
|
|
NS_ASSERTION(info->nArgs == 0, "Wrong number of arguments to CallMethod");
|
|
|
|
Destroy();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case nsWindow::SET_FOCUS:
|
|
|
|
NS_ASSERTION(info->nArgs == 0, "Wrong number of arguments to CallMethod");
|
2001-03-19 18:44:59 +00:00
|
|
|
SetFocus(PR_FALSE);
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
bRet = FALSE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return bRet;
|
|
|
|
}
|
|
|
|
|
1998-08-03 22:28:00 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
void nsWindow::SetUpForPaint(HDC aHDC)
|
|
|
|
{
|
|
|
|
::SetBkColor (aHDC, NSRGB_2_COLOREF(mBackground));
|
|
|
|
::SetTextColor(aHDC, NSRGB_2_COLOREF(mForeground));
|
|
|
|
::SetBkMode (aHDC, TRANSPARENT);
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1999-03-09 23:48:58 +00:00
|
|
|
//---------------------------------------------------------
|
1999-08-26 14:41:17 +00:00
|
|
|
NS_METHOD nsWindow::EnableDragDrop(PRBool aEnable)
|
1999-03-09 23:48:58 +00:00
|
|
|
{
|
1999-08-26 14:41:17 +00:00
|
|
|
nsresult rv = NS_ERROR_FAILURE;
|
|
|
|
|
|
|
|
if (aEnable) {
|
|
|
|
if (nsnull == mNativeDragTarget) {
|
|
|
|
mNativeDragTarget = new nsNativeDragTarget(this);
|
|
|
|
if (NULL != mNativeDragTarget) {
|
|
|
|
mNativeDragTarget->AddRef();
|
|
|
|
if (S_OK == ::CoLockObjectExternal((LPUNKNOWN)mNativeDragTarget,TRUE,FALSE)) {
|
|
|
|
if (S_OK == ::RegisterDragDrop(mWnd, (LPDROPTARGET)mNativeDragTarget)) {
|
|
|
|
rv = NS_OK;
|
|
|
|
}
|
|
|
|
}
|
1999-04-17 13:45:10 +00:00
|
|
|
}
|
1999-08-26 14:41:17 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (nsnull != mWnd && NULL != mNativeDragTarget) {
|
|
|
|
::RevokeDragDrop(mWnd);
|
|
|
|
if (S_OK == ::CoLockObjectExternal((LPUNKNOWN)mNativeDragTarget, FALSE, TRUE)) {
|
|
|
|
rv = NS_OK;
|
|
|
|
}
|
|
|
|
NS_RELEASE(mNativeDragTarget);
|
|
|
|
}
|
|
|
|
}
|
1999-06-17 23:23:11 +00:00
|
|
|
|
1999-08-26 14:41:17 +00:00
|
|
|
return rv;
|
1999-03-09 23:48:58 +00:00
|
|
|
}
|
1999-03-01 16:22:40 +00:00
|
|
|
|
2000-02-02 15:00:59 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
UINT nsWindow::MapFromNativeToDOM(UINT aNativeKeyCode)
|
|
|
|
{
|
2000-05-03 21:34:09 +00:00
|
|
|
switch (aNativeKeyCode) {
|
|
|
|
case 0xBA: return NS_VK_SEMICOLON;
|
|
|
|
case 0xBB: return NS_VK_EQUALS;
|
|
|
|
case 0xBD: return NS_VK_SUBTRACT;
|
2000-02-02 15:00:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return aNativeKeyCode;
|
|
|
|
}
|
1999-04-23 14:30:51 +00:00
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// OnKey
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2002-02-02 00:21:53 +00:00
|
|
|
PRBool nsWindow::DispatchKeyEvent(PRUint32 aEventType, WORD aCharCode, UINT aVirtualCharCode, LPARAM aKeyData)
|
1999-04-23 14:30:51 +00:00
|
|
|
{
|
2004-01-12 08:25:18 +00:00
|
|
|
nsKeyEvent event(aEventType, this);
|
|
|
|
nsPoint point(0, 0);
|
1999-04-23 14:30:51 +00:00
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event, &point); // this add ref's event.widget
|
1999-04-23 14:30:51 +00:00
|
|
|
|
2000-05-12 21:54:25 +00:00
|
|
|
event.charCode = aCharCode;
|
|
|
|
event.keyCode = aVirtualCharCode;
|
1999-04-23 14:30:51 +00:00
|
|
|
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
#ifdef KE_DEBUG
|
|
|
|
static cnt=0;
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("%d DispatchKE Type: %s charCode %d keyCode %d ", cnt++,
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
(NS_KEY_PRESS == aEventType)?"PRESS":(aEventType == NS_KEY_UP?"Up":"Down"),
|
|
|
|
event.charCode, event.keyCode);
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("Shift: %s Control %s Alt: %s \n", (mIsShiftDown?"D":"U"), (mIsControlDown?"D":"U"), (mIsAltDown?"D":"U"));
|
|
|
|
printf("[%c][%c][%c] <== [%c][%c][%c][ space bar ][%c][%c][%c]\n",
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
IS_VK_DOWN(NS_VK_SHIFT) ? 'S' : ' ',
|
|
|
|
IS_VK_DOWN(NS_VK_CONTROL) ? 'C' : ' ',
|
|
|
|
IS_VK_DOWN(NS_VK_ALT) ? 'A' : ' ',
|
|
|
|
IS_VK_DOWN(VK_LSHIFT) ? 'S' : ' ',
|
|
|
|
IS_VK_DOWN(VK_LCONTROL) ? 'C' : ' ',
|
|
|
|
IS_VK_DOWN(VK_LMENU) ? 'A' : ' ',
|
|
|
|
IS_VK_DOWN(VK_RMENU) ? 'A' : ' ',
|
|
|
|
IS_VK_DOWN(VK_RCONTROL) ? 'C' : ' ',
|
|
|
|
IS_VK_DOWN(VK_RSHIFT) ? 'S' : ' '
|
|
|
|
|
2000-10-28 22:17:53 +00:00
|
|
|
);
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
#endif
|
1999-04-23 14:30:51 +00:00
|
|
|
|
|
|
|
event.isShift = mIsShiftDown;
|
|
|
|
event.isControl = mIsControlDown;
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
event.isMeta = PR_FALSE;
|
1999-04-23 14:30:51 +00:00
|
|
|
event.isAlt = mIsAltDown;
|
|
|
|
|
2001-12-29 22:21:31 +00:00
|
|
|
nsPluginEvent pluginEvent;
|
|
|
|
|
|
|
|
switch (aEventType)
|
|
|
|
{
|
|
|
|
case NS_KEY_UP:
|
|
|
|
pluginEvent.event = WM_KEYUP;
|
|
|
|
break;
|
|
|
|
case NS_KEY_DOWN:
|
|
|
|
pluginEvent.event = WM_KEYDOWN;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2002-02-02 00:21:53 +00:00
|
|
|
pluginEvent.wParam = aVirtualCharCode;
|
|
|
|
pluginEvent.lParam = aKeyData;
|
2001-12-29 22:21:31 +00:00
|
|
|
|
|
|
|
event.nativeMsg = (void *)&pluginEvent;
|
|
|
|
|
1999-04-23 14:30:51 +00:00
|
|
|
PRBool result = DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2004-04-18 11:03:51 +00:00
|
|
|
BOOL nsWindow::OnKeyDown(UINT aVirtualKeyCode, UINT aScanCode, LPARAM aKeyData)
|
1999-06-10 21:38:05 +00:00
|
|
|
{
|
2004-04-18 11:03:51 +00:00
|
|
|
UINT virtualKeyCode = mIMEIsComposing ? aVirtualKeyCode : MapFromNativeToDOM(aVirtualKeyCode);
|
2000-05-12 21:54:25 +00:00
|
|
|
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2004-04-18 11:03:51 +00:00
|
|
|
//printf("In OnKeyDown ascii %d virt: %d scan: %d\n", asciiKey, virtualKeyCode, aScanCode);
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
1999-09-20 21:07:39 +00:00
|
|
|
|
2004-04-18 11:03:51 +00:00
|
|
|
BOOL result = DispatchKeyEvent(NS_KEY_DOWN, 0, virtualKeyCode, aKeyData);
|
|
|
|
|
|
|
|
// If we won't be getting a WM_CHAR, WM_SYSCHAR or WM_DEADCHAR, synthesize a keypress
|
|
|
|
// for almost all keys
|
|
|
|
switch (virtualKeyCode) {
|
|
|
|
case NS_VK_SHIFT:
|
|
|
|
case NS_VK_CONTROL:
|
|
|
|
case NS_VK_ALT:
|
|
|
|
case NS_VK_CAPS_LOCK:
|
|
|
|
case NS_VK_NUM_LOCK:
|
|
|
|
case NS_VK_SCROLL_LOCK: return result;
|
|
|
|
}
|
1999-09-20 21:07:39 +00:00
|
|
|
|
2004-04-18 11:03:51 +00:00
|
|
|
MSG msg;
|
|
|
|
BOOL gotMsg = ::PeekMessage(&msg, mWnd, 0, 0, PM_NOREMOVE | PM_NOYIELD);
|
|
|
|
// Enter and backspace are always handled here to avoid for example the
|
|
|
|
// confusion between ctrl-enter and ctrl-J.
|
|
|
|
if (virtualKeyCode == NS_VK_RETURN || virtualKeyCode == NS_VK_BACK)
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
{
|
2004-04-18 11:03:51 +00:00
|
|
|
// Remove a possible WM_CHAR or WM_SYSCHAR from the message queue
|
|
|
|
if (gotMsg && (msg.message == WM_CHAR || msg.message == WM_SYSCHAR)) {
|
|
|
|
::GetMessage(&msg, mWnd, 0, 0);
|
|
|
|
}
|
2001-10-22 22:43:52 +00:00
|
|
|
}
|
2004-04-18 11:03:51 +00:00
|
|
|
else if (gotMsg &&
|
|
|
|
(msg.message == WM_CHAR || msg.message == WM_SYSCHAR || msg.message == WM_DEADCHAR)) {
|
|
|
|
return result;
|
2002-06-12 14:25:02 +00:00
|
|
|
}
|
2004-04-18 11:03:51 +00:00
|
|
|
|
|
|
|
WORD asciiKey = 0;
|
|
|
|
|
|
|
|
switch (virtualKeyCode) {
|
|
|
|
// keys to be sent as characters
|
|
|
|
case NS_VK_ADD : asciiKey = '+'; break;
|
|
|
|
case NS_VK_SUBTRACT : asciiKey = '-'; break;
|
|
|
|
case NS_VK_SEMICOLON : asciiKey = ';'; break;
|
|
|
|
case NS_VK_EQUALS : asciiKey = '='; break;
|
|
|
|
case NS_VK_COMMA : asciiKey = ','; break;
|
|
|
|
case NS_VK_PERIOD : asciiKey = '.'; break;
|
|
|
|
case NS_VK_QUOTE : asciiKey = '\''; break;
|
|
|
|
case NS_VK_BACK_QUOTE: asciiKey = '`'; break;
|
|
|
|
case NS_VK_DIVIDE :
|
|
|
|
case NS_VK_SLASH : asciiKey = '/'; break;
|
|
|
|
case NS_VK_MULTIPLY : asciiKey = '*'; break;
|
|
|
|
default:
|
|
|
|
// NS_VK_0 - NS_VK9 and NS_VK_A - NS_VK_Z match their ascii values
|
|
|
|
if ((NS_VK_0 <= virtualKeyCode && virtualKeyCode <= NS_VK_9) ||
|
|
|
|
(NS_VK_A <= virtualKeyCode && virtualKeyCode <= NS_VK_Z)) {
|
|
|
|
asciiKey = virtualKeyCode;
|
|
|
|
// Take the Shift state into account
|
|
|
|
if (!mIsShiftDown && NS_VK_A <= virtualKeyCode && virtualKeyCode <= NS_VK_Z)
|
|
|
|
asciiKey += 0x20;
|
|
|
|
}
|
1999-09-20 21:07:39 +00:00
|
|
|
}
|
2004-04-18 11:03:51 +00:00
|
|
|
if (asciiKey)
|
|
|
|
DispatchKeyEvent(NS_KEY_PRESS, asciiKey, 0, aKeyData);
|
|
|
|
else
|
|
|
|
DispatchKeyEvent(NS_KEY_PRESS, 0, virtualKeyCode, aKeyData);
|
|
|
|
|
1999-09-20 21:07:39 +00:00
|
|
|
return result;
|
1999-06-10 21:38:05 +00:00
|
|
|
}
|
1999-04-23 14:30:51 +00:00
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2002-02-02 00:21:53 +00:00
|
|
|
BOOL nsWindow::OnKeyUp( UINT aVirtualKeyCode, UINT aScanCode, LPARAM aKeyData)
|
1999-04-23 14:30:51 +00:00
|
|
|
{
|
2004-04-18 11:03:51 +00:00
|
|
|
aVirtualKeyCode = mIMEIsComposing ? aVirtualKeyCode : MapFromNativeToDOM(aVirtualKeyCode);
|
2002-02-02 00:21:53 +00:00
|
|
|
BOOL result = DispatchKeyEvent(NS_KEY_UP, 0, aVirtualKeyCode, aKeyData);
|
2000-02-12 00:10:22 +00:00
|
|
|
return result;
|
1999-04-23 14:30:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2004-04-18 11:03:51 +00:00
|
|
|
BOOL nsWindow::OnChar(UINT charCode)
|
1999-06-04 05:14:01 +00:00
|
|
|
{
|
2001-10-03 00:00:15 +00:00
|
|
|
wchar_t uniChar;
|
|
|
|
|
2004-04-18 11:03:51 +00:00
|
|
|
if (mIMEIsComposing) {
|
2001-10-03 00:00:15 +00:00
|
|
|
HandleEndComposition();
|
|
|
|
}
|
1999-06-04 05:14:01 +00:00
|
|
|
|
2004-04-18 11:03:51 +00:00
|
|
|
if (mIsControlDown && charCode <= 0x1A) { // Ctrl+A Ctrl+Z, see Programming Windows 3.1 page 110 for details
|
|
|
|
// need to account for shift here. bug 16486
|
|
|
|
if (mIsShiftDown)
|
|
|
|
uniChar = charCode - 1 + 'A';
|
|
|
|
else
|
|
|
|
uniChar = charCode - 1 + 'a';
|
|
|
|
charCode = 0;
|
|
|
|
}
|
|
|
|
else if (mIsControlDown && charCode <= 0x1F) {
|
2002-02-16 01:44:54 +00:00
|
|
|
// Fix for 50255 - <ctrl><[> and <ctrl><]> are not being processed.
|
|
|
|
// also fixes ctrl+\ (x1c), ctrl+^ (x1e) and ctrl+_ (x1f)
|
|
|
|
// for some reason the keypress handler need to have the uniChar code set
|
|
|
|
// with the addition of a upper case A not the lower case.
|
2004-04-18 11:03:51 +00:00
|
|
|
uniChar = charCode - 1 + 'A';
|
|
|
|
charCode = 0;
|
|
|
|
} else { // 0x20 - SPACE, 0x3D - EQUALS
|
|
|
|
if (charCode < 0x20 || (charCode == 0x3D && mIsControlDown)) {
|
2001-05-01 13:29:14 +00:00
|
|
|
uniChar = 0;
|
2004-04-18 11:03:51 +00:00
|
|
|
} else {
|
|
|
|
if (nsToolkit::mIsNT) {
|
|
|
|
uniChar = charCode;
|
|
|
|
} else {
|
|
|
|
char charToConvert[3];
|
|
|
|
size_t length;
|
|
|
|
|
|
|
|
if (charCode <= 0xFF) { // not a multibyte character
|
|
|
|
if (mLeadByte) { // mLeadByte is used for keeping the lead-byte of CJK char
|
|
|
|
charToConvert[0] = mLeadByte;
|
|
|
|
charToConvert[1] = LOBYTE(charCode);
|
|
|
|
mLeadByte = '\0';
|
|
|
|
length = 2;
|
|
|
|
} else {
|
|
|
|
charToConvert[0] = LOBYTE(charCode);
|
|
|
|
if (::IsDBCSLeadByteEx(gCurrentKeyboardCP, charToConvert[0])) {
|
|
|
|
mLeadByte = charToConvert[0];
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
length = 1;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// SC double-byte punctuation mark in Windows-English is 0x0000aca3
|
|
|
|
uniChar = LOWORD(charCode);
|
|
|
|
charToConvert[0] = LOBYTE(uniChar);
|
|
|
|
charToConvert[1] = HIBYTE(uniChar);
|
|
|
|
mLeadByte = '\0';
|
|
|
|
length=2;
|
|
|
|
}
|
|
|
|
::MultiByteToWideChar(gCurrentKeyboardCP, MB_PRECOMPOSED, charToConvert, length,
|
|
|
|
&uniChar, 1);
|
|
|
|
}
|
|
|
|
charCode = 0;
|
2001-05-01 13:29:14 +00:00
|
|
|
}
|
|
|
|
}
|
2004-04-18 11:03:51 +00:00
|
|
|
return DispatchKeyEvent(NS_KEY_PRESS, uniChar, charCode, 0);
|
1999-06-04 05:14:01 +00:00
|
|
|
}
|
|
|
|
|
1999-04-23 14:30:51 +00:00
|
|
|
|
2000-04-01 22:16:43 +00:00
|
|
|
void nsWindow::ConstrainZLevel(HWND *aAfter) {
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
nsZLevelEvent event(NS_SETZLEVEL, this);
|
2000-04-01 22:16:43 +00:00
|
|
|
nsWindow *aboveWindow = 0;
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event);
|
2000-04-01 22:16:43 +00:00
|
|
|
|
|
|
|
if (*aAfter == HWND_BOTTOM)
|
|
|
|
event.mPlacement = nsWindowZBottom;
|
|
|
|
else if (*aAfter == HWND_TOP || *aAfter == HWND_TOPMOST || *aAfter == HWND_NOTOPMOST)
|
|
|
|
event.mPlacement = nsWindowZTop;
|
|
|
|
else {
|
|
|
|
event.mPlacement = nsWindowZRelative;
|
2000-04-27 00:23:18 +00:00
|
|
|
aboveWindow = GetNSWindowPtr(*aAfter);
|
2000-04-01 22:16:43 +00:00
|
|
|
}
|
|
|
|
event.mReqBelow = aboveWindow;
|
2002-02-27 01:30:40 +00:00
|
|
|
event.mActualBelow = nsnull;
|
2000-04-01 22:16:43 +00:00
|
|
|
|
|
|
|
event.mImmediate = PR_FALSE;
|
|
|
|
event.mAdjusted = PR_FALSE;
|
|
|
|
DispatchWindowEvent(&event);
|
|
|
|
|
|
|
|
if (event.mAdjusted) {
|
|
|
|
if (event.mPlacement == nsWindowZBottom)
|
|
|
|
*aAfter = HWND_BOTTOM;
|
|
|
|
else if (event.mPlacement == nsWindowZTop)
|
|
|
|
*aAfter = HWND_TOP;
|
|
|
|
else {
|
|
|
|
*aAfter = (HWND)event.mActualBelow->GetNativeData(NS_NATIVE_WINDOW);
|
|
|
|
}
|
|
|
|
}
|
2002-02-27 01:30:40 +00:00
|
|
|
NS_IF_RELEASE(event.mActualBelow);
|
2000-04-01 22:16:43 +00:00
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
}
|
|
|
|
|
2000-08-30 21:21:39 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Process all nsWindows messages
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
static PRBool gJustGotDeactivate = PR_FALSE;
|
|
|
|
static PRBool gJustGotActivate = PR_FALSE;
|
|
|
|
|
2000-05-11 13:39:17 +00:00
|
|
|
#ifdef NS_DEBUG
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char * mStr;
|
|
|
|
long mId;
|
|
|
|
} EventMsgInfo;
|
|
|
|
|
|
|
|
EventMsgInfo gAllEvents[] = {
|
|
|
|
{"WM_NULL ", 0x0000},
|
|
|
|
{"WM_CREATE ", 0x0001},
|
|
|
|
{"WM_DESTROY ", 0x0002},
|
|
|
|
{"WM_MOVE ", 0x0003},
|
|
|
|
{"WM_SIZE ", 0x0005},
|
|
|
|
{"WM_ACTIVATE ", 0x0006},
|
|
|
|
{"WM_SETFOCUS ", 0x0007},
|
|
|
|
{"WM_KILLFOCUS ", 0x0008},
|
|
|
|
{"WM_ENABLE ", 0x000A},
|
|
|
|
{"WM_SETREDRAW ", 0x000B},
|
|
|
|
{"WM_SETTEXT ", 0x000C},
|
|
|
|
{"WM_GETTEXT ", 0x000D},
|
|
|
|
{"WM_GETTEXTLENGTH ", 0x000E},
|
|
|
|
{"WM_PAINT ", 0x000F},
|
|
|
|
{"WM_CLOSE ", 0x0010},
|
|
|
|
{"WM_QUERYENDSESSION", 0x0011},
|
|
|
|
{"WM_QUIT ", 0x0012},
|
|
|
|
{"WM_QUERYOPEN ", 0x0013},
|
|
|
|
{"WM_ERASEBKGND ", 0x0014},
|
|
|
|
{"WM_SYSCOLORCHANGE ", 0x0015},
|
|
|
|
{"WM_ENDSESSION ", 0x0016},
|
|
|
|
{"WM_SHOWWINDOW ", 0x0018},
|
|
|
|
{"WM_SETTINGCHANGE ", 0x001A},
|
|
|
|
{"WM_DEVMODECHANGE ", 0x001B},
|
|
|
|
{"WM_ACTIVATEAPP ", 0x001C},
|
|
|
|
{"WM_FONTCHANGE ", 0x001D},
|
|
|
|
{"WM_TIMECHANGE ", 0x001E},
|
|
|
|
{"WM_CANCELMODE ", 0x001F},
|
|
|
|
{"WM_SETCURSOR ", 0x0020},
|
|
|
|
{"WM_MOUSEACTIVATE ", 0x0021},
|
|
|
|
{"WM_CHILDACTIVATE ", 0x0022},
|
|
|
|
{"WM_QUEUESYNC ", 0x0023},
|
|
|
|
{"WM_GETMINMAXINFO ", 0x0024},
|
|
|
|
{"WM_PAINTICON ", 0x0026},
|
|
|
|
{"WM_ICONERASEBKGND ", 0x0027},
|
|
|
|
{"WM_NEXTDLGCTL ", 0x0028},
|
|
|
|
{"WM_SPOOLERSTATUS ", 0x002A},
|
|
|
|
{"WM_DRAWITEM ", 0x002B},
|
|
|
|
{"WM_MEASUREITEM ", 0x002C},
|
|
|
|
{"WM_DELETEITEM ", 0x002D},
|
|
|
|
{"WM_VKEYTOITEM ", 0x002E},
|
|
|
|
{"WM_CHARTOITEM ", 0x002F},
|
|
|
|
{"WM_SETFONT ", 0x0030},
|
|
|
|
{"WM_GETFONT ", 0x0031},
|
|
|
|
{"WM_SETHOTKEY ", 0x0032},
|
|
|
|
{"WM_GETHOTKEY ", 0x0033},
|
|
|
|
{"WM_QUERYDRAGICON ", 0x0037},
|
|
|
|
{"WM_COMPAREITEM ", 0x0039},
|
|
|
|
{"WM_GETOBJECT ", 0x003D},
|
|
|
|
{"WM_COMPACTING ", 0x0041},
|
|
|
|
{"WM_COMMNOTIFY ", 0x0044},
|
|
|
|
{"WM_WINDOWPOSCHANGING", 0x0046},
|
|
|
|
{"WM_WINDOWPOSCHANGED ", 0x0047},
|
|
|
|
{"WM_POWER ", 0x0048},
|
|
|
|
{"WM_COPYDATA ", 0x004A},
|
|
|
|
{"WM_CANCELJOURNAL ", 0x004B},
|
|
|
|
{"WM_NOTIFY ", 0x004E},
|
|
|
|
{"WM_INPUTLANGCHANGEREQUEST ", 0x0050},
|
|
|
|
{"WM_INPUTLANGCHANGE", 0x0051},
|
|
|
|
{"WM_TCARD ", 0x0052},
|
|
|
|
{"WM_HELP ", 0x0053},
|
|
|
|
{"WM_USERCHANGED ", 0x0054},
|
|
|
|
{"WM_NOTIFYFORMAT ", 0x0055},
|
|
|
|
{"WM_CONTEXTMENU ", 0x007B},
|
|
|
|
{"WM_STYLECHANGING ", 0x007C},
|
|
|
|
{"WM_STYLECHANGED ", 0x007D},
|
|
|
|
{"WM_DISPLAYCHANGE ", 0x007E},
|
|
|
|
{"WM_GETICON ", 0x007F},
|
|
|
|
{"WM_SETICON ", 0x0080},
|
|
|
|
{"WM_NCCREATE ", 0x0081},
|
|
|
|
{"WM_NCDESTROY ", 0x0082},
|
|
|
|
{"WM_NCCALCSIZE ", 0x0083},
|
|
|
|
{"WM_NCHITTEST ", 0x0084},
|
|
|
|
{"WM_NCPAINT ", 0x0085},
|
|
|
|
{"WM_NCACTIVATE ", 0x0086},
|
|
|
|
{"WM_GETDLGCODE ", 0x0087},
|
|
|
|
{"WM_SYNCPAINT ", 0x0088},
|
|
|
|
{"WM_NCMOUSEMOVE ", 0x00A0},
|
|
|
|
{"WM_NCLBUTTONDOWN ", 0x00A1},
|
|
|
|
{"WM_NCLBUTTONUP ", 0x00A2},
|
|
|
|
{"WM_NCLBUTTONDBLCLK", 0x00A3},
|
|
|
|
{"WM_NCRBUTTONDOWN ", 0x00A4},
|
|
|
|
{"WM_NCRBUTTONUP ", 0x00A5},
|
|
|
|
{"WM_NCRBUTTONDBLCLK", 0x00A6},
|
|
|
|
{"WM_NCMBUTTONDOWN ", 0x00A7},
|
|
|
|
{"WM_NCMBUTTONUP ", 0x00A8},
|
|
|
|
{"WM_NCMBUTTONDBLCLK", 0x00A9},
|
2001-05-25 10:53:32 +00:00
|
|
|
{"EM_GETSEL ", 0x00B0},
|
|
|
|
{"EM_SETSEL ", 0x00B1},
|
|
|
|
{"EM_GETRECT ", 0x00B2},
|
|
|
|
{"EM_SETRECT ", 0x00B3},
|
|
|
|
{"EM_SETRECTNP ", 0x00B4},
|
|
|
|
{"EM_SCROLL ", 0x00B5},
|
|
|
|
{"EM_LINESCROLL ", 0x00B6},
|
|
|
|
{"EM_SCROLLCARET ", 0x00B7},
|
|
|
|
{"EM_GETMODIFY ", 0x00B8},
|
|
|
|
{"EM_SETMODIFY ", 0x00B9},
|
|
|
|
{"EM_GETLINECOUNT ", 0x00BA},
|
|
|
|
{"EM_LINEINDEX ", 0x00BB},
|
|
|
|
{"EM_SETHANDLE ", 0x00BC},
|
|
|
|
{"EM_GETHANDLE ", 0x00BD},
|
|
|
|
{"EM_GETTHUMB ", 0x00BE},
|
|
|
|
{"EM_LINELENGTH ", 0x00C1},
|
|
|
|
{"EM_REPLACESEL ", 0x00C2},
|
|
|
|
{"EM_GETLINE ", 0x00C4},
|
|
|
|
{"EM_LIMITTEXT ", 0x00C5},
|
|
|
|
{"EM_CANUNDO ", 0x00C6},
|
|
|
|
{"EM_UNDO ", 0x00C7},
|
|
|
|
{"EM_FMTLINES ", 0x00C8},
|
|
|
|
{"EM_LINEFROMCHAR ", 0x00C9},
|
|
|
|
{"EM_SETTABSTOPS ", 0x00CB},
|
|
|
|
{"EM_SETPASSWORDCHAR ", 0x00CC},
|
|
|
|
{"EM_EMPTYUNDOBUFFER ", 0x00CD},
|
|
|
|
{"EM_GETFIRSTVISIBLELINE", 0x00CE},
|
|
|
|
{"EM_SETREADONLY ", 0x00CF},
|
|
|
|
{"EM_SETWORDBREAKPROC ", 0x00D0},
|
|
|
|
{"EM_GETWORDBREAKPROC ", 0x00D1},
|
|
|
|
{"EM_GETPASSWORDCHAR ", 0x00D2},
|
|
|
|
{"EM_SETMARGINS ", 0x00D3},
|
|
|
|
{"EM_GETMARGINS ", 0x00D4},
|
|
|
|
{"EM_GETLIMITTEXT ", 0x00D5},
|
|
|
|
{"EM_POSFROMCHAR ", 0x00D6},
|
|
|
|
{"EM_CHARFROMPOS ", 0x00D7},
|
|
|
|
{"EM_SETIMESTATUS ", 0x00D8},
|
|
|
|
{"EM_GETIMESTATUS ", 0x00D9},
|
2000-05-11 13:39:17 +00:00
|
|
|
{"SBM_SETPOS ", 0x00E0},
|
|
|
|
{"SBM_GETPOS ", 0x00E1},
|
|
|
|
{"SBM_SETRANGE ", 0x00E2},
|
|
|
|
{"SBM_SETRANGEREDRAW", 0x00E6},
|
|
|
|
{"SBM_GETRANGE ", 0x00E3},
|
|
|
|
{"SBM_ENABLE_ARROWS ", 0x00E4},
|
|
|
|
{"SBM_SETSCROLLINFO ", 0x00E9},
|
|
|
|
{"SBM_GETSCROLLINFO ", 0x00EA},
|
|
|
|
{"WM_KEYDOWN ", 0x0100},
|
|
|
|
{"WM_KEYUP ", 0x0101},
|
|
|
|
{"WM_CHAR ", 0x0102},
|
|
|
|
{"WM_DEADCHAR ", 0x0103},
|
|
|
|
{"WM_SYSKEYDOWN ", 0x0104},
|
|
|
|
{"WM_SYSKEYUP ", 0x0105},
|
|
|
|
{"WM_SYSCHAR ", 0x0106},
|
|
|
|
{"WM_SYSDEADCHAR ", 0x0107},
|
|
|
|
{"WM_KEYLAST ", 0x0108},
|
|
|
|
{"WM_IME_STARTCOMPOSITION ", 0x010D},
|
|
|
|
{"WM_IME_ENDCOMPOSITION ", 0x010E},
|
|
|
|
{"WM_IME_COMPOSITION", 0x010F},
|
|
|
|
{"WM_INITDIALOG ", 0x0110},
|
|
|
|
{"WM_COMMAND ", 0x0111},
|
|
|
|
{"WM_SYSCOMMAND ", 0x0112},
|
|
|
|
{"WM_TIMER ", 0x0113},
|
|
|
|
{"WM_HSCROLL ", 0x0114},
|
|
|
|
{"WM_VSCROLL ", 0x0115},
|
|
|
|
{"WM_INITMENU ", 0x0116},
|
|
|
|
{"WM_INITMENUPOPUP ", 0x0117},
|
|
|
|
{"WM_MENUSELECT ", 0x011F},
|
|
|
|
{"WM_MENUCHAR ", 0x0120},
|
|
|
|
{"WM_ENTERIDLE ", 0x0121},
|
|
|
|
{"WM_MENURBUTTONUP ", 0x0122},
|
|
|
|
{"WM_MENUDRAG ", 0x0123},
|
|
|
|
{"WM_MENUGETOBJECT ", 0x0124},
|
|
|
|
{"WM_UNINITMENUPOPUP", 0x0125},
|
|
|
|
{"WM_MENUCOMMAND ", 0x0126},
|
|
|
|
{"WM_CTLCOLORMSGBOX ", 0x0132},
|
|
|
|
{"WM_CTLCOLOREDIT ", 0x0133},
|
|
|
|
{"WM_CTLCOLORLISTBOX", 0x0134},
|
|
|
|
{"WM_CTLCOLORBTN ", 0x0135},
|
|
|
|
{"WM_CTLCOLORDLG ", 0x0136},
|
|
|
|
{"WM_CTLCOLORSCROLLBAR", 0x0137},
|
|
|
|
{"WM_CTLCOLORSTATIC ", 0x0138},
|
2001-05-25 10:53:32 +00:00
|
|
|
{"CB_GETEDITSEL ", 0x0140},
|
|
|
|
{"CB_LIMITTEXT ", 0x0141},
|
|
|
|
{"CB_SETEDITSEL ", 0x0142},
|
|
|
|
{"CB_ADDSTRING ", 0x0143},
|
|
|
|
{"CB_DELETESTRING ", 0x0144},
|
|
|
|
{"CB_DIR ", 0x0145},
|
|
|
|
{"CB_GETCOUNT ", 0x0146},
|
|
|
|
{"CB_GETCURSEL ", 0x0147},
|
|
|
|
{"CB_GETLBTEXT ", 0x0148},
|
|
|
|
{"CB_GETLBTEXTLEN ", 0x0149},
|
|
|
|
{"CB_INSERTSTRING ", 0x014A},
|
|
|
|
{"CB_RESETCONTENT ", 0x014B},
|
|
|
|
{"CB_FINDSTRING ", 0x014C},
|
|
|
|
{"CB_SELECTSTRING ", 0x014D},
|
|
|
|
{"CB_SETCURSEL ", 0x014E},
|
|
|
|
{"CB_SHOWDROPDOWN ", 0x014F},
|
|
|
|
{"CB_GETITEMDATA ", 0x0150},
|
|
|
|
{"CB_SETITEMDATA ", 0x0151},
|
|
|
|
{"CB_GETDROPPEDCONTROLRECT", 0x0152},
|
|
|
|
{"CB_SETITEMHEIGHT ", 0x0153},
|
|
|
|
{"CB_GETITEMHEIGHT ", 0x0154},
|
|
|
|
{"CB_SETEXTENDEDUI ", 0x0155},
|
|
|
|
{"CB_GETEXTENDEDUI ", 0x0156},
|
|
|
|
{"CB_GETDROPPEDSTATE ", 0x0157},
|
|
|
|
{"CB_FINDSTRINGEXACT ", 0x0158},
|
|
|
|
{"CB_SETLOCALE ", 0x0159},
|
|
|
|
{"CB_GETLOCALE ", 0x015A},
|
|
|
|
{"CB_GETTOPINDEX ", 0x015b},
|
|
|
|
{"CB_SETTOPINDEX ", 0x015c},
|
|
|
|
{"CB_GETHORIZONTALEXTENT ", 0x015d},
|
|
|
|
{"CB_SETHORIZONTALEXTENT ", 0x015e},
|
|
|
|
{"CB_GETDROPPEDWIDTH ", 0x015f},
|
|
|
|
{"CB_SETDROPPEDWIDTH ", 0x0160},
|
|
|
|
{"CB_INITSTORAGE ", 0x0161},
|
|
|
|
{"CB_MSGMAX ", 0x0162},
|
|
|
|
{"LB_ADDSTRING ", 0x0180},
|
|
|
|
{"LB_INSERTSTRING ", 0x0181},
|
|
|
|
{"LB_DELETESTRING ", 0x0182},
|
|
|
|
{"LB_SELITEMRANGEEX ", 0x0183},
|
|
|
|
{"LB_RESETCONTENT ", 0x0184},
|
|
|
|
{"LB_SETSEL ", 0x0185},
|
|
|
|
{"LB_SETCURSEL ", 0x0186},
|
|
|
|
{"LB_GETSEL ", 0x0187},
|
|
|
|
{"LB_GETCURSEL ", 0x0188},
|
|
|
|
{"LB_GETTEXT ", 0x0189},
|
|
|
|
{"LB_GETTEXTLEN ", 0x018A},
|
|
|
|
{"LB_GETCOUNT ", 0x018B},
|
|
|
|
{"LB_SELECTSTRING ", 0x018C},
|
|
|
|
{"LB_DIR ", 0x018D},
|
|
|
|
{"LB_GETTOPINDEX ", 0x018E},
|
|
|
|
{"LB_FINDSTRING ", 0x018F},
|
|
|
|
{"LB_GETSELCOUNT ", 0x0190},
|
|
|
|
{"LB_GETSELITEMS ", 0x0191},
|
|
|
|
{"LB_SETTABSTOPS ", 0x0192},
|
|
|
|
{"LB_GETHORIZONTALEXTENT", 0x0193},
|
|
|
|
{"LB_SETHORIZONTALEXTENT", 0x0194},
|
|
|
|
{"LB_SETCOLUMNWIDTH ", 0x0195},
|
|
|
|
{"LB_ADDFILE ", 0x0196},
|
|
|
|
{"LB_SETTOPINDEX ", 0x0197},
|
|
|
|
{"LB_GETITEMRECT ", 0x0198},
|
|
|
|
{"LB_GETITEMDATA ", 0x0199},
|
|
|
|
{"LB_SETITEMDATA ", 0x019A},
|
|
|
|
{"LB_SELITEMRANGE ", 0x019B},
|
|
|
|
{"LB_SETANCHORINDEX ", 0x019C},
|
|
|
|
{"LB_GETANCHORINDEX ", 0x019D},
|
|
|
|
{"LB_SETCARETINDEX ", 0x019E},
|
|
|
|
{"LB_GETCARETINDEX ", 0x019F},
|
|
|
|
{"LB_SETITEMHEIGHT ", 0x01A0},
|
|
|
|
{"LB_GETITEMHEIGHT ", 0x01A1},
|
|
|
|
{"LB_FINDSTRINGEXACT ", 0x01A2},
|
|
|
|
{"LB_SETLOCALE ", 0x01A5},
|
|
|
|
{"LB_GETLOCALE ", 0x01A6},
|
|
|
|
{"LB_SETCOUNT ", 0x01A7},
|
|
|
|
{"LB_INITSTORAGE ", 0x01A8},
|
|
|
|
{"LB_ITEMFROMPOINT ", 0x01A9},
|
|
|
|
{"LB_MSGMAX ", 0x01B0},
|
2000-05-11 13:39:17 +00:00
|
|
|
{"WM_MOUSEFIRST ", 0x0200},
|
|
|
|
{"WM_MOUSEMOVE ", 0x0200},
|
|
|
|
{"WM_LBUTTONDOWN ", 0x0201},
|
|
|
|
{"WM_LBUTTONUP ", 0x0202},
|
|
|
|
{"WM_LBUTTONDBLCLK ", 0x0203},
|
|
|
|
{"WM_RBUTTONDOWN ", 0x0204},
|
|
|
|
{"WM_RBUTTONUP ", 0x0205},
|
|
|
|
{"WM_RBUTTONDBLCLK ", 0x0206},
|
|
|
|
{"WM_MBUTTONDOWN ", 0x0207},
|
|
|
|
{"WM_MBUTTONUP ", 0x0208},
|
|
|
|
{"WM_MBUTTONDBLCLK ", 0x0209},
|
|
|
|
{"WM_MOUSEWHEEL ", 0x020A},
|
|
|
|
{"WM_MOUSELAST ", 0x020A},
|
|
|
|
{"WM_MOUSELAST ", 0x0209},
|
|
|
|
{"WM_PARENTNOTIFY ", 0x0210},
|
|
|
|
{"WM_ENTERMENULOOP ", 0x0211},
|
|
|
|
{"WM_EXITMENULOOP ", 0x0212},
|
|
|
|
{"WM_NEXTMENU ", 0x0213},
|
|
|
|
{"WM_SIZING ", 0x0214},
|
|
|
|
{"WM_CAPTURECHANGED ", 0x0215},
|
|
|
|
{"WM_MOVING ", 0x0216},
|
|
|
|
{"WM_POWERBROADCAST ", 0x0218},
|
|
|
|
{"WM_DEVICECHANGE ", 0x0219},
|
|
|
|
{"WM_MDICREATE ", 0x0220},
|
|
|
|
{"WM_MDIDESTROY ", 0x0221},
|
|
|
|
{"WM_MDIACTIVATE ", 0x0222},
|
|
|
|
{"WM_MDIRESTORE ", 0x0223},
|
|
|
|
{"WM_MDINEXT ", 0x0224},
|
|
|
|
{"WM_MDIMAXIMIZE ", 0x0225},
|
|
|
|
{"WM_MDITILE ", 0x0226},
|
|
|
|
{"WM_MDICASCADE ", 0x0227},
|
|
|
|
{"WM_MDIICONARRANGE ", 0x0228},
|
|
|
|
{"WM_MDIGETACTIVE ", 0x0229},
|
|
|
|
{"WM_MDISETMENU ", 0x0230},
|
|
|
|
{"WM_ENTERSIZEMOVE ", 0x0231},
|
|
|
|
{"WM_EXITSIZEMOVE ", 0x0232},
|
|
|
|
{"WM_DROPFILES ", 0x0233},
|
|
|
|
{"WM_MDIREFRESHMENU ", 0x0234},
|
|
|
|
{"WM_IME_SETCONTEXT ", 0x0281},
|
|
|
|
{"WM_IME_NOTIFY ", 0x0282},
|
|
|
|
{"WM_IME_CONTROL ", 0x0283},
|
|
|
|
{"WM_IME_COMPOSITIONFULL", 0x0284},
|
|
|
|
{"WM_IME_SELECT ", 0x0285},
|
|
|
|
{"WM_IME_CHAR ", 0x0286},
|
|
|
|
{"WM_IME_REQUEST ", 0x0288},
|
|
|
|
{"WM_IME_KEYDOWN ", 0x0290},
|
|
|
|
{"WM_IME_KEYUP ", 0x0291},
|
|
|
|
{"WM_MOUSEHOVER ", 0x02A1},
|
|
|
|
{"WM_MOUSELEAVE ", 0x02A3},
|
|
|
|
{"WM_CUT ", 0x0300},
|
|
|
|
{"WM_COPY ", 0x0301},
|
|
|
|
{"WM_PASTE ", 0x0302},
|
|
|
|
{"WM_CLEAR ", 0x0303},
|
|
|
|
{"WM_UNDO ", 0x0304},
|
|
|
|
{"WM_RENDERFORMAT ", 0x0305},
|
|
|
|
{"WM_RENDERALLFORMATS ", 0x0306},
|
|
|
|
{"WM_DESTROYCLIPBOARD ", 0x0307},
|
|
|
|
{"WM_DRAWCLIPBOARD ", 0x0308},
|
|
|
|
{"WM_PAINTCLIPBOARD ", 0x0309},
|
|
|
|
{"WM_VSCROLLCLIPBOARD ", 0x030A},
|
|
|
|
{"WM_SIZECLIPBOARD ", 0x030B},
|
|
|
|
{"WM_ASKCBFORMATNAME ", 0x030C},
|
|
|
|
{"WM_CHANGECBCHAIN ", 0x030D},
|
|
|
|
{"WM_HSCROLLCLIPBOARD ", 0x030E},
|
|
|
|
{"WM_QUERYNEWPALETTE ", 0x030F},
|
|
|
|
{"WM_PALETTEISCHANGING", 0x0310},
|
|
|
|
{"WM_PALETTECHANGED ", 0x0311},
|
|
|
|
{"WM_HOTKEY ", 0x0312},
|
|
|
|
{"WM_PRINT ", 0x0317},
|
|
|
|
{"WM_PRINTCLIENT ", 0x0318},
|
2001-12-17 22:51:39 +00:00
|
|
|
{"WM_THEMECHANGED ", 0x031A},
|
2000-05-11 13:39:17 +00:00
|
|
|
{"WM_HANDHELDFIRST ", 0x0358},
|
|
|
|
{"WM_HANDHELDLAST ", 0x035F},
|
|
|
|
{"WM_AFXFIRST ", 0x0360},
|
|
|
|
{"WM_AFXLAST ", 0x037F},
|
|
|
|
{"WM_PENWINFIRST ", 0x0380},
|
|
|
|
{"WM_PENWINLAST ", 0x038F},
|
|
|
|
{"WM_APP ", 0x8000},
|
|
|
|
{NULL, 0x0}
|
|
|
|
};
|
|
|
|
|
2001-05-25 10:53:32 +00:00
|
|
|
|
2000-05-11 13:39:17 +00:00
|
|
|
static long gEventCounter = 0;
|
|
|
|
static long gLastEventMsg = 0;
|
|
|
|
|
|
|
|
void PrintEvent(UINT msg, PRBool aShowAllEvents, PRBool aShowMouseMoves)
|
|
|
|
{
|
|
|
|
int inx = 0;
|
|
|
|
while (gAllEvents[inx].mId != (long)msg && gAllEvents[inx].mStr != NULL) {
|
|
|
|
inx++;
|
|
|
|
}
|
|
|
|
if (aShowAllEvents || (!aShowAllEvents && gLastEventMsg != (long)msg)) {
|
|
|
|
if (aShowMouseMoves || (!aShowMouseMoves && msg != 0x0020 && msg != 0x0200 && msg != 0x0084)) {
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("%6d - 0x%04X %s\n", gEventCounter++, msg, gAllEvents[inx].mStr?gAllEvents[inx].mStr:"Unknown");
|
2000-05-11 13:39:17 +00:00
|
|
|
gLastEventMsg = msg;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2001-12-17 22:51:39 +00:00
|
|
|
#define WM_XP_THEMECHANGED 0x031A
|
2000-05-11 13:39:17 +00:00
|
|
|
|
2002-02-27 02:18:12 +00:00
|
|
|
// Static helper functions for heap dumping
|
|
|
|
static nsresult HeapDump(const char *filename, const char *heading)
|
|
|
|
{
|
|
|
|
|
|
|
|
// Make sure heapwalk() is available
|
|
|
|
typedef BOOL WINAPI HeapWalkProc(HANDLE hHeap, LPPROCESS_HEAP_ENTRY lpEntry);
|
|
|
|
typedef DWORD WINAPI GetProcessHeapsProc(DWORD NumberOfHeaps, PHANDLE ProcessHeaps);
|
|
|
|
|
|
|
|
static PRBool firstTime = PR_TRUE;
|
|
|
|
static HeapWalkProc *heapWalkP = NULL;
|
|
|
|
static GetProcessHeapsProc *getProcessHeapsP = NULL;
|
|
|
|
|
|
|
|
if (firstTime) {
|
|
|
|
firstTime = PR_FALSE;
|
|
|
|
HMODULE kernel = GetModuleHandle("kernel32.dll");
|
|
|
|
if (kernel) {
|
|
|
|
heapWalkP = (HeapWalkProc *)
|
|
|
|
GetProcAddress(kernel, "HeapWalk");
|
|
|
|
getProcessHeapsP = (GetProcessHeapsProc *)
|
|
|
|
GetProcAddress(kernel, "GetProcessHeaps");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!heapWalkP)
|
|
|
|
return NS_ERROR_NOT_AVAILABLE;
|
|
|
|
|
|
|
|
PRFileDesc *prfd = PR_Open(filename, PR_CREATE_FILE | PR_APPEND | PR_WRONLY, 0777);
|
|
|
|
if (!prfd)
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
|
|
|
|
char buf[1024];
|
|
|
|
PRUint32 n;
|
|
|
|
PRUint32 written = 0;
|
|
|
|
HANDLE heapHandle[64];
|
|
|
|
DWORD nheap = (*getProcessHeapsP)(64, heapHandle);
|
|
|
|
if (nheap == 0 || nheap > 64) {
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
n = PR_snprintf(buf, sizeof buf, "BEGIN HEAPDUMP : %s\n", heading);
|
|
|
|
PR_Write(prfd, buf, n);
|
|
|
|
for (DWORD i = 0; i < nheap; i++) {
|
|
|
|
// Dump each heap
|
|
|
|
PROCESS_HEAP_ENTRY ent = {0};
|
2002-02-27 22:36:08 +00:00
|
|
|
n = PR_snprintf(buf, sizeof buf, "BEGIN heap %d : 0x%p\n", i+1, heapHandle[i]);
|
2002-02-27 02:18:12 +00:00
|
|
|
PR_Write(prfd, buf, n);
|
|
|
|
ent.lpData = NULL;
|
|
|
|
while ((*heapWalkP)(heapHandle[i], &ent)) {
|
2002-02-27 22:36:08 +00:00
|
|
|
if (ent.wFlags & PROCESS_HEAP_REGION)
|
|
|
|
n = PR_snprintf(buf, sizeof buf, "REGION %08p : overhead %d committed %d uncommitted %d firstblock %08p lastblock %08p\n",
|
|
|
|
ent.lpData, ent.cbOverhead,
|
|
|
|
ent.Region.dwCommittedSize, ent.Region.dwUnCommittedSize,
|
|
|
|
ent.Region.lpFirstBlock, ent.Region.lpLastBlock);
|
|
|
|
else
|
|
|
|
n = PR_snprintf(buf, sizeof buf, "%s %08p : %6d overhead %2d\n",
|
|
|
|
(ent.wFlags & PROCESS_HEAP_UNCOMMITTED_RANGE) ? "----" : ((ent.wFlags & PROCESS_HEAP_ENTRY_BUSY) ? "USED" : "FREE"),
|
|
|
|
ent.lpData, ent.cbData, ent.cbOverhead);
|
2002-02-27 02:18:12 +00:00
|
|
|
PR_Write(prfd, buf, n);
|
|
|
|
}
|
2002-02-27 22:36:08 +00:00
|
|
|
n = PR_snprintf(buf, sizeof buf, "END heap %d : 0x%p\n", i+1, heapHandle[i]);
|
|
|
|
PR_Write(prfd, buf, n);
|
2002-02-27 02:18:12 +00:00
|
|
|
}
|
|
|
|
n = PR_snprintf(buf, sizeof buf, "END HEAPDUMP : %s\n", heading);
|
|
|
|
PR_Write(prfd, buf, n);
|
|
|
|
|
|
|
|
PR_Close(prfd);
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2002-09-20 01:24:36 +00:00
|
|
|
// Recursively dispatch synchronous paints for nsIWidget
|
|
|
|
// descendants with invalidated rectangles.
|
|
|
|
|
|
|
|
BOOL CALLBACK nsWindow::DispatchStarvedPaints(HWND aWnd, LPARAM aMsg)
|
|
|
|
{
|
2002-10-16 23:28:18 +00:00
|
|
|
LONG proc = nsToolkit::mGetWindowLong(aWnd, GWL_WNDPROC);
|
2002-09-20 01:24:36 +00:00
|
|
|
if (proc == (LONG)&nsWindow::WindowProc) {
|
|
|
|
// its one of our windows so check to see if it has a
|
|
|
|
// invalidated rect. If it does. Dispatch a synchronous
|
|
|
|
// paint.
|
|
|
|
if (GetUpdateRect(aWnd, NULL, FALSE)) {
|
|
|
|
VERIFY(::UpdateWindow(aWnd));
|
|
|
|
}
|
2002-10-07 20:07:54 +00:00
|
|
|
}
|
2002-09-20 01:24:36 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2002-09-28 15:04:47 +00:00
|
|
|
// Check for pending paints and dispatch any pending paint
|
2002-09-20 01:24:36 +00:00
|
|
|
// messages for any nsIWidget which is a descendant of the
|
|
|
|
// top-level window that *this* window is embedded within.
|
2002-09-28 15:04:47 +00:00
|
|
|
// Also dispatch pending PL_Events to avoid PL_EventQueue starvation.
|
|
|
|
// Note: We do not dispatch pending paint messages for non
|
|
|
|
// nsIWidget managed windows.
|
2002-09-20 01:24:36 +00:00
|
|
|
|
2002-09-28 15:04:47 +00:00
|
|
|
void nsWindow::DispatchPendingEvents()
|
2002-09-20 01:24:36 +00:00
|
|
|
{
|
2002-10-01 03:04:22 +00:00
|
|
|
gLastInputEventTime = PR_IntervalToMicroseconds(PR_IntervalNow());
|
|
|
|
|
2002-09-28 15:04:47 +00:00
|
|
|
// Need to flush all pending PL_Events before
|
|
|
|
// painting to prevent reflow events from being starved.
|
|
|
|
// Note: Unfortunately, The flushing of PL_Events can not done by
|
|
|
|
// dispatching the native WM_TIMER event that is used for PL_Event
|
|
|
|
// notification because the timer message will not appear in the
|
|
|
|
// native msg queue until 10ms after the event is posted. Which is too late.
|
|
|
|
nsCOMPtr<nsIEventQueue> eventQueue;
|
|
|
|
nsToolkit *toolkit = NS_STATIC_CAST(nsToolkit *, mToolkit);
|
|
|
|
eventQueue = toolkit->GetEventQueue();
|
|
|
|
if (eventQueue) {
|
|
|
|
eventQueue->ProcessPendingEvents();
|
|
|
|
}
|
|
|
|
|
2002-09-20 01:24:36 +00:00
|
|
|
// Quickly check to see if there are any
|
|
|
|
// paint events pending.
|
|
|
|
if (::GetQueueStatus(QS_PAINT)) {
|
|
|
|
// Find the top level window.
|
|
|
|
HWND topWnd = mWnd;
|
|
|
|
HWND parentWnd = ::GetParent(mWnd);
|
|
|
|
while (parentWnd) {
|
|
|
|
topWnd = parentWnd;
|
|
|
|
parentWnd = ::GetParent(parentWnd);
|
|
|
|
}
|
|
|
|
|
2002-10-07 20:07:54 +00:00
|
|
|
// Dispatch pending paints for all topWnd's descendant windows.
|
|
|
|
// Note: EnumChildWindows enumerates all descendant windows not just
|
|
|
|
// it's children.
|
|
|
|
::EnumChildWindows(topWnd, nsWindow::DispatchStarvedPaints, NULL);
|
2002-09-20 01:24:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
PRBool nsWindow::ProcessMessage(UINT msg, WPARAM wParam, LPARAM lParam, LRESULT *aRetValue)
|
|
|
|
{
|
2000-11-02 05:15:34 +00:00
|
|
|
static UINT vkKeyCached = 0; // caches VK code fon WM_KEYDOWN
|
1998-08-19 00:57:02 +00:00
|
|
|
PRBool result = PR_FALSE; // call the default nsWindow proc
|
2001-01-01 01:37:00 +00:00
|
|
|
static PRBool getWheelInfo = PR_TRUE;
|
1999-03-01 16:22:40 +00:00
|
|
|
*aRetValue = 0;
|
2001-05-18 12:07:42 +00:00
|
|
|
PRBool isMozWindowTakingFocus = PR_TRUE;
|
2001-11-07 04:45:21 +00:00
|
|
|
nsPaletteInfo palInfo;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2000-05-11 13:39:17 +00:00
|
|
|
// Uncomment this to see all windows messages
|
|
|
|
// first param showss all events
|
|
|
|
// second param indicates whether to show mouse move events
|
|
|
|
//PrintEvent(msg, PR_FALSE, PR_FALSE);
|
|
|
|
|
1999-03-05 15:34:53 +00:00
|
|
|
switch (msg) {
|
1998-06-01 17:04:16 +00:00
|
|
|
case WM_COMMAND: {
|
|
|
|
WORD wNotifyCode = HIWORD(wParam); // notification code
|
1999-05-28 02:11:55 +00:00
|
|
|
if ((CBN_SELENDOK == wNotifyCode) || (CBN_SELENDCANCEL == wNotifyCode)) { // Combo box change
|
2004-01-12 08:25:18 +00:00
|
|
|
nsGUIEvent event(NS_CONTROL_CHANGE, this);
|
1999-05-28 02:11:55 +00:00
|
|
|
nsPoint point(0,0);
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event, &point); // this add ref's event.widget
|
1999-05-28 02:11:55 +00:00
|
|
|
result = DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
} else if (wNotifyCode == 0) { // Menu selection
|
2004-01-12 08:25:18 +00:00
|
|
|
nsMenuEvent event(NS_MENU_SELECTED, this);
|
1998-10-07 22:11:37 +00:00
|
|
|
event.mCommand = LOWORD(wParam);
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event);
|
1998-10-08 00:04:21 +00:00
|
|
|
result = DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
1998-06-01 17:04:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
1999-10-06 21:54:49 +00:00
|
|
|
case WM_DISPLAYCHANGE:
|
|
|
|
DispatchStandardEvent(NS_DISPLAYCHANGED);
|
|
|
|
break;
|
2002-06-04 17:47:54 +00:00
|
|
|
|
|
|
|
case WM_SYSCOLORCHANGE:
|
|
|
|
// Note: This is sent for child windows as well as top-level windows.
|
|
|
|
// The Win32 toolkit normally only sends these events to top-level windows.
|
|
|
|
// But we cycle through all of the childwindows and send it to them as well
|
|
|
|
// so all presentations get notified properly.
|
|
|
|
// See nsWindow::GlobalMsgWindowProc.
|
|
|
|
DispatchStandardEvent(NS_SYSCOLORCHANGED);
|
|
|
|
break;
|
1998-04-17 00:16:11 +00:00
|
|
|
|
|
|
|
case WM_NOTIFY:
|
|
|
|
// TAB change
|
1998-04-24 23:09:11 +00:00
|
|
|
{
|
|
|
|
LPNMHDR pnmh = (LPNMHDR) lParam;
|
|
|
|
|
1998-05-04 19:25:25 +00:00
|
|
|
switch (pnmh->code) {
|
|
|
|
case TCN_SELCHANGE: {
|
|
|
|
DispatchStandardEvent(NS_TABCHANGE);
|
|
|
|
result = PR_TRUE;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
1998-04-24 23:09:11 +00:00
|
|
|
}
|
1998-04-17 00:16:11 +00:00
|
|
|
}
|
1998-04-24 23:09:11 +00:00
|
|
|
break;
|
|
|
|
|
2001-12-17 22:51:39 +00:00
|
|
|
case WM_XP_THEMECHANGED: {
|
|
|
|
DispatchStandardEvent(NS_THEMECHANGED);
|
|
|
|
|
|
|
|
// Invalidate the window so that the repaint will
|
|
|
|
// pick up the new theme.
|
|
|
|
Invalidate(PR_FALSE);
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
2001-06-11 22:42:27 +00:00
|
|
|
case WM_FONTCHANGE:
|
|
|
|
{
|
|
|
|
nsresult rv;
|
2001-08-14 02:32:10 +00:00
|
|
|
PRBool didChange = PR_FALSE;
|
2001-06-11 22:42:27 +00:00
|
|
|
|
|
|
|
// update the global font list
|
|
|
|
nsCOMPtr<nsIFontEnumerator> fontEnum = do_GetService("@mozilla.org/gfx/fontenumerator;1", &rv);
|
|
|
|
if (NS_SUCCEEDED(rv)) {
|
2001-08-14 02:32:10 +00:00
|
|
|
fontEnum->UpdateFontList(&didChange);
|
|
|
|
//didChange is TRUE only if new font langGroup is added to the list.
|
|
|
|
if (didChange) {
|
2002-02-16 01:39:56 +00:00
|
|
|
nsCOMPtr<nsIFontPackageService> proxy = do_GetService("@mozilla.org/intl/fontpackageservice;1", &rv);
|
|
|
|
if (proxy) {
|
|
|
|
// font in the system is changed. Notify the font download service.
|
|
|
|
proxy->FontPackageHandled(PR_FALSE, PR_FALSE, "");
|
|
|
|
|
|
|
|
// update device context font cache
|
|
|
|
// Dirty but easiest way:
|
|
|
|
// Changing nsIPref entry which triggers callbacks
|
|
|
|
// and flows into calling mDeviceContext->FlushFontCache()
|
|
|
|
// to update the font cache in all the instance of Browsers
|
2004-04-01 22:51:46 +00:00
|
|
|
nsCOMPtr<nsIPrefService> prefs =
|
|
|
|
do_GetService(NS_PREFSERVICE_CONTRACTID);
|
|
|
|
if (prefs) {
|
|
|
|
nsCOMPtr<nsIPrefBranch> fiPrefs;
|
|
|
|
prefs->GetBranch("font.internaluseonly.",
|
|
|
|
getter_AddRefs(fiPrefs));
|
|
|
|
if (fiPrefs) {
|
|
|
|
PRBool fontInternalChange = PR_FALSE;
|
|
|
|
fiPrefs->GetBoolPref("changed", &fontInternalChange);
|
|
|
|
fiPrefs->SetBoolPref("changed", !fontInternalChange);
|
|
|
|
}
|
|
|
|
}
|
2001-08-14 02:32:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} //if (NS_SUCCEEDED(rv))
|
2001-06-11 22:42:27 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
1998-04-24 23:09:11 +00:00
|
|
|
case WM_MOVE: // Window moved
|
|
|
|
{
|
1998-05-29 22:44:13 +00:00
|
|
|
PRInt32 x = (PRInt32)LOWORD(lParam); // horizontal position in screen coordinates
|
|
|
|
PRInt32 y = (PRInt32)HIWORD(lParam); // vertical position in screen coordinates
|
|
|
|
result = OnMove(x, y);
|
1998-04-24 23:09:11 +00:00
|
|
|
}
|
|
|
|
break;
|
1998-04-17 00:16:11 +00:00
|
|
|
|
1999-12-01 22:38:06 +00:00
|
|
|
case WM_CLOSE: // close request
|
|
|
|
DispatchStandardEvent(NS_XUL_CLOSE);
|
|
|
|
result = PR_TRUE; // abort window closure
|
|
|
|
break;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
case WM_DESTROY:
|
|
|
|
// clean up.
|
|
|
|
OnDestroy();
|
|
|
|
result = PR_TRUE;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_PAINT:
|
|
|
|
result = OnPaint();
|
|
|
|
break;
|
2003-04-14 22:56:35 +00:00
|
|
|
|
|
|
|
case WM_PRINTCLIENT:
|
|
|
|
result = OnPaint((HDC) wParam);
|
|
|
|
break;
|
|
|
|
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
case WM_SYSCHAR:
|
|
|
|
case WM_CHAR:
|
|
|
|
{
|
|
|
|
#ifdef KE_DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("%s\tchar=%c\twp=%4x\tlp=%8x\n", (msg == WM_SYSCHAR) ? "WM_SYSCHAR" : "WM_CHAR" , wParam, wParam, lParam);
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
#endif
|
1999-11-16 23:45:44 +00:00
|
|
|
|
2000-12-19 20:00:31 +00:00
|
|
|
// ignore [shift+]alt+space so the OS can handle it
|
|
|
|
if (mIsAltDown && !mIsControlDown && IS_VK_DOWN(NS_VK_SPACE)) {
|
|
|
|
result = PR_FALSE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2004-04-18 11:03:51 +00:00
|
|
|
// WM_CHAR with Control and Alt (== AltGr) down really means a normal character
|
|
|
|
PRBool saveIsAltDown = mIsAltDown;
|
|
|
|
PRBool saveIsControlDown = mIsControlDown;
|
|
|
|
if (mIsAltDown && mIsControlDown)
|
|
|
|
mIsAltDown = mIsControlDown = PR_FALSE;
|
|
|
|
|
|
|
|
result = OnChar(wParam);
|
|
|
|
|
|
|
|
mIsAltDown = saveIsAltDown;
|
|
|
|
mIsControlDown = saveIsControlDown;
|
2001-05-01 13:29:14 +00:00
|
|
|
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
break;
|
|
|
|
}
|
1999-04-23 14:30:51 +00:00
|
|
|
case WM_SYSKEYUP:
|
2002-09-20 01:24:36 +00:00
|
|
|
case WM_KEYUP:
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
#ifdef KE_DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("%s\t\twp=%x\tlp=%x\n",
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
(WM_KEYUP==msg)?"WM_KEYUP":"WM_SYSKEYUP" , wParam, lParam);
|
|
|
|
#endif
|
1998-09-02 21:14:45 +00:00
|
|
|
mIsShiftDown = IS_VK_DOWN(NS_VK_SHIFT);
|
2004-04-18 11:03:51 +00:00
|
|
|
mIsControlDown = IS_VK_DOWN(NS_VK_CONTROL);
|
|
|
|
mIsAltDown = IS_VK_DOWN(NS_VK_ALT);
|
1999-04-23 14:30:51 +00:00
|
|
|
|
2004-04-18 11:03:51 +00:00
|
|
|
// Note: the original code passed (HIWORD(lParam)) to OnKeyUp as
|
|
|
|
// scan code. However, this breaks Alt+Num pad input.
|
1999-12-01 22:10:13 +00:00
|
|
|
// http://msdn.microsoft.com/library/psdk/winui/keybinpt_8qp5.htm
|
2004-04-18 11:03:51 +00:00
|
|
|
// states the following:
|
|
|
|
// Typically, ToAscii performs the translation based on the
|
1999-12-01 22:10:13 +00:00
|
|
|
// virtual-key code. In some cases, however, bit 15 of the
|
2004-04-18 11:03:51 +00:00
|
|
|
// uScanCode parameter may be used to distinguish between a key
|
1999-12-01 22:10:13 +00:00
|
|
|
// press and a key release. The scan code is used for
|
|
|
|
// translating ALT+number key combinations.
|
|
|
|
|
2002-02-02 05:26:36 +00:00
|
|
|
// ignore [shift+]alt+space so the OS can handle it
|
|
|
|
if (mIsAltDown && !mIsControlDown && IS_VK_DOWN(NS_VK_SPACE)) {
|
|
|
|
result = PR_FALSE;
|
2002-09-28 15:04:47 +00:00
|
|
|
DispatchPendingEvents();
|
2002-02-02 05:26:36 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
if (!mIMEIsComposing)
|
2002-02-02 00:21:53 +00:00
|
|
|
result = OnKeyUp(wParam, (HIWORD(lParam)), lParam);
|
2004-04-18 11:03:51 +00:00
|
|
|
else
|
|
|
|
result = PR_FALSE;
|
2002-09-28 15:04:47 +00:00
|
|
|
|
|
|
|
DispatchPendingEvents();
|
1999-04-06 20:23:55 +00:00
|
|
|
break;
|
|
|
|
|
1999-07-19 08:08:57 +00:00
|
|
|
// Let ths fall through if it isn't a key pad
|
|
|
|
case WM_SYSKEYDOWN:
|
2004-04-18 11:03:51 +00:00
|
|
|
case WM_KEYDOWN:
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
#ifdef KE_DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("%s\t\twp=%4x\tlp=%8x\n",
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
(WM_KEYDOWN==msg)?"WM_KEYDOWN":"WM_SYSKEYDOWN" , wParam, lParam);
|
|
|
|
#endif
|
2002-02-16 01:44:54 +00:00
|
|
|
|
1999-04-23 14:30:51 +00:00
|
|
|
mIsShiftDown = IS_VK_DOWN(NS_VK_SHIFT);
|
2004-04-18 11:03:51 +00:00
|
|
|
mIsControlDown = IS_VK_DOWN(NS_VK_CONTROL);
|
|
|
|
mIsAltDown = IS_VK_DOWN(NS_VK_ALT);
|
|
|
|
|
|
|
|
// Note: the original code passed (HIWORD(lParam)) to OnKeyDown as
|
|
|
|
// scan code. However, this breaks Alt+Num pad input.
|
1999-12-01 22:10:13 +00:00
|
|
|
// http://msdn.microsoft.com/library/psdk/winui/keybinpt_8qp5.htm
|
2004-04-18 11:03:51 +00:00
|
|
|
// states the following:
|
|
|
|
// Typically, ToAscii performs the translation based on the
|
1999-12-01 22:10:13 +00:00
|
|
|
// virtual-key code. In some cases, however, bit 15 of the
|
2004-04-18 11:03:51 +00:00
|
|
|
// uScanCode parameter may be used to distinguish between a key
|
1999-12-01 22:10:13 +00:00
|
|
|
// press and a key release. The scan code is used for
|
|
|
|
// translating ALT+number key combinations.
|
|
|
|
|
2002-02-02 05:26:36 +00:00
|
|
|
// ignore [shift+]alt+space so the OS can handle it
|
|
|
|
if (mIsAltDown && !mIsControlDown && IS_VK_DOWN(NS_VK_SPACE)) {
|
2004-04-18 11:03:51 +00:00
|
|
|
result = PR_FALSE;
|
|
|
|
DispatchPendingEvents();
|
|
|
|
break;
|
2002-02-02 05:26:36 +00:00
|
|
|
}
|
|
|
|
|
2000-10-11 21:50:50 +00:00
|
|
|
if (mIsAltDown && mIMEIsStatusChanged) {
|
2004-04-18 11:03:51 +00:00
|
|
|
mIMEIsStatusChanged = FALSE;
|
|
|
|
result = PR_FALSE;
|
2000-10-11 21:50:50 +00:00
|
|
|
}
|
2004-04-18 11:03:51 +00:00
|
|
|
else if (!mIMEIsComposing) {
|
|
|
|
result = OnKeyDown(wParam, (HIWORD(lParam)), lParam);
|
1999-04-06 20:23:55 +00:00
|
|
|
}
|
2004-04-18 11:03:51 +00:00
|
|
|
else
|
|
|
|
result = PR_FALSE;
|
2000-02-11 23:35:14 +00:00
|
|
|
|
2001-03-29 03:33:09 +00:00
|
|
|
if (wParam == VK_MENU || (wParam == VK_F10 && !mIsShiftDown)) {
|
2002-10-01 04:38:28 +00:00
|
|
|
// We need to let Windows handle this keypress,
|
|
|
|
// by returning PR_FALSE, if there's a native menu
|
|
|
|
// bar somewhere in our containing window hierarchy.
|
|
|
|
// Otherwise we handle the keypress and don't pass
|
|
|
|
// it on to Windows, by returning PR_TRUE.
|
|
|
|
PRBool hasNativeMenu = PR_FALSE;
|
|
|
|
HWND hWnd = mWnd;
|
|
|
|
while (hWnd) {
|
|
|
|
if (::GetMenu(hWnd)) {
|
|
|
|
hasNativeMenu = PR_TRUE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
hWnd = ::GetParent(hWnd);
|
|
|
|
}
|
|
|
|
result = !hasNativeMenu;
|
2000-02-11 23:35:14 +00:00
|
|
|
}
|
2002-09-28 15:04:47 +00:00
|
|
|
DispatchPendingEvents();
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
1998-04-28 19:24:52 +00:00
|
|
|
// say we've dealt with erase background if widget does
|
|
|
|
// not need auto-erasing
|
1998-04-29 19:59:06 +00:00
|
|
|
case WM_ERASEBKGND:
|
1998-05-05 19:58:27 +00:00
|
|
|
if (! AutoErase()) {
|
1998-04-28 19:24:52 +00:00
|
|
|
*aRetValue = 1;
|
|
|
|
result = PR_TRUE;
|
1998-04-29 19:59:06 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
2001-09-27 11:10:17 +00:00
|
|
|
case WM_GETDLGCODE:
|
|
|
|
*aRetValue = DLGC_WANTALLKEYS;
|
|
|
|
result = PR_TRUE;
|
|
|
|
break;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
case WM_MOUSEMOVE:
|
2002-09-20 01:24:36 +00:00
|
|
|
//RelayMouseEvent(msg,wParam, lParam);
|
|
|
|
|
2002-09-28 15:04:47 +00:00
|
|
|
// Suppress dispatch of pending events
|
|
|
|
// when mouse moves are generated by widget
|
2002-09-20 01:24:36 +00:00
|
|
|
// creation instead of user input.
|
|
|
|
{
|
|
|
|
POINT mp;
|
|
|
|
DWORD pos = ::GetMessagePos();
|
|
|
|
mp.x = (short)LOWORD(pos);
|
|
|
|
mp.y = (short)HIWORD(pos);
|
2002-09-28 15:04:47 +00:00
|
|
|
PRBool userMovedMouse = PR_FALSE;
|
2002-09-20 01:24:36 +00:00
|
|
|
if ((gLastMouseMovePoint.x != mp.x) ||
|
|
|
|
(gLastMouseMovePoint.y != mp.y)) {
|
2002-09-28 15:04:47 +00:00
|
|
|
userMovedMouse = PR_TRUE;
|
2002-09-20 01:24:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
result = DispatchMouseEvent(NS_MOUSE_MOVE, wParam);
|
2002-09-28 15:04:47 +00:00
|
|
|
if (userMovedMouse) {
|
|
|
|
DispatchPendingEvents();
|
|
|
|
}
|
2002-09-20 01:24:36 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_LBUTTONDOWN:
|
1999-05-04 22:38:45 +00:00
|
|
|
//SetFocus(); // this is bad
|
1998-05-04 19:25:25 +00:00
|
|
|
//RelayMouseEvent(msg,wParam, lParam);
|
1999-12-01 22:10:13 +00:00
|
|
|
{
|
2000-08-04 21:43:29 +00:00
|
|
|
// check whether IME window do mouse operation
|
2002-10-01 02:47:41 +00:00
|
|
|
if (IMEMouseHandling(NS_MOUSE_LEFT_BUTTON_DOWN, IMEMOUSE_LDOWN, lParam))
|
|
|
|
break;
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_LEFT_BUTTON_DOWN, wParam);
|
2002-09-28 15:04:47 +00:00
|
|
|
DispatchPendingEvents();
|
1999-12-01 22:10:13 +00:00
|
|
|
} break;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
case WM_LBUTTONUP:
|
1998-05-04 19:25:25 +00:00
|
|
|
//RelayMouseEvent(msg,wParam, lParam);
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_LEFT_BUTTON_UP, wParam);
|
2002-09-28 15:04:47 +00:00
|
|
|
DispatchPendingEvents();
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
2001-03-29 03:33:09 +00:00
|
|
|
case WM_CONTEXTMENU:
|
2001-05-17 18:37:50 +00:00
|
|
|
{
|
|
|
|
// if the context menu is brought up from the keyboard, |lParam|
|
|
|
|
// will be maxlong. Send a different event msg instead.
|
|
|
|
PRUint32 msg = (lParam == 0xFFFFFFFF) ? NS_CONTEXTMENU_KEY : NS_CONTEXTMENU;
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(msg, wParam);
|
2001-05-17 18:37:50 +00:00
|
|
|
}
|
2001-03-29 03:33:09 +00:00
|
|
|
break;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
case WM_LBUTTONDBLCLK:
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_LEFT_DOUBLECLICK, wParam);
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_MBUTTONDOWN:
|
1999-12-01 22:10:13 +00:00
|
|
|
{
|
2000-08-04 21:43:29 +00:00
|
|
|
// check whether IME window do mouse operation
|
2002-10-01 02:47:41 +00:00
|
|
|
if (IMEMouseHandling(NS_MOUSE_MIDDLE_BUTTON_DOWN, IMEMOUSE_MDOWN, lParam))
|
|
|
|
break;
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_MIDDLE_BUTTON_DOWN, wParam);
|
2002-09-28 15:04:47 +00:00
|
|
|
DispatchPendingEvents();
|
1999-12-01 22:10:13 +00:00
|
|
|
} break;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
case WM_MBUTTONUP:
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_MIDDLE_BUTTON_UP, wParam);
|
2002-09-28 15:04:47 +00:00
|
|
|
DispatchPendingEvents();
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_MBUTTONDBLCLK:
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_MIDDLE_BUTTON_DOWN, wParam);
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_RBUTTONDOWN:
|
1999-12-01 22:10:13 +00:00
|
|
|
{
|
2000-08-04 21:43:29 +00:00
|
|
|
// check whether IME window do mouse operation
|
2002-10-01 02:47:41 +00:00
|
|
|
if (IMEMouseHandling(NS_MOUSE_RIGHT_BUTTON_DOWN, IMEMOUSE_RDOWN, lParam))
|
|
|
|
break;
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_RIGHT_BUTTON_DOWN, wParam);
|
2002-09-28 15:04:47 +00:00
|
|
|
DispatchPendingEvents();
|
1999-12-01 22:10:13 +00:00
|
|
|
} break;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
case WM_RBUTTONUP:
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_RIGHT_BUTTON_UP, wParam);
|
2002-09-28 15:04:47 +00:00
|
|
|
DispatchPendingEvents();
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case WM_RBUTTONDBLCLK:
|
2002-02-05 06:13:44 +00:00
|
|
|
result = DispatchMouseEvent(NS_MOUSE_RIGHT_DOUBLECLICK, wParam);
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
|
2002-12-06 03:41:43 +00:00
|
|
|
case WM_APPCOMMAND:
|
|
|
|
{
|
|
|
|
PRUint32 appCommand = GET_APPCOMMAND_LPARAM(lParam);
|
|
|
|
|
|
|
|
switch (appCommand)
|
|
|
|
{
|
|
|
|
case APPCOMMAND_BROWSER_BACKWARD:
|
|
|
|
case APPCOMMAND_BROWSER_FORWARD:
|
|
|
|
case APPCOMMAND_BROWSER_REFRESH:
|
|
|
|
case APPCOMMAND_BROWSER_STOP:
|
|
|
|
DispatchAppCommandEvent(appCommand);
|
|
|
|
// tell the driver that we handled the event
|
2003-01-13 04:10:57 +00:00
|
|
|
*aRetValue = 1;
|
2002-12-06 03:41:43 +00:00
|
|
|
result = PR_TRUE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
// default = PR_FALSE - tell the driver that the event was not handled
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
case WM_HSCROLL:
|
1999-03-05 15:34:53 +00:00
|
|
|
case WM_VSCROLL:
|
1998-04-13 20:24:54 +00:00
|
|
|
// check for the incoming nsWindow handle to be null in which case
|
|
|
|
// we assume the message is coming from a horizontal scrollbar inside
|
|
|
|
// a listbox and we don't bother processing it (well, we don't have to)
|
|
|
|
if (lParam) {
|
2000-04-27 00:23:18 +00:00
|
|
|
nsWindow* scrollbar = GetNSWindowPtr((HWND)lParam);
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
if (scrollbar) {
|
|
|
|
result = scrollbar->OnScroll(LOWORD(wParam), (short)HIWORD(wParam));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
1998-08-03 22:28:00 +00:00
|
|
|
case WM_CTLCOLORLISTBOX:
|
1998-04-13 20:24:54 +00:00
|
|
|
case WM_CTLCOLOREDIT:
|
1998-07-21 18:04:18 +00:00
|
|
|
case WM_CTLCOLORBTN:
|
1999-01-20 15:42:51 +00:00
|
|
|
//case WM_CTLCOLORSCROLLBAR: //XXX causes a the scrollbar to be drawn incorrectly
|
1998-04-13 20:24:54 +00:00
|
|
|
case WM_CTLCOLORSTATIC:
|
|
|
|
if (lParam) {
|
2000-04-27 00:23:18 +00:00
|
|
|
nsWindow* control = GetNSWindowPtr((HWND)lParam);
|
1998-04-13 20:24:54 +00:00
|
|
|
if (control) {
|
1998-08-03 22:28:00 +00:00
|
|
|
control->SetUpForPaint((HDC)wParam);
|
1998-04-13 20:24:54 +00:00
|
|
|
*aRetValue = (LPARAM)control->OnControlColor();
|
1998-08-03 22:28:00 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
result = PR_TRUE;
|
|
|
|
break;
|
|
|
|
|
2000-04-01 22:16:43 +00:00
|
|
|
case WM_ACTIVATE:
|
|
|
|
if (mEventCallback) {
|
|
|
|
PRInt32 fActive = LOWORD(wParam);
|
|
|
|
|
|
|
|
if(WA_INACTIVE == fActive) {
|
|
|
|
gJustGotDeactivate = PR_TRUE;
|
|
|
|
} else {
|
|
|
|
gJustGotActivate = PR_TRUE;
|
2004-01-12 08:25:18 +00:00
|
|
|
nsMouseEvent event(NS_MOUSE_ACTIVATE, this);
|
|
|
|
InitEvent(event);
|
2000-04-01 22:16:43 +00:00
|
|
|
|
|
|
|
event.acceptActivation = PR_TRUE;
|
|
|
|
|
|
|
|
PRBool result = DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
|
|
|
|
if(event.acceptActivation)
|
|
|
|
*aRetValue = MA_ACTIVATE;
|
|
|
|
else
|
|
|
|
*aRetValue = MA_NOACTIVATE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2000-08-24 04:53:31 +00:00
|
|
|
case WM_MOUSEACTIVATE:
|
|
|
|
{
|
|
|
|
// This seems to be the only way we're
|
|
|
|
// notified when a child window that doesn't have this handler proc
|
|
|
|
// (read as: windows created by plugins like Adobe Acrobat)
|
|
|
|
// has been activated via clicking.
|
2001-05-18 12:07:42 +00:00
|
|
|
DispatchFocus(NS_PLUGIN_ACTIVATE, isMozWindowTakingFocus);
|
2000-08-24 04:53:31 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2000-04-01 22:16:43 +00:00
|
|
|
case WM_WINDOWPOSCHANGING: {
|
|
|
|
LPWINDOWPOS info = (LPWINDOWPOS) lParam;
|
2003-07-25 14:54:39 +00:00
|
|
|
// enforce local z-order rules
|
2000-04-01 22:16:43 +00:00
|
|
|
if (!(info->flags & SWP_NOZORDER))
|
|
|
|
ConstrainZLevel(&info->hwndInsertAfter);
|
2003-07-25 14:54:39 +00:00
|
|
|
// prevent rude external programs from making hidden window visible
|
|
|
|
if (mWindowType == eWindowType_invisible)
|
|
|
|
info->flags &= ~SWP_SHOWWINDOW;
|
2000-04-01 22:16:43 +00:00
|
|
|
break;
|
|
|
|
}
|
1999-11-13 05:16:33 +00:00
|
|
|
|
2000-02-11 23:35:14 +00:00
|
|
|
case WM_SETFOCUS:
|
2001-05-18 12:07:42 +00:00
|
|
|
result = DispatchFocus(NS_GOTFOCUS, isMozWindowTakingFocus);
|
2000-04-01 22:16:43 +00:00
|
|
|
if(gJustGotActivate) {
|
2000-02-11 23:35:14 +00:00
|
|
|
gJustGotActivate = PR_FALSE;
|
2002-06-20 04:55:13 +00:00
|
|
|
gJustGotDeactivate = PR_FALSE;
|
2001-05-18 12:07:42 +00:00
|
|
|
result = DispatchFocus(NS_ACTIVATE, isMozWindowTakingFocus);
|
2000-04-01 22:16:43 +00:00
|
|
|
}
|
2001-09-25 08:34:42 +00:00
|
|
|
#ifdef ACCESSIBILITY
|
2003-04-15 08:45:55 +00:00
|
|
|
if (nsWindow::gIsAccessibilityOn && !mRootAccessible &&
|
|
|
|
mIsTopWidgetWindow)
|
2001-09-25 08:34:42 +00:00
|
|
|
CreateRootAccessible();
|
|
|
|
#endif
|
2000-02-11 23:35:14 +00:00
|
|
|
break;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2000-02-11 23:35:14 +00:00
|
|
|
case WM_KILLFOCUS:
|
2002-07-03 00:55:47 +00:00
|
|
|
WCHAR className[19];
|
2002-09-09 23:58:39 +00:00
|
|
|
nsToolkit::mGetClassName((HWND)wParam, className, 19);
|
2002-07-03 00:55:47 +00:00
|
|
|
if(wcscmp(className, WindowClassW()))
|
|
|
|
isMozWindowTakingFocus = PR_FALSE;
|
2000-04-01 22:16:43 +00:00
|
|
|
if(gJustGotDeactivate) {
|
2000-02-11 23:35:14 +00:00
|
|
|
gJustGotDeactivate = PR_FALSE;
|
2001-05-18 12:07:42 +00:00
|
|
|
result = DispatchFocus(NS_DEACTIVATE, isMozWindowTakingFocus);
|
2000-04-01 22:16:43 +00:00
|
|
|
}
|
2001-06-14 03:46:35 +00:00
|
|
|
result = DispatchFocus(NS_LOSTFOCUS, isMozWindowTakingFocus);
|
2000-02-11 23:35:14 +00:00
|
|
|
break;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2000-02-11 23:35:14 +00:00
|
|
|
case WM_WINDOWPOSCHANGED:
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
|
|
|
WINDOWPOS *wp = (LPWINDOWPOS)lParam;
|
1998-06-02 02:33:29 +00:00
|
|
|
|
|
|
|
// We only care about a resize, so filter out things like z-order
|
|
|
|
// changes. Note: there's a WM_MOVE handler above which is why we're
|
|
|
|
// not handling them here...
|
|
|
|
if (0 == (wp->flags & SWP_NOSIZE)) {
|
|
|
|
// XXX Why are we using the client size area? If the size notification
|
|
|
|
// is for the client area then the origin should be (0,0) and not
|
|
|
|
// the window origin in screen coordinates...
|
|
|
|
RECT r;
|
1998-11-04 21:43:47 +00:00
|
|
|
::GetWindowRect(mWnd, &r);
|
1998-06-19 02:46:25 +00:00
|
|
|
PRInt32 newWidth, newHeight;
|
|
|
|
newWidth = PRInt32(r.right - r.left);
|
|
|
|
newHeight = PRInt32(r.bottom - r.top);
|
|
|
|
nsRect rect(wp->x, wp->y, newWidth, newHeight);
|
2000-05-11 22:59:20 +00:00
|
|
|
if (newWidth != mLastSize.width)
|
1998-06-19 02:46:25 +00:00
|
|
|
{
|
|
|
|
RECT drect;
|
|
|
|
|
|
|
|
//getting wider
|
|
|
|
|
2000-05-11 22:59:20 +00:00
|
|
|
drect.left = wp->x + mLastSize.width;
|
|
|
|
drect.top = wp->y;
|
|
|
|
drect.right = drect.left + (newWidth - mLastSize.width);
|
1998-06-19 02:46:25 +00:00
|
|
|
drect.bottom = drect.top + newHeight;
|
|
|
|
|
|
|
|
::RedrawWindow(mWnd, &drect, NULL,
|
|
|
|
RDW_INVALIDATE | RDW_NOERASE | RDW_NOINTERNALPAINT | RDW_ERASENOW | RDW_ALLCHILDREN);
|
|
|
|
}
|
2000-05-11 22:59:20 +00:00
|
|
|
if (newHeight != mLastSize.height)
|
1998-06-19 02:46:25 +00:00
|
|
|
{
|
|
|
|
RECT drect;
|
|
|
|
|
|
|
|
//getting taller
|
|
|
|
|
|
|
|
drect.left = wp->x;
|
2000-05-11 22:59:20 +00:00
|
|
|
drect.top = wp->y + mLastSize.height;
|
1998-06-19 02:46:25 +00:00
|
|
|
drect.right = drect.left + newWidth;
|
2000-05-11 22:59:20 +00:00
|
|
|
drect.bottom = drect.top + (newHeight - mLastSize.height);
|
1998-06-19 02:46:25 +00:00
|
|
|
|
|
|
|
::RedrawWindow(mWnd, &drect, NULL,
|
|
|
|
RDW_INVALIDATE | RDW_NOERASE | RDW_NOINTERNALPAINT | RDW_ERASENOW | RDW_ALLCHILDREN);
|
|
|
|
}
|
1998-11-24 14:57:09 +00:00
|
|
|
mBounds.width = newWidth;
|
|
|
|
mBounds.height = newHeight;
|
2000-05-11 22:59:20 +00:00
|
|
|
mLastSize.width = newWidth;
|
|
|
|
mLastSize.height = newHeight;
|
1998-06-02 02:33:29 +00:00
|
|
|
///nsRect rect(wp->x, wp->y, wp->cx, wp->cy);
|
1998-11-04 21:43:47 +00:00
|
|
|
|
2000-10-27 02:41:08 +00:00
|
|
|
// If we're being minimized, don't send the resize event to Gecko because
|
|
|
|
// it will cause the scrollbar in the content area to go away and we'll
|
|
|
|
// forget the scroll position of the page.
|
|
|
|
if ( !newWidth && !newHeight ) {
|
|
|
|
result = PR_FALSE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
1998-11-04 21:43:47 +00:00
|
|
|
// recalculate the width and height
|
|
|
|
// this time based on the client area
|
|
|
|
if (::GetClientRect(mWnd, &r)) {
|
|
|
|
rect.width = PRInt32(r.right - r.left);
|
|
|
|
rect.height = PRInt32(r.bottom - r.top);
|
|
|
|
}
|
1998-06-02 02:33:29 +00:00
|
|
|
result = OnResize(rect);
|
|
|
|
}
|
2000-12-19 03:01:31 +00:00
|
|
|
|
|
|
|
/* handle size mode changes
|
|
|
|
(the framechanged message seems a handy place to hook in,
|
|
|
|
because it happens early enough (WM_SIZE is too late) and
|
|
|
|
because in testing it seems an accurate harbinger of
|
|
|
|
an impending min/max/restore change (WM_NCCALCSIZE would
|
|
|
|
also work, but it's also sent when merely resizing.)) */
|
2002-07-03 04:03:20 +00:00
|
|
|
if (wp->flags & SWP_FRAMECHANGED && ::IsWindowVisible(mWnd)) {
|
2000-12-19 03:01:31 +00:00
|
|
|
WINDOWPLACEMENT pl;
|
|
|
|
pl.length = sizeof(pl);
|
|
|
|
::GetWindowPlacement(mWnd, &pl);
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
nsSizeModeEvent event(NS_SIZEMODE, this);
|
2000-12-19 03:01:31 +00:00
|
|
|
if (pl.showCmd == SW_SHOWMAXIMIZED)
|
|
|
|
event.mSizeMode = nsSizeMode_Maximized;
|
|
|
|
else if (pl.showCmd == SW_SHOWMINIMIZED)
|
|
|
|
event.mSizeMode = nsSizeMode_Minimized;
|
|
|
|
else
|
|
|
|
event.mSizeMode = nsSizeMode_Normal;
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event);
|
2000-12-19 03:01:31 +00:00
|
|
|
|
|
|
|
result = DispatchWindowEvent(&event);
|
2002-06-20 04:55:13 +00:00
|
|
|
|
|
|
|
if (pl.showCmd == SW_SHOWMINIMIZED) {
|
|
|
|
// Deactivate
|
2002-07-03 00:55:47 +00:00
|
|
|
WCHAR className[19];
|
2002-09-09 23:58:39 +00:00
|
|
|
nsToolkit::mGetClassName((HWND)wParam, className, 19);
|
2002-07-03 00:55:47 +00:00
|
|
|
if(wcscmp(className, WindowClassW()))
|
|
|
|
isMozWindowTakingFocus = PR_FALSE;
|
2002-06-20 04:55:13 +00:00
|
|
|
gJustGotDeactivate = PR_FALSE;
|
|
|
|
result = DispatchFocus(NS_DEACTIVATE, isMozWindowTakingFocus);
|
|
|
|
} else if (pl.showCmd == SW_SHOWNORMAL){
|
|
|
|
// Make sure we're active
|
|
|
|
result = DispatchFocus(NS_GOTFOCUS, PR_TRUE);
|
|
|
|
result = DispatchFocus(NS_ACTIVATE, PR_TRUE);
|
|
|
|
}
|
|
|
|
|
2000-12-19 03:01:31 +00:00
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
break;
|
|
|
|
}
|
1999-03-05 15:34:53 +00:00
|
|
|
|
|
|
|
case WM_SETTINGCHANGE:
|
2000-11-02 05:15:34 +00:00
|
|
|
getWheelInfo = PR_TRUE;
|
1999-11-29 21:14:43 +00:00
|
|
|
break;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-08-19 00:57:02 +00:00
|
|
|
case WM_PALETTECHANGED:
|
|
|
|
if ((HWND)wParam == mWnd) {
|
|
|
|
// We caused the WM_PALETTECHANGED message so avoid realizing
|
|
|
|
// another foreground palette
|
|
|
|
result = PR_TRUE;
|
|
|
|
break;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
1998-08-19 00:57:02 +00:00
|
|
|
// fall thru...
|
|
|
|
|
2000-02-11 14:35:01 +00:00
|
|
|
case WM_QUERYNEWPALETTE: // this window is about to become active
|
1998-08-19 00:57:02 +00:00
|
|
|
mContext->GetPaletteInfo(palInfo);
|
|
|
|
if (palInfo.isPaletteDevice && palInfo.palette) {
|
1998-04-13 20:24:54 +00:00
|
|
|
HDC hDC = ::GetDC(mWnd);
|
2002-04-16 20:54:23 +00:00
|
|
|
HPALETTE hOldPal = ::SelectPalette(hDC, (HPALETTE)palInfo.palette, TRUE);
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-08-19 00:57:02 +00:00
|
|
|
// Realize the drawing palette
|
1998-04-13 20:24:54 +00:00
|
|
|
int i = ::RealizePalette(hDC);
|
|
|
|
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
//printf("number of colors that changed=%d\n",i);
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
2000-02-11 14:35:01 +00:00
|
|
|
// we should always invalidate.. because the lookup may have changed
|
|
|
|
::InvalidateRect(mWnd, (LPRECT)NULL, TRUE);
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
::ReleaseDC(mWnd, hDC);
|
1998-08-19 02:31:08 +00:00
|
|
|
*aRetValue = TRUE;
|
1998-08-19 00:57:02 +00:00
|
|
|
}
|
|
|
|
result = PR_TRUE;
|
|
|
|
break;
|
1999-03-09 23:48:58 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_INPUTLANGCHANGEREQUEST:
|
|
|
|
*aRetValue = TRUE;
|
|
|
|
result = PR_FALSE;
|
|
|
|
break;
|
1999-08-24 21:46:43 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_INPUTLANGCHANGE:
|
1999-12-01 22:10:13 +00:00
|
|
|
result = OnInputLangChange((HKL)lParam,
|
1999-11-11 22:28:52 +00:00
|
|
|
aRetValue);
|
|
|
|
break;
|
1999-08-24 21:46:43 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_IME_STARTCOMPOSITION:
|
|
|
|
result = OnIMEStartComposition();
|
|
|
|
break;
|
1999-10-27 00:14:46 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_IME_COMPOSITION:
|
|
|
|
result = OnIMEComposition(lParam);
|
|
|
|
break;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_IME_ENDCOMPOSITION:
|
|
|
|
result = OnIMEEndComposition();
|
|
|
|
break;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_IME_CHAR:
|
2002-06-11 22:59:54 +00:00
|
|
|
// We receive double byte char code. No need to worry about the <Shift>
|
|
|
|
mIsShiftDown = PR_FALSE;
|
1999-11-11 22:28:52 +00:00
|
|
|
result = OnIMEChar((BYTE)(wParam>>8),
|
|
|
|
(BYTE) (wParam & 0x00FF),
|
|
|
|
lParam);
|
|
|
|
break;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_IME_NOTIFY:
|
|
|
|
result = OnIMENotify(wParam, lParam, aRetValue);
|
|
|
|
break;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
// This is a Window 98/2000 only message
|
|
|
|
case WM_IME_REQUEST:
|
|
|
|
result = OnIMERequest(wParam, lParam, aRetValue);
|
|
|
|
break;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_IME_SELECT:
|
|
|
|
result = OnIMESelect(wParam, (WORD)(lParam & 0x0FFFF));
|
|
|
|
break;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
case WM_IME_SETCONTEXT:
|
|
|
|
result = OnIMESetContext(wParam, lParam);
|
|
|
|
break;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-03-09 23:48:58 +00:00
|
|
|
case WM_DROPFILES: {
|
2001-06-20 05:48:45 +00:00
|
|
|
#if 0
|
|
|
|
HDROP hDropInfo = (HDROP) wParam;
|
1999-03-09 23:48:58 +00:00
|
|
|
UINT nFiles = ::DragQueryFile(hDropInfo, (UINT)-1, NULL, 0);
|
|
|
|
|
|
|
|
for (UINT iFile = 0; iFile < nFiles; iFile++) {
|
|
|
|
TCHAR szFileName[_MAX_PATH];
|
|
|
|
::DragQueryFile(hDropInfo, iFile, szFileName, _MAX_PATH);
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("szFileName [%s]\n", szFileName);
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
1999-03-09 23:48:58 +00:00
|
|
|
nsAutoString fileStr(szFileName);
|
|
|
|
nsEventStatus status;
|
2004-01-12 08:25:18 +00:00
|
|
|
nsDragDropEvent event(NS_DRAGDROP_EVENT, this);
|
|
|
|
InitEvent(event);
|
1999-03-09 23:48:58 +00:00
|
|
|
event.mType = nsDragDropEventStatus_eDrop;
|
|
|
|
event.mIsFileURL = PR_FALSE;
|
2004-02-28 22:34:07 +00:00
|
|
|
event.mURL = fileStr.get();
|
1999-03-09 23:48:58 +00:00
|
|
|
DispatchEvent(&event, status);
|
2002-02-27 01:30:40 +00:00
|
|
|
NS_RELEASE(event.widget);
|
2001-06-20 05:48:45 +00:00
|
|
|
}
|
|
|
|
#endif
|
1999-03-09 23:48:58 +00:00
|
|
|
} break;
|
1999-03-23 21:26:20 +00:00
|
|
|
|
|
|
|
case WM_DESTROYCLIPBOARD: {
|
|
|
|
nsIClipboard* clipboard;
|
|
|
|
nsresult rv = nsServiceManager::GetService(kCClipboardCID,
|
2000-02-04 00:39:15 +00:00
|
|
|
NS_GET_IID(nsIClipboard),
|
1999-03-23 21:26:20 +00:00
|
|
|
(nsISupports **)&clipboard);
|
2000-04-14 02:52:58 +00:00
|
|
|
clipboard->EmptyClipboard(nsIClipboard::kGlobalClipboard);
|
1999-04-23 14:30:51 +00:00
|
|
|
nsServiceManager::ReleaseService(kCClipboardCID, clipboard);
|
1999-03-23 21:26:20 +00:00
|
|
|
} break;
|
|
|
|
|
2001-08-17 03:13:07 +00:00
|
|
|
#ifdef ACCESSIBILITY
|
2001-04-01 01:38:35 +00:00
|
|
|
case WM_GETOBJECT:
|
|
|
|
{
|
2001-09-25 08:34:42 +00:00
|
|
|
nsWindow::gIsAccessibilityOn = TRUE;
|
|
|
|
LRESULT lAcc = 0;
|
|
|
|
if (mIsTopWidgetWindow && !mRootAccessible)
|
|
|
|
CreateRootAccessible();
|
2002-06-25 22:54:23 +00:00
|
|
|
if (mRootAccessible) {
|
2003-04-01 20:02:51 +00:00
|
|
|
IAccessible *msaaAccessible = NULL;
|
2003-02-13 22:56:18 +00:00
|
|
|
if (lParam == OBJID_CLIENT) { // oleacc.dll will be loaded dynamically
|
2003-04-01 20:02:51 +00:00
|
|
|
mRootAccessible->GetNativeInterface((void**)&msaaAccessible); // does an addref
|
2003-02-13 22:56:18 +00:00
|
|
|
}
|
2003-04-01 20:02:51 +00:00
|
|
|
else if (lParam == OBJID_CARET) { // each root accessible owns a caret accessible
|
|
|
|
nsCOMPtr<nsIAccessibleDocument> accDoc(do_QueryInterface(mRootAccessible));
|
|
|
|
if (accDoc) {
|
2003-07-22 14:55:22 +00:00
|
|
|
nsCOMPtr<nsIAccessible> accessibleCaret;
|
2003-04-01 20:02:51 +00:00
|
|
|
accDoc->GetCaretAccessible(getter_AddRefs(accessibleCaret));
|
2003-07-22 14:55:22 +00:00
|
|
|
if (accessibleCaret) {
|
|
|
|
accessibleCaret->GetNativeInterface((void**)&msaaAccessible);
|
2002-06-25 22:54:23 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2003-04-01 20:02:51 +00:00
|
|
|
if (msaaAccessible) {
|
|
|
|
lAcc = LresultFromObject(IID_IAccessible, wParam, msaaAccessible); // does an addref
|
|
|
|
msaaAccessible->Release(); // release extra addref
|
|
|
|
}
|
2002-06-25 22:54:23 +00:00
|
|
|
}
|
2001-09-25 08:34:42 +00:00
|
|
|
return (*aRetValue = lAcc) != 0;
|
|
|
|
}
|
2001-08-17 03:13:07 +00:00
|
|
|
#endif
|
2002-02-16 01:44:54 +00:00
|
|
|
|
2004-04-01 22:51:46 +00:00
|
|
|
case WM_SYSCOMMAND:
|
|
|
|
// prevent Windows from trimming the working set. bug 76831
|
|
|
|
if (!gTrimOnMinimize && wParam == SC_MINIMIZE) {
|
|
|
|
::ShowWindow(mWnd, SW_SHOWMINIMIZED);
|
|
|
|
result = PR_TRUE;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2000-03-18 00:57:23 +00:00
|
|
|
default: {
|
|
|
|
// Handle both flavors of mouse wheel events.
|
2000-11-02 05:15:34 +00:00
|
|
|
if ((msg == WM_MOUSEWHEEL) || (msg == uMSH_MOUSEWHEEL)) {
|
|
|
|
static int iDeltaPerLine;
|
|
|
|
static ULONG ulScrollLines;
|
|
|
|
|
|
|
|
// Get mouse wheel metrics (but only once).
|
|
|
|
if (getWheelInfo) {
|
|
|
|
getWheelInfo = PR_FALSE;
|
|
|
|
|
|
|
|
// This needs to be done differently for Win95 than Win98/NT
|
|
|
|
// Taken from sample code in MS Intellimouse SDK
|
|
|
|
// http://www.microsoft.com/Mouse/intellimouse/sdk/sdkmessaging.htm
|
|
|
|
|
|
|
|
OSVERSIONINFO osversion;
|
|
|
|
memset(&osversion, 0, sizeof(OSVERSIONINFO));
|
|
|
|
osversion.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
|
|
|
|
GetVersionEx(&osversion);
|
|
|
|
|
|
|
|
if ((osversion.dwPlatformId == VER_PLATFORM_WIN32_WINDOWS) &&
|
|
|
|
(osversion.dwMajorVersion == 4) &&
|
|
|
|
(osversion.dwMinorVersion == 0))
|
|
|
|
{
|
2003-03-14 23:35:18 +00:00
|
|
|
#ifndef __MINGW32__
|
2000-11-02 05:15:34 +00:00
|
|
|
// This is the Windows 95 case
|
|
|
|
HWND hdlMsWheel = FindWindow(MSH_WHEELMODULE_CLASS,
|
|
|
|
MSH_WHEELMODULE_TITLE);
|
|
|
|
if (hdlMsWheel) {
|
|
|
|
UINT uiMsh_MsgScrollLines = RegisterWindowMessage(MSH_SCROLL_LINES);
|
|
|
|
if (uiMsh_MsgScrollLines) {
|
|
|
|
ulScrollLines = (int) SendMessage(hdlMsWheel,
|
|
|
|
uiMsh_MsgScrollLines, 0,
|
|
|
|
0);
|
|
|
|
}
|
2000-04-12 01:43:39 +00:00
|
|
|
}
|
2003-03-14 23:35:18 +00:00
|
|
|
#endif
|
2000-11-02 05:15:34 +00:00
|
|
|
}
|
|
|
|
else if (osversion.dwMajorVersion >= 4) {
|
|
|
|
// This is the Win98/NT4/Win2K case
|
|
|
|
SystemParametersInfo (SPI_GETWHEELSCROLLLINES, 0,
|
|
|
|
&ulScrollLines, 0);
|
2000-03-18 00:57:23 +00:00
|
|
|
}
|
|
|
|
|
2000-11-02 05:15:34 +00:00
|
|
|
// ulScrollLines usually equals 3 or 0 (for no scrolling)
|
|
|
|
// WHEEL_DELTA equals 120, so iDeltaPerLine will be 40.
|
|
|
|
|
|
|
|
// However, if ulScrollLines > WHEEL_DELTA, we assume that
|
|
|
|
// the mouse driver wants a page scroll. The docs state that
|
|
|
|
// ulScrollLines should explicitly equal WHEEL_PAGESCROLL, but
|
|
|
|
// since some mouse drivers use an arbitrary large number instead,
|
|
|
|
// we have to handle that as well.
|
|
|
|
|
|
|
|
iDeltaPerLine = 0;
|
|
|
|
if (ulScrollLines) {
|
|
|
|
if (ulScrollLines <= WHEEL_DELTA) {
|
|
|
|
iDeltaPerLine = WHEEL_DELTA / ulScrollLines;
|
|
|
|
} else {
|
|
|
|
ulScrollLines = WHEEL_PAGESCROLL;
|
|
|
|
}
|
2000-04-12 01:43:39 +00:00
|
|
|
}
|
2000-11-02 05:15:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ((ulScrollLines != WHEEL_PAGESCROLL) && (!iDeltaPerLine))
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
// The mousewheel event will be dispatched to the toplevel
|
|
|
|
// window. We need to give it to the child window
|
|
|
|
|
|
|
|
POINT point;
|
|
|
|
point.x = (short) LOWORD(lParam);
|
|
|
|
point.y = (short) HIWORD(lParam);
|
|
|
|
HWND destWnd = ::WindowFromPoint(point);
|
|
|
|
|
|
|
|
// Since we receive mousewheel events for as long as
|
|
|
|
// we are focused, it's entirely possible that there
|
|
|
|
// is another app's window or no window under the
|
|
|
|
// pointer.
|
|
|
|
|
|
|
|
if (!destWnd) {
|
|
|
|
// No window is under the pointer
|
|
|
|
break;
|
|
|
|
}
|
2002-04-29 14:50:58 +00:00
|
|
|
|
|
|
|
// We don't care about windows belonging to other processes.
|
|
|
|
DWORD processId = 0;
|
|
|
|
GetWindowThreadProcessId(destWnd, &processId);
|
|
|
|
if (processId != GetCurrentProcessId())
|
|
|
|
{
|
|
|
|
// Somebody elses window
|
|
|
|
break;
|
|
|
|
}
|
2000-11-02 05:15:34 +00:00
|
|
|
|
2002-10-16 23:28:18 +00:00
|
|
|
LONG proc = nsToolkit::mGetWindowLong(destWnd, GWL_WNDPROC);
|
2000-11-02 05:15:34 +00:00
|
|
|
if (proc != (LONG)&nsWindow::WindowProc) {
|
2001-09-29 00:05:58 +00:00
|
|
|
// Some other app, or a plugin window.
|
|
|
|
// Windows directs WM_MOUSEWHEEL to the focused window.
|
|
|
|
// However, Mozilla does not like plugins having focus, so a
|
|
|
|
// Mozilla window (ie, the plugin's parent (us!) has focus.)
|
|
|
|
// Therefore, plugins etc _should_ get first grab at the
|
|
|
|
// message, but this focus vaguary means the plugin misses
|
|
|
|
// out. If the window is a child of ours, forward it on.
|
|
|
|
// Determine if a child by walking the parent list until
|
|
|
|
// we find a parent matching our wndproc.
|
|
|
|
HWND parentWnd = ::GetParent(destWnd);
|
|
|
|
while (parentWnd) {
|
|
|
|
LONG parentWndProc = ::GetClassLong(parentWnd, GCL_WNDPROC);
|
|
|
|
if (parentWndProc == (LONG)&nsWindow::DefaultWindowProc || parentWndProc == (LONG)&nsWindow::WindowProc) {
|
|
|
|
// We have a child window - quite possibly a plugin window.
|
|
|
|
// However, not all plugins are created equal - some will handle this message themselves,
|
|
|
|
// some will forward directly back to us, while others will call DefWndProc, which
|
|
|
|
// itself still forwards back to us.
|
|
|
|
// So if we have sent it once, we need to handle it ourself.
|
|
|
|
if (mIsInMouseWheelProcessing) {
|
|
|
|
destWnd = parentWnd;
|
|
|
|
} else {
|
|
|
|
// First time we have seen this message.
|
|
|
|
// Call the child - either it will consume it, or
|
|
|
|
// it will wind it's way back to us, triggering the destWnd case above.
|
|
|
|
// either way, when the call returns, we are all done with the message,
|
|
|
|
mIsInMouseWheelProcessing = PR_TRUE;
|
|
|
|
if (0==SendMessage(destWnd, msg, wParam, lParam)) {
|
|
|
|
result = PR_TRUE; // consumed - don't call DefWndProc
|
|
|
|
}
|
|
|
|
destWnd = nsnull;
|
|
|
|
mIsInMouseWheelProcessing = PR_FALSE;
|
|
|
|
}
|
|
|
|
break; // stop parent search
|
|
|
|
}
|
|
|
|
parentWnd = ::GetParent(parentWnd);
|
|
|
|
} // while parentWnd
|
2000-11-02 05:15:34 +00:00
|
|
|
}
|
2001-09-29 00:05:58 +00:00
|
|
|
if (destWnd == nsnull)
|
|
|
|
break; // done with this message.
|
|
|
|
if (destWnd != mWnd) {
|
2000-11-02 05:15:34 +00:00
|
|
|
nsWindow* destWindow = GetNSWindowPtr(destWnd);
|
|
|
|
if (destWindow) {
|
|
|
|
return destWindow->ProcessMessage(msg, wParam, lParam,
|
|
|
|
aRetValue);
|
2000-03-18 00:57:23 +00:00
|
|
|
}
|
2000-11-02 05:15:34 +00:00
|
|
|
#ifdef DEBUG
|
|
|
|
else
|
|
|
|
printf("WARNING: couldn't get child window for MW event\n");
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
nsMouseScrollEvent scrollEvent(NS_MOUSE_SCROLL, this);
|
2000-11-13 18:16:43 +00:00
|
|
|
scrollEvent.scrollFlags = nsMouseScrollEvent::kIsVertical;
|
2000-11-02 05:15:34 +00:00
|
|
|
if (ulScrollLines == WHEEL_PAGESCROLL) {
|
2000-11-13 18:16:43 +00:00
|
|
|
scrollEvent.scrollFlags |= nsMouseScrollEvent::kIsFullPage;
|
2000-03-18 00:57:23 +00:00
|
|
|
if (msg == WM_MOUSEWHEEL)
|
2000-11-02 05:15:34 +00:00
|
|
|
scrollEvent.delta = (((short) HIWORD (wParam)) > 0) ? -1 : 1;
|
2000-03-18 00:57:23 +00:00
|
|
|
else
|
2000-11-02 05:15:34 +00:00
|
|
|
scrollEvent.delta = ((int) wParam > 0) ? -1 : 1;
|
|
|
|
} else {
|
|
|
|
if (msg == WM_MOUSEWHEEL)
|
|
|
|
scrollEvent.delta = -((short) HIWORD (wParam) / iDeltaPerLine);
|
|
|
|
else
|
|
|
|
scrollEvent.delta = -((int) wParam / iDeltaPerLine);
|
|
|
|
}
|
|
|
|
|
|
|
|
scrollEvent.isShift = IS_VK_DOWN(NS_VK_SHIFT);
|
|
|
|
scrollEvent.isControl = IS_VK_DOWN(NS_VK_CONTROL);
|
|
|
|
scrollEvent.isMeta = PR_FALSE;
|
|
|
|
scrollEvent.isAlt = IS_VK_DOWN(NS_VK_ALT);
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(scrollEvent);
|
2000-11-02 05:15:34 +00:00
|
|
|
if (nsnull != mEventCallback) {
|
|
|
|
result = DispatchWindowEvent(&scrollEvent);
|
|
|
|
}
|
|
|
|
NS_RELEASE(scrollEvent.widget);
|
2000-03-18 00:57:23 +00:00
|
|
|
} // WM_MOUSEWHEEL || uMSH_MOUSEWHEEL
|
2000-11-02 05:15:34 +00:00
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
//
|
|
|
|
// reconvertion meesage for Windows 95 / NT 4.0
|
|
|
|
//
|
|
|
|
// See the following URL
|
|
|
|
// http://msdn.microsoft.com/library/specs/msimeif_perimeinterfaces.htm#WM_MSIME_RECONVERT
|
|
|
|
// http://www.justsystem.co.jp/tech/atok/api12_04.html#4_11
|
2000-11-02 05:15:34 +00:00
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
else if ((msg == nsWindow::uWM_ATOK_RECONVERT) || (msg == nsWindow::uWM_MSIME_RECONVERT)) {
|
|
|
|
result = OnIMERequest(wParam, lParam, aRetValue, PR_TRUE);
|
|
|
|
}
|
2002-02-27 02:18:12 +00:00
|
|
|
else if (msg == nsWindow::uWM_HEAP_DUMP) {
|
|
|
|
// XXX for now we use c:\heapdump.txt until we figure out how to
|
|
|
|
// XXX pass in message parameters.
|
|
|
|
HeapDump("c:\\heapdump.txt", "whatever");
|
|
|
|
result = PR_TRUE;
|
|
|
|
}
|
2000-08-04 21:43:29 +00:00
|
|
|
|
2000-03-18 00:57:23 +00:00
|
|
|
} break;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
1999-07-09 21:08:09 +00:00
|
|
|
//*aRetValue = result;
|
1999-07-12 22:28:19 +00:00
|
|
|
if (mWnd) {
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
//Events which caused mWnd destruction and aren't consumed
|
|
|
|
//will crash during the Windows default processing.
|
|
|
|
return PR_TRUE;
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// return the window class name and initialize the class if needed
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2002-01-05 23:50:52 +00:00
|
|
|
|
|
|
|
#define CS_XP_DROPSHADOW 0x00020000
|
|
|
|
|
2002-07-03 00:55:47 +00:00
|
|
|
LPCWSTR nsWindow::WindowClassW()
|
|
|
|
{
|
|
|
|
const LPCWSTR className = L"MozillaWindowClass";
|
|
|
|
|
|
|
|
if (!nsWindow::sIsRegistered) {
|
|
|
|
WNDCLASSW wc;
|
|
|
|
|
|
|
|
// wc.style = CS_HREDRAW | CS_VREDRAW | CS_DBLCLKS;
|
|
|
|
wc.style = CS_DBLCLKS;
|
|
|
|
wc.lpfnWndProc = nsWindow::DefaultWindowProc;
|
|
|
|
wc.cbClsExtra = 0;
|
|
|
|
wc.cbWndExtra = 0;
|
|
|
|
wc.hInstance = nsToolkit::mDllInstance;
|
|
|
|
wc.hIcon = ::LoadIconW(::GetModuleHandle(NULL), MAKEINTRESOURCEW(IDI_APPLICATION));
|
|
|
|
wc.hCursor = NULL;
|
|
|
|
wc.hbrBackground = mBrush;
|
|
|
|
wc.lpszMenuName = NULL;
|
|
|
|
wc.lpszClassName = className;
|
|
|
|
|
2002-09-09 23:58:39 +00:00
|
|
|
nsWindow::sIsRegistered = nsToolkit::mRegisterClass(&wc);
|
2002-07-03 00:55:47 +00:00
|
|
|
// Call FilterClientWindows method since it enables ActiveIME on CJK Windows
|
|
|
|
if(nsToolkit::gAIMMApp)
|
|
|
|
nsToolkit::gAIMMApp->FilterClientWindows((ATOM*)&nsWindow::sIsRegistered,1);
|
|
|
|
}
|
|
|
|
|
|
|
|
return className;
|
|
|
|
}
|
|
|
|
|
|
|
|
LPCWSTR nsWindow::WindowPopupClassW()
|
|
|
|
{
|
|
|
|
const LPCWSTR className = L"MozillaDropShadowWindowClass";
|
|
|
|
|
|
|
|
if (!nsWindow::sIsPopupClassRegistered) {
|
|
|
|
WNDCLASSW wc;
|
|
|
|
wc.style = CS_DBLCLKS | CS_XP_DROPSHADOW;
|
|
|
|
wc.lpfnWndProc = nsWindow::DefaultWindowProc;
|
|
|
|
wc.cbClsExtra = 0;
|
|
|
|
wc.cbWndExtra = 0;
|
|
|
|
wc.hInstance = nsToolkit::mDllInstance;
|
|
|
|
wc.hIcon = ::LoadIconW(::GetModuleHandle(NULL), MAKEINTRESOURCEW(IDI_APPLICATION));
|
|
|
|
wc.hCursor = NULL;
|
|
|
|
wc.hbrBackground = mBrush;
|
|
|
|
wc.lpszMenuName = NULL;
|
|
|
|
wc.lpszClassName = className;
|
|
|
|
|
2002-09-09 23:58:39 +00:00
|
|
|
nsWindow::sIsPopupClassRegistered = nsToolkit::mRegisterClass(&wc);
|
2002-07-03 00:55:47 +00:00
|
|
|
if (!nsWindow::sIsPopupClassRegistered) {
|
|
|
|
// For older versions of Win32 (i.e., not XP), the registration will
|
|
|
|
// fail, so we have to re-register without the CS_XP_DROPSHADOW flag.
|
|
|
|
wc.style = CS_DBLCLKS;
|
2002-09-09 23:58:39 +00:00
|
|
|
nsWindow::sIsPopupClassRegistered = nsToolkit::mRegisterClass(&wc);
|
2002-07-03 00:55:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return className;
|
|
|
|
}
|
|
|
|
|
2002-07-29 21:44:53 +00:00
|
|
|
LPCTSTR nsWindow::WindowClass()
|
|
|
|
{
|
2003-04-28 10:24:52 +00:00
|
|
|
// Call into the wide version to make sure things get
|
|
|
|
// registered properly.
|
|
|
|
WindowClassW();
|
|
|
|
|
|
|
|
// XXX: The class name used here must be kept in sync with
|
|
|
|
// the classname used in WindowClassW();
|
|
|
|
return "MozillaWindowClass";
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
2002-01-05 23:50:52 +00:00
|
|
|
LPCTSTR nsWindow::WindowPopupClass()
|
|
|
|
{
|
2003-04-28 10:24:52 +00:00
|
|
|
// Call into the wide version to make sure things get
|
|
|
|
// registered properly.
|
|
|
|
WindowPopupClassW();
|
|
|
|
|
|
|
|
// XXX: The class name used here must be kept in sync with
|
|
|
|
// the classname used in WindowPopupClassW();
|
|
|
|
return "MozillaDropShadowWindowClass";
|
2002-01-05 23:50:52 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// return nsWindow styles
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
DWORD nsWindow::WindowStyle()
|
|
|
|
{
|
2000-03-21 03:42:00 +00:00
|
|
|
DWORD style;
|
|
|
|
|
|
|
|
switch(mWindowType) {
|
|
|
|
|
|
|
|
case eWindowType_child:
|
|
|
|
style = WS_OVERLAPPED;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eWindowType_dialog:
|
|
|
|
if (mBorderStyle == eBorderStyle_default) {
|
|
|
|
style = WS_OVERLAPPED | WS_BORDER | WS_DLGFRAME | WS_SYSMENU |
|
|
|
|
DS_3DLOOK | DS_MODALFRAME;
|
|
|
|
} else {
|
|
|
|
style = WS_OVERLAPPED | WS_BORDER | WS_DLGFRAME | WS_SYSMENU |
|
|
|
|
DS_3DLOOK | DS_MODALFRAME |
|
|
|
|
WS_THICKFRAME | WS_MINIMIZEBOX | WS_MAXIMIZEBOX;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case eWindowType_popup:
|
|
|
|
style = WS_OVERLAPPED | WS_POPUP;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
NS_ASSERTION(0, "unknown border style");
|
|
|
|
// fall through
|
|
|
|
|
|
|
|
case eWindowType_toplevel:
|
2003-07-25 14:54:39 +00:00
|
|
|
case eWindowType_invisible:
|
2000-03-21 03:42:00 +00:00
|
|
|
style = WS_OVERLAPPED | WS_BORDER | WS_DLGFRAME | WS_SYSMENU |
|
|
|
|
WS_THICKFRAME | WS_MINIMIZEBOX | WS_MAXIMIZEBOX;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mBorderStyle != eBorderStyle_default && mBorderStyle != eBorderStyle_all) {
|
|
|
|
if (mBorderStyle == eBorderStyle_none || !(mBorderStyle & eBorderStyle_border))
|
|
|
|
style &= ~WS_BORDER;
|
|
|
|
|
|
|
|
if (mBorderStyle == eBorderStyle_none || !(mBorderStyle & eBorderStyle_title)) {
|
|
|
|
style &= ~WS_DLGFRAME;
|
|
|
|
style |= WS_POPUP;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mBorderStyle == eBorderStyle_none || !(mBorderStyle & eBorderStyle_close))
|
|
|
|
style &= ~0;
|
|
|
|
// XXX The close box can only be removed by changing the window class,
|
|
|
|
// as far as I know --- roc+moz@cs.cmu.edu
|
|
|
|
|
|
|
|
if (mBorderStyle == eBorderStyle_none ||
|
|
|
|
!(mBorderStyle & (eBorderStyle_menu | eBorderStyle_close)))
|
|
|
|
style &= ~WS_SYSMENU;
|
|
|
|
// Looks like getting rid of the system menu also does away with the
|
|
|
|
// close box. So, we only get rid of the system menu if you want neither it
|
|
|
|
// nor the close box. How does the Windows "Dialog" window class get just
|
|
|
|
// closebox and no sysmenu? Who knows.
|
|
|
|
|
|
|
|
if (mBorderStyle == eBorderStyle_none || !(mBorderStyle & eBorderStyle_resizeh))
|
|
|
|
style &= ~WS_THICKFRAME;
|
|
|
|
|
|
|
|
if (mBorderStyle == eBorderStyle_none || !(mBorderStyle & eBorderStyle_minimize))
|
|
|
|
style &= ~WS_MINIMIZEBOX;
|
|
|
|
|
|
|
|
if (mBorderStyle == eBorderStyle_none || !(mBorderStyle & eBorderStyle_maximize))
|
|
|
|
style &= ~WS_MAXIMIZEBOX;
|
|
|
|
}
|
|
|
|
|
|
|
|
return style;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// return nsWindow extended styles
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
DWORD nsWindow::WindowExStyle()
|
|
|
|
{
|
2000-03-21 03:42:00 +00:00
|
|
|
switch(mWindowType)
|
|
|
|
{
|
|
|
|
case eWindowType_child:
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
case eWindowType_dialog:
|
|
|
|
return WS_EX_WINDOWEDGE;
|
|
|
|
|
|
|
|
case eWindowType_popup:
|
|
|
|
return WS_EX_TOPMOST | WS_EX_TOOLWINDOW;
|
|
|
|
|
|
|
|
default:
|
|
|
|
NS_ASSERTION(0, "unknown border style");
|
|
|
|
// fall through
|
|
|
|
|
|
|
|
case eWindowType_toplevel:
|
2003-07-25 14:54:39 +00:00
|
|
|
case eWindowType_invisible:
|
2000-03-21 03:42:00 +00:00
|
|
|
return WS_EX_WINDOWEDGE;
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// -----------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Subclass (or remove the subclass from) this component's nsWindow
|
|
|
|
//
|
|
|
|
// -----------------------------------------------------------------------
|
|
|
|
void nsWindow::SubclassWindow(BOOL bState)
|
|
|
|
{
|
1998-09-15 03:45:06 +00:00
|
|
|
if (NULL != mWnd) {
|
1998-04-13 20:24:54 +00:00
|
|
|
NS_PRECONDITION(::IsWindow(mWnd), "Invalid window handle");
|
|
|
|
|
|
|
|
if (bState) {
|
|
|
|
// change the nsWindow proc
|
2002-12-04 01:51:31 +00:00
|
|
|
if (mUnicodeWidget)
|
|
|
|
mPrevWndProc = (WNDPROC)nsToolkit::mSetWindowLong(mWnd, GWL_WNDPROC,
|
|
|
|
(LONG)nsWindow::WindowProc);
|
|
|
|
else
|
|
|
|
mPrevWndProc = (WNDPROC)::SetWindowLong(mWnd, GWL_WNDPROC,
|
2002-07-03 00:55:47 +00:00
|
|
|
(LONG)nsWindow::WindowProc);
|
1998-04-13 20:24:54 +00:00
|
|
|
NS_ASSERTION(mPrevWndProc, "Null standard window procedure");
|
|
|
|
// connect the this pointer to the nsWindow handle
|
2000-04-27 00:23:18 +00:00
|
|
|
SetNSWindowPtr(mWnd, this);
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
else {
|
2002-12-04 01:51:31 +00:00
|
|
|
if (mUnicodeWidget)
|
|
|
|
nsToolkit::mSetWindowLong(mWnd, GWL_WNDPROC, (LONG)mPrevWndProc);
|
|
|
|
else
|
|
|
|
::SetWindowLong(mWnd, GWL_WNDPROC, (LONG)mPrevWndProc);
|
2000-04-27 00:23:18 +00:00
|
|
|
SetNSWindowPtr(mWnd, NULL);
|
1998-04-13 20:24:54 +00:00
|
|
|
mPrevWndProc = NULL;
|
|
|
|
}
|
1998-09-15 03:45:06 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// WM_DESTROY has been called
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
void nsWindow::OnDestroy()
|
|
|
|
{
|
1998-09-15 03:45:06 +00:00
|
|
|
mOnDestroyCalled = PR_TRUE;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
SubclassWindow(FALSE);
|
1998-08-18 22:03:34 +00:00
|
|
|
mWnd = NULL;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-08-06 05:06:24 +00:00
|
|
|
// free GDI objects
|
|
|
|
if (mBrush) {
|
1998-08-09 01:37:30 +00:00
|
|
|
VERIFY(::DeleteObject(mBrush));
|
|
|
|
mBrush = NULL;
|
|
|
|
}
|
2001-08-09 20:22:39 +00:00
|
|
|
|
|
|
|
#if 0
|
1998-08-09 01:37:30 +00:00
|
|
|
if (mPalette) {
|
|
|
|
VERIFY(::DeleteObject(mPalette));
|
|
|
|
mPalette = NULL;
|
|
|
|
}
|
2001-08-09 20:22:39 +00:00
|
|
|
#endif
|
1998-08-09 01:37:30 +00:00
|
|
|
|
|
|
|
// if we were in the middle of deferred window positioning then
|
|
|
|
// free the memory for the multiple-window position structure
|
|
|
|
if (mDeferredPositioner) {
|
|
|
|
VERIFY(::EndDeferWindowPos(mDeferredPositioner));
|
|
|
|
mDeferredPositioner = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
// release references to children, device context, toolkit, and app shell
|
1998-09-23 19:19:23 +00:00
|
|
|
nsBaseWidget::OnDestroy();
|
|
|
|
|
1998-08-06 05:06:24 +00:00
|
|
|
// dispatch the event
|
1998-08-06 02:11:43 +00:00
|
|
|
if (!mIsDestroying) {
|
1998-08-06 05:06:24 +00:00
|
|
|
// dispatching of the event may cause the reference count to drop to 0
|
1998-08-06 02:11:43 +00:00
|
|
|
// and result in this object being destroyed. To avoid that, add a reference
|
|
|
|
// and then release it after dispatching the event
|
|
|
|
AddRef();
|
|
|
|
DispatchStandardEvent(NS_DESTROY);
|
|
|
|
Release();
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
1998-05-29 22:44:13 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Move
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
PRBool nsWindow::OnMove(PRInt32 aX, PRInt32 aY)
|
|
|
|
{
|
2003-11-14 21:58:08 +00:00
|
|
|
mBounds.x = aX;
|
|
|
|
mBounds.y = aY;
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
nsGUIEvent event(NS_MOVE, this);
|
|
|
|
InitEvent(event);
|
1998-05-29 22:44:13 +00:00
|
|
|
event.point.x = aX;
|
|
|
|
event.point.y = aY;
|
1998-10-08 00:04:21 +00:00
|
|
|
|
|
|
|
PRBool result = DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
return result;
|
1998-05-29 22:44:13 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Paint
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2003-04-14 22:56:35 +00:00
|
|
|
PRBool nsWindow::OnPaint(HDC aDC)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
|
|
|
nsRect bounds;
|
|
|
|
PRBool result = PR_TRUE;
|
|
|
|
PAINTSTRUCT ps;
|
1999-11-12 02:06:52 +00:00
|
|
|
nsEventStatus eventStatus = nsEventStatus_eIgnore;
|
1998-12-15 05:44:21 +00:00
|
|
|
|
1999-09-09 03:47:26 +00:00
|
|
|
#ifdef NS_DEBUG
|
|
|
|
HRGN debugPaintFlashRegion = NULL;
|
|
|
|
HDC debugPaintFlashDC = NULL;
|
1998-12-15 05:44:21 +00:00
|
|
|
|
1999-09-09 03:47:26 +00:00
|
|
|
if (debug_WantPaintFlashing())
|
|
|
|
{
|
|
|
|
debugPaintFlashRegion = ::CreateRectRgn(0, 0, 0, 0);
|
|
|
|
::GetUpdateRgn(mWnd, debugPaintFlashRegion, TRUE);
|
|
|
|
debugPaintFlashDC = ::GetDC(mWnd);
|
|
|
|
}
|
|
|
|
#endif // NS_DEBUG
|
1998-12-15 05:44:21 +00:00
|
|
|
|
2003-04-14 22:56:35 +00:00
|
|
|
HDC hDC = aDC ? aDC : (::BeginPaint(mWnd, &ps));
|
|
|
|
RECT paintRect;
|
|
|
|
if (aDC) {
|
|
|
|
::GetClientRect(mWnd, &paintRect);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
paintRect = ps.rcPaint;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!IsRectEmpty(&paintRect))
|
|
|
|
{
|
1998-04-13 20:24:54 +00:00
|
|
|
// call the event callback
|
1999-09-09 03:47:26 +00:00
|
|
|
if (mEventCallback)
|
|
|
|
{
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
nsPaintEvent event(NS_PAINT, this);
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event);
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2003-04-14 22:56:35 +00:00
|
|
|
nsRect rect(paintRect.left,
|
|
|
|
paintRect.top,
|
|
|
|
paintRect.right - paintRect.left,
|
|
|
|
paintRect.bottom - paintRect.top);
|
2003-03-25 02:58:10 +00:00
|
|
|
event.region = nsnull;
|
|
|
|
event.rect = ▭
|
|
|
|
// Should probably pass in a real region here, using GetRandomRgn
|
|
|
|
// http://msdn.microsoft.com/library/default.asp?url=/library/en-us/gdi/clipping_4q0e.asp
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1999-09-09 03:47:26 +00:00
|
|
|
#ifdef NS_DEBUG
|
|
|
|
debug_DumpPaintEvent(stdout,
|
|
|
|
this,
|
|
|
|
&event,
|
2000-09-03 00:46:03 +00:00
|
|
|
nsCAutoString("noname"),
|
1999-09-09 03:47:26 +00:00
|
|
|
(PRInt32) mWnd);
|
|
|
|
#endif // NS_DEBUG
|
1998-12-15 05:44:21 +00:00
|
|
|
|
1999-07-09 19:41:46 +00:00
|
|
|
if (NS_OK == nsComponentManager::CreateInstance(kRenderingContextCID,
|
|
|
|
nsnull,
|
2000-02-04 00:39:15 +00:00
|
|
|
NS_GET_IID(nsIRenderingContext),
|
1999-07-09 19:41:46 +00:00
|
|
|
(void **)&event.renderingContext))
|
1998-12-15 05:44:21 +00:00
|
|
|
{
|
|
|
|
nsIRenderingContextWin *winrc;
|
|
|
|
|
2000-02-04 00:39:15 +00:00
|
|
|
if (NS_OK == event.renderingContext->QueryInterface(NS_GET_IID(nsIRenderingContextWin), (void **)&winrc))
|
1998-12-15 05:44:21 +00:00
|
|
|
{
|
|
|
|
nsDrawingSurface surf;
|
|
|
|
|
|
|
|
//i know all of this seems a little backwards. i'll fix it, i swear. MMP
|
|
|
|
|
|
|
|
if (NS_OK == winrc->CreateDrawingSurface(hDC, surf))
|
|
|
|
{
|
|
|
|
event.renderingContext->Init(mContext, surf);
|
1999-11-12 02:06:52 +00:00
|
|
|
result = DispatchWindowEvent(&event, eventStatus);
|
1998-12-15 05:44:21 +00:00
|
|
|
event.renderingContext->DestroyDrawingSurface(surf);
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_RELEASE(winrc);
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
NS_RELEASE(event.renderingContext);
|
1998-10-08 00:04:21 +00:00
|
|
|
}
|
1998-12-15 05:44:21 +00:00
|
|
|
else
|
|
|
|
result = PR_FALSE;
|
1998-10-08 00:04:21 +00:00
|
|
|
|
1998-12-15 05:44:21 +00:00
|
|
|
NS_RELEASE(event.widget);
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-04-14 22:56:35 +00:00
|
|
|
if (!aDC) {
|
|
|
|
::EndPaint(mWnd, &ps);
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1999-09-09 03:47:26 +00:00
|
|
|
#ifdef NS_DEBUG
|
|
|
|
if (debug_WantPaintFlashing())
|
|
|
|
{
|
1999-11-12 02:06:52 +00:00
|
|
|
// Only flash paint events which have not ignored the paint message.
|
|
|
|
// Those that ignore the paint message aren't painting anything so there
|
|
|
|
// is only the overhead of the dispatching the paint event.
|
|
|
|
if (nsEventStatus_eIgnore != eventStatus) {
|
|
|
|
::InvertRgn(debugPaintFlashDC, debugPaintFlashRegion);
|
|
|
|
int x;
|
|
|
|
for (x = 0; x < 1000000; x++);
|
|
|
|
::InvertRgn(debugPaintFlashDC, debugPaintFlashRegion);
|
|
|
|
for (x = 0; x < 1000000; x++);
|
|
|
|
}
|
1999-09-09 03:47:26 +00:00
|
|
|
::ReleaseDC(mWnd, debugPaintFlashDC);
|
|
|
|
::DeleteObject(debugPaintFlashRegion);
|
|
|
|
}
|
|
|
|
#endif // NS_DEBUG
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Send a resize message to the listener
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
PRBool nsWindow::OnResize(nsRect &aWindowRect)
|
|
|
|
{
|
1998-10-07 22:11:37 +00:00
|
|
|
// call the event callback
|
|
|
|
if (mEventCallback) {
|
2004-01-12 08:25:18 +00:00
|
|
|
nsSizeEvent event(NS_SIZE, this);
|
|
|
|
InitEvent(event);
|
1998-10-07 22:11:37 +00:00
|
|
|
event.windowSize = &aWindowRect;
|
1998-11-04 21:43:47 +00:00
|
|
|
RECT r;
|
|
|
|
if (::GetWindowRect(mWnd, &r)) {
|
|
|
|
event.mWinWidth = PRInt32(r.right - r.left);
|
|
|
|
event.mWinHeight = PRInt32(r.bottom - r.top);
|
|
|
|
} else {
|
|
|
|
event.mWinWidth = 0;
|
|
|
|
event.mWinHeight = 0;
|
|
|
|
}
|
1998-10-08 00:04:21 +00:00
|
|
|
PRBool result = DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
return result;
|
1998-10-07 22:11:37 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-10-07 22:11:37 +00:00
|
|
|
return PR_FALSE;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Deal with all sort of mouse event
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2002-02-05 06:13:44 +00:00
|
|
|
PRBool nsWindow::DispatchMouseEvent(PRUint32 aEventType, WPARAM wParam, nsPoint* aPoint)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
|
|
|
PRBool result = PR_FALSE;
|
|
|
|
|
|
|
|
if (nsnull == mEventCallback && nsnull == mMouseListener) {
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
nsMouseEvent event(aEventType, this);
|
2003-05-15 00:12:03 +00:00
|
|
|
if (aEventType == NS_CONTEXTMENU_KEY) {
|
|
|
|
nsPoint zero(0, 0);
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event, &zero);
|
2003-05-15 00:12:03 +00:00
|
|
|
} else {
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event, aPoint);
|
2003-05-15 00:12:03 +00:00
|
|
|
}
|
|
|
|
|
1999-02-03 22:36:34 +00:00
|
|
|
event.isShift = IS_VK_DOWN(NS_VK_SHIFT);
|
|
|
|
event.isControl = IS_VK_DOWN(NS_VK_CONTROL);
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
event.isMeta = PR_FALSE;
|
1999-02-03 22:36:34 +00:00
|
|
|
event.isAlt = IS_VK_DOWN(NS_VK_ALT);
|
1998-05-08 14:54:09 +00:00
|
|
|
|
1999-09-22 02:29:33 +00:00
|
|
|
//Dblclicks are used to set the click count, then changed to mousedowns
|
2000-04-28 20:27:18 +00:00
|
|
|
LONG curMsgTime = ::GetMessageTime();
|
2000-12-12 12:22:49 +00:00
|
|
|
POINT mp;
|
|
|
|
DWORD pos = ::GetMessagePos();
|
2001-04-10 02:27:41 +00:00
|
|
|
mp.x = (short)LOWORD(pos);
|
|
|
|
mp.y = (short)HIWORD(pos);
|
2001-05-25 10:53:32 +00:00
|
|
|
PRBool insideMovementThreshold = (abs(gLastMousePoint.x - mp.x) < (short)::GetSystemMetrics(SM_CXDOUBLECLK)) &&
|
|
|
|
(abs(gLastMousePoint.y - mp.y) < (short)::GetSystemMetrics(SM_CYDOUBLECLK));
|
2000-04-28 20:27:18 +00:00
|
|
|
|
2001-12-06 02:55:06 +00:00
|
|
|
// Supress mouse moves caused by widget creation
|
|
|
|
if ((aEventType == NS_MOUSE_MOVE) &&
|
|
|
|
(gLastMouseMovePoint.x == mp.x) &&
|
|
|
|
(gLastMouseMovePoint.y == mp.y))
|
|
|
|
{
|
2002-02-27 01:30:40 +00:00
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
return result;
|
2001-12-06 02:55:06 +00:00
|
|
|
} else {
|
|
|
|
gLastMouseMovePoint.x = mp.x;
|
|
|
|
gLastMouseMovePoint.y = mp.y;
|
|
|
|
}
|
|
|
|
|
2000-04-28 20:27:18 +00:00
|
|
|
// we're going to time double-clicks from mouse *up* to next mouse *down*
|
2001-02-23 00:40:19 +00:00
|
|
|
if (aEventType == NS_MOUSE_LEFT_DOUBLECLICK) {
|
|
|
|
event.message = NS_MOUSE_LEFT_BUTTON_DOWN;
|
2000-04-28 20:27:18 +00:00
|
|
|
gLastClickCount = 2;
|
2001-02-23 00:40:19 +00:00
|
|
|
}
|
|
|
|
else if (aEventType == NS_MOUSE_MIDDLE_DOUBLECLICK) {
|
|
|
|
event.message = NS_MOUSE_MIDDLE_BUTTON_DOWN;
|
|
|
|
gLastClickCount = 2;
|
|
|
|
}
|
|
|
|
else if (aEventType == NS_MOUSE_RIGHT_DOUBLECLICK) {
|
|
|
|
event.message = NS_MOUSE_RIGHT_BUTTON_DOWN;
|
|
|
|
gLastClickCount = 2;
|
|
|
|
}
|
|
|
|
else if (aEventType == NS_MOUSE_LEFT_BUTTON_UP || aEventType == NS_MOUSE_MIDDLE_BUTTON_UP || aEventType == NS_MOUSE_RIGHT_BUTTON_UP) {
|
2000-04-28 20:27:18 +00:00
|
|
|
// remember when this happened for the next mouse down
|
|
|
|
DWORD pos = ::GetMessagePos();
|
2001-04-10 02:27:41 +00:00
|
|
|
gLastMousePoint.x = (short)LOWORD(pos);
|
|
|
|
gLastMousePoint.y = (short)HIWORD(pos);
|
2001-02-23 00:40:19 +00:00
|
|
|
}
|
|
|
|
else if (aEventType == NS_MOUSE_LEFT_BUTTON_DOWN || aEventType == NS_MOUSE_MIDDLE_BUTTON_DOWN || aEventType == NS_MOUSE_RIGHT_BUTTON_DOWN) {
|
2000-04-28 20:27:18 +00:00
|
|
|
// now look to see if we want to convert this to a double- or triple-click
|
2000-12-12 12:22:49 +00:00
|
|
|
|
|
|
|
#ifdef NS_DEBUG_XX
|
2000-12-13 11:53:10 +00:00
|
|
|
printf("Msg: %d Last: %d Dif: %d Max %d\n", curMsgTime, gLastMouseDownTime, curMsgTime-gLastMouseDownTime, ::GetDoubleClickTime());
|
2000-12-12 12:22:49 +00:00
|
|
|
printf("Mouse %d %d\n", abs(gLastMousePoint.x - mp.x), abs(gLastMousePoint.y - mp.y));
|
|
|
|
#endif
|
2000-12-13 11:53:10 +00:00
|
|
|
if (((curMsgTime - gLastMouseDownTime) < (LONG)::GetDoubleClickTime()) && insideMovementThreshold) {
|
2000-04-28 20:27:18 +00:00
|
|
|
gLastClickCount ++;
|
|
|
|
} else {
|
|
|
|
// reset the click count, to count *this* click
|
|
|
|
gLastClickCount = 1;
|
|
|
|
}
|
2000-12-13 11:53:10 +00:00
|
|
|
// Set last Click time on MouseDown only
|
|
|
|
gLastMouseDownTime = curMsgTime;
|
2001-02-23 00:40:19 +00:00
|
|
|
}
|
|
|
|
else if (aEventType == NS_MOUSE_MOVE && !insideMovementThreshold) {
|
2000-12-12 12:22:49 +00:00
|
|
|
gLastClickCount = 0;
|
2000-04-28 20:27:18 +00:00
|
|
|
}
|
2000-12-12 12:22:49 +00:00
|
|
|
event.clickCount = gLastClickCount;
|
2000-04-28 20:27:18 +00:00
|
|
|
|
2000-12-12 12:22:49 +00:00
|
|
|
#ifdef NS_DEBUG_XX
|
|
|
|
printf("Msg Time: %d Click Count: %d\n", curMsgTime, event.clickCount);
|
|
|
|
#endif
|
2000-04-28 20:27:18 +00:00
|
|
|
|
1999-06-25 21:17:52 +00:00
|
|
|
nsPluginEvent pluginEvent;
|
|
|
|
|
|
|
|
switch (aEventType)//~~~
|
|
|
|
{
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_DOWN:
|
|
|
|
pluginEvent.event = WM_LBUTTONDOWN;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_UP:
|
|
|
|
pluginEvent.event = WM_LBUTTONUP;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_LEFT_DOUBLECLICK:
|
|
|
|
pluginEvent.event = WM_LBUTTONDBLCLK;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_DOWN:
|
|
|
|
pluginEvent.event = WM_RBUTTONDOWN;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_UP:
|
|
|
|
pluginEvent.event = WM_RBUTTONUP;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_RIGHT_DOUBLECLICK:
|
|
|
|
pluginEvent.event = WM_RBUTTONDBLCLK;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_DOWN:
|
|
|
|
pluginEvent.event = WM_MBUTTONDOWN;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_UP:
|
|
|
|
pluginEvent.event = WM_MBUTTONUP;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_MIDDLE_DOUBLECLICK:
|
|
|
|
pluginEvent.event = WM_MBUTTONDBLCLK;
|
|
|
|
break;
|
|
|
|
case NS_MOUSE_MOVE:
|
|
|
|
pluginEvent.event = WM_MOUSEMOVE;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2002-02-05 06:13:44 +00:00
|
|
|
pluginEvent.wParam = wParam; // plugins NEED raw OS event flags!
|
1999-06-25 21:17:52 +00:00
|
|
|
pluginEvent.lParam = MAKELONG(event.point.x, event.point.y);
|
|
|
|
|
|
|
|
event.nativeMsg = (void *)&pluginEvent;
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
// call the event callback
|
|
|
|
if (nsnull != mEventCallback) {
|
1998-04-24 23:09:11 +00:00
|
|
|
|
1998-10-07 22:11:37 +00:00
|
|
|
result = DispatchWindowEvent(&event);
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
if (aEventType == NS_MOUSE_MOVE) {
|
|
|
|
|
1999-08-05 14:56:21 +00:00
|
|
|
// if we are not in mouse cpature mode (mouse down and hold)
|
|
|
|
// then use "this" window
|
|
|
|
// if we are in mouse capture, then all events are being directed
|
|
|
|
// back to the nsWindow doing the capture. So therefore, the detection
|
|
|
|
// of whether we are in a new nsWindow is wrong. Meaning this MOUSE_MOVE
|
|
|
|
// event hold the captured windows pointer not the one the mouse is over.
|
|
|
|
//
|
|
|
|
// So we use "WindowFromPoint" to find what window we are over and
|
|
|
|
// set that window into the mouse trailer timer.
|
|
|
|
if (!mIsInMouseCapture) {
|
|
|
|
MouseTrailer * mouseTrailer = MouseTrailer::GetMouseTrailer(0);
|
|
|
|
MouseTrailer::SetMouseTrailerWindow(this);
|
|
|
|
mouseTrailer->CreateTimer();
|
|
|
|
} else {
|
|
|
|
POINT mp;
|
|
|
|
DWORD pos = ::GetMessagePos();
|
2001-04-10 02:27:41 +00:00
|
|
|
mp.x = (short)LOWORD(pos);
|
|
|
|
mp.y = (short)HIWORD(pos);
|
1999-09-09 13:38:30 +00:00
|
|
|
|
|
|
|
// OK, now find out if we are still inside
|
|
|
|
// the captured native window
|
|
|
|
POINT cpos;
|
2001-04-10 02:27:41 +00:00
|
|
|
cpos.x = (short)LOWORD(pos);
|
|
|
|
cpos.y = (short)HIWORD(pos);
|
1999-09-09 13:38:30 +00:00
|
|
|
|
|
|
|
nsWindow * someWindow = NULL;
|
|
|
|
HWND hWnd = ::WindowFromPoint(mp);
|
|
|
|
if (hWnd != NULL) {
|
|
|
|
::ScreenToClient(hWnd, &cpos);
|
|
|
|
RECT r;
|
|
|
|
VERIFY(::GetWindowRect(hWnd, &r));
|
|
|
|
if (cpos.x >= r.left && cpos.x <= r.right &&
|
|
|
|
cpos.y >= r.top && cpos.y <= r.bottom) {
|
|
|
|
// yes we are so we should be able to get a valid window
|
|
|
|
// although, strangley enough when we are on the frame part of the
|
|
|
|
// window we get right here when in capture mode
|
|
|
|
// but this window won't match the capture mode window so
|
|
|
|
// we are ok
|
2000-04-27 00:23:18 +00:00
|
|
|
someWindow = GetNSWindowPtr(hWnd);
|
1999-09-09 13:38:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// only set the window into the mouse trailer if we have a good window
|
1999-08-05 14:56:21 +00:00
|
|
|
if (nsnull != someWindow) {
|
|
|
|
MouseTrailer * mouseTrailer = MouseTrailer::GetMouseTrailer(0);
|
|
|
|
MouseTrailer::SetMouseTrailerWindow(someWindow);
|
|
|
|
mouseTrailer->CreateTimer();
|
|
|
|
}
|
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
|
|
|
nsRect rect;
|
|
|
|
GetBounds(rect);
|
|
|
|
rect.x = 0;
|
|
|
|
rect.y = 0;
|
|
|
|
|
|
|
|
if (rect.Contains(event.point.x, event.point.y)) {
|
1998-05-29 22:44:13 +00:00
|
|
|
if (gCurrentWindow == NULL || gCurrentWindow != this) {
|
|
|
|
if ((nsnull != gCurrentWindow) && (!gCurrentWindow->mIsDestroying)) {
|
|
|
|
MouseTrailer::IgnoreNextCycle();
|
2002-02-05 06:13:44 +00:00
|
|
|
gCurrentWindow->DispatchMouseEvent(NS_MOUSE_EXIT, wParam, gCurrentWindow->GetLastPoint());
|
1998-05-29 22:44:13 +00:00
|
|
|
}
|
|
|
|
gCurrentWindow = this;
|
|
|
|
if (!mIsDestroying) {
|
2002-02-05 06:13:44 +00:00
|
|
|
gCurrentWindow->DispatchMouseEvent(NS_MOUSE_ENTER, wParam);
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if (aEventType == NS_MOUSE_EXIT) {
|
1998-05-29 22:44:13 +00:00
|
|
|
if (gCurrentWindow == this) {
|
|
|
|
gCurrentWindow = nsnull;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
}
|
2002-04-02 21:08:29 +00:00
|
|
|
|
|
|
|
// Release the widget with NS_IF_RELEASE() just in case
|
|
|
|
// the context menu key code in nsEventListenerManager::HandleEvent()
|
|
|
|
// released it already.
|
|
|
|
|
|
|
|
NS_IF_RELEASE(event.widget);
|
1998-04-13 20:24:54 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (nsnull != mMouseListener) {
|
|
|
|
switch (aEventType) {
|
|
|
|
case NS_MOUSE_MOVE: {
|
|
|
|
result = ConvertStatus(mMouseListener->MouseMoved(event));
|
|
|
|
nsRect rect;
|
|
|
|
GetBounds(rect);
|
|
|
|
if (rect.Contains(event.point.x, event.point.y)) {
|
1998-05-29 22:44:13 +00:00
|
|
|
if (gCurrentWindow == NULL || gCurrentWindow != this) {
|
|
|
|
gCurrentWindow = this;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
} else {
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
//printf("Mouse exit");
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
} break;
|
|
|
|
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_DOWN:
|
|
|
|
result = ConvertStatus(mMouseListener->MousePressed(event));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_UP:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_UP:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_UP:
|
|
|
|
result = ConvertStatus(mMouseListener->MouseReleased(event));
|
|
|
|
result = ConvertStatus(mMouseListener->MouseClicked(event));
|
|
|
|
break;
|
|
|
|
} // switch
|
|
|
|
}
|
1998-10-08 00:04:21 +00:00
|
|
|
NS_RELEASE(event.widget);
|
1998-04-13 20:24:54 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2001-04-01 01:38:35 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
2001-08-03 08:15:20 +00:00
|
|
|
// Deal with accessibile event
|
2001-04-01 01:38:35 +00:00
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2001-08-17 03:13:07 +00:00
|
|
|
#ifdef ACCESSIBILITY
|
2001-04-01 01:38:35 +00:00
|
|
|
PRBool nsWindow::DispatchAccessibleEvent(PRUint32 aEventType, nsIAccessible** aAcc, nsPoint* aPoint)
|
|
|
|
{
|
|
|
|
PRBool result = PR_FALSE;
|
|
|
|
|
|
|
|
if (nsnull == mEventCallback) {
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
*aAcc = nsnull;
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
nsAccessibleEvent event(aEventType, this);
|
|
|
|
InitEvent(event, aPoint);
|
2001-04-01 01:38:35 +00:00
|
|
|
|
|
|
|
event.isShift = IS_VK_DOWN(NS_VK_SHIFT);
|
|
|
|
event.isControl = IS_VK_DOWN(NS_VK_CONTROL);
|
|
|
|
event.isMeta = PR_FALSE;
|
|
|
|
event.isAlt = IS_VK_DOWN(NS_VK_ALT);
|
|
|
|
event.accessible = nsnull;
|
|
|
|
|
|
|
|
result = DispatchWindowEvent(&event);
|
|
|
|
|
|
|
|
// if the event returned an accesssible get it.
|
|
|
|
if (event.accessible)
|
|
|
|
*aAcc = event.accessible;
|
|
|
|
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2001-08-17 03:13:07 +00:00
|
|
|
#endif
|
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Deal with focus messages
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2001-05-18 12:07:42 +00:00
|
|
|
PRBool nsWindow::DispatchFocus(PRUint32 aEventType, PRBool isMozWindowTakingFocus)
|
1998-04-13 20:24:54 +00:00
|
|
|
{
|
1999-07-27 20:50:05 +00:00
|
|
|
// call the event callback
|
|
|
|
if (mEventCallback) {
|
2004-01-12 08:25:18 +00:00
|
|
|
nsFocusEvent event(aEventType, this);
|
|
|
|
InitEvent(event);
|
1999-07-27 20:50:05 +00:00
|
|
|
|
|
|
|
//focus and blur event should go to their base widget loc, not current mouse pos
|
|
|
|
event.point.x = 0;
|
|
|
|
event.point.y = 0;
|
|
|
|
|
2001-05-18 12:07:42 +00:00
|
|
|
event.isMozWindowTakingFocus = isMozWindowTakingFocus;
|
|
|
|
|
1999-07-27 20:50:05 +00:00
|
|
|
nsPluginEvent pluginEvent;
|
|
|
|
|
|
|
|
switch (aEventType)//~~~
|
|
|
|
{
|
|
|
|
case NS_GOTFOCUS:
|
|
|
|
pluginEvent.event = WM_SETFOCUS;
|
|
|
|
break;
|
|
|
|
case NS_LOSTFOCUS:
|
|
|
|
pluginEvent.event = WM_KILLFOCUS;
|
2000-08-24 04:53:31 +00:00
|
|
|
break;
|
|
|
|
case NS_PLUGIN_ACTIVATE:
|
|
|
|
pluginEvent.event = WM_KILLFOCUS;
|
1999-07-27 20:50:05 +00:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
1999-07-27 20:50:05 +00:00
|
|
|
event.nativeMsg = (void *)&pluginEvent;
|
|
|
|
|
|
|
|
PRBool result = DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
return PR_FALSE;
|
1998-04-13 20:24:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Deal with scrollbar messages (actually implemented only in nsScrollbar)
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
PRBool nsWindow::OnScroll(UINT scrollCode, int cPos)
|
|
|
|
{
|
|
|
|
return PR_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Return the brush used to paint the background of this control
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
HBRUSH nsWindow::OnControlColor()
|
|
|
|
{
|
|
|
|
return mBrush;
|
|
|
|
}
|
|
|
|
|
1998-07-21 18:04:18 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Deal with all sort of mouse event
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
2002-02-05 06:13:44 +00:00
|
|
|
PRBool ChildWindow::DispatchMouseEvent(PRUint32 aEventType, WPARAM wParam, nsPoint* aPoint)
|
1998-07-21 18:04:18 +00:00
|
|
|
{
|
|
|
|
PRBool result = PR_FALSE;
|
|
|
|
|
|
|
|
if (nsnull == mEventCallback && nsnull == mMouseListener) {
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (aEventType) {
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_DOWN:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_DOWN:
|
1999-08-05 14:56:21 +00:00
|
|
|
CaptureMouse(PR_TRUE);
|
1998-07-21 18:04:18 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case NS_MOUSE_LEFT_BUTTON_UP:
|
|
|
|
case NS_MOUSE_MIDDLE_BUTTON_UP:
|
|
|
|
case NS_MOUSE_RIGHT_BUTTON_UP:
|
1999-08-05 14:56:21 +00:00
|
|
|
CaptureMouse(PR_FALSE);
|
1998-07-21 18:04:18 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
|
|
|
|
} // switch
|
|
|
|
|
2002-02-05 06:13:44 +00:00
|
|
|
return nsWindow::DispatchMouseEvent(aEventType, wParam, aPoint);
|
1998-07-21 18:04:18 +00:00
|
|
|
}
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2000-03-21 03:42:00 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// return the style for a child nsWindow
|
|
|
|
//
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
DWORD ChildWindow::WindowStyle()
|
1999-07-27 04:27:17 +00:00
|
|
|
{
|
2000-03-21 03:42:00 +00:00
|
|
|
return WS_CHILD | WS_CLIPCHILDREN | nsWindow::WindowStyle();
|
1999-07-27 04:27:17 +00:00
|
|
|
}
|
|
|
|
|
1998-04-17 23:45:07 +00:00
|
|
|
|
2000-01-31 22:53:35 +00:00
|
|
|
static char* GetACPString(const nsString& aStr)
|
|
|
|
{
|
|
|
|
int acplen = aStr.Length() * 2 + 1;
|
|
|
|
char * acp = new char[acplen];
|
|
|
|
if(acp)
|
|
|
|
{
|
|
|
|
int outlen = ::WideCharToMultiByte( CP_ACP, 0,
|
2001-06-30 11:02:25 +00:00
|
|
|
aStr.get(), aStr.Length(),
|
2000-01-31 22:53:35 +00:00
|
|
|
acp, acplen, NULL, NULL);
|
2001-07-03 00:21:56 +00:00
|
|
|
if ( outlen >= 0)
|
2000-01-31 22:53:35 +00:00
|
|
|
acp[outlen] = '\0'; // null terminate
|
|
|
|
}
|
|
|
|
return acp;
|
|
|
|
}
|
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::SetTitle(const nsString& aTitle)
|
1998-04-17 23:45:07 +00:00
|
|
|
{
|
1999-10-22 21:45:19 +00:00
|
|
|
char* title = GetACPString(aTitle);
|
|
|
|
if (title) {
|
2002-09-09 23:58:39 +00:00
|
|
|
nsToolkit::mSendMessage(mWnd, WM_SETTEXT, (WPARAM)0, (LPARAM)(LPCWSTR)PromiseFlatString(aTitle).get());
|
1999-10-22 21:45:19 +00:00
|
|
|
delete [] title;
|
|
|
|
}
|
1998-09-28 22:32:48 +00:00
|
|
|
return NS_OK;
|
1998-04-17 23:45:07 +00:00
|
|
|
}
|
|
|
|
|
2002-03-23 22:26:36 +00:00
|
|
|
NS_METHOD nsWindow::SetIcon(const nsAString& anIconSpec)
|
2001-04-14 00:57:30 +00:00
|
|
|
{
|
|
|
|
// Start at app chrome directory.
|
|
|
|
nsCOMPtr<nsIFile> chromeDir;
|
|
|
|
if ( NS_FAILED( NS_GetSpecialDirectory( NS_APP_CHROME_DIR,
|
|
|
|
getter_AddRefs( chromeDir ) ) ) ) {
|
2003-10-30 01:35:14 +00:00
|
|
|
return NS_ERROR_FAILURE;
|
2001-04-14 00:57:30 +00:00
|
|
|
}
|
|
|
|
// Get native file name of that directory.
|
2002-05-07 23:07:19 +00:00
|
|
|
nsAutoString iconPath;
|
|
|
|
chromeDir->GetPath( iconPath );
|
2001-04-14 00:57:30 +00:00
|
|
|
|
|
|
|
// Now take input path...
|
|
|
|
nsAutoString iconSpec( anIconSpec );
|
|
|
|
// ...append ".ico" to that.
|
|
|
|
iconSpec.Append( NS_LITERAL_STRING(".ico") );
|
|
|
|
// ...and figure out where /chrome/... is within that
|
|
|
|
// (and skip the "resource:///chrome" part).
|
|
|
|
nsAutoString key(NS_LITERAL_STRING("/chrome/"));
|
|
|
|
PRInt32 n = iconSpec.Find( key ) + key.Length();
|
|
|
|
// Convert / to \.
|
|
|
|
nsAutoString slash(NS_LITERAL_STRING("/"));
|
|
|
|
nsAutoString bslash(NS_LITERAL_STRING("\\"));
|
2001-06-30 11:02:25 +00:00
|
|
|
iconSpec.ReplaceChar( *(slash.get()), *(bslash.get()) );
|
2001-04-14 00:57:30 +00:00
|
|
|
|
|
|
|
// Append that to icon resource path.
|
2001-06-30 11:02:25 +00:00
|
|
|
iconPath.Append( iconSpec.get() + n - 1 );
|
2001-04-14 00:57:30 +00:00
|
|
|
|
2001-06-20 01:47:29 +00:00
|
|
|
::SetLastError( 0 );
|
2001-04-14 00:57:30 +00:00
|
|
|
HICON bigIcon = (HICON)::LoadImageW( NULL,
|
2001-06-30 11:02:25 +00:00
|
|
|
(LPCWSTR)iconPath.get(),
|
2001-04-14 00:57:30 +00:00
|
|
|
IMAGE_ICON,
|
|
|
|
::GetSystemMetrics(SM_CXICON),
|
|
|
|
::GetSystemMetrics(SM_CYICON),
|
2003-04-20 20:57:36 +00:00
|
|
|
LR_LOADFROMFILE );
|
2001-04-14 00:57:30 +00:00
|
|
|
HICON smallIcon = (HICON)::LoadImageW( NULL,
|
2001-06-30 11:02:25 +00:00
|
|
|
(LPCWSTR)iconPath.get(),
|
2001-04-14 00:57:30 +00:00
|
|
|
IMAGE_ICON,
|
|
|
|
::GetSystemMetrics(SM_CXSMICON),
|
|
|
|
::GetSystemMetrics(SM_CYSMICON),
|
2003-04-20 20:57:36 +00:00
|
|
|
LR_LOADFROMFILE );
|
2001-06-20 01:47:29 +00:00
|
|
|
|
|
|
|
// See if unicode API not implemented and if not, try ascii version
|
|
|
|
if ( ::GetLastError() == ERROR_CALL_NOT_IMPLEMENTED ) {
|
2003-10-30 01:35:14 +00:00
|
|
|
nsCOMPtr<nsILocalFile> pathConverter;
|
|
|
|
if ( NS_SUCCEEDED( NS_NewLocalFile( iconPath,
|
|
|
|
PR_FALSE,
|
|
|
|
getter_AddRefs( pathConverter ) ) ) ) {
|
|
|
|
// Now try the char* path.
|
|
|
|
nsCAutoString aPath;
|
|
|
|
pathConverter->GetNativePath( aPath );
|
|
|
|
bigIcon = (HICON)::LoadImage( NULL,
|
|
|
|
aPath.get(),
|
|
|
|
IMAGE_ICON,
|
|
|
|
::GetSystemMetrics(SM_CXICON),
|
|
|
|
::GetSystemMetrics(SM_CYICON),
|
|
|
|
LR_LOADFROMFILE );
|
|
|
|
smallIcon = (HICON)::LoadImage( NULL,
|
|
|
|
aPath.get(),
|
|
|
|
IMAGE_ICON,
|
|
|
|
::GetSystemMetrics(SM_CXSMICON),
|
|
|
|
::GetSystemMetrics(SM_CYSMICON),
|
|
|
|
LR_LOADFROMFILE );
|
|
|
|
}
|
2001-06-20 01:47:29 +00:00
|
|
|
}
|
|
|
|
|
2001-04-14 00:57:30 +00:00
|
|
|
if ( bigIcon ) {
|
2003-10-30 01:35:14 +00:00
|
|
|
HICON icon = (HICON) nsToolkit::mSendMessage(mWnd, WM_SETICON, (WPARAM)ICON_BIG, (LPARAM)bigIcon);
|
|
|
|
if (icon)
|
|
|
|
::DestroyIcon(icon);
|
2001-04-14 00:57:30 +00:00
|
|
|
}
|
|
|
|
#ifdef DEBUG_law
|
|
|
|
else {
|
|
|
|
nsCAutoString cPath; cPath.AssignWithConversion(iconPath);
|
|
|
|
printf( "\nIcon load error; icon=%s, rc=0x%08X\n\n", (const char*)cPath, ::GetLastError() );
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
if ( smallIcon ) {
|
2003-10-30 01:35:14 +00:00
|
|
|
HICON icon = (HICON) nsToolkit::mSendMessage(mWnd, WM_SETICON, (WPARAM)ICON_SMALL, (LPARAM)smallIcon);
|
|
|
|
if (icon)
|
|
|
|
::DestroyIcon(icon);
|
2001-04-14 00:57:30 +00:00
|
|
|
}
|
|
|
|
#ifdef DEBUG_law
|
|
|
|
else {
|
|
|
|
nsCAutoString cPath; cPath.AssignWithConversion(iconPath);
|
|
|
|
printf( "\nSmall icon load error; icon=%s, rc=0x%08X\n\n", (const char*)cPath, ::GetLastError() );
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
1998-04-17 23:45:07 +00:00
|
|
|
|
1998-04-28 19:24:52 +00:00
|
|
|
PRBool nsWindow::AutoErase()
|
|
|
|
{
|
|
|
|
return(PR_FALSE);
|
|
|
|
}
|
|
|
|
|
1998-09-28 22:32:48 +00:00
|
|
|
NS_METHOD nsWindow::GetPreferredSize(PRInt32& aWidth, PRInt32& aHeight)
|
|
|
|
{
|
|
|
|
aWidth = mPreferredWidth;
|
|
|
|
aHeight = mPreferredHeight;
|
|
|
|
return NS_ERROR_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_METHOD nsWindow::SetPreferredSize(PRInt32 aWidth, PRInt32 aHeight)
|
|
|
|
{
|
|
|
|
mPreferredWidth = aWidth;
|
|
|
|
mPreferredHeight = aHeight;
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2002-03-22 23:09:01 +00:00
|
|
|
#define ZH_CN_INTELLEGENT_ABC_IME ((HKL)0xe0040804L)
|
2002-05-23 22:03:49 +00:00
|
|
|
#define ZH_CN_MS_PINYIN_IME_3_0 ((HKL)0xe00e0804L)
|
|
|
|
#define ZH_CN_NEIMA_IME ((HKL)0xe0050804L)
|
2002-09-25 02:23:01 +00:00
|
|
|
#define PINYIN_IME_ON_XP(kl) ((nsToolkit::mIsWinXP) \
|
2002-06-11 22:20:39 +00:00
|
|
|
&& (ZH_CN_MS_PINYIN_IME_3_0 == (kl)))
|
2002-09-25 02:23:01 +00:00
|
|
|
PRBool gPinYinIMECaretCreated = PR_FALSE;
|
2002-03-22 23:09:01 +00:00
|
|
|
|
1999-03-19 23:36:20 +00:00
|
|
|
void
|
1999-10-27 23:05:24 +00:00
|
|
|
nsWindow::HandleTextEvent(HIMC hIMEContext,PRBool aCheckAttr)
|
1999-03-19 23:36:20 +00:00
|
|
|
{
|
1999-11-16 23:45:44 +00:00
|
|
|
NS_ASSERTION( mIMECompString, "mIMECompString is null");
|
|
|
|
NS_ASSERTION( mIMECompUnicode, "mIMECompUnicode is null");
|
1999-11-10 23:43:46 +00:00
|
|
|
NS_ASSERTION( mIMEIsComposing, "conflict state");
|
1999-11-16 23:45:44 +00:00
|
|
|
if((nsnull == mIMECompString) || (nsnull == mIMECompUnicode))
|
|
|
|
return;
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
nsTextEvent event(NS_TEXT_TEXT, this);
|
|
|
|
nsPoint point(0, 0);
|
1999-06-29 20:31:22 +00:00
|
|
|
size_t unicharSize;
|
1999-08-06 07:42:35 +00:00
|
|
|
CANDIDATEFORM candForm;
|
1998-04-17 23:45:07 +00:00
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event, &point);
|
1999-06-29 20:31:22 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// convert the composition string text into unicode before it is sent to xp-land
|
2000-04-13 22:23:04 +00:00
|
|
|
// but, on Windows NT / 2000, need not convert.
|
1999-06-29 20:31:22 +00:00
|
|
|
//
|
2002-03-18 23:29:39 +00:00
|
|
|
if (!nsToolkit::mUseImeApiW) {
|
2000-04-13 22:23:04 +00:00
|
|
|
unicharSize = ::MultiByteToWideChar(gCurrentKeyboardCP,MB_PRECOMPOSED,
|
2001-03-02 09:26:57 +00:00
|
|
|
mIMECompString->get(),
|
2000-04-13 22:23:04 +00:00
|
|
|
mIMECompString->Length(),
|
|
|
|
NULL,0);
|
|
|
|
|
|
|
|
mIMECompUnicode->SetCapacity(unicharSize+1);
|
|
|
|
|
|
|
|
unicharSize = ::MultiByteToWideChar(gCurrentKeyboardCP,MB_PRECOMPOSED,
|
2001-03-02 09:26:57 +00:00
|
|
|
mIMECompString->get(),
|
2000-04-13 22:23:04 +00:00
|
|
|
mIMECompString->Length(),
|
2004-02-28 22:34:07 +00:00
|
|
|
mIMECompUnicode->BeginWriting(),
|
2001-11-14 12:35:52 +00:00
|
|
|
unicharSize+1);
|
|
|
|
mIMECompUnicode->SetLength(unicharSize);
|
2000-04-13 22:23:04 +00:00
|
|
|
}
|
1999-03-19 23:36:20 +00:00
|
|
|
|
1999-06-29 20:31:22 +00:00
|
|
|
//
|
|
|
|
// we need to convert the attribute array, which is alligned with the mutibyte text into an array of offsets
|
|
|
|
// mapped to the unicode text
|
|
|
|
//
|
1999-10-27 00:14:46 +00:00
|
|
|
|
1999-10-27 23:05:24 +00:00
|
|
|
if(aCheckAttr) {
|
1999-10-27 00:14:46 +00:00
|
|
|
MapDBCSAtrributeArrayToUnicodeOffsets(&(event.rangeCount),&(event.rangeArray));
|
|
|
|
} else {
|
|
|
|
event.rangeCount = 0;
|
|
|
|
event.rangeArray = nsnull;
|
|
|
|
}
|
1999-06-29 20:31:22 +00:00
|
|
|
|
2004-02-28 22:34:07 +00:00
|
|
|
event.theText = mIMECompUnicode->get();
|
1999-06-29 20:31:22 +00:00
|
|
|
event.isShift = mIsShiftDown;
|
1999-03-19 23:36:20 +00:00
|
|
|
event.isControl = mIsControlDown;
|
landing keyEvent_19991004_BRANCH
bugs # see the log of the check in into branch
author/reviewer:
mozilla/layout/base/src/nsRangeList.cpp brade/mjudge
mozilla/layout/html/forms/src/nsGfxTextControlFrame.cpp brade/ftang
mozilla/layout/events/src/nsDOMEvent.cpp brade/joki
mozilla/layout/events/src/nsEventStateManager.cpp brade/joki
mozilla/widget/public/nsGUIEvent.h akkana/ftang
mozilla/widget/src/windows/nsWindow.cpp ftang/mjudge
mozilla/widget/src/windows/nsWindow.h ftang/mjudge
mozilla/widget/src/mac/nsTextAreaWidget.cpp brade/ftang
mozilla/widget/src/mac/nsMacEventHandler.cpp brade/simon
mozilla/widget/src/xpwidgets/nsKeyBindMgr.cpp brade/ftang
mozilla/widget/src/gtk/nsGtkEventHandler.cpp akkana/?
mozilla/widget/src/gtk/nsWidget.cpp erik/ftang
mozilla/layout/xul/base/src/nsTreeCellFrame.cpp brade/ftang
mozilla/editor/base/nsEditorEventListeners.cpp brade/akkana
mozilla/editor/base/nsHTMLEditor.cpp brade/akkana
mozilla/rdf/content/src/nsXULKeyListener.cpp ftang/saari
fix the master bug- 15693
fix at least, but not limited to, the following bugs
10158,11956,6053,9333,10901,14348,6449,11845,13016,14410,15657,15307,15842,13856
1999-10-14 18:27:01 +00:00
|
|
|
event.isMeta = PR_FALSE;
|
1999-06-29 20:31:22 +00:00
|
|
|
event.isAlt = mIsAltDown;
|
1999-03-19 23:36:20 +00:00
|
|
|
|
|
|
|
(void)DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
1998-04-17 23:45:07 +00:00
|
|
|
|
1999-10-25 22:17:09 +00:00
|
|
|
if(event.rangeArray)
|
|
|
|
delete [] event.rangeArray;
|
|
|
|
|
1999-08-06 07:42:35 +00:00
|
|
|
//
|
|
|
|
// Post process event
|
|
|
|
//
|
2002-02-18 23:46:51 +00:00
|
|
|
if((0 != event.theReply.mCursorPosition.width) ||
|
|
|
|
(0 != event.theReply.mCursorPosition.height) )
|
|
|
|
{
|
|
|
|
candForm.dwIndex = 0;
|
|
|
|
candForm.dwStyle = CFS_EXCLUDE;
|
|
|
|
candForm.ptCurrentPos.x = event.theReply.mCursorPosition.x;
|
|
|
|
candForm.ptCurrentPos.y = event.theReply.mCursorPosition.y;
|
|
|
|
candForm.rcArea.right = candForm.rcArea.left = candForm.ptCurrentPos.x;
|
|
|
|
candForm.rcArea.top = candForm.ptCurrentPos.y;
|
|
|
|
candForm.rcArea.bottom = candForm.ptCurrentPos.y +
|
|
|
|
event.theReply.mCursorPosition.height;
|
2001-03-21 21:13:26 +00:00
|
|
|
|
2002-09-25 02:23:01 +00:00
|
|
|
if (gPinYinIMECaretCreated)
|
|
|
|
{
|
|
|
|
SetCaretPos(candForm.ptCurrentPos.x, candForm.ptCurrentPos.y);
|
|
|
|
}
|
|
|
|
|
2002-02-18 23:46:51 +00:00
|
|
|
NS_IMM_SETCANDIDATEWINDOW(hIMEContext,&candForm);
|
2002-03-22 23:09:01 +00:00
|
|
|
// somehow the "Intellegent ABC IME" in Simplified Chinese
|
|
|
|
// window listen to the caret position to decide where to put the
|
|
|
|
// candidate window
|
|
|
|
if(gKeyboardLayout == ZH_CN_INTELLEGENT_ABC_IME)
|
|
|
|
{
|
|
|
|
CreateCaret(mWnd, nsnull, 1, 1);
|
|
|
|
SetCaretPos( candForm.ptCurrentPos.x, candForm.ptCurrentPos.y);
|
|
|
|
DestroyCaret();
|
|
|
|
}
|
2002-10-01 02:47:41 +00:00
|
|
|
|
|
|
|
// Record previous composing char position
|
|
|
|
// The cursor is always on the right char before it, but not nessarily on the
|
|
|
|
// left of next char, as what happens in wrapping.
|
|
|
|
if (mIMECursorPosition &&
|
|
|
|
mIMECompCharPos &&
|
|
|
|
mIMECursorPosition < IME_MAX_CHAR_POS) {
|
|
|
|
mIMECompCharPos[mIMECursorPosition-1].right = event.theReply.mCursorPosition.x;
|
|
|
|
mIMECompCharPos[mIMECursorPosition-1].top = event.theReply.mCursorPosition.y;
|
|
|
|
mIMECompCharPos[mIMECursorPosition-1].bottom = event.theReply.mCursorPosition.YMost();
|
|
|
|
if (mIMECompCharPos[mIMECursorPosition-1].top != event.theReply.mCursorPosition.y) {
|
|
|
|
// wrapping, invalidate left position
|
|
|
|
mIMECompCharPos[mIMECursorPosition-1].left = -1;
|
|
|
|
}
|
|
|
|
mIMECompCharPos[mIMECursorPosition].left = event.theReply.mCursorPosition.x;
|
|
|
|
mIMECompCharPos[mIMECursorPosition].top = event.theReply.mCursorPosition.y;
|
|
|
|
mIMECompCharPos[mIMECursorPosition].bottom = event.theReply.mCursorPosition.YMost();
|
|
|
|
}
|
2002-02-18 23:46:51 +00:00
|
|
|
} else {
|
|
|
|
// for some reason we don't know yet, theReply may contains invalid result
|
|
|
|
// need more debugging in nsCaret to find out the reason
|
|
|
|
// the best we can do now is to ignore the invalid result
|
|
|
|
}
|
1999-08-06 07:42:35 +00:00
|
|
|
|
1999-03-19 23:36:20 +00:00
|
|
|
}
|
1999-05-03 22:57:48 +00:00
|
|
|
|
2002-05-23 22:03:49 +00:00
|
|
|
BOOL
|
1999-08-31 01:20:32 +00:00
|
|
|
nsWindow::HandleStartComposition(HIMC hIMEContext)
|
1999-05-03 22:57:48 +00:00
|
|
|
{
|
1999-11-10 23:43:46 +00:00
|
|
|
NS_ASSERTION( !mIMEIsComposing, "conflict state");
|
2004-01-12 08:25:18 +00:00
|
|
|
nsCompositionEvent event(NS_COMPOSITION_START, this);
|
|
|
|
nsPoint point(0, 0);
|
1999-08-31 01:20:32 +00:00
|
|
|
CANDIDATEFORM candForm;
|
1999-05-03 22:57:48 +00:00
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event,&point);
|
1999-05-03 22:57:48 +00:00
|
|
|
(void)DispatchWindowEvent(&event);
|
1999-08-31 01:20:32 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// Post process event
|
|
|
|
//
|
2002-02-18 23:46:51 +00:00
|
|
|
if((0 != event.theReply.mCursorPosition.width) ||
|
|
|
|
(0 != event.theReply.mCursorPosition.height) )
|
|
|
|
{
|
|
|
|
candForm.dwIndex = 0;
|
|
|
|
candForm.dwStyle = CFS_CANDIDATEPOS;
|
|
|
|
candForm.ptCurrentPos.x = event.theReply.mCursorPosition.x + IME_X_OFFSET;
|
|
|
|
candForm.ptCurrentPos.y = event.theReply.mCursorPosition.y + IME_Y_OFFSET
|
|
|
|
+ event.theReply.mCursorPosition.height;
|
|
|
|
candForm.rcArea.right = 0;
|
|
|
|
candForm.rcArea.left = 0;
|
|
|
|
candForm.rcArea.top = 0;
|
|
|
|
candForm.rcArea.bottom = 0;
|
1999-11-30 22:09:28 +00:00
|
|
|
#ifdef DEBUG_IME2
|
2002-02-18 23:46:51 +00:00
|
|
|
printf("Candidate window position: x=%d, y=%d\n",candForm.ptCurrentPos.x,candForm.ptCurrentPos.y);
|
1999-08-31 01:20:32 +00:00
|
|
|
#endif
|
2002-09-25 02:23:01 +00:00
|
|
|
|
|
|
|
if (!gPinYinIMECaretCreated && PINYIN_IME_ON_XP(gKeyboardLayout))
|
|
|
|
{
|
|
|
|
gPinYinIMECaretCreated = CreateCaret(mWnd, nsnull, 1, 1);
|
|
|
|
SetCaretPos(candForm.ptCurrentPos.x, candForm.ptCurrentPos.y);
|
|
|
|
}
|
|
|
|
|
2002-02-18 23:46:51 +00:00
|
|
|
NS_IMM_SETCANDIDATEWINDOW(hIMEContext, &candForm);
|
2002-10-01 02:47:41 +00:00
|
|
|
|
|
|
|
mIMECompCharPos = (RECT*)PR_MALLOC(IME_MAX_CHAR_POS*sizeof(RECT));
|
|
|
|
if (mIMECompCharPos) {
|
|
|
|
memset(mIMECompCharPos, -1, sizeof(RECT)*IME_MAX_CHAR_POS);
|
|
|
|
mIMECompCharPos[0].left = event.theReply.mCursorPosition.x;
|
|
|
|
mIMECompCharPos[0].top = event.theReply.mCursorPosition.y;
|
|
|
|
mIMECompCharPos[0].bottom = event.theReply.mCursorPosition.YMost();
|
|
|
|
}
|
2002-02-18 23:46:51 +00:00
|
|
|
} else {
|
|
|
|
// for some reason we don't know yet, theReply may contains invalid result
|
|
|
|
// need more debugging in nsCaret to find out the reason
|
|
|
|
// the best we can do now is to ignore the invalid result
|
|
|
|
}
|
2002-10-01 02:47:41 +00:00
|
|
|
|
1999-05-03 22:57:48 +00:00
|
|
|
NS_RELEASE(event.widget);
|
1999-11-16 23:45:44 +00:00
|
|
|
|
|
|
|
if(nsnull == mIMECompString)
|
|
|
|
mIMECompString = new nsCAutoString();
|
|
|
|
if(nsnull == mIMECompUnicode)
|
|
|
|
mIMECompUnicode = new nsAutoString();
|
1999-11-10 23:43:46 +00:00
|
|
|
mIMEIsComposing = PR_TRUE;
|
|
|
|
|
2002-05-23 22:03:49 +00:00
|
|
|
return PR_TRUE;
|
1999-05-03 22:57:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
nsWindow::HandleEndComposition(void)
|
|
|
|
{
|
1999-11-10 23:43:46 +00:00
|
|
|
NS_ASSERTION(mIMEIsComposing, "conflict state");
|
2004-01-12 08:25:18 +00:00
|
|
|
nsCompositionEvent event(NS_COMPOSITION_END, this);
|
|
|
|
nsPoint point(0, 0);
|
1999-05-03 22:57:48 +00:00
|
|
|
|
2002-09-25 02:23:01 +00:00
|
|
|
if (gPinYinIMECaretCreated)
|
|
|
|
{
|
|
|
|
DestroyCaret();
|
|
|
|
gPinYinIMECaretCreated = PR_FALSE;
|
|
|
|
}
|
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event,&point);
|
1999-05-03 22:57:48 +00:00
|
|
|
(void)DispatchWindowEvent(&event);
|
|
|
|
NS_RELEASE(event.widget);
|
2002-10-01 02:47:41 +00:00
|
|
|
PR_FREEIF(mIMECompCharPos);
|
|
|
|
mIMECompCharPos = nsnull;
|
1999-11-10 23:43:46 +00:00
|
|
|
mIMEIsComposing = PR_FALSE;
|
1999-05-03 22:57:48 +00:00
|
|
|
}
|
1999-06-29 20:31:22 +00:00
|
|
|
|
1999-11-30 22:09:28 +00:00
|
|
|
static PRUint32 PlatformToNSAttr(PRUint8 aAttr)
|
1999-10-25 22:17:09 +00:00
|
|
|
{
|
|
|
|
switch(aAttr)
|
|
|
|
{
|
1999-11-30 22:09:28 +00:00
|
|
|
case ATTR_INPUT_ERROR:
|
|
|
|
// case ATTR_FIXEDCONVERTED:
|
1999-10-25 22:17:09 +00:00
|
|
|
case ATTR_INPUT:
|
|
|
|
return NS_TEXTRANGE_RAWINPUT;
|
|
|
|
case ATTR_CONVERTED:
|
|
|
|
return NS_TEXTRANGE_CONVERTEDTEXT;
|
|
|
|
case ATTR_TARGET_NOTCONVERTED:
|
|
|
|
return NS_TEXTRANGE_SELECTEDRAWTEXT;
|
|
|
|
case ATTR_TARGET_CONVERTED:
|
|
|
|
return NS_TEXTRANGE_SELECTEDCONVERTEDTEXT;
|
|
|
|
default:
|
|
|
|
NS_ASSERTION(PR_FALSE, "unknown attribute");
|
|
|
|
return NS_TEXTRANGE_CARETPOSITION;
|
|
|
|
}
|
|
|
|
}
|
1999-06-29 20:31:22 +00:00
|
|
|
//
|
|
|
|
// This function converters the composition string (CGS_COMPSTR) into Unicode while mapping the
|
|
|
|
// attribute (GCS_ATTR) string t
|
|
|
|
void
|
|
|
|
nsWindow::MapDBCSAtrributeArrayToUnicodeOffsets(PRUint32* textRangeListLengthResult,nsTextRangeArray* textRangeListResult)
|
|
|
|
{
|
1999-11-16 23:45:44 +00:00
|
|
|
NS_ASSERTION( mIMECompString, "mIMECompString is null");
|
|
|
|
NS_ASSERTION( mIMECompUnicode, "mIMECompUnicode is null");
|
|
|
|
if((nsnull == mIMECompString) || (nsnull == mIMECompUnicode))
|
|
|
|
return;
|
1999-11-30 22:09:28 +00:00
|
|
|
PRInt32 rangePointer;
|
1999-06-29 20:31:22 +00:00
|
|
|
size_t lastUnicodeOffset, substringLength, lastMBCSOffset;
|
2000-04-13 22:23:04 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// On Windows NT / 2000, it doesn't use mIMECompString.
|
|
|
|
// IME strings already store to mIMECompUnicode.
|
|
|
|
//
|
|
|
|
|
2002-03-18 23:29:39 +00:00
|
|
|
long maxlen = nsToolkit::mUseImeApiW ? mIMECompUnicode->Length() : mIMECompString->Length();
|
1999-11-30 22:09:28 +00:00
|
|
|
long cursor = mIMECursorPosition;
|
|
|
|
NS_ASSERTION(cursor <= maxlen, "wrong cursor positoin");
|
|
|
|
if(cursor > maxlen)
|
|
|
|
cursor = maxlen;
|
|
|
|
|
1999-06-29 20:31:22 +00:00
|
|
|
//
|
|
|
|
// figure out the ranges from the compclause string
|
|
|
|
//
|
|
|
|
if (mIMECompClauseStringLength==0) {
|
1999-07-14 20:08:02 +00:00
|
|
|
*textRangeListLengthResult = 2;
|
|
|
|
*textRangeListResult = new nsTextRange[2];
|
1999-06-29 20:31:22 +00:00
|
|
|
(*textRangeListResult)[0].mStartOffset=0;
|
2002-03-18 23:29:39 +00:00
|
|
|
substringLength = nsToolkit::mUseImeApiW ? mIMECompUnicode->Length() :
|
2000-04-13 22:23:04 +00:00
|
|
|
::MultiByteToWideChar(gCurrentKeyboardCP,MB_PRECOMPOSED,
|
2001-03-02 09:26:57 +00:00
|
|
|
mIMECompString->get(), maxlen,NULL,0);
|
1999-07-14 20:08:02 +00:00
|
|
|
(*textRangeListResult)[0].mEndOffset = substringLength;
|
1999-07-19 21:17:21 +00:00
|
|
|
(*textRangeListResult)[0].mRangeType = NS_TEXTRANGE_RAWINPUT;
|
2002-03-18 23:29:39 +00:00
|
|
|
substringLength = nsToolkit::mUseImeApiW ? cursor :
|
2001-03-02 09:26:57 +00:00
|
|
|
::MultiByteToWideChar(gCurrentKeyboardCP,MB_PRECOMPOSED,mIMECompString->get(),
|
1999-11-30 22:09:28 +00:00
|
|
|
cursor,NULL,0);
|
1999-10-25 22:17:09 +00:00
|
|
|
(*textRangeListResult)[1].mStartOffset=substringLength;
|
|
|
|
(*textRangeListResult)[1].mEndOffset = substringLength;
|
|
|
|
(*textRangeListResult)[1].mRangeType = NS_TEXTRANGE_CARETPOSITION;
|
1999-07-14 20:08:02 +00:00
|
|
|
|
|
|
|
|
1999-06-29 20:31:22 +00:00
|
|
|
} else {
|
|
|
|
|
1999-11-30 22:09:28 +00:00
|
|
|
*textRangeListLengthResult = mIMECompClauseStringLength;
|
1999-06-29 20:31:22 +00:00
|
|
|
|
|
|
|
//
|
|
|
|
// allocate the offset array
|
|
|
|
//
|
|
|
|
*textRangeListResult = new nsTextRange[*textRangeListLengthResult];
|
|
|
|
|
1999-07-14 20:08:02 +00:00
|
|
|
//
|
|
|
|
// figure out the cursor position
|
|
|
|
//
|
|
|
|
|
2002-03-18 23:29:39 +00:00
|
|
|
substringLength = nsToolkit::mUseImeApiW ? cursor :
|
2000-04-13 22:23:04 +00:00
|
|
|
::MultiByteToWideChar(gCurrentKeyboardCP,
|
2001-03-02 09:26:57 +00:00
|
|
|
MB_PRECOMPOSED,mIMECompString->get(),cursor,NULL,0);
|
1999-07-14 20:08:02 +00:00
|
|
|
(*textRangeListResult)[0].mStartOffset=substringLength;
|
|
|
|
(*textRangeListResult)[0].mEndOffset = substringLength;
|
|
|
|
(*textRangeListResult)[0].mRangeType = NS_TEXTRANGE_CARETPOSITION;
|
|
|
|
|
|
|
|
|
1999-06-29 20:31:22 +00:00
|
|
|
//
|
|
|
|
// iterate over the attributes and convert them into unicode
|
1999-11-30 22:09:28 +00:00
|
|
|
for(rangePointer=1, lastUnicodeOffset= lastMBCSOffset = 0;
|
|
|
|
rangePointer<mIMECompClauseStringLength;
|
|
|
|
rangePointer++)
|
|
|
|
{
|
|
|
|
long current = mIMECompClauseString[rangePointer];
|
|
|
|
NS_ASSERTION(current <= maxlen, "wrong offset");
|
|
|
|
if(current > maxlen)
|
|
|
|
current = maxlen;
|
|
|
|
|
|
|
|
(*textRangeListResult)[rangePointer].mRangeType =
|
|
|
|
PlatformToNSAttr(mIMEAttributeString[lastMBCSOffset]);
|
|
|
|
(*textRangeListResult)[rangePointer].mStartOffset = lastUnicodeOffset;
|
|
|
|
|
2002-03-18 23:29:39 +00:00
|
|
|
lastUnicodeOffset += nsToolkit::mUseImeApiW ? current - lastMBCSOffset :
|
2000-04-13 22:23:04 +00:00
|
|
|
::MultiByteToWideChar(gCurrentKeyboardCP,
|
2001-03-02 09:26:57 +00:00
|
|
|
MB_PRECOMPOSED,mIMECompString->get()+lastMBCSOffset,
|
1999-11-30 22:09:28 +00:00
|
|
|
current-lastMBCSOffset,NULL,0);
|
|
|
|
|
|
|
|
(*textRangeListResult)[rangePointer].mEndOffset = lastUnicodeOffset;
|
|
|
|
|
|
|
|
lastMBCSOffset = current;
|
|
|
|
} // for
|
|
|
|
} // if else
|
1999-06-29 20:31:22 +00:00
|
|
|
|
|
|
|
|
|
|
|
}
|
1999-11-11 22:28:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//==========================================================================
|
1999-12-01 22:10:13 +00:00
|
|
|
BOOL nsWindow::OnInputLangChange(HKL aHKL, LRESULT *oRetValue)
|
1999-11-11 22:28:52 +00:00
|
|
|
{
|
1999-12-01 22:10:13 +00:00
|
|
|
#ifdef KE_DEBUG
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnInputLanguageChange\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
|
2001-09-29 00:15:21 +00:00
|
|
|
if(gKeyboardLayout != aHKL)
|
|
|
|
{
|
|
|
|
gKeyboardLayout = aHKL;
|
|
|
|
*oRetValue = LangIDToCP((WORD)((DWORD)gKeyboardLayout & 0x0FFFF),
|
|
|
|
gCurrentKeyboardCP);
|
2002-05-08 20:24:55 +00:00
|
|
|
if (nsToolkit::mW2KXP_CP936) {
|
|
|
|
DWORD imeProp = 0;
|
|
|
|
NS_IMM_GETPROPERTY(gKeyboardLayout, IGP_PROPERTY, imeProp);
|
|
|
|
nsToolkit::mUseImeApiW = (imeProp & IME_PROP_UNICODE) ? PR_TRUE : PR_FALSE;
|
|
|
|
}
|
2001-09-29 00:15:21 +00:00
|
|
|
}
|
1999-11-11 22:28:52 +00:00
|
|
|
|
2001-09-29 00:15:21 +00:00
|
|
|
ResetInputState();
|
|
|
|
|
|
|
|
if (mIMEIsComposing) {
|
|
|
|
HandleEndComposition();
|
|
|
|
}
|
|
|
|
|
|
|
|
return PR_FALSE; // always pass to child window
|
1999-11-11 22:28:52 +00:00
|
|
|
}
|
|
|
|
//==========================================================================
|
|
|
|
BOOL nsWindow::OnIMEChar(BYTE aByte1, BYTE aByte2, LPARAM aKeyState)
|
|
|
|
{
|
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMEChar\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
2002-05-23 22:03:49 +00:00
|
|
|
wchar_t uniChar;
|
|
|
|
char charToConvert[3];
|
|
|
|
size_t length;
|
|
|
|
int err = 0;
|
1999-11-11 22:28:52 +00:00
|
|
|
|
2002-09-18 23:19:18 +00:00
|
|
|
if (nsToolkit::mIsNT) {
|
2002-09-12 18:21:52 +00:00
|
|
|
uniChar = MAKEWORD(aByte2, aByte1);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (aByte1) {
|
|
|
|
charToConvert[0] = aByte1;
|
|
|
|
charToConvert[1] = aByte2;
|
|
|
|
length=2;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
charToConvert[0] = aByte2;
|
|
|
|
length=1;
|
|
|
|
}
|
|
|
|
err = ::MultiByteToWideChar(gCurrentKeyboardCP, MB_PRECOMPOSED, charToConvert, length,
|
|
|
|
&uniChar, 1);
|
|
|
|
}
|
2002-05-23 22:03:49 +00:00
|
|
|
|
|
|
|
#ifdef DEBUG_IME
|
|
|
|
if (!err) {
|
|
|
|
DWORD lastError = ::GetLastError();
|
|
|
|
switch (lastError)
|
|
|
|
{
|
|
|
|
case ERROR_INSUFFICIENT_BUFFER:
|
|
|
|
printf("ERROR_INSUFFICIENT_BUFFER\n");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ERROR_INVALID_FLAGS:
|
|
|
|
printf("ERROR_INVALID_FLAGS\n");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ERROR_INVALID_PARAMETER:
|
|
|
|
printf("ERROR_INVALID_PARAMETER\n");
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ERROR_NO_UNICODE_TRANSLATION:
|
|
|
|
printf("ERROR_NO_UNICODE_TRANSLATION\n");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2004-04-18 11:03:51 +00:00
|
|
|
// We need to return TRUE here so that Windows doesn't
|
2002-05-23 22:03:49 +00:00
|
|
|
// send two WM_CHAR msgs
|
|
|
|
DispatchKeyEvent(NS_KEY_PRESS, uniChar, 0, 0);
|
|
|
|
return PR_TRUE;
|
1999-11-11 22:28:52 +00:00
|
|
|
}
|
|
|
|
//==========================================================================
|
|
|
|
BOOL nsWindow::OnIMEComposition(LPARAM aGCS)
|
|
|
|
{
|
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMEComposition\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
2001-01-18 03:16:04 +00:00
|
|
|
// for bug #60050
|
|
|
|
// MS-IME 95/97/98/2000 may send WM_IME_COMPOSITION with non-conversion
|
|
|
|
// mode before it send WM_IME_STARTCOMPOSITION.
|
|
|
|
|
|
|
|
if (mIMEIsComposing != PR_TRUE)
|
|
|
|
{
|
|
|
|
if(!mIMECompString)
|
|
|
|
mIMECompString = new nsCAutoString();
|
|
|
|
|
|
|
|
if(!mIMECompUnicode)
|
|
|
|
mIMECompUnicode = new nsAutoString();
|
|
|
|
}
|
|
|
|
|
1999-11-16 23:45:44 +00:00
|
|
|
NS_ASSERTION( mIMECompString, "mIMECompString is null");
|
|
|
|
NS_ASSERTION( mIMECompUnicode, "mIMECompUnicode is null");
|
|
|
|
if((nsnull == mIMECompString) || (nsnull == mIMECompUnicode))
|
|
|
|
return PR_TRUE;
|
1999-11-11 22:28:52 +00:00
|
|
|
|
|
|
|
HIMC hIMEContext;
|
|
|
|
|
|
|
|
BOOL result = PR_FALSE; // will change this if an IME message we handle
|
2000-01-07 00:34:34 +00:00
|
|
|
NS_IMM_GETCONTEXT(mWnd, hIMEContext);
|
1999-11-11 22:28:52 +00:00
|
|
|
if (hIMEContext==NULL)
|
|
|
|
return PR_TRUE;
|
|
|
|
|
|
|
|
//
|
|
|
|
// This catches a fixed result
|
|
|
|
//
|
|
|
|
if (aGCS & GCS_RESULTSTR) {
|
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
fprintf(stderr,"Handling GCS_RESULTSTR\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
if(! mIMEIsComposing)
|
|
|
|
HandleStartComposition(hIMEContext);
|
|
|
|
|
2000-04-13 22:23:04 +00:00
|
|
|
//
|
|
|
|
// On Windows 2000, ImmGetCompositionStringA() don't work well using IME of
|
|
|
|
// different code page. (See BUG # 29606)
|
|
|
|
// And ImmGetCompositionStringW() don't work on Windows 9x.
|
|
|
|
//
|
|
|
|
|
2000-01-07 00:34:34 +00:00
|
|
|
long compStrLen;
|
2002-03-18 23:29:39 +00:00
|
|
|
if (nsToolkit::mUseImeApiW) {
|
2000-04-13 22:23:04 +00:00
|
|
|
// Imm* Unicode API works on Windows NT / 2000.
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext, GCS_RESULTSTR, NULL, 0, compStrLen);
|
|
|
|
|
|
|
|
mIMECompUnicode->SetCapacity((compStrLen / sizeof(WCHAR))+1);
|
1999-11-16 23:45:44 +00:00
|
|
|
|
2001-11-15 23:42:00 +00:00
|
|
|
long buflen = compStrLen + sizeof(WCHAR);
|
2000-04-13 22:23:04 +00:00
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext, GCS_RESULTSTR,
|
2001-11-15 23:42:00 +00:00
|
|
|
(LPVOID)mIMECompUnicode->get(), buflen, compStrLen);
|
2000-04-13 22:23:04 +00:00
|
|
|
compStrLen = compStrLen / sizeof(WCHAR);
|
2001-11-14 12:35:52 +00:00
|
|
|
mIMECompUnicode->SetLength(compStrLen);
|
2000-04-13 22:23:04 +00:00
|
|
|
} else {
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext, GCS_RESULTSTR, NULL, 0, compStrLen);
|
2000-01-07 00:34:34 +00:00
|
|
|
|
2000-04-13 22:23:04 +00:00
|
|
|
mIMECompString->SetCapacity(compStrLen+1);
|
1999-11-11 22:28:52 +00:00
|
|
|
|
2001-11-15 23:42:00 +00:00
|
|
|
long buflen = compStrLen + 1;
|
2000-04-13 22:23:04 +00:00
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext, GCS_RESULTSTR,
|
2001-11-15 23:42:00 +00:00
|
|
|
(LPVOID)mIMECompString->get(), buflen, compStrLen);
|
2001-11-14 12:35:52 +00:00
|
|
|
mIMECompString->SetLength(compStrLen);
|
2000-04-13 22:23:04 +00:00
|
|
|
}
|
1999-11-11 22:28:52 +00:00
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
fprintf(stderr,"GCS_RESULTSTR compStrLen = %d\n", compStrLen);
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
result = PR_TRUE;
|
|
|
|
HandleTextEvent(hIMEContext, PR_FALSE);
|
|
|
|
HandleEndComposition();
|
|
|
|
}
|
1999-11-30 22:09:28 +00:00
|
|
|
|
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
//
|
|
|
|
// This provides us with a composition string
|
|
|
|
//
|
1999-11-30 22:09:28 +00:00
|
|
|
if (aGCS &
|
|
|
|
(GCS_COMPSTR | GCS_COMPATTR | GCS_COMPCLAUSE | GCS_CURSORPOS ))
|
|
|
|
{
|
1999-11-11 22:28:52 +00:00
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
fprintf(stderr,"Handling GCS_COMPSTR\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
1999-11-30 22:09:28 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
if(! mIMEIsComposing)
|
|
|
|
HandleStartComposition(hIMEContext);
|
|
|
|
|
1999-11-30 22:09:28 +00:00
|
|
|
//--------------------------------------------------------
|
|
|
|
// 1. Get GCS_COMPATTR
|
|
|
|
//--------------------------------------------------------
|
|
|
|
// This provides us with the attribute string necessary
|
|
|
|
// for doing hiliting
|
2000-01-07 00:34:34 +00:00
|
|
|
long attrStrLen;
|
2002-03-18 23:29:39 +00:00
|
|
|
if (nsToolkit::mUseImeApiW) {
|
2000-04-13 22:23:04 +00:00
|
|
|
// Imm* Unicode API works on Windows NT / 2000.
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext, GCS_COMPATTR, NULL, 0, attrStrLen);
|
|
|
|
if (attrStrLen > mIMEAttributeStringSize) {
|
|
|
|
if (mIMEAttributeString != NULL)
|
|
|
|
delete [] mIMEAttributeString;
|
|
|
|
mIMEAttributeString = new PRUint8[attrStrLen+32];
|
|
|
|
mIMEAttributeStringSize = attrStrLen+32;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext, GCS_COMPATTR, mIMEAttributeString, mIMEAttributeStringSize, attrStrLen);
|
|
|
|
} else {
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext, GCS_COMPATTR, NULL, 0, attrStrLen);
|
|
|
|
if (attrStrLen>mIMEAttributeStringSize) {
|
|
|
|
if (mIMEAttributeString!=NULL)
|
|
|
|
delete [] mIMEAttributeString;
|
|
|
|
mIMEAttributeString = new PRUint8[attrStrLen+32];
|
|
|
|
mIMEAttributeStringSize = attrStrLen+32;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext, GCS_COMPATTR, mIMEAttributeString, mIMEAttributeStringSize, attrStrLen);
|
|
|
|
}
|
|
|
|
|
1999-11-30 22:09:28 +00:00
|
|
|
mIMEAttributeStringLength = attrStrLen;
|
|
|
|
|
|
|
|
//--------------------------------------------------------
|
|
|
|
// 2. Get GCS_COMPCLAUSE
|
|
|
|
//--------------------------------------------------------
|
2000-01-07 00:34:34 +00:00
|
|
|
long compClauseLen;
|
2000-04-13 22:23:04 +00:00
|
|
|
long compClauseLen2;
|
2002-03-18 23:29:39 +00:00
|
|
|
if (nsToolkit::mUseImeApiW) {
|
2000-04-13 22:23:04 +00:00
|
|
|
// Imm* Unicode API works on Windows NT / 2000.
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext,
|
|
|
|
GCS_COMPCLAUSE, NULL, 0, compClauseLen);
|
|
|
|
compClauseLen = compClauseLen / sizeof(PRUint32);
|
|
|
|
|
|
|
|
if (compClauseLen > mIMECompClauseStringSize) {
|
|
|
|
if (mIMECompClauseString != NULL)
|
|
|
|
delete [] mIMECompClauseString;
|
|
|
|
mIMECompClauseString = new PRUint32 [compClauseLen+32];
|
|
|
|
mIMECompClauseStringSize = compClauseLen+32;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext,
|
|
|
|
GCS_COMPCLAUSE,
|
|
|
|
mIMECompClauseString,
|
|
|
|
mIMECompClauseStringSize * sizeof(PRUint32),
|
|
|
|
compClauseLen2);
|
|
|
|
} else {
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext,
|
|
|
|
GCS_COMPCLAUSE, NULL, 0, compClauseLen);
|
|
|
|
compClauseLen = compClauseLen / sizeof(PRUint32);
|
|
|
|
|
|
|
|
if (compClauseLen>mIMECompClauseStringSize) {
|
|
|
|
if (mIMECompClauseString!=NULL)
|
|
|
|
delete [] mIMECompClauseString;
|
|
|
|
mIMECompClauseString = new PRUint32 [compClauseLen+32];
|
|
|
|
mIMECompClauseStringSize = compClauseLen+32;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext,
|
|
|
|
GCS_COMPCLAUSE,
|
|
|
|
mIMECompClauseString,
|
|
|
|
mIMECompClauseStringSize * sizeof(PRUint32),
|
|
|
|
compClauseLen2);
|
|
|
|
}
|
2000-01-07 00:34:34 +00:00
|
|
|
compClauseLen2 = compClauseLen2 / sizeof(PRUint32);
|
1999-12-01 22:10:13 +00:00
|
|
|
NS_ASSERTION(compClauseLen2 == compClauseLen, "strange result");
|
|
|
|
if(compClauseLen > compClauseLen2)
|
|
|
|
compClauseLen = compClauseLen2;
|
1999-11-30 22:09:28 +00:00
|
|
|
mIMECompClauseStringLength = compClauseLen;
|
1999-12-01 22:10:13 +00:00
|
|
|
|
1999-11-30 22:09:28 +00:00
|
|
|
|
|
|
|
//--------------------------------------------------------
|
|
|
|
// 3. Get GCS_CURSOPOS
|
|
|
|
//--------------------------------------------------------
|
2002-03-18 23:29:39 +00:00
|
|
|
if (nsToolkit::mUseImeApiW) {
|
2000-04-13 22:23:04 +00:00
|
|
|
// Imm* Unicode API works on Windows NT / 2000.
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext, GCS_CURSORPOS, NULL, 0, mIMECursorPosition);
|
|
|
|
} else {
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext, GCS_CURSORPOS, NULL, 0, mIMECursorPosition);
|
|
|
|
}
|
1999-11-30 22:09:28 +00:00
|
|
|
|
|
|
|
//--------------------------------------------------------
|
|
|
|
// 4. Get GCS_COMPSTR
|
|
|
|
//--------------------------------------------------------
|
2000-01-07 00:34:34 +00:00
|
|
|
long compStrLen;
|
2002-03-18 23:29:39 +00:00
|
|
|
if (nsToolkit::mUseImeApiW) {
|
2000-04-13 22:23:04 +00:00
|
|
|
// Imm* Unicode API works on Windows NT / 2000.
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext, GCS_COMPSTR, NULL, 0, compStrLen);
|
|
|
|
|
|
|
|
mIMECompUnicode->SetCapacity((compStrLen / sizeof(WCHAR)) + 1);
|
|
|
|
|
2001-11-15 23:42:00 +00:00
|
|
|
long buflen = compStrLen + sizeof(WCHAR);
|
2000-04-13 22:23:04 +00:00
|
|
|
NS_IMM_GETCOMPOSITIONSTRINGW(hIMEContext,
|
|
|
|
GCS_COMPSTR,
|
2001-06-30 11:02:25 +00:00
|
|
|
(LPVOID)mIMECompUnicode->get(),
|
2001-11-15 23:42:00 +00:00
|
|
|
buflen, compStrLen);
|
2000-04-13 22:23:04 +00:00
|
|
|
compStrLen = compStrLen / sizeof(WCHAR);
|
2001-11-14 12:35:52 +00:00
|
|
|
mIMECompUnicode->SetLength(compStrLen);
|
2000-04-13 22:23:04 +00:00
|
|
|
} else {
|
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext, GCS_COMPSTR, NULL, 0, compStrLen);
|
|
|
|
mIMECompString->SetCapacity(compStrLen+1);
|
|
|
|
|
2001-11-15 23:42:00 +00:00
|
|
|
long buflen = compStrLen + 1;
|
2000-04-13 22:23:04 +00:00
|
|
|
NS_IMM_GETCOMPOSITIONSTRING(hIMEContext,
|
|
|
|
GCS_COMPSTR,
|
2004-02-28 22:34:07 +00:00
|
|
|
mIMECompString->BeginWriting(),
|
2001-11-15 23:42:00 +00:00
|
|
|
buflen, compStrLen);
|
2001-11-14 12:35:52 +00:00
|
|
|
mIMECompString->SetLength(compStrLen);
|
2000-04-13 22:23:04 +00:00
|
|
|
}
|
1999-11-11 22:28:52 +00:00
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
fprintf(stderr,"GCS_COMPSTR compStrLen = %d\n", compStrLen);
|
1999-12-01 22:10:13 +00:00
|
|
|
#endif
|
|
|
|
#ifdef DEBUG
|
|
|
|
for(int kk=0;kk<mIMECompClauseStringLength;kk++)
|
|
|
|
{
|
2002-03-18 23:29:39 +00:00
|
|
|
NS_ASSERTION(mIMECompClauseString[kk] <= (nsToolkit::mUseImeApiW ? mIMECompUnicode->Length() : mIMECompString->Length()), "illegal pos");
|
1999-12-01 22:10:13 +00:00
|
|
|
}
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
1999-11-30 22:09:28 +00:00
|
|
|
//--------------------------------------------------------
|
|
|
|
// 5. Sent the text event
|
|
|
|
//--------------------------------------------------------
|
1999-11-11 22:28:52 +00:00
|
|
|
HandleTextEvent(hIMEContext);
|
|
|
|
result = PR_TRUE;
|
|
|
|
}
|
|
|
|
if(! result)
|
|
|
|
{
|
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
fprintf(stderr,"Haandle 0 length TextEvent. \n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
if(! mIMEIsComposing)
|
|
|
|
HandleStartComposition(hIMEContext);
|
|
|
|
|
2002-03-18 23:29:39 +00:00
|
|
|
if (nsToolkit::mUseImeApiW) {
|
2001-11-14 12:35:52 +00:00
|
|
|
mIMECompUnicode->Truncate();
|
2000-04-13 22:23:04 +00:00
|
|
|
} else {
|
2001-11-14 12:35:52 +00:00
|
|
|
mIMECompString->Truncate();
|
2000-04-13 22:23:04 +00:00
|
|
|
}
|
1999-11-11 22:28:52 +00:00
|
|
|
HandleTextEvent(hIMEContext,PR_FALSE);
|
|
|
|
result = PR_TRUE;
|
|
|
|
}
|
2000-01-07 00:34:34 +00:00
|
|
|
|
|
|
|
NS_IMM_RELEASECONTEXT(mWnd, hIMEContext);
|
1999-11-11 22:28:52 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
//==========================================================================
|
|
|
|
BOOL nsWindow::OnIMECompositionFull()
|
|
|
|
{
|
1999-11-30 22:09:28 +00:00
|
|
|
#ifdef DEBUG_IME2
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMECompositionFull\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// not implement yet
|
|
|
|
return PR_FALSE;
|
|
|
|
}
|
|
|
|
//==========================================================================
|
|
|
|
BOOL nsWindow::OnIMEEndComposition()
|
|
|
|
{
|
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMEEndComposition\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
if(mIMEIsComposing)
|
|
|
|
{
|
|
|
|
HIMC hIMEContext;
|
|
|
|
|
|
|
|
if ((mIMEProperty & IME_PROP_SPECIAL_UI) ||
|
|
|
|
(mIMEProperty & IME_PROP_AT_CARET))
|
|
|
|
return PR_FALSE;
|
|
|
|
|
2000-01-07 00:34:34 +00:00
|
|
|
NS_IMM_GETCONTEXT(mWnd, hIMEContext);
|
1999-11-11 22:28:52 +00:00
|
|
|
if (hIMEContext==NULL)
|
|
|
|
return PR_TRUE;
|
|
|
|
|
|
|
|
// IME on Korean NT somehow send WM_IME_ENDCOMPOSITION
|
|
|
|
// first when we hit space in composition mode
|
|
|
|
// we need to clear out the current composition string
|
|
|
|
// in that case.
|
2002-03-18 23:29:39 +00:00
|
|
|
if (nsToolkit::mUseImeApiW) {
|
2001-11-14 12:35:52 +00:00
|
|
|
mIMECompUnicode->Truncate(0);
|
2000-04-13 22:23:04 +00:00
|
|
|
} else {
|
2001-11-14 12:35:52 +00:00
|
|
|
mIMECompString->Truncate(0);
|
2000-04-13 22:23:04 +00:00
|
|
|
}
|
1999-11-11 22:28:52 +00:00
|
|
|
HandleTextEvent(hIMEContext, PR_FALSE);
|
|
|
|
|
|
|
|
HandleEndComposition();
|
2000-01-07 00:34:34 +00:00
|
|
|
NS_IMM_RELEASECONTEXT(mWnd, hIMEContext);
|
1999-11-11 22:28:52 +00:00
|
|
|
}
|
|
|
|
return PR_TRUE;
|
|
|
|
}
|
|
|
|
//==========================================================================
|
|
|
|
BOOL nsWindow::OnIMENotify(WPARAM aIMN, LPARAM aData, LRESULT *oResult)
|
|
|
|
{
|
1999-11-30 22:09:28 +00:00
|
|
|
#ifdef DEBUG_IME2
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMENotify ");
|
1999-11-15 20:57:41 +00:00
|
|
|
switch(aIMN) {
|
|
|
|
case IMN_CHANGECANDIDATE:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_CHANGECANDIDATE %x\n", aData);
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_CLOSECANDIDATE:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_CLOSECANDIDATE %x\n", aData);
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_CLOSESTATUSWINDOW:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_CLOSESTATUSWINDOW\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_GUIDELINE:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_GUIDELINE\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_OPENCANDIDATE:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_OPENCANDIDATE %x\n", aData);
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_OPENSTATUSWINDOW:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_OPENSTATUSWINDOW\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_SETCANDIDATEPOS:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_SETCANDIDATEPOS %x\n", aData);
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_SETCOMPOSITIONFONT:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_SETCOMPOSITIONFONT\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_SETCOMPOSITIONWINDOW:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_SETCOMPOSITIONWINDOW\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_SETCONVERSIONMODE:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_SETCONVERSIONMODE\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_SETOPENSTATUS:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_SETOPENSTATUS\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_SETSENTENCEMODE:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_SETSENTENCEMODE\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
|
|
|
case IMN_SETSTATUSWINDOWPOS:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_SETSTATUSWINDOWPOS\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
break;
|
2000-01-07 00:34:34 +00:00
|
|
|
case IMN_PRIVATE:
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("IMN_PRIVATE\n");
|
2000-01-07 00:34:34 +00:00
|
|
|
break;
|
1999-11-15 20:57:41 +00:00
|
|
|
};
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
|
2000-03-04 00:27:16 +00:00
|
|
|
// add hacky code here
|
2004-04-18 11:03:51 +00:00
|
|
|
if (IS_VK_DOWN(NS_VK_ALT)) {
|
|
|
|
mIsShiftDown = PR_FALSE;
|
|
|
|
mIsControlDown = PR_FALSE;
|
|
|
|
mIsAltDown = PR_TRUE;
|
|
|
|
|
|
|
|
DispatchKeyEvent(NS_KEY_PRESS, 0, 192, 0); // XXX hack hack hack
|
|
|
|
if (aIMN == IMN_SETOPENSTATUS)
|
|
|
|
mIMEIsStatusChanged = PR_TRUE;
|
2000-03-04 00:27:16 +00:00
|
|
|
}
|
2004-04-18 11:03:51 +00:00
|
|
|
// not implemented yet
|
|
|
|
return PR_FALSE;
|
1999-11-11 22:28:52 +00:00
|
|
|
}
|
|
|
|
//==========================================================================
|
2000-08-04 21:43:29 +00:00
|
|
|
BOOL nsWindow::OnIMERequest(WPARAM aIMR, LPARAM aData, LRESULT *oResult, PRBool aUseUnicode)
|
1999-11-11 22:28:52 +00:00
|
|
|
{
|
2000-08-04 21:43:29 +00:00
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMERequest\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
PRBool result = PR_FALSE;
|
|
|
|
|
|
|
|
switch(aIMR) {
|
|
|
|
case IMR_RECONVERTSTRING:
|
|
|
|
result = OnIMEReconvert(aData, oResult, aUseUnicode);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
//==========================================================================
|
|
|
|
PRBool nsWindow::OnIMEReconvert(LPARAM aData, LRESULT *oResult, PRBool aUseUnicode)
|
|
|
|
{
|
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMEReconvert\n");
|
2000-08-04 21:43:29 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
PRBool result = PR_FALSE;
|
|
|
|
RECONVERTSTRING* pReconv = (RECONVERTSTRING*) aData;
|
|
|
|
int len = 0;
|
|
|
|
|
|
|
|
if(!pReconv) {
|
|
|
|
|
|
|
|
//
|
|
|
|
// When reconvert, it must return need size to reconvert.
|
|
|
|
//
|
|
|
|
if(mIMEReconvertUnicode) {
|
|
|
|
nsMemory::Free(mIMEReconvertUnicode);
|
|
|
|
mIMEReconvertUnicode = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get reconversion string
|
2004-01-12 08:25:18 +00:00
|
|
|
nsReconversionEvent event(NS_RECONVERSION_QUERY, this);
|
|
|
|
nsPoint point(0, 0);
|
2000-08-04 21:43:29 +00:00
|
|
|
|
2004-01-12 08:25:18 +00:00
|
|
|
InitEvent(event, &point);
|
2000-08-04 21:43:29 +00:00
|
|
|
event.theReply.mReconversionString = NULL;
|
|
|
|
DispatchWindowEvent(&event);
|
|
|
|
|
|
|
|
mIMEReconvertUnicode = event.theReply.mReconversionString;
|
|
|
|
NS_RELEASE(event.widget);
|
|
|
|
|
|
|
|
// Return need size
|
|
|
|
|
|
|
|
if(mIMEReconvertUnicode) {
|
|
|
|
if (aUseUnicode) {
|
|
|
|
len = nsCRT::strlen(mIMEReconvertUnicode);
|
|
|
|
*oResult = sizeof(RECONVERTSTRING) + len * sizeof(WCHAR);
|
|
|
|
} else {
|
|
|
|
len = ::WideCharToMultiByte(gCurrentKeyboardCP, 0,
|
|
|
|
mIMEReconvertUnicode,
|
|
|
|
nsCRT::strlen(mIMEReconvertUnicode),
|
|
|
|
NULL, 0, NULL, NULL);
|
|
|
|
*oResult = sizeof(RECONVERTSTRING) + len;
|
|
|
|
}
|
|
|
|
|
|
|
|
result = PR_TRUE;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
|
|
|
|
//
|
|
|
|
// Fill reconvert struct
|
|
|
|
//
|
|
|
|
|
|
|
|
if (aUseUnicode) {
|
|
|
|
len = nsCRT::strlen(mIMEReconvertUnicode);
|
|
|
|
*oResult = sizeof(RECONVERTSTRING) + len * sizeof(WCHAR);
|
|
|
|
} else {
|
|
|
|
len = ::WideCharToMultiByte(gCurrentKeyboardCP, 0,
|
|
|
|
mIMEReconvertUnicode,
|
|
|
|
nsCRT::strlen(mIMEReconvertUnicode),
|
|
|
|
NULL, 0, NULL, NULL);
|
|
|
|
*oResult = sizeof(RECONVERTSTRING) + len;
|
|
|
|
}
|
|
|
|
|
|
|
|
::ZeroMemory(pReconv, sizeof(RECONVERTSTRING));
|
|
|
|
pReconv->dwSize = sizeof(RECONVERTSTRING);
|
|
|
|
pReconv->dwVersion = 0;
|
|
|
|
pReconv->dwStrLen = len;
|
|
|
|
pReconv->dwStrOffset = sizeof(RECONVERTSTRING);
|
|
|
|
pReconv->dwCompStrLen = len;
|
|
|
|
pReconv->dwCompStrOffset = 0;
|
|
|
|
pReconv->dwTargetStrLen = len;
|
|
|
|
pReconv->dwTargetStrOffset = 0;
|
|
|
|
|
|
|
|
if (aUseUnicode) {
|
|
|
|
::CopyMemory((LPVOID) (aData + sizeof(RECONVERTSTRING)),
|
|
|
|
mIMEReconvertUnicode, len * sizeof(WCHAR));
|
|
|
|
} else {
|
|
|
|
::WideCharToMultiByte(gCurrentKeyboardCP, 0,
|
|
|
|
mIMEReconvertUnicode,
|
|
|
|
nsCRT::strlen(mIMEReconvertUnicode),
|
|
|
|
(LPSTR) (aData + sizeof(RECONVERTSTRING)),
|
|
|
|
len,
|
|
|
|
NULL, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
result = PR_TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
1999-11-11 22:28:52 +00:00
|
|
|
}
|
2000-08-04 21:43:29 +00:00
|
|
|
|
1999-11-11 22:28:52 +00:00
|
|
|
//==========================================================================
|
|
|
|
BOOL nsWindow::OnIMESelect(BOOL aSelected, WORD aLangID)
|
|
|
|
{
|
1999-11-30 22:09:28 +00:00
|
|
|
#ifdef DEBUG_IME2
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMESelect\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// not implement yet
|
|
|
|
return PR_FALSE;
|
|
|
|
}
|
|
|
|
//==========================================================================
|
1999-11-15 20:57:41 +00:00
|
|
|
BOOL nsWindow::OnIMESetContext(BOOL aActive, LPARAM& aISC)
|
1999-11-11 22:28:52 +00:00
|
|
|
{
|
1999-11-30 22:09:28 +00:00
|
|
|
#ifdef DEBUG_IME2
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMESetContext %x %s %s %s Candidate[%s%s%s%s]\n", this,
|
1999-11-15 20:57:41 +00:00
|
|
|
(aActive ? "Active" : "Deactiv"),
|
|
|
|
((aISC & ISC_SHOWUICOMPOSITIONWINDOW) ? "[Comp]" : ""),
|
|
|
|
((aISC & ISC_SHOWUIGUIDELINE) ? "[GUID]" : ""),
|
|
|
|
((aISC & ISC_SHOWUICANDIDATEWINDOW) ? "0" : ""),
|
|
|
|
((aISC & (ISC_SHOWUICANDIDATEWINDOW<<1)) ? "1" : ""),
|
|
|
|
((aISC & (ISC_SHOWUICANDIDATEWINDOW<<2)) ? "2" : ""),
|
|
|
|
((aISC & (ISC_SHOWUICANDIDATEWINDOW<<3)) ? "3" : "")
|
2000-10-28 22:17:53 +00:00
|
|
|
);
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
1999-11-15 20:57:41 +00:00
|
|
|
if(! aActive)
|
|
|
|
ResetInputState();
|
1999-11-11 22:28:52 +00:00
|
|
|
|
2002-09-25 02:23:01 +00:00
|
|
|
aISC &= ~ ISC_SHOWUICOMPOSITIONWINDOW;
|
2002-05-23 22:03:49 +00:00
|
|
|
|
1999-11-15 20:57:41 +00:00
|
|
|
// We still return false here because we need to pass the
|
|
|
|
// aISC w/ ISC_SHOWUICOMPOSITIONWINDOW clear to the default
|
|
|
|
// window proc so it will draw the candidcate window for us...
|
1999-11-11 22:28:52 +00:00
|
|
|
return PR_FALSE;
|
|
|
|
}
|
|
|
|
//==========================================================================
|
|
|
|
BOOL nsWindow::OnIMEStartComposition()
|
|
|
|
{
|
|
|
|
#ifdef DEBUG_IME
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("OnIMEStartComposition\n");
|
1999-11-11 22:28:52 +00:00
|
|
|
#endif
|
|
|
|
HIMC hIMEContext;
|
|
|
|
|
|
|
|
if ((mIMEProperty & IME_PROP_SPECIAL_UI) ||
|
|
|
|
(mIMEProperty & IME_PROP_AT_CARET))
|
|
|
|
return PR_FALSE;
|
|
|
|
|
2000-01-07 00:34:34 +00:00
|
|
|
NS_IMM_GETCONTEXT(mWnd, hIMEContext);
|
1999-11-11 22:28:52 +00:00
|
|
|
if (hIMEContext==NULL)
|
|
|
|
return PR_TRUE;
|
|
|
|
|
2002-05-23 22:03:49 +00:00
|
|
|
PRBool rtn = HandleStartComposition(hIMEContext);
|
2000-01-07 00:34:34 +00:00
|
|
|
NS_IMM_RELEASECONTEXT(mWnd, hIMEContext);
|
2002-05-23 22:03:49 +00:00
|
|
|
return rtn;
|
1999-11-11 22:28:52 +00:00
|
|
|
}
|
1999-11-15 20:57:41 +00:00
|
|
|
|
|
|
|
//==========================================================================
|
|
|
|
NS_IMETHODIMP nsWindow::ResetInputState()
|
|
|
|
{
|
|
|
|
#ifdef DEBUG_KBSTATE
|
2000-10-28 22:17:53 +00:00
|
|
|
printf("ResetInputState\n");
|
1999-11-15 20:57:41 +00:00
|
|
|
#endif
|
1999-12-08 03:39:53 +00:00
|
|
|
//if(mIMEIsComposing) {
|
2000-01-07 00:34:34 +00:00
|
|
|
HIMC hIMC;
|
|
|
|
NS_IMM_GETCONTEXT(mWnd, hIMC);
|
1999-11-15 20:57:41 +00:00
|
|
|
if(hIMC) {
|
2000-09-22 01:06:51 +00:00
|
|
|
BOOL ret = FALSE;
|
|
|
|
NS_IMM_NOTIFYIME(hIMC, NI_COMPOSITIONSTR, CPS_COMPLETE, NULL, ret);
|
2001-09-07 03:43:07 +00:00
|
|
|
NS_IMM_NOTIFYIME(hIMC, NI_COMPOSITIONSTR, CPS_CANCEL, NULL, ret);
|
1999-12-08 03:39:53 +00:00
|
|
|
//NS_ASSERTION(ret, "ImmNotify failed");
|
2000-01-07 00:34:34 +00:00
|
|
|
NS_IMM_RELEASECONTEXT(mWnd, hIMC);
|
1999-11-15 20:57:41 +00:00
|
|
|
}
|
1999-12-08 03:39:53 +00:00
|
|
|
//}
|
1999-11-15 20:57:41 +00:00
|
|
|
return NS_OK;
|
|
|
|
}
|
2000-08-04 21:43:29 +00:00
|
|
|
|
|
|
|
|
2002-10-01 02:47:41 +00:00
|
|
|
#define PT_IN_RECT(pt, rc) ((pt).x>(rc).left && (pt).x <(rc).right && (pt).y>(rc).top && (pt).y<(rc).bottom)
|
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
// Mouse operation of IME
|
2002-10-01 02:47:41 +00:00
|
|
|
PRBool
|
|
|
|
nsWindow::IMEMouseHandling(PRUint32 aEventType, PRInt32 aAction, LPARAM lParam)
|
|
|
|
{
|
|
|
|
POINT ptPos;
|
|
|
|
ptPos.x = (short)LOWORD(lParam);
|
|
|
|
ptPos.y = (short)HIWORD(lParam);
|
|
|
|
|
|
|
|
if (mIMEIsComposing && nsWindow::uWM_MSIME_MOUSE) {
|
|
|
|
if (IMECompositionHitTest(aEventType, &ptPos))
|
|
|
|
if (HandleMouseActionOfIME(aAction, &ptPos))
|
|
|
|
return PR_TRUE;
|
|
|
|
} else {
|
|
|
|
HWND parentWnd = ::GetParent(mWnd);
|
|
|
|
if (parentWnd) {
|
|
|
|
nsWindow* parentWidget = GetNSWindowPtr(parentWnd);
|
2002-12-10 13:00:18 +00:00
|
|
|
if (parentWidget && parentWidget->mIMEIsComposing && nsWindow::uWM_MSIME_MOUSE) {
|
2002-10-01 02:47:41 +00:00
|
|
|
if (parentWidget->IMECompositionHitTest(aEventType, &ptPos))
|
|
|
|
if (parentWidget->HandleMouseActionOfIME(aAction, &ptPos))
|
|
|
|
return PR_TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return PR_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2000-08-04 21:43:29 +00:00
|
|
|
PRBool
|
2002-10-01 02:47:41 +00:00
|
|
|
nsWindow::HandleMouseActionOfIME(int aAction, POINT *ptPos)
|
2000-08-04 21:43:29 +00:00
|
|
|
{
|
|
|
|
PRBool IsHandle = PR_FALSE;
|
|
|
|
|
2000-09-22 01:06:51 +00:00
|
|
|
if (mWnd) {
|
|
|
|
HIMC hIMC = NULL;
|
|
|
|
NS_IMM_GETCONTEXT(mWnd, hIMC);
|
2000-08-04 21:43:29 +00:00
|
|
|
if (hIMC) {
|
|
|
|
int positioning = 0;
|
|
|
|
int offset = 0;
|
|
|
|
|
|
|
|
// calcurate positioning and offset
|
2002-10-01 02:47:41 +00:00
|
|
|
// char : JCH1|JCH2|JCH3
|
|
|
|
// offset: 0011 1122 2233
|
|
|
|
// positioning: 2301 2301 2301
|
|
|
|
|
|
|
|
// Note: hitText has been done, so no check of mIMECompCharPos
|
|
|
|
// and composing char maximum limit is necessary.
|
2004-04-18 11:03:51 +00:00
|
|
|
PRUint32 i = 0;
|
2003-09-18 17:22:33 +00:00
|
|
|
for (i = 0; i < mIMECompUnicode->Length(); i++) {
|
2002-10-01 02:47:41 +00:00
|
|
|
if (PT_IN_RECT(*ptPos, mIMECompCharPos[i]))
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
offset = i;
|
|
|
|
if (ptPos->x - mIMECompCharPos[i].left > mIMECompCharPos[i].right - ptPos->x)
|
|
|
|
offset++;
|
|
|
|
|
|
|
|
positioning = (ptPos->x - mIMECompCharPos[i].left) * 4 /
|
|
|
|
(mIMECompCharPos[i].right - mIMECompCharPos[i].left);
|
|
|
|
positioning = (positioning + 2) % 4;
|
2000-08-04 21:43:29 +00:00
|
|
|
|
|
|
|
// send MS_MSIME_MOUSE message to default IME window.
|
2002-10-01 02:47:41 +00:00
|
|
|
HWND imeWnd;
|
|
|
|
NS_IMM_GETDEFAULTIMEWND(mWnd, &imeWnd);
|
|
|
|
if (nsToolkit::mSendMessage(imeWnd, nsWindow::uWM_MSIME_MOUSE, MAKELONG(MAKEWORD(aAction, positioning), offset), (LPARAM) hIMC) == 1)
|
2000-08-04 21:43:29 +00:00
|
|
|
IsHandle = PR_TRUE;
|
|
|
|
}
|
2000-09-22 01:06:51 +00:00
|
|
|
NS_IMM_RELEASECONTEXT(mWnd, hIMC);
|
2000-08-04 21:43:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return IsHandle;
|
|
|
|
}
|
2000-09-22 01:06:51 +00:00
|
|
|
|
|
|
|
//The coordinate is relative to the upper-left corner of the client area.
|
|
|
|
PRBool nsWindow::IMECompositionHitTest(PRUint32 aEventType, POINT * ptPos)
|
|
|
|
{
|
|
|
|
PRBool IsHit = PR_FALSE;
|
|
|
|
|
2002-10-01 02:47:41 +00:00
|
|
|
if (mIMECompCharPos){
|
|
|
|
// figure out how many char in composing string,
|
|
|
|
// but keep it below the limit we can handle
|
|
|
|
PRInt32 len = mIMECompUnicode->Length();
|
|
|
|
if (len > IME_MAX_CHAR_POS)
|
|
|
|
len = IME_MAX_CHAR_POS;
|
|
|
|
|
|
|
|
PRInt32 i;
|
|
|
|
PRInt32 aveWidth = 0;
|
|
|
|
// found per char width
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
if (mIMECompCharPos[i].left >= 0 && mIMECompCharPos[i].right > 0) {
|
|
|
|
aveWidth = mIMECompCharPos[i].right - mIMECompCharPos[i].left;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// validate each rect and test
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
if (mIMECompCharPos[i].left < 0) {
|
|
|
|
if (i != 0 && mIMECompCharPos[i-1].top == mIMECompCharPos[i].top)
|
|
|
|
mIMECompCharPos[i].left = mIMECompCharPos[i-1].right;
|
|
|
|
else
|
|
|
|
mIMECompCharPos[i].left = mIMECompCharPos[i].right - aveWidth;
|
|
|
|
}
|
|
|
|
if (mIMECompCharPos[i].right < 0)
|
|
|
|
mIMECompCharPos[i].right = mIMECompCharPos[i].left + aveWidth;
|
|
|
|
if (mIMECompCharPos[i].top < 0) {
|
|
|
|
mIMECompCharPos[i].top = mIMECompCharPos[i-1].top;
|
|
|
|
mIMECompCharPos[i].bottom = mIMECompCharPos[i-1].bottom;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (PT_IN_RECT(*ptPos, mIMECompCharPos[i])) {
|
|
|
|
IsHit = PR_TRUE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2000-09-22 01:06:51 +00:00
|
|
|
|
|
|
|
return IsHit;
|
|
|
|
}
|
|
|
|
|
|
|
|
void nsWindow::GetCompositionWindowPos(HIMC hIMC, PRUint32 aEventType, COMPOSITIONFORM *cpForm)
|
|
|
|
{
|
|
|
|
nsTextEvent event;
|
|
|
|
POINT point;
|
|
|
|
point.x = 0;
|
|
|
|
point.y = 0;
|
|
|
|
DWORD pos = ::GetMessagePos();
|
|
|
|
|
2001-04-10 02:27:41 +00:00
|
|
|
point.x = (short)LOWORD(pos);
|
|
|
|
point.y = (short)HIWORD(pos);
|
2000-09-22 01:06:51 +00:00
|
|
|
|
|
|
|
if (mWnd != NULL) {
|
|
|
|
::ScreenToClient(mWnd, &point);
|
|
|
|
event.point.x = point.x;
|
|
|
|
event.point.y = point.y;
|
|
|
|
} else {
|
|
|
|
event.point.x = 0;
|
|
|
|
event.point.y = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMM_GETCOMPOSITIONWINDOW(hIMC, cpForm);
|
|
|
|
|
|
|
|
cpForm->ptCurrentPos.x = event.theReply.mCursorPosition.x + IME_X_OFFSET;
|
|
|
|
cpForm->ptCurrentPos.y = event.theReply.mCursorPosition.y + IME_Y_OFFSET
|
|
|
|
+ event.theReply.mCursorPosition.height ;
|
|
|
|
cpForm->rcArea.left = cpForm->ptCurrentPos.x;
|
|
|
|
cpForm->rcArea.top = cpForm->ptCurrentPos.y;
|
|
|
|
cpForm->rcArea.right = cpForm->ptCurrentPos.x + event.theReply.mCursorPosition.width;
|
|
|
|
cpForm->rcArea.bottom = cpForm->ptCurrentPos.y + event.theReply.mCursorPosition.height;
|
|
|
|
}
|
|
|
|
|
1999-12-10 07:20:51 +00:00
|
|
|
// This function is called on a timer to do the flashing. It simply toggles the flash
|
|
|
|
// status until the window comes to the foreground.
|
2001-11-16 01:58:17 +00:00
|
|
|
static VOID CALLBACK nsGetAttentionTimerFunc(HWND hwnd, UINT uMsg, UINT idEvent, DWORD dwTime) {
|
|
|
|
|
|
|
|
// flash the window until we're in the foreground.
|
|
|
|
if (::GetForegroundWindow() != hwnd)
|
2002-06-29 12:31:15 +00:00
|
|
|
{
|
|
|
|
// flash the outermost owner
|
|
|
|
HWND flashwnd = gAttentionTimerMonitor->GetFlashWindowFor(hwnd);
|
|
|
|
|
2004-02-11 03:46:30 +00:00
|
|
|
PRInt32 maxFlashCount = gAttentionTimerMonitor->GetMaxFlashCount(hwnd);
|
|
|
|
PRInt32 flashCount = gAttentionTimerMonitor->GetFlashCount(hwnd);
|
|
|
|
if (maxFlashCount > 0) {
|
|
|
|
// We have a max flash count, if we haven't met it yet, flash again.
|
|
|
|
if (flashCount < maxFlashCount) {
|
|
|
|
::FlashWindow(flashwnd, TRUE);
|
|
|
|
gAttentionTimerMonitor->IncrementFlashCount(hwnd);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
gAttentionTimerMonitor->KillTimer(hwnd);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// The caller didn't specify a flash count.
|
|
|
|
::FlashWindow(flashwnd, TRUE);
|
|
|
|
}
|
|
|
|
|
2002-06-29 12:31:15 +00:00
|
|
|
gAttentionTimerMonitor->SetFlashed(hwnd);
|
|
|
|
}
|
2001-11-16 01:58:17 +00:00
|
|
|
else
|
|
|
|
gAttentionTimerMonitor->KillTimer(hwnd);
|
1999-12-10 07:20:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Draw user's attention to this window until it comes to foreground.
|
|
|
|
NS_IMETHODIMP
|
2004-02-11 03:46:30 +00:00
|
|
|
nsWindow::GetAttention(PRInt32 aCycleCount) {
|
1999-12-10 07:20:51 +00:00
|
|
|
|
2001-11-16 01:58:17 +00:00
|
|
|
// Got window?
|
|
|
|
if (!mWnd)
|
|
|
|
return NS_ERROR_NOT_INITIALIZED;
|
|
|
|
|
2004-02-11 03:46:30 +00:00
|
|
|
// Don't flash if the flash count is 0.
|
|
|
|
if (aCycleCount == 0)
|
|
|
|
return NS_OK;
|
|
|
|
|
2001-11-16 01:58:17 +00:00
|
|
|
// timer is on the parentmost window; window to flash is its ownermost
|
|
|
|
HWND nextwnd,
|
|
|
|
flashwnd,
|
|
|
|
timerwnd = mWnd;
|
|
|
|
while ((nextwnd = ::GetParent(timerwnd)) != 0)
|
|
|
|
timerwnd = nextwnd;
|
|
|
|
flashwnd = timerwnd;
|
|
|
|
while ((nextwnd = ::GetWindow(flashwnd, GW_OWNER)) != 0)
|
|
|
|
flashwnd = nextwnd;
|
|
|
|
|
|
|
|
// If window is in foreground, no notification is necessary.
|
|
|
|
if (::GetForegroundWindow() != timerwnd) {
|
|
|
|
// kick off a timer that does single flash until the window comes to the foreground
|
|
|
|
if (!gAttentionTimerMonitor)
|
|
|
|
gAttentionTimerMonitor = new nsAttentionTimerMonitor;
|
|
|
|
if (gAttentionTimerMonitor) {
|
2004-02-11 03:46:30 +00:00
|
|
|
gAttentionTimerMonitor->AddTimer(timerwnd, flashwnd, aCycleCount, NS_FLASH_TIMER_ID);
|
2001-11-16 01:58:17 +00:00
|
|
|
::SetTimer(timerwnd, NS_FLASH_TIMER_ID, GetCaretBlinkTime(), (TIMERPROC)nsGetAttentionTimerFunc);
|
1999-12-10 07:20:51 +00:00
|
|
|
}
|
2001-11-16 01:58:17 +00:00
|
|
|
}
|
1999-12-10 07:20:51 +00:00
|
|
|
|
2001-11-16 01:58:17 +00:00
|
|
|
return NS_OK;
|
1999-12-10 07:20:51 +00:00
|
|
|
}
|
2001-05-25 10:53:32 +00:00
|
|
|
|
2002-10-01 03:04:22 +00:00
|
|
|
NS_IMETHODIMP
|
|
|
|
nsWindow::GetLastInputEventTime(PRUint32& aTime)
|
|
|
|
{
|
|
|
|
WORD qstatus = HIWORD(GetQueueStatus(QS_INPUT));
|
|
|
|
|
|
|
|
// If there is pending input or the user is currently
|
|
|
|
// moving the window then return the current time.
|
|
|
|
// Note: When the user is moving the window WIN32 spins
|
|
|
|
// a separate event loop and input events are not
|
|
|
|
// reported to the application.
|
|
|
|
nsToolkit* toolkit = (nsToolkit *)mToolkit;
|
|
|
|
if (qstatus || (toolkit && toolkit->UserIsMovingWindow())) {
|
|
|
|
gLastInputEventTime = PR_IntervalToMicroseconds(PR_IntervalNow());
|
|
|
|
}
|
|
|
|
|
|
|
|
aTime = gLastInputEventTime;
|
|
|
|
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2001-05-25 10:53:32 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//-- NOTE!!! These hook functions can be removed when we migrate to
|
|
|
|
//-- XBL-Form Controls
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
//#define DISPLAY_NOISY_MSGF_MSG
|
|
|
|
|
|
|
|
#ifdef DISPLAY_NOISY_MSGF_MSG
|
|
|
|
typedef struct {
|
|
|
|
char * mStr;
|
|
|
|
int mId;
|
|
|
|
} MSGFEventMsgInfo;
|
|
|
|
|
|
|
|
MSGFEventMsgInfo gMSGFEvents[] = {
|
|
|
|
"MSGF_DIALOGBOX", 0,
|
|
|
|
"MSGF_MESSAGEBOX", 1,
|
|
|
|
"MSGF_MENU", 2,
|
|
|
|
"MSGF_SCROLLBAR", 5,
|
|
|
|
"MSGF_NEXTWINDOW", 6,
|
|
|
|
"MSGF_MAX", 8,
|
|
|
|
"MSGF_USER", 4096,
|
|
|
|
NULL, 0};
|
|
|
|
|
|
|
|
void PrintEvent(UINT msg, PRBool aShowAllEvents, PRBool aShowMouseMoves);
|
|
|
|
int gLastMsgCode = 0;
|
|
|
|
|
|
|
|
#define DISPLAY_NMM_PRT(_arg) printf((_arg));
|
|
|
|
#else
|
|
|
|
#define DISPLAY_NMM_PRT(_arg)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2001-06-14 02:08:39 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
// Scedules a timer for a window, so we can rollup after processing the hook event
|
|
|
|
void nsWindow::ScheduleHookTimer(HWND aWnd, UINT aMsgId)
|
|
|
|
{
|
|
|
|
// In some cases multiple hooks may be schedule
|
|
|
|
// so ignore any other requests once one timer is scheduled
|
|
|
|
if (gHookTimerId == 0) {
|
|
|
|
// Remember the message ID to be used later
|
|
|
|
gRollupMsgId = aMsgId;
|
|
|
|
// Schedule native timer for doing the rollup after
|
|
|
|
// this event is done being processed
|
|
|
|
gHookTimerId = ::SetTimer( NULL, 0, 0, (TIMERPROC)HookTimerForPopups );
|
|
|
|
NS_ASSERTION(gHookTimerId, "Timer couldn't be created.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-05-25 10:53:32 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
// Process Menu messages
|
|
|
|
// Rollup when when is clicked
|
|
|
|
LRESULT CALLBACK nsWindow::MozSpecialMsgFilter(int code, WPARAM wParam, LPARAM lParam)
|
|
|
|
{
|
|
|
|
#ifdef DISPLAY_NOISY_MSGF_MSG
|
|
|
|
if (gProcessHook) {
|
|
|
|
MSG* pMsg = (MSG*)lParam;
|
|
|
|
|
|
|
|
int inx = 0;
|
|
|
|
while (gMSGFEvents[inx].mId != code && gMSGFEvents[inx].mStr != NULL) {
|
|
|
|
inx++;
|
|
|
|
}
|
|
|
|
if (code != gLastMsgCode) {
|
|
|
|
if (gMSGFEvents[inx].mId == code) {
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2001-05-25 10:53:32 +00:00
|
|
|
printf("MozSpecialMessageProc - code: 0x%X - %s hw: %p\n", code, gMSGFEvents[inx].mStr, pMsg->hwnd);
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
2001-05-25 10:53:32 +00:00
|
|
|
} else {
|
2001-06-20 05:48:45 +00:00
|
|
|
#ifdef DEBUG
|
2001-05-25 10:53:32 +00:00
|
|
|
printf("MozSpecialMessageProc - code: 0x%X - %d hw: %p\n", code, gMSGFEvents[inx].mId, pMsg->hwnd);
|
2001-06-20 05:48:45 +00:00
|
|
|
#endif
|
2001-05-25 10:53:32 +00:00
|
|
|
}
|
|
|
|
gLastMsgCode = code;
|
|
|
|
}
|
|
|
|
PrintEvent(pMsg->message, FALSE, FALSE);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (gProcessHook && code == MSGF_MENU) {
|
|
|
|
MSG* pMsg = (MSG*)lParam;
|
2001-06-14 02:08:39 +00:00
|
|
|
ScheduleHookTimer( pMsg->hwnd, pMsg->message);
|
2001-05-25 10:53:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return ::CallNextHookEx(gMsgFilterHook, code, wParam, lParam);
|
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
// Process all mouse messages
|
|
|
|
// Roll up when a click is in a native window that doesn't have an nsIWidget
|
|
|
|
LRESULT CALLBACK nsWindow::MozSpecialMouseProc(int code, WPARAM wParam, LPARAM lParam)
|
|
|
|
{
|
|
|
|
if (gProcessHook) {
|
|
|
|
MOUSEHOOKSTRUCT* ms = (MOUSEHOOKSTRUCT*)lParam;
|
|
|
|
if (wParam == WM_LBUTTONDOWN) {
|
|
|
|
nsIWidget* mozWin = (nsIWidget*)GetNSWindowPtr(ms->hwnd);
|
|
|
|
if (mozWin == NULL) {
|
2001-06-14 02:08:39 +00:00
|
|
|
ScheduleHookTimer( ms->hwnd, (UINT)wParam);
|
2001-05-25 10:53:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ::CallNextHookEx(gCallMouseHook, code, wParam, lParam);
|
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
// Process all messages
|
|
|
|
// Roll up when the window is moving, or is resizing or when maximized or mininized
|
|
|
|
LRESULT CALLBACK nsWindow::MozSpecialWndProc(int code, WPARAM wParam, LPARAM lParam)
|
|
|
|
{
|
|
|
|
#ifdef DISPLAY_NOISY_MSGF_MSG
|
|
|
|
if (gProcessHook) {
|
|
|
|
CWPSTRUCT* cwpt = (CWPSTRUCT*)lParam;
|
|
|
|
PrintEvent(cwpt->message, FALSE, FALSE);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (gProcessHook) {
|
|
|
|
CWPSTRUCT* cwpt = (CWPSTRUCT*)lParam;
|
|
|
|
if (cwpt->message == WM_MOVING ||
|
|
|
|
cwpt->message == WM_SIZING ||
|
|
|
|
cwpt->message == WM_GETMINMAXINFO) {
|
2001-06-14 02:08:39 +00:00
|
|
|
ScheduleHookTimer( cwpt->hwnd, (UINT)cwpt->message);
|
2001-05-25 10:53:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return ::CallNextHookEx(gCallProcHook, code, wParam, lParam);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
// Register the special "hooks" for dropdown processing
|
|
|
|
void nsWindow::RegisterSpecialDropdownHooks()
|
|
|
|
{
|
|
|
|
NS_ASSERTION(!gMsgFilterHook, "gMsgFilterHook must be NULL!");
|
|
|
|
NS_ASSERTION(!gCallProcHook, "gCallProcHook must be NULL!");
|
|
|
|
|
|
|
|
DISPLAY_NMM_PRT("***************** Installing Msg Hooks ***************\n");
|
|
|
|
|
|
|
|
//HMODULE hMod = GetModuleHandle("gkwidget.dll");
|
|
|
|
|
|
|
|
// Install msg hook for moving the window and resizing
|
|
|
|
if (!gMsgFilterHook) {
|
|
|
|
DISPLAY_NMM_PRT("***** Hooking gMsgFilterHook!\n");
|
|
|
|
gMsgFilterHook = SetWindowsHookEx(WH_MSGFILTER, MozSpecialMsgFilter, NULL, GetCurrentThreadId());
|
|
|
|
#ifdef DISPLAY_NOISY_MSGF_MSG
|
|
|
|
if (!gMsgFilterHook) {
|
|
|
|
printf("***** SetWindowsHookEx is NOT installed for WH_MSGFILTER!\n");
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
// Install msg hook for menus
|
|
|
|
if (!gCallProcHook) {
|
|
|
|
DISPLAY_NMM_PRT("***** Hooking gCallProcHook!\n");
|
|
|
|
gCallProcHook = SetWindowsHookEx(WH_CALLWNDPROC, MozSpecialWndProc, NULL, GetCurrentThreadId());
|
|
|
|
#ifdef DISPLAY_NOISY_MSGF_MSG
|
|
|
|
if (!gCallProcHook) {
|
|
|
|
printf("***** SetWindowsHookEx is NOT installed for WH_CALLWNDPROC!\n");
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
// Install msg hook for the mouse
|
|
|
|
if (!gCallMouseHook) {
|
|
|
|
DISPLAY_NMM_PRT("***** Hooking gCallMouseHook!\n");
|
|
|
|
gCallMouseHook = SetWindowsHookEx(WH_MOUSE, MozSpecialMouseProc, NULL, GetCurrentThreadId());
|
|
|
|
#ifdef DISPLAY_NOISY_MSGF_MSG
|
|
|
|
if (!gCallMouseHook) {
|
|
|
|
printf("***** SetWindowsHookEx is NOT installed for WH_MOUSE!\n");
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
// Unhook special message hooks for dropdowns
|
|
|
|
void nsWindow::UnregisterSpecialDropdownHooks()
|
|
|
|
{
|
|
|
|
|
|
|
|
DISPLAY_NMM_PRT("***************** De-installing Msg Hooks ***************\n");
|
|
|
|
|
|
|
|
if (gCallProcHook) {
|
|
|
|
DISPLAY_NMM_PRT("***** Unhooking gCallProcHook!\n");
|
|
|
|
if (!::UnhookWindowsHookEx(gCallProcHook)) {
|
|
|
|
DISPLAY_NMM_PRT("***** UnhookWindowsHookEx failed for gCallProcHook!\n");
|
|
|
|
}
|
|
|
|
gCallProcHook = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (gMsgFilterHook) {
|
|
|
|
DISPLAY_NMM_PRT("***** Unhooking gMsgFilterHook!\n");
|
|
|
|
if (!::UnhookWindowsHookEx(gMsgFilterHook)) {
|
|
|
|
DISPLAY_NMM_PRT("***** UnhookWindowsHookEx failed for gMsgFilterHook!\n");
|
|
|
|
}
|
|
|
|
gMsgFilterHook = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (gCallMouseHook) {
|
|
|
|
DISPLAY_NMM_PRT("***** Unhooking gCallMouseHook!\n");
|
|
|
|
if (!::UnhookWindowsHookEx(gCallMouseHook)) {
|
|
|
|
DISPLAY_NMM_PRT("***** UnhookWindowsHookEx failed for gCallMouseHook!\n");
|
|
|
|
}
|
|
|
|
gCallMouseHook = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-06-14 02:08:39 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
// This timer is designed to only fire one time at most each time a "hook" function
|
|
|
|
// is used to rollup the dropdown
|
|
|
|
// In some cases, the timer may be scheduled from the hook, but that hook event or
|
|
|
|
// a subsequent event may roll up the dropdown before this timer function is executed.
|
|
|
|
//
|
|
|
|
// For example, if an MFC control takes focus, the combobox will lose focus and rollup
|
|
|
|
// before this function fires.
|
|
|
|
//
|
|
|
|
VOID CALLBACK nsWindow::HookTimerForPopups( HWND hwnd, UINT uMsg, UINT idEvent, DWORD dwTime )
|
|
|
|
{
|
|
|
|
if (gHookTimerId != 0) {
|
|
|
|
// if the window is NULL then we need to use the ID to kill the timer
|
|
|
|
BOOL status = ::KillTimer(NULL, gHookTimerId);
|
|
|
|
NS_ASSERTION(status, "Hook Timer was not killed.");
|
|
|
|
gHookTimerId = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (gRollupMsgId != 0) {
|
|
|
|
// Note: DealWithPopups does the check to make sure that
|
|
|
|
// gRollupListener and gRollupWidget are not NULL
|
|
|
|
LRESULT popupHandlingResult;
|
|
|
|
DealWithPopups(gRollupMsgId, 0, 0, &popupHandlingResult);
|
|
|
|
gRollupMsgId = 0;
|
|
|
|
}
|
|
|
|
}
|
2001-09-25 08:34:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef ACCESSIBILITY
|
|
|
|
void nsWindow::CreateRootAccessible()
|
|
|
|
{
|
|
|
|
// Create this as early as possible in new window, if accessibility is turned on
|
|
|
|
// We need it to be created early so it can generate accessibility events right away
|
Bug 109851, bug 108629, bug 109921, bug 109977, bug 109153, bug 109187, bug 109213, bug 109221. Check in latest XUL accessibility support - menus, <colorpicker>, <progressmeter>, <groupbox>, mixed states for checkboxes, buttons that can be 'checked' ie pressed down, fixes extra MSAA events being generated, couldn't see HTML content
2001-11-20 02:05:26 +00:00
|
|
|
|
|
|
|
if (!mRootAccessible) {
|
2003-04-01 20:02:51 +00:00
|
|
|
DispatchAccessibleEvent(NS_GETACCESSIBLE, &mRootAccessible);
|
2001-09-25 08:34:42 +00:00
|
|
|
}
|
|
|
|
}
|
2003-04-01 20:02:51 +00:00
|
|
|
|
|
|
|
HINSTANCE nsWindow::gmAccLib = 0;
|
|
|
|
LPFNLRESULTFROMOBJECT nsWindow::gmLresultFromObject = 0;
|
|
|
|
|
|
|
|
STDMETHODIMP_(LRESULT) nsWindow::LresultFromObject(REFIID riid,
|
|
|
|
WPARAM wParam,
|
|
|
|
LPUNKNOWN pAcc)
|
|
|
|
{
|
|
|
|
// open the dll dynamically
|
|
|
|
if (!gmAccLib)
|
|
|
|
gmAccLib =::LoadLibrary("OLEACC.DLL");
|
|
|
|
|
|
|
|
if (gmAccLib) {
|
|
|
|
if (!gmLresultFromObject)
|
|
|
|
gmLresultFromObject = (LPFNLRESULTFROMOBJECT)GetProcAddress(gmAccLib,"LresultFromObject");
|
|
|
|
|
|
|
|
if (gmLresultFromObject)
|
|
|
|
return gmLresultFromObject(riid,wParam,pAcc);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2001-09-25 08:34:42 +00:00
|
|
|
#endif
|