- Fix applications that depend on KF_DLGMODE flag.

- Added the Alt-Tab intercept for win32k.

svn path=/trunk/; revision=54077
This commit is contained in:
James Tabor 2011-10-11 03:48:47 +00:00
parent d5a6da4ea8
commit d118a53f82
2 changed files with 20 additions and 4 deletions

View file

@ -33,11 +33,13 @@ extern PATTACHINFO gpai;
/* Scan Codes */
#define SC_KEY_UP 0x8000
/* lParam bits */
#define LP_EXT_BIT (1<<24)
#define LP_EXT_BIT (KF_EXTENDED<<16)
#define LP_DO_NOT_CARE_BIT (1<<25) // for GetKeyNameText
#define LP_CONTEXT_BIT (1<<29)
#define LP_PREV_STATE_BIT (1<<30)
#define LP_TRANSITION_BIT (1<<31)
#define LP_DLGMODE (KF_DLGMODE<<16)
#define LP_MENUMODE (KF_MENUMODE<<16)
#define LP_CONTEXT_BIT (KF_ALTDOWN<<16)
#define LP_PREV_STATE_BIT (KF_REPEAT<<16)
#define LP_TRANSITION_BIT (KF_UP<<16)
INIT_FUNCTION NTSTATUS NTAPI InitInputImpl(VOID);

View file

@ -790,6 +790,12 @@ UserSendKeyboardInput(KEYBDINPUT *pKbdInput, BOOL bInjected)
Msg.lParam |= LP_TRANSITION_BIT;
}
/* FIXME: set KF_DLGMODE and KF_MENUMODE when needed */
if ( pFocusQueue && pFocusQueue->QF_flags & QF_DIALOGACTIVE )
Msg.lParam |= LP_DLGMODE;
if ( pFocusQueue && pFocusQueue->MenuOwner )//pFocusQueue->MenuState ) // MenuState needs a start flag...
Msg.lParam |= LP_MENUMODE;
/* Init wParam and cursor position */
Msg.wParam = wVk; // Note: it's simplified by msg queue
Msg.pt = gpsi->ptCursor;
@ -834,6 +840,14 @@ UserSendKeyboardInput(KEYBDINPUT *pKbdInput, BOOL bInjected)
co_IntKeyboardSendAltKeyMsg();
}
/* Alt-Tab/Esc Check. Use FocusQueue or RIT Queue */
if (!(pKbdInput->dwFlags & KEYEVENTF_KEYUP) &&
HIWORD(Msg.lParam) & KF_ALTDOWN &&
( Msg.wParam == VK_ESCAPE || Msg.wParam == VK_TAB ) )
{
TRACE("Alt-Tab/Esc Pressed wParam %x\n",Msg.wParam);
}
/* If we have a focus queue, post a keyboard message */
if (pFocusQueue && bPostMsg)
{