1213 lines
26 KiB
C
1213 lines
26 KiB
C
|
/*++
|
||
|
|
||
|
Copyright (c) 1985 - 1999, Microsoft Corporation
|
||
|
|
||
|
Module Name:
|
||
|
|
||
|
dbcs.c
|
||
|
|
||
|
Abstract:
|
||
|
|
||
|
Author:
|
||
|
|
||
|
KazuM May.11.1992
|
||
|
|
||
|
Revision History:
|
||
|
|
||
|
--*/
|
||
|
|
||
|
#include "precomp.h"
|
||
|
#pragma hdrstop
|
||
|
|
||
|
#if defined(FE_SB)
|
||
|
#include "conime.h"
|
||
|
|
||
|
#if !defined(BUILD_WOW6432)
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
GetConsoleNlsMode(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
OUT LPDWORD lpNlsMode
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
lpNlsMode - Supplies a pointer to the NLS mode.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
|
||
|
#if defined(FE_IME)
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_NLS_MODE_MSG a = &m.u.GetConsoleNlsMode;
|
||
|
NTSTATUS Status;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->Handle = hConsoleHandle;
|
||
|
a->Ready = FALSE;
|
||
|
|
||
|
Status = NtCreateEvent(&(a->hEvent),
|
||
|
EVENT_ALL_ACCESS,
|
||
|
NULL,
|
||
|
SynchronizationEvent,
|
||
|
(BOOLEAN)FALSE
|
||
|
);
|
||
|
if (!NT_SUCCESS(Status)) {
|
||
|
SET_LAST_NT_ERROR(Status);
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepGetNlsMode
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
|
||
|
if (NT_SUCCESS( m.ReturnValue )) {
|
||
|
Status = NtWaitForSingleObject(a->hEvent, FALSE, NULL);
|
||
|
|
||
|
if (a->Ready == FALSE)
|
||
|
{
|
||
|
/*
|
||
|
* If not ready conversion status on this console,
|
||
|
* then one more try get status.
|
||
|
*/
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepGetNlsMode
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
if (! NT_SUCCESS( m.ReturnValue )) {
|
||
|
SET_LAST_NT_ERROR (m.ReturnValue);
|
||
|
NtClose(a->hEvent);
|
||
|
return FALSE;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Status = NtWaitForSingleObject(a->hEvent, FALSE, NULL);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
NtClose(a->hEvent);
|
||
|
|
||
|
try {
|
||
|
*lpNlsMode = a->NlsMode;
|
||
|
} except( EXCEPTION_EXECUTE_HANDLER ) {
|
||
|
SET_LAST_ERROR (ERROR_INVALID_ACCESS);
|
||
|
return FALSE;
|
||
|
}
|
||
|
return TRUE;
|
||
|
} else {
|
||
|
SET_LAST_NT_ERROR (m.ReturnValue);
|
||
|
NtClose(a->hEvent);
|
||
|
return FALSE;
|
||
|
}
|
||
|
#else
|
||
|
return FALSE;
|
||
|
#endif
|
||
|
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
SetConsoleNlsMode(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
IN DWORD dwNlsMode
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
dwNlsMode - Supplies NLS mode.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
|
||
|
#if defined(FE_IME)
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_NLS_MODE_MSG a = &m.u.SetConsoleNlsMode;
|
||
|
NTSTATUS Status;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->Handle = hConsoleHandle;
|
||
|
a->NlsMode = dwNlsMode;
|
||
|
|
||
|
Status = NtCreateEvent(&(a->hEvent),
|
||
|
EVENT_ALL_ACCESS,
|
||
|
NULL,
|
||
|
SynchronizationEvent,
|
||
|
(BOOLEAN)FALSE
|
||
|
);
|
||
|
if (!NT_SUCCESS(Status)) {
|
||
|
SET_LAST_NT_ERROR(Status);
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepSetNlsMode
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
if (NT_SUCCESS( m.ReturnValue )) {
|
||
|
Status = NtWaitForSingleObject(a->hEvent, FALSE, NULL);
|
||
|
NtClose(a->hEvent);
|
||
|
if (Status != 0) {
|
||
|
SET_LAST_NT_ERROR(Status);
|
||
|
return FALSE;
|
||
|
}
|
||
|
return TRUE;
|
||
|
} else {
|
||
|
SET_LAST_NT_ERROR (m.ReturnValue);
|
||
|
NtClose(a->hEvent);
|
||
|
return FALSE;
|
||
|
}
|
||
|
#else
|
||
|
return FALSE;
|
||
|
#endif
|
||
|
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
GetConsoleCharType(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
IN COORD coordCheck,
|
||
|
OUT PDWORD pdwType
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
coordCheck - set check position to these coordinates
|
||
|
|
||
|
pdwType - receive character type
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_CHAR_TYPE_MSG a = &m.u.GetConsoleCharType;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->Handle = hConsoleHandle;
|
||
|
a->coordCheck = coordCheck;
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepCharType
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
if (NT_SUCCESS( m.ReturnValue )) {
|
||
|
try {
|
||
|
*pdwType = a->dwType;
|
||
|
} except( EXCEPTION_EXECUTE_HANDLER ) {
|
||
|
SET_LAST_ERROR (ERROR_INVALID_ACCESS);
|
||
|
return FALSE;
|
||
|
}
|
||
|
return TRUE;
|
||
|
} else {
|
||
|
SET_LAST_NT_ERROR (m.ReturnValue);
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
SetConsoleLocalEUDC(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
IN WORD wCodePoint,
|
||
|
IN COORD cFontSize,
|
||
|
IN PCHAR lpSB
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
wCodePoint - Code point of font by Shift JIS code.
|
||
|
|
||
|
cFontSize - FontSize of Font
|
||
|
|
||
|
lpSB - Pointer of font bitmap Buffer
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_LOCAL_EUDC_MSG a = &m.u.SetConsoleLocalEUDC;
|
||
|
PCSR_CAPTURE_HEADER CaptureBuffer;
|
||
|
ULONG DataLength;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->Handle = hConsoleHandle;
|
||
|
a->CodePoint = wCodePoint;
|
||
|
a->FontSize = cFontSize;
|
||
|
|
||
|
DataLength = ((cFontSize.X + 7) / 8) * cFontSize.Y;
|
||
|
|
||
|
CaptureBuffer = CsrAllocateCaptureBuffer( 1,
|
||
|
DataLength
|
||
|
);
|
||
|
if (CaptureBuffer == NULL) {
|
||
|
SET_LAST_ERROR(ERROR_NOT_ENOUGH_MEMORY);
|
||
|
return FALSE;
|
||
|
}
|
||
|
CsrCaptureMessageBuffer( CaptureBuffer,
|
||
|
lpSB,
|
||
|
DataLength,
|
||
|
(PVOID *) &a->FontFace
|
||
|
);
|
||
|
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
CaptureBuffer,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepSetLocalEUDC
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
CsrFreeCaptureBuffer( CaptureBuffer );
|
||
|
|
||
|
if (NT_SUCCESS( m.ReturnValue )) {
|
||
|
return TRUE;
|
||
|
} else {
|
||
|
SET_LAST_NT_ERROR (m.ReturnValue);
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
SetConsoleCursorMode(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
IN BOOL Blink,
|
||
|
IN BOOL DBEnable
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
Blink - Blinking enable/disable switch.
|
||
|
|
||
|
DBEnable - Double Byte width enable/disable switch.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_CURSOR_MODE_MSG a = &m.u.SetConsoleCursorMode;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->Handle = hConsoleHandle;
|
||
|
a->Blink = Blink;
|
||
|
a->DBEnable = DBEnable;
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepSetCursorMode
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
if (NT_SUCCESS( m.ReturnValue )) {
|
||
|
return TRUE;
|
||
|
} else {
|
||
|
SET_LAST_NT_ERROR (m.ReturnValue);
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
GetConsoleCursorMode(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
OUT PBOOL pbBlink,
|
||
|
OUT PBOOL pbDBEnable
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
Blink - Blinking enable/disable switch.
|
||
|
|
||
|
DBEnable - Double Byte width enable/disable switch.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_CURSOR_MODE_MSG a = &m.u.GetConsoleCursorMode;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->Handle = hConsoleHandle;
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepGetCursorMode
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
if (NT_SUCCESS( m.ReturnValue )) {
|
||
|
try {
|
||
|
*pbBlink = a->Blink;
|
||
|
*pbDBEnable = a->DBEnable;
|
||
|
} except( EXCEPTION_EXECUTE_HANDLER ) {
|
||
|
SET_LAST_ERROR (ERROR_INVALID_ACCESS);
|
||
|
return FALSE;
|
||
|
}
|
||
|
return TRUE;
|
||
|
} else {
|
||
|
SET_LAST_NT_ERROR (m.ReturnValue);
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
RegisterConsoleOS2(
|
||
|
IN BOOL fOs2Register
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Description:
|
||
|
|
||
|
This routine registers the OS/2 with the console.
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_REGISTEROS2_MSG a = &m.u.RegisterConsoleOS2;
|
||
|
NTSTATUS Status;
|
||
|
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->fOs2Register = fOs2Register;
|
||
|
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepRegisterOS2
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
if (!NT_SUCCESS( m.ReturnValue)) {
|
||
|
SET_LAST_NT_ERROR(m.ReturnValue);
|
||
|
return FALSE;
|
||
|
}
|
||
|
else {
|
||
|
return TRUE;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
SetConsoleOS2OemFormat(
|
||
|
IN BOOL fOs2OemFormat
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Description:
|
||
|
|
||
|
This routine sets the OS/2 OEM Format with the console.
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_SETOS2OEMFORMAT_MSG a = &m.u.SetConsoleOS2OemFormat;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->fOs2OemFormat = fOs2OemFormat;
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepSetOS2OemFormat
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
if (!NT_SUCCESS( m.ReturnValue)) {
|
||
|
SET_LAST_NT_ERROR(m.ReturnValue);
|
||
|
return FALSE;
|
||
|
}
|
||
|
else {
|
||
|
return TRUE;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#endif //!defined(BUILD_WOW6432)
|
||
|
|
||
|
#if defined(FE_IME)
|
||
|
|
||
|
#if !defined(BUILD_WOW6432)
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
RegisterConsoleIMEInternal(
|
||
|
IN HWND hWndConsoleIME,
|
||
|
IN DWORD dwConsoleIMEThreadId,
|
||
|
IN DWORD DesktopLength,
|
||
|
IN LPWSTR Desktop,
|
||
|
OUT DWORD *dwConsoleThreadId
|
||
|
)
|
||
|
{
|
||
|
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_REGISTER_CONSOLEIME_MSG a = &m.u.RegisterConsoleIME;
|
||
|
PCSR_CAPTURE_HEADER CaptureBuffer = NULL;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->hWndConsoleIME = hWndConsoleIME;
|
||
|
a->dwConsoleIMEThreadId = dwConsoleIMEThreadId;
|
||
|
a->DesktopLength = DesktopLength;
|
||
|
|
||
|
CaptureBuffer = CsrAllocateCaptureBuffer( 1,
|
||
|
DesktopLength
|
||
|
);
|
||
|
if (CaptureBuffer == NULL) {
|
||
|
SET_LAST_ERROR(ERROR_NOT_ENOUGH_MEMORY);
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
CsrCaptureMessageBuffer( CaptureBuffer,
|
||
|
Desktop,
|
||
|
a->DesktopLength,
|
||
|
(PVOID *) &a->Desktop
|
||
|
);
|
||
|
|
||
|
|
||
|
// Connect to the server process
|
||
|
|
||
|
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
CaptureBuffer,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepRegisterConsoleIME
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
|
||
|
//HS Jan.20 if (CaptureBuffer) {
|
||
|
CsrFreeCaptureBuffer( CaptureBuffer );
|
||
|
//HS Jan.20 }
|
||
|
|
||
|
if (!NT_SUCCESS( m.ReturnValue)) {
|
||
|
SET_LAST_NT_ERROR(m.ReturnValue);
|
||
|
return FALSE;
|
||
|
}
|
||
|
else {
|
||
|
try {
|
||
|
if (dwConsoleThreadId != NULL)
|
||
|
*dwConsoleThreadId = a->dwConsoleThreadId;
|
||
|
} except( EXCEPTION_EXECUTE_HANDLER ) {
|
||
|
SET_LAST_ERROR (ERROR_INVALID_ACCESS);
|
||
|
return FALSE;
|
||
|
}
|
||
|
return TRUE;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
#endif //!defined(BUILD_WOW6432)
|
||
|
|
||
|
#if !defined(BUILD_WOW64)
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
RegisterConsoleIME(
|
||
|
IN HWND hWndConsoleIME,
|
||
|
OUT DWORD *dwConsoleThreadId
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Description:
|
||
|
|
||
|
This routine register the Console IME on the current desktop.
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE - The operation failed.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
STARTUPINFOW StartupInfo;
|
||
|
DWORD dwDesktopLength;
|
||
|
GetStartupInfoW(&StartupInfo);
|
||
|
|
||
|
if (StartupInfo.lpDesktop != NULL && *StartupInfo.lpDesktop != 0) {
|
||
|
dwDesktopLength = (USHORT)((wcslen(StartupInfo.lpDesktop)+1)*sizeof(WCHAR));
|
||
|
dwDesktopLength = (USHORT)(min(dwDesktopLength,MAX_TITLE_LENGTH));
|
||
|
} else {
|
||
|
dwDesktopLength = 0;
|
||
|
}
|
||
|
|
||
|
return RegisterConsoleIMEInternal(hWndConsoleIME,
|
||
|
GetCurrentThreadId(),
|
||
|
dwDesktopLength,
|
||
|
StartupInfo.lpDesktop,
|
||
|
dwConsoleThreadId);
|
||
|
}
|
||
|
|
||
|
#endif //!defined(BUILD_WOW64)
|
||
|
|
||
|
#if !defined(BUILD_WOW6432)
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
UnregisterConsoleIMEInternal(
|
||
|
IN DWORD dwConsoleIMEThtreadId
|
||
|
)
|
||
|
{
|
||
|
CONSOLE_API_MSG m;
|
||
|
PCONSOLE_UNREGISTER_CONSOLEIME_MSG a = &m.u.UnregisterConsoleIME;
|
||
|
|
||
|
a->ConsoleHandle = GET_CONSOLE_HANDLE;
|
||
|
a->dwConsoleIMEThreadId = dwConsoleIMEThtreadId;
|
||
|
|
||
|
|
||
|
// Connect to the server process
|
||
|
|
||
|
|
||
|
CsrClientCallServer( (PCSR_API_MSG)&m,
|
||
|
NULL,
|
||
|
CSR_MAKE_API_NUMBER( CONSRV_SERVERDLL_INDEX,
|
||
|
ConsolepUnregisterConsoleIME
|
||
|
),
|
||
|
sizeof( *a )
|
||
|
);
|
||
|
|
||
|
if (!NT_SUCCESS( m.ReturnValue)) {
|
||
|
SET_LAST_NT_ERROR(m.ReturnValue);
|
||
|
return FALSE;
|
||
|
}
|
||
|
else {
|
||
|
return TRUE;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#endif //!defined(BUILD_WOW6432)
|
||
|
|
||
|
#if !defined(BUILD_WOW64)
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
UnregisterConsoleIME(
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Description:
|
||
|
|
||
|
This routine unregister the Console IME on the current desktop.
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE - The operation failed.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
|
||
|
return UnregisterConsoleIMEInternal(GetCurrentThreadId());
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
NTSTATUS MyRegOpenKey(IN HANDLE hKey, IN LPWSTR lpSubKey, OUT PHANDLE phResult)
|
||
|
{
|
||
|
OBJECT_ATTRIBUTES Obja;
|
||
|
UNICODE_STRING SubKey;
|
||
|
|
||
|
RtlInitUnicodeString( &SubKey, lpSubKey );// Convert the subkey to a counted Unicode string.
|
||
|
|
||
|
// Initialize the OBJECT_ATTRIBUTES structure and open the key.
|
||
|
InitializeObjectAttributes(&Obja, &SubKey, OBJ_CASE_INSENSITIVE, hKey, NULL);
|
||
|
return NtOpenKey(phResult, KEY_READ, &Obja);
|
||
|
}
|
||
|
|
||
|
NTSTATUS
|
||
|
MyRegQueryValue(
|
||
|
IN HANDLE hKey,
|
||
|
IN LPWSTR lpValueName,
|
||
|
IN DWORD dwValueLength,
|
||
|
OUT LPBYTE lpData
|
||
|
)
|
||
|
{
|
||
|
UNICODE_STRING ValueName;
|
||
|
ULONG BufferLength;
|
||
|
ULONG ResultLength;
|
||
|
PKEY_VALUE_FULL_INFORMATION KeyValueInformation;
|
||
|
NTSTATUS Status;
|
||
|
|
||
|
|
||
|
// Convert the subkey to a counted Unicode string.
|
||
|
RtlInitUnicodeString( &ValueName, lpValueName );
|
||
|
BufferLength = sizeof(KEY_VALUE_FULL_INFORMATION) + dwValueLength + ValueName.Length;;
|
||
|
KeyValueInformation = LocalAlloc(LPTR,BufferLength);
|
||
|
if (KeyValueInformation == NULL)
|
||
|
return STATUS_NO_MEMORY;
|
||
|
|
||
|
Status = NtQueryValueKey(hKey, &ValueName, KeyValueFullInformation, KeyValueInformation, BufferLength, &ResultLength);
|
||
|
if (NT_SUCCESS(Status)) {
|
||
|
ASSERT(KeyValueInformation->DataLength <= dwValueLength);
|
||
|
RtlMoveMemory(lpData, (PBYTE)KeyValueInformation + KeyValueInformation->DataOffset, KeyValueInformation->DataLength);
|
||
|
if (KeyValueInformation->Type == REG_SZ) {
|
||
|
if (KeyValueInformation->DataLength + sizeof(WCHAR) > dwValueLength) {
|
||
|
KeyValueInformation->DataLength -= sizeof(WCHAR);
|
||
|
}
|
||
|
lpData[KeyValueInformation->DataLength++] = 0;
|
||
|
lpData[KeyValueInformation->DataLength] = 0;
|
||
|
}
|
||
|
}
|
||
|
LocalFree(KeyValueInformation);
|
||
|
return Status;
|
||
|
}
|
||
|
|
||
|
VOID
|
||
|
GetCommandLineString(
|
||
|
IN LPWSTR CommandLine,
|
||
|
IN DWORD dwSize
|
||
|
)
|
||
|
{
|
||
|
NTSTATUS Status;
|
||
|
HANDLE hkRegistry;
|
||
|
WCHAR awchBuffer[ 512 ];
|
||
|
DWORD dwRet;
|
||
|
|
||
|
dwRet = GetSystemDirectoryW(CommandLine, dwSize);
|
||
|
if (dwRet)
|
||
|
{
|
||
|
CommandLine[dwRet++] = L'\\';
|
||
|
CommandLine[dwRet] = L'\0';
|
||
|
dwSize -= dwRet;
|
||
|
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
CommandLine[0] = L'\0';
|
||
|
}
|
||
|
|
||
|
Status = MyRegOpenKey(NULL,
|
||
|
MACHINE_REGISTRY_CONSOLE,
|
||
|
&hkRegistry);
|
||
|
if (NT_SUCCESS( Status ))
|
||
|
{
|
||
|
Status = MyRegQueryValue(hkRegistry,
|
||
|
MACHINE_REGISTRY_CONSOLEIME,
|
||
|
sizeof(awchBuffer), (PBYTE)&awchBuffer);
|
||
|
if (NT_SUCCESS( Status ))
|
||
|
{
|
||
|
dwRet = wcslen(awchBuffer);
|
||
|
if (dwRet < dwSize)
|
||
|
{
|
||
|
wcscat(CommandLine, awchBuffer);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
CommandLine[0] = L'\0';
|
||
|
goto ErrorExit;
|
||
|
}
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
goto ErrorExit;
|
||
|
}
|
||
|
|
||
|
NtClose(hkRegistry);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
goto ErrorExit;
|
||
|
}
|
||
|
|
||
|
return;
|
||
|
|
||
|
ErrorExit:
|
||
|
wcscat(CommandLine, L"conime.exe");
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
|
||
|
DWORD ConsoleIMERoutine(IN LPVOID lpThreadParameter)
|
||
|
/*++
|
||
|
Routine Description:
|
||
|
This thread is created when the create input thread.
|
||
|
It invokes the console IME process.
|
||
|
Arguments:
|
||
|
lpThreadParameter - not use.
|
||
|
Return Value:
|
||
|
STATUS_SUCCESS - function was successful
|
||
|
--*/
|
||
|
{
|
||
|
NTSTATUS Status;
|
||
|
BOOL fRet;
|
||
|
static BOOL fInConIMERoutine = FALSE;
|
||
|
|
||
|
DWORD fdwCreate;
|
||
|
STARTUPINFOW StartupInfo;
|
||
|
STARTUPINFOW StartupInfoConsole;
|
||
|
WCHAR CommandLine[MAX_PATH*2];
|
||
|
PROCESS_INFORMATION ProcessInformation;
|
||
|
HANDLE hEvent;
|
||
|
DWORD dwWait;
|
||
|
|
||
|
Status = STATUS_SUCCESS;
|
||
|
|
||
|
// Prevent the user from launching multiple applets attached to a single console
|
||
|
if (fInConIMERoutine) {
|
||
|
return (ULONG)STATUS_UNSUCCESSFUL;
|
||
|
}
|
||
|
|
||
|
fInConIMERoutine = TRUE;
|
||
|
|
||
|
// Create event
|
||
|
hEvent = CreateEventW(NULL, // Security attributes
|
||
|
FALSE, // Manual reset
|
||
|
FALSE, // Initial state
|
||
|
CONSOLEIME_EVENT); // Event object name
|
||
|
if (hEvent == NULL)
|
||
|
{
|
||
|
goto ErrorExit;
|
||
|
}
|
||
|
if (GetLastError() == ERROR_ALREADY_EXISTS)
|
||
|
{
|
||
|
goto ErrorExit;
|
||
|
}
|
||
|
|
||
|
// Get Console IME process name and event name
|
||
|
GetCommandLineString(CommandLine, sizeof(CommandLine)/sizeof(WCHAR));
|
||
|
|
||
|
GetStartupInfoW(&StartupInfoConsole);
|
||
|
RtlZeroMemory(&StartupInfo, sizeof(StartupInfo));
|
||
|
StartupInfo.cb = sizeof(StartupInfo);
|
||
|
StartupInfo.wShowWindow = SW_HIDE;
|
||
|
StartupInfo.dwFlags = STARTF_FORCEONFEEDBACK;
|
||
|
StartupInfo.lpDesktop = StartupInfoConsole.lpDesktop;
|
||
|
|
||
|
// create Console IME process
|
||
|
fdwCreate = NORMAL_PRIORITY_CLASS | CREATE_DEFAULT_ERROR_MODE | CREATE_NEW_PROCESS_GROUP;
|
||
|
fRet = CreateProcessW(NULL, // Application name
|
||
|
CommandLine, // Command line
|
||
|
NULL, // process security attributes
|
||
|
NULL, // thread security attributes
|
||
|
FALSE, // inherit handles
|
||
|
fdwCreate, // create flags
|
||
|
NULL, // environment
|
||
|
NULL, // current directory
|
||
|
&StartupInfo, // Start up information
|
||
|
&ProcessInformation // process information
|
||
|
);
|
||
|
if (! fRet)
|
||
|
{
|
||
|
Status = GetLastError();
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
dwWait = WaitForSingleObject(hEvent, 10 * 1000); // wait 10 sec for console IME process
|
||
|
if (dwWait == WAIT_TIMEOUT)
|
||
|
{
|
||
|
TerminateProcess(ProcessInformation.hProcess, 0);
|
||
|
}
|
||
|
CloseHandle(ProcessInformation.hThread) ;
|
||
|
CloseHandle(ProcessInformation.hProcess) ;
|
||
|
}
|
||
|
|
||
|
CloseHandle(hEvent);
|
||
|
|
||
|
ErrorExit:
|
||
|
fInConIMERoutine = FALSE;
|
||
|
return Status;
|
||
|
}
|
||
|
|
||
|
#endif //!defined(BUILD_WOW6432)
|
||
|
|
||
|
#endif // FE_IME
|
||
|
|
||
|
|
||
|
#else // FE_SB
|
||
|
|
||
|
// Followings are stub functions for FE Console Support
|
||
|
|
||
|
|
||
|
#if !defined(BUILD_WOW6432)
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
GetConsoleNlsMode(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
OUT LPDWORD lpNlsMode
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
lpNlsMode - Supplies a pointer to the NLS mode.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
SetConsoleNlsMode(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
IN DWORD dwNlsMode
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
dwNlsMode - Supplies NLS mode.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
GetConsoleCharType(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
IN COORD coordCheck,
|
||
|
OUT PDWORD pdwType
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
coordCheck - set check position to these coordinates
|
||
|
|
||
|
pdwType - receive character type
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
SetConsoleLocalEUDC(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
IN WORD wCodePoint,
|
||
|
IN COORD cFontSize,
|
||
|
IN PCHAR lpSB
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
wCodePoint - Code point of font by Shift JIS code.
|
||
|
|
||
|
cFontSize - FontSize of Font
|
||
|
|
||
|
lpSB - Pointer of font bitmap Buffer
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
SetConsoleCursorMode(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
IN BOOL Blink,
|
||
|
IN BOOL DBEnable
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
Blink - Blinking enable/disable switch.
|
||
|
|
||
|
DBEnable - Double Byte width enable/disable switch.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
GetConsoleCursorMode(
|
||
|
IN HANDLE hConsoleHandle,
|
||
|
OUT PBOOL pbBlink,
|
||
|
OUT PBOOL pbDBEnable
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
hConsoleHandle - Supplies a console input or output handle.
|
||
|
|
||
|
Blink - Blinking enable/disable switch.
|
||
|
|
||
|
DBEnable - Double Byte width enable/disable switch.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
RegisterConsoleOS2(
|
||
|
IN BOOL fOs2Register
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Description:
|
||
|
|
||
|
This routine registers the OS/2 with the console.
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
APIENTRY
|
||
|
SetConsoleOS2OemFormat(
|
||
|
IN BOOL fOs2OemFormat
|
||
|
)
|
||
|
|
||
|
/*++
|
||
|
|
||
|
Description:
|
||
|
|
||
|
This routine sets the OS/2 OEM Format with the console.
|
||
|
|
||
|
Parameters:
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
TRUE - The operation was successful.
|
||
|
|
||
|
FALSE/NULL - The operation failed. Extended error status is available
|
||
|
using GetLastError.
|
||
|
|
||
|
--*/
|
||
|
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
#endif //!defined(BUILD_WOW6432)
|
||
|
|
||
|
#if defined(FE_IME)
|
||
|
|
||
|
#if !defined(BUILD_WOW64)
|
||
|
BOOL APIENTRY RegisterConsoleIME(IN HWND hWndConsoleIME, OUT DWORD *dwConsoleThreadId)
|
||
|
/*++
|
||
|
Description:
|
||
|
This routine register the Console IME on the current desktop.
|
||
|
Return Value:
|
||
|
TRUE - The operation was successful.
|
||
|
FALSE - The operation failed.
|
||
|
--*/
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
|
||
|
BOOL APIENTRY UnregisterConsoleIME()
|
||
|
/*++
|
||
|
Description:
|
||
|
This routine unregister the Console IME on the current desktop.
|
||
|
Return Value:
|
||
|
TRUE - The operation was successful.
|
||
|
FALSE - The operation failed.
|
||
|
--*/
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
#endif //!defined(BUILD_WOW64)
|
||
|
#endif // FE_IME
|
||
|
#endif // FE_SB
|