summaryrefslogtreecommitdiff
path: root/redo/basicctrls_windows.c
diff options
context:
space:
mode:
authorPietro Gagliardi <[email protected]>2014-08-20 12:04:36 -0400
committerPietro Gagliardi <[email protected]>2014-08-20 12:04:36 -0400
commite06e32715552764769e85c72a43bf5ee78e5f555 (patch)
treeb2137b70744875ede9b1645ce5ecc10d17b9e226 /redo/basicctrls_windows.c
parentac1b8e3cca971c38c8091f60fedfe093e6fe78df (diff)
Implemented TextField.OnChanged() on Windows.
Diffstat (limited to 'redo/basicctrls_windows.c')
-rw-r--r--redo/basicctrls_windows.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/redo/basicctrls_windows.c b/redo/basicctrls_windows.c
index a703d75..1676776 100644
--- a/redo/basicctrls_windows.c
+++ b/redo/basicctrls_windows.c
@@ -78,3 +78,29 @@ void checkboxSetChecked(HWND hwnd, BOOL c)
check = BST_UNCHECKED;
SendMessage(hwnd, BM_SETCHECK, check, 0);
}
+
+static LRESULT CALLBACK textfieldSubProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam, UINT_PTR id, DWORD_PTR data)
+{
+ switch (uMsg) {
+ case msgCOMMAND:
+ if (HIWORD(wParam) == EN_CHANGE) {
+ textfieldChanged((void *) data);
+ return 0;
+ }
+ return (*fv_DefSubclassProc)(hwnd, uMsg, wParam, lParam);
+ case WM_NCDESTROY:
+ if ((*fv_RemoveWindowSubclass)(hwnd, textfieldSubProc, id) == FALSE)
+ xpanic("error removing TextField subclass (which was for its own event handler)", GetLastError());
+ return (*fv_DefSubclassProc)(hwnd, uMsg, wParam, lParam);
+ default:
+ return (*fv_DefSubclassProc)(hwnd, uMsg, wParam, lParam);
+ }
+ xmissedmsg("TextField", "textfieldSubProc()", uMsg);
+ return 0; // unreached
+}
+
+void setTextFieldSubclass(HWND hwnd, void *data)
+{
+ if ((*fv_SetWindowSubclass)(hwnd, textfieldSubProc, 0, (DWORD_PTR) data) == FALSE)
+ xpanic("error subclassing TextField to give it its own event handler", GetLastError());
+}