#include "precomp.h"
#include "undocuser.h"
#include "winxx.h"
#include <strsafe.h>
#include "msgdump.h"
Go to the source code of this file.
|
enum | STAGE_TYPE { STAGE_TYPE_SEQUENCE,
STAGE_TYPE_COUNTING
} |
|
enum | ACTION {
ACTION_ZERO = 0,
ACTION_FIRSTMINMAX,
ACTION_NCCREATE,
ACTION_SHOW,
ACTION_IME_SETCONTEXT_OPEN,
ACTION_IME_NOTIFY_OPEN,
ACTION_DESTROY,
ACTION_IME_SETCONTEXT_CLOSE,
ACTION_IME_NOTIFY_CLOSE,
ACTION_HIDE,
ACTION_DEACTIVATE,
ACTION_ACTIVATE
} |
|
|
static void | MsgDumpPrintf (LPCSTR fmt,...) |
|
static void | DoInitialize (const STAGE *pStages, INT cStages) |
|
static void | DoFinish (void) |
|
static void | DoAction (HWND hwnd, INT iAction, WPARAM wParam, LPARAM lParam) |
|
static void | NextStage (HWND hwnd) |
|
static void | DoStage (HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam) |
|
static LRESULT CALLBACK | InnerWindowProc (HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam) |
|
static void | DoBuildPrefix (void) |
|
static LRESULT CALLBACK | WindowProc (HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam) |
|
static void | General_DoTest (void) |
|
static void | IME_DoTest (void) |
|
| START_TEST (MessageStateAnalyzer) |
|
◆ HEIGHT
◆ MSGDUMP_PREFIX
◆ MSGDUMP_TPRINTF
◆ PARENT_MSG
◆ TIMEOUT_TIMER
◆ TOTAL_TIMEOUT
#define TOTAL_TIMEOUT (5 * 1000) |
◆ WIDTH
◆ ACTION
◆ STAGE
◆ STAGE_TYPE
◆ ACTION
Enumerator |
---|
ACTION_ZERO | |
ACTION_FIRSTMINMAX | |
ACTION_NCCREATE | |
ACTION_SHOW | |
ACTION_IME_SETCONTEXT_OPEN | |
ACTION_IME_NOTIFY_OPEN | |
ACTION_DESTROY | |
ACTION_IME_SETCONTEXT_CLOSE | |
ACTION_IME_NOTIFY_CLOSE | |
ACTION_HIDE | |
ACTION_DEACTIVATE | |
ACTION_ACTIVATE | |
Definition at line 82 of file MessageStateAnalyzer.c.
◆ STAGE_TYPE
◆ DoAction()
◆ DoBuildPrefix()
Definition at line 278 of file MessageStateAnalyzer.c.
283 if (
Flags & ISMEX_CALLBACK)
285 if (
Flags & ISMEX_NOTIFY)
287 if (
Flags & ISMEX_REPLIED)
289 if (
Flags & ISMEX_SEND)
_Must_inspect_result_ _In_ ULONG Flags
DWORD WINAPI InSendMessageEx(LPVOID lpReserved)
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Referenced by WindowProc().
◆ DoFinish()
◆ DoInitialize()
◆ DoStage()
Definition at line 188 of file MessageStateAnalyzer.c.
198 switch (pStage->
nType)
205 "Line %d, Step %d: Level expected %d but %d.\n",
208 "Line %d, Step %d: PARENT_MSG expected %u but %u.\n",
227 "Line %d: Level expected %d but %d.\n",
230 "Line %d: PARENT_MSG expected %u but %u.\n",
static const STAGE * s_pStages
static void NextStage(HWND hwnd)
static INT s_nCounters[10]
#define ok_int(expression, result)
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
static void DoAction(HWND hwnd, INT iAction, WPARAM wParam, LPARAM lParam)
Referenced by WindowProc().
◆ General_DoTest()
Definition at line 357 of file MessageStateAnalyzer.c.
362 static const char s_szName[] =
"MessageStateAnalyzerGeneral";
364 trace(
"General_DoTest\n");
378 skip(
"RegisterClassW failed.\n");
388 skip(
"CreateWindowW failed.\n");
BOOL WINAPI TranslateMessage(_In_ const MSG *)
LRESULT WINAPI DispatchMessageA(_In_ const MSG *)
TW_UINT32 TW_UINT16 TW_UINT16 MSG
BOOL WINAPI GetMessageA(_Out_ LPMSG, _In_opt_ HWND, _In_ UINT, _In_ UINT)
static void DoFinish(void)
static const STAGE s_GeneralStages[]
#define CreateWindowA(a, b, c, d, e, f, g, h, i, j, k)
#define ok_int(expression, result)
static LRESULT CALLBACK WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
HMODULE WINAPI DECLSPEC_HOTPATCH GetModuleHandleA(LPCSTR lpModuleName)
static WCHAR s_szName[MAX_PATH]
static void DoInitialize(const STAGE *pStages, INT cStages)
#define WS_OVERLAPPEDWINDOW
HMODULE WINAPI GetModuleHandleW(LPCWSTR lpModuleName)
BOOL WINAPI UnregisterClassA(_In_ LPCSTR, HINSTANCE)
ATOM WINAPI RegisterClassA(_In_ CONST WNDCLASSA *)
Referenced by START_TEST().
◆ IME_DoTest()
Definition at line 523 of file MessageStateAnalyzer.c.
528 static const char s_szName[] =
"MessageStateAnalyzerIME";
530 trace(
"IME_DoTest\n");
544 skip(
"RegisterClassW failed.\n");
554 skip(
"CreateWindowW failed.\n");
BOOL WINAPI TranslateMessage(_In_ const MSG *)
LRESULT WINAPI DispatchMessageA(_In_ const MSG *)
TW_UINT32 TW_UINT16 TW_UINT16 MSG
BOOL WINAPI GetMessageA(_Out_ LPMSG, _In_opt_ HWND, _In_ UINT, _In_ UINT)
static void DoFinish(void)
#define CreateWindowA(a, b, c, d, e, f, g, h, i, j, k)
#define ok_int(expression, result)
static LRESULT CALLBACK WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
HMODULE WINAPI DECLSPEC_HOTPATCH GetModuleHandleA(LPCSTR lpModuleName)
static WCHAR s_szName[MAX_PATH]
static void DoInitialize(const STAGE *pStages, INT cStages)
#define WS_OVERLAPPEDWINDOW
HMODULE WINAPI GetModuleHandleW(LPCWSTR lpModuleName)
BOOL WINAPI UnregisterClassA(_In_ LPCSTR, HINSTANCE)
static const STAGE s_IMEStages[]
ATOM WINAPI RegisterClassA(_In_ CONST WNDCLASSA *)
Referenced by START_TEST().
◆ InnerWindowProc()
Definition at line 254 of file MessageStateAnalyzer.c.
BOOL WINAPI DestroyWindow(_In_ HWND)
UINT_PTR WINAPI SetTimer(_In_opt_ HWND, _In_ UINT_PTR, _In_ UINT, _In_opt_ TIMERPROC)
BOOL WINAPI KillTimer(_In_opt_ HWND, _In_ UINT_PTR)
static void DoAction(HWND hwnd, INT iAction, WPARAM wParam, LPARAM lParam)
__analysis_noreturn void WINAPI PostQuitMessage(_In_ int)
Referenced by WindowProc().
◆ MsgDumpPrintf()
Definition at line 13 of file MessageStateAnalyzer.c.
15 static char s_szText[1024];
19 trace(
"%s", s_szText);
STRSAFEAPI StringCbVPrintfA(STRSAFE_LPSTR pszDest, size_t cbDest, STRSAFE_LPCSTR pszFormat, va_list argList)
◆ NextStage()
Definition at line 152 of file MessageStateAnalyzer.c.
165 "Line %d: s_nCounters[%d] expected %d but %d.\n",
static const STAGE * s_pStages
BOOL WINAPI DestroyWindow(_In_ HWND)
static INT s_nCounters[10]
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Referenced by DoStage().
◆ START_TEST()
START_TEST |
( |
MessageStateAnalyzer |
| ) |
|
◆ WindowProc()
Definition at line 329 of file MessageStateAnalyzer.c.
static void DoBuildPrefix(void)
static void DoStage(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
STRSAFEAPI StringCbCopyA(STRSAFE_LPSTR pszDest, size_t cbDest, STRSAFE_LPCSTR pszSrc)
static LRESULT CALLBACK InnerWindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
static UINT s_msgStack[32]
static __inline LRESULT MSGDUMP_API MD_msgresult(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT lResult)
static __inline LRESULT MSGDUMP_API MD_msgdump(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
Referenced by General_DoTest(), and IME_DoTest().
◆ s_bNextStage
◆ s_cStages
◆ s_GeneralStages
◆ s_IMEStages
◆ s_iStage
◆ s_iStep
◆ s_msgStack
◆ s_nCounters
◆ s_nLevel
◆ s_prefix
◆ s_pStages