Edit updates
Dimitrie O. Paun
dpaun at rogers.com
Tue Sep 24 01:09:04 CDT 2002
This patch is trying to bring the edit.c in line
with the other controls.
Alexandre, also:
cvs rm -f controls/EDIT.TODO
ChangeLog
-- Stop passing hwnd around when we're passing EDITSTATE
-- Merge the non-obosete bits of EDIT.TODO into edit.c
-- Small cleanups and simplifications
Index: controls/edit.c
===================================================================
RCS file: /var/cvs/wine/controls/edit.c,v
retrieving revision 1.102
diff -u -r1.102 edit.c
--- controls/edit.c 21 Sep 2002 01:21:00 -0000 1.102
+++ controls/edit.c 24 Sep 2002 04:06:21 -0000
@@ -19,10 +19,22 @@
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- */
-
-/*
- * please read EDIT.TODO (and update it when you change things)
+ *
+ * TODO:
+ * - ES_CENTER
+ * - ES_RIGHT
+ * - ES_NUMBER (new since win95)
+ * - ES_OEMCONVERT
+ * -!ES_AUTOVSCROLL (every multi line control *is* auto vscroll)
+ * -!ES_AUTOHSCROLL (every single line control *is* auto hscroll)
+ *
+ * When there is no autoscrolling, the control should first check whether
+ * the new text would fit. If not, an EN_MAXTEXT should be sent.
+ * However, currently this would require the actual change to be made,
+ * then call EDIT_BuildLineDefs() and then find out that the new text doesn't
+ * fit. After all this, things should be put back in the state before the
+ * changes. Note that for multi line controls !ES_AUTOHSCROLL works : wordwrap.
+ *
*/
#include "config.h"
@@ -66,19 +78,19 @@
typedef enum
{
- END_0 = 0, /* line ends with terminating '\0' character */
- END_WRAP, /* line is wrapped */
- END_HARD, /* line ends with a hard return '\r\n' */
- END_SOFT, /* line ends with a soft return '\r\r\n' */
- END_RICH /* line ends with a single '\n' */
+ END_0 = 0, /* line ends with terminating '\0' character */
+ END_WRAP, /* line is wrapped */
+ END_HARD, /* line ends with a hard return '\r\n' */
+ END_SOFT, /* line ends with a soft return '\r\r\n' */
+ END_RICH /* line ends with a single '\n' */
} LINE_END;
typedef struct tagLINEDEF {
- INT length; /* bruto length of a line in bytes */
- INT net_length; /* netto length of a line in visible characters */
+ INT length; /* bruto length of a line in bytes */
+ INT net_length; /* netto length of a line in visible characters */
LINE_END ending;
- INT width; /* width of the line in pixels */
- INT index; /* line index into the buffer */
+ INT width; /* width of the line in pixels */
+ INT index; /* line index into the buffer */
struct tagLINEDEF *next;
} LINEDEF;
@@ -92,10 +104,10 @@
INT x_offset; /* scroll offset for multi lines this is in pixels
for single lines it's in characters */
INT line_height; /* height of a screen line in pixels */
- INT char_width; /* average character width in pixels */
+ INT char_width; /* average character width in pixels */
DWORD style; /* sane version of wnd->dwStyle */
WORD flags; /* flags that are not in es->style or wnd->flags (EF_XXX) */
- INT undo_insert_count; /* number of characters inserted in sequence */
+ INT undo_insert_count; /* number of characters inserted in sequence */
UINT undo_position; /* character index of the insertion and deletion */
LPWSTR undo_text; /* deleted text */
UINT undo_buffer_size; /* size of the deleted text buffer */
@@ -111,63 +123,42 @@
INT region_posy; /* -1: to left, 0: within, 1: to right */
EDITWORDBREAKPROC16 word_break_proc16;
void *word_break_proc; /* 32-bit word break proc: ANSI or Unicode */
- INT line_count; /* number of lines */
+ INT line_count; /* number of lines */
INT y_offset; /* scroll offset in number of lines */
- BOOL bCaptureState; /* flag indicating whether mouse was captured */
- BOOL bEnableState; /* flag keeping the enable state */
- HWND hwndParent; /* Handle of parent for sending EN_* messages.
- Even if parent will change, EN_* messages
- should be sent to the first parent. */
- HWND hwndListBox; /* handle of ComboBox's listbox or NULL */
+ BOOL bCaptureState; /* flag indicating whether mouse was captured */
+ BOOL bEnableState; /* flag keeping the enable state */
+ HWND hwndSelf; /* the our window handle */
+ HWND hwndParent; /* Handle of parent for sending EN_* messages.
+ Even if parent will change, EN_* messages
+ should be sent to the first parent. */
+ HWND hwndListBox; /* handle of ComboBox's listbox or NULL */
/*
* only for multi line controls
*/
- INT lock_count; /* amount of re-entries in the EditWndProc */
+ INT lock_count; /* amount of re-entries in the EditWndProc */
INT tabs_count;
LPINT tabs;
LINEDEF *first_line_def; /* linked list of (soft) linebreaks */
- HLOCAL hloc32W; /* our unicode local memory block */
- HLOCAL16 hloc16; /* alias for 16-bit control receiving EM_GETHANDLE16
- or EM_SETHANDLE16 */
- HLOCAL hloc32A; /* alias for ANSI control receiving EM_GETHANDLE
- or EM_SETHANDLE */
+ HLOCAL hloc32W; /* our unicode local memory block */
+ HLOCAL16 hloc16; /* alias for 16-bit control receiving EM_GETHANDLE16
+ or EM_SETHANDLE16 */
+ HLOCAL hloc32A; /* alias for ANSI control receiving EM_GETHANDLE
+ or EM_SETHANDLE */
} EDITSTATE;
-#define SWAP_INT32(x,y) do { INT temp = (INT)(x); (x) = (INT)(y); (y) = temp; } while(0)
-#define ORDER_INT(x,y) do { if ((INT)(y) < (INT)(x)) SWAP_INT32((x),(y)); } while(0)
-
#define SWAP_UINT32(x,y) do { UINT temp = (UINT)(x); (x) = (UINT)(y); (y) = temp; } while(0)
#define ORDER_UINT(x,y) do { if ((UINT)(y) < (UINT)(x)) SWAP_UINT32((x),(y)); } while(0)
-#define DPRINTF_EDIT_NOTIFY(hwnd, str) \
- do {TRACE("notification " str " sent to hwnd=%08x\n", \
- (UINT)(hwnd));} while(0)
-
/* used for disabled or read-only edit control */
-#define EDIT_SEND_CTLCOLORSTATIC(hwnd,hdc) \
- (SendMessageW(GetParent(hwnd), WM_CTLCOLORSTATIC, \
- (WPARAM)(hdc), (LPARAM)(hwnd)))
-#define EDIT_SEND_CTLCOLOR(hwnd,hdc) \
- (SendMessageW(GetParent(hwnd), WM_CTLCOLOREDIT, \
- (WPARAM)(hdc), (LPARAM)(hwnd)))
-#define EDIT_NOTIFY_PARENT(hwnd, es, wNotifyCode, str) \
+#define EDIT_NOTIFY_PARENT(es, wNotifyCode, str) \
do \
{ /* Notify parent which has created this edit control */ \
- DPRINTF_EDIT_NOTIFY((es)->hwndParent, str); \
- SendMessageW((es)->hwndParent, WM_COMMAND, \
- MAKEWPARAM(GetWindowLongA((hwnd),GWL_ID), wNotifyCode), \
- (LPARAM)(hwnd)); \
+ TRACE("notification " str " sent to hwnd=%08x\n", es->hwndParent); \
+ SendMessageW(es->hwndParent, WM_COMMAND, \
+ MAKEWPARAM(GetWindowLongA((es->hwndSelf),GWL_ID), wNotifyCode), \
+ (LPARAM)(es->hwndSelf)); \
} while(0)
-#define DPRINTF_EDIT_MSG16(str) \
- TRACE(\
- "16 bit : " str ": hwnd=%08x, wParam=%08x, lParam=%08x\n", \
- hwnd, (UINT)wParam, (UINT)lParam)
-#define DPRINTF_EDIT_MSG32(str) \
- TRACE(\
- "32 bit %c : " str ": hwnd=%08x, wParam=%08x, lParam=%08x\n", \
- unicode ? 'W' : 'A', \
- hwnd, (UINT)wParam, (UINT)lParam)
/*********************************************************************
*
@@ -182,105 +173,105 @@
*/
static inline BOOL EDIT_EM_CanUndo(EDITSTATE *es);
static inline void EDIT_EM_EmptyUndoBuffer(EDITSTATE *es);
-static inline void EDIT_WM_Clear(HWND hwnd, EDITSTATE *es);
-static inline void EDIT_WM_Cut(HWND hwnd, EDITSTATE *es);
+static inline void EDIT_WM_Clear(EDITSTATE *es);
+static inline void EDIT_WM_Cut(EDITSTATE *es);
/*
* Helper functions only valid for one type of control
*/
-static void EDIT_BuildLineDefs_ML(HWND hwnd, EDITSTATE *es, INT iStart, INT iEnd, INT delta, HRGN hrgn);
-static void EDIT_CalcLineWidth_SL(HWND hwnd, EDITSTATE *es);
+static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT iStart, INT iEnd, INT delta, HRGN hrgn);
+static void EDIT_CalcLineWidth_SL(EDITSTATE *es);
static LPWSTR EDIT_GetPasswordPointer_SL(EDITSTATE *es);
-static void EDIT_MoveDown_ML(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_MovePageDown_ML(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_MovePageUp_ML(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_MoveUp_ML(HWND hwnd, EDITSTATE *es, BOOL extend);
+static void EDIT_MoveDown_ML(EDITSTATE *es, BOOL extend);
+static void EDIT_MovePageDown_ML(EDITSTATE *es, BOOL extend);
+static void EDIT_MovePageUp_ML(EDITSTATE *es, BOOL extend);
+static void EDIT_MoveUp_ML(EDITSTATE *es, BOOL extend);
/*
* Helper functions valid for both single line _and_ multi line controls
*/
static INT EDIT_CallWordBreakProc(EDITSTATE *es, INT start, INT index, INT count, INT action);
-static INT EDIT_CharFromPos(HWND hwnd, EDITSTATE *es, INT x, INT y, LPBOOL after_wrap);
+static INT EDIT_CharFromPos(EDITSTATE *es, INT x, INT y, LPBOOL after_wrap);
static void EDIT_ConfinePoint(EDITSTATE *es, LPINT x, LPINT y);
-static void EDIT_GetLineRect(HWND hwnd, EDITSTATE *es, INT line, INT scol, INT ecol, LPRECT rc);
-static void EDIT_InvalidateText(HWND hwnd, EDITSTATE *es, INT start, INT end);
-static void EDIT_LockBuffer(HWND hwnd, EDITSTATE *es);
-static BOOL EDIT_MakeFit(HWND hwnd, EDITSTATE *es, UINT size);
+static void EDIT_GetLineRect(EDITSTATE *es, INT line, INT scol, INT ecol, LPRECT rc);
+static void EDIT_InvalidateText(EDITSTATE *es, INT start, INT end);
+static void EDIT_LockBuffer(EDITSTATE *es);
+static BOOL EDIT_MakeFit(EDITSTATE *es, UINT size);
static BOOL EDIT_MakeUndoFit(EDITSTATE *es, UINT size);
-static void EDIT_MoveBackward(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_MoveEnd(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_MoveForward(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_MoveHome(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_MoveWordBackward(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_MoveWordForward(HWND hwnd, EDITSTATE *es, BOOL extend);
-static void EDIT_PaintLine(HWND hwnd, EDITSTATE *es, HDC hdc, INT line, BOOL rev);
+static void EDIT_MoveBackward(EDITSTATE *es, BOOL extend);
+static void EDIT_MoveEnd(EDITSTATE *es, BOOL extend);
+static void EDIT_MoveForward(EDITSTATE *es, BOOL extend);
+static void EDIT_MoveHome(EDITSTATE *es, BOOL extend);
+static void EDIT_MoveWordBackward(EDITSTATE *es, BOOL extend);
+static void EDIT_MoveWordForward(EDITSTATE *es, BOOL extend);
+static void EDIT_PaintLine(EDITSTATE *es, HDC hdc, INT line, BOOL rev);
static INT EDIT_PaintText(EDITSTATE *es, HDC hdc, INT x, INT y, INT line, INT col, INT count, BOOL rev);
-static void EDIT_SetCaretPos(HWND hwnd, EDITSTATE *es, INT pos, BOOL after_wrap);
-static void EDIT_SetRectNP(HWND hwnd, EDITSTATE *es, LPRECT lprc);
-static void EDIT_UnlockBuffer(HWND hwnd, EDITSTATE *es, BOOL force);
-static void EDIT_UpdateScrollInfo(HWND hwnd, EDITSTATE *es);
+static void EDIT_SetCaretPos(EDITSTATE *es, INT pos, BOOL after_wrap);
+static void EDIT_SetRectNP(EDITSTATE *es, LPRECT lprc);
+static void EDIT_UnlockBuffer(EDITSTATE *es, BOOL force);
+static void EDIT_UpdateScrollInfo(EDITSTATE *es);
static INT CALLBACK EDIT_WordBreakProc(LPWSTR s, INT index, INT count, INT action);
/*
* EM_XXX message handlers
*/
-static LRESULT EDIT_EM_CharFromPos(HWND hwnd, EDITSTATE *es, INT x, INT y);
+static LRESULT EDIT_EM_CharFromPos(EDITSTATE *es, INT x, INT y);
static BOOL EDIT_EM_FmtLines(EDITSTATE *es, BOOL add_eol);
static HLOCAL EDIT_EM_GetHandle(EDITSTATE *es);
-static HLOCAL16 EDIT_EM_GetHandle16(HWND hwnd, EDITSTATE *es);
+static HLOCAL16 EDIT_EM_GetHandle16(EDITSTATE *es);
static INT EDIT_EM_GetLine(EDITSTATE *es, INT line, LPARAM lParam, BOOL unicode);
static LRESULT EDIT_EM_GetSel(EDITSTATE *es, PUINT start, PUINT end);
-static LRESULT EDIT_EM_GetThumb(HWND hwnd, EDITSTATE *es);
+static LRESULT EDIT_EM_GetThumb(EDITSTATE *es);
static INT EDIT_EM_LineFromChar(EDITSTATE *es, INT index);
static INT EDIT_EM_LineIndex(EDITSTATE *es, INT line);
static INT EDIT_EM_LineLength(EDITSTATE *es, INT index);
-static BOOL EDIT_EM_LineScroll(HWND hwnd, EDITSTATE *es, INT dx, INT dy);
-static BOOL EDIT_EM_LineScroll_internal(HWND hwnd, EDITSTATE *es, INT dx, INT dy);
-static LRESULT EDIT_EM_PosFromChar(HWND hwnd, EDITSTATE *es, INT index, BOOL after_wrap);
-static void EDIT_EM_ReplaceSel(HWND hwnd, EDITSTATE *es, BOOL can_undo, LPCWSTR lpsz_replace, BOOL send_update);
-static LRESULT EDIT_EM_Scroll(HWND hwnd, EDITSTATE *es, INT action);
-static void EDIT_EM_ScrollCaret(HWND hwnd, EDITSTATE *es);
-static void EDIT_EM_SetHandle(HWND hwnd, EDITSTATE *es, HLOCAL hloc);
-static void EDIT_EM_SetHandle16(HWND hwnd, EDITSTATE *es, HLOCAL16 hloc);
+static BOOL EDIT_EM_LineScroll(EDITSTATE *es, INT dx, INT dy);
+static BOOL EDIT_EM_LineScroll_internal(EDITSTATE *es, INT dx, INT dy);
+static LRESULT EDIT_EM_PosFromChar(EDITSTATE *es, INT index, BOOL after_wrap);
+static void EDIT_EM_ReplaceSel(EDITSTATE *es, BOOL can_undo, LPCWSTR lpsz_replace, BOOL send_update);
+static LRESULT EDIT_EM_Scroll(EDITSTATE *es, INT action);
+static void EDIT_EM_ScrollCaret(EDITSTATE *es);
+static void EDIT_EM_SetHandle(EDITSTATE *es, HLOCAL hloc);
+static void EDIT_EM_SetHandle16(EDITSTATE *es, HLOCAL16 hloc);
static void EDIT_EM_SetLimitText(EDITSTATE *es, INT limit);
static void EDIT_EM_SetMargins(EDITSTATE *es, INT action, INT left, INT right);
-static void EDIT_EM_SetPasswordChar(HWND hwnd, EDITSTATE *es, WCHAR c);
-static void EDIT_EM_SetSel(HWND hwnd, EDITSTATE *es, UINT start, UINT end, BOOL after_wrap);
+static void EDIT_EM_SetPasswordChar(EDITSTATE *es, WCHAR c);
+static void EDIT_EM_SetSel(EDITSTATE *es, UINT start, UINT end, BOOL after_wrap);
static BOOL EDIT_EM_SetTabStops(EDITSTATE *es, INT count, LPINT tabs);
static BOOL EDIT_EM_SetTabStops16(EDITSTATE *es, INT count, LPINT16 tabs);
-static void EDIT_EM_SetWordBreakProc(HWND hwnd, EDITSTATE *es, LPARAM lParam);
-static void EDIT_EM_SetWordBreakProc16(HWND hwnd, EDITSTATE *es, EDITWORDBREAKPROC16 wbp);
-static BOOL EDIT_EM_Undo(HWND hwnd, EDITSTATE *es);
+static void EDIT_EM_SetWordBreakProc(EDITSTATE *es, LPARAM lParam);
+static void EDIT_EM_SetWordBreakProc16(EDITSTATE *es, EDITWORDBREAKPROC16 wbp);
+static BOOL EDIT_EM_Undo(EDITSTATE *es);
/*
* WM_XXX message handlers
*/
-static void EDIT_WM_Char(HWND hwnd, EDITSTATE *es, WCHAR c);
-static void EDIT_WM_Command(HWND hwnd, EDITSTATE *es, INT code, INT id, HWND conrtol);
-static void EDIT_WM_ContextMenu(HWND hwnd, EDITSTATE *es, INT x, INT y);
-static void EDIT_WM_Copy(HWND hwnd, EDITSTATE *es);
-static LRESULT EDIT_WM_Create(HWND hwnd, EDITSTATE *es, LPCWSTR name);
-static void EDIT_WM_Destroy(HWND hwnd, EDITSTATE *es);
-static LRESULT EDIT_WM_EraseBkGnd(HWND hwnd, EDITSTATE *es, HDC dc);
+static void EDIT_WM_Char(EDITSTATE *es, WCHAR c);
+static void EDIT_WM_Command(EDITSTATE *es, INT code, INT id, HWND conrtol);
+static void EDIT_WM_ContextMenu(EDITSTATE *es, INT x, INT y);
+static void EDIT_WM_Copy(EDITSTATE *es);
+static LRESULT EDIT_WM_Create(EDITSTATE *es, LPCWSTR name);
+static void EDIT_WM_Destroy(EDITSTATE *es);
+static LRESULT EDIT_WM_EraseBkGnd(EDITSTATE *es, HDC dc);
static INT EDIT_WM_GetText(EDITSTATE *es, INT count, LPARAM lParam, BOOL unicode);
-static LRESULT EDIT_WM_HScroll(HWND hwnd, EDITSTATE *es, INT action, INT pos);
-static LRESULT EDIT_WM_KeyDown(HWND hwnd, EDITSTATE *es, INT key);
-static LRESULT EDIT_WM_KillFocus(HWND hwnd, EDITSTATE *es);
-static LRESULT EDIT_WM_LButtonDblClk(HWND hwnd, EDITSTATE *es);
-static LRESULT EDIT_WM_LButtonDown(HWND hwnd, EDITSTATE *es, DWORD keys, INT x, INT y);
-static LRESULT EDIT_WM_LButtonUp(HWND hwndSelf, EDITSTATE *es);
-static LRESULT EDIT_WM_MButtonDown(HWND hwnd);
-static LRESULT EDIT_WM_MouseMove(HWND hwnd, EDITSTATE *es, INT x, INT y);
+static LRESULT EDIT_WM_HScroll(EDITSTATE *es, INT action, INT pos);
+static LRESULT EDIT_WM_KeyDown(EDITSTATE *es, INT key);
+static LRESULT EDIT_WM_KillFocus(EDITSTATE *es);
+static LRESULT EDIT_WM_LButtonDblClk(EDITSTATE *es);
+static LRESULT EDIT_WM_LButtonDown(EDITSTATE *es, DWORD keys, INT x, INT y);
+static LRESULT EDIT_WM_LButtonUp(EDITSTATE *es);
+static LRESULT EDIT_WM_MButtonDown(EDITSTATE *es);
+static LRESULT EDIT_WM_MouseMove(EDITSTATE *es, INT x, INT y);
static LRESULT EDIT_WM_NCCreate(HWND hwnd, DWORD style, HWND hwndParent, BOOL unicode);
-static void EDIT_WM_Paint(HWND hwnd, EDITSTATE *es, WPARAM wParam);
-static void EDIT_WM_Paste(HWND hwnd, EDITSTATE *es);
-static void EDIT_WM_SetFocus(HWND hwnd, EDITSTATE *es);
-static void EDIT_WM_SetFont(HWND hwnd, EDITSTATE *es, HFONT font, BOOL redraw);
-static void EDIT_WM_SetText(HWND hwnd, EDITSTATE *es, LPARAM lParam, BOOL unicode);
-static void EDIT_WM_Size(HWND hwnd, EDITSTATE *es, UINT action, INT width, INT height);
-static LRESULT EDIT_WM_StyleChanged (HWND hwnd, EDITSTATE *es, WPARAM which, const STYLESTRUCT *style);
-static LRESULT EDIT_WM_SysKeyDown(HWND hwnd, EDITSTATE *es, INT key, DWORD key_data);
-static void EDIT_WM_Timer(HWND hwnd, EDITSTATE *es);
-static LRESULT EDIT_WM_VScroll(HWND hwnd, EDITSTATE *es, INT action, INT pos);
-static void EDIT_UpdateText(HWND hwnd, EDITSTATE *es, LPRECT rc, BOOL bErase);
-static void EDIT_UpdateTextRegion(HWND hwnd, EDITSTATE *es, HRGN hrgn, BOOL bErase);
+static void EDIT_WM_Paint(EDITSTATE *es, WPARAM wParam);
+static void EDIT_WM_Paste(EDITSTATE *es);
+static void EDIT_WM_SetFocus(EDITSTATE *es);
+static void EDIT_WM_SetFont(EDITSTATE *es, HFONT font, BOOL redraw);
+static void EDIT_WM_SetText(EDITSTATE *es, LPARAM lParam, BOOL unicode);
+static void EDIT_WM_Size(EDITSTATE *es, UINT action, INT width, INT height);
+static LRESULT EDIT_WM_StyleChanged(EDITSTATE *es, WPARAM which, const STYLESTRUCT *style);
+static LRESULT EDIT_WM_SysKeyDown(EDITSTATE *es, INT key, DWORD key_data);
+static void EDIT_WM_Timer(EDITSTATE *es);
+static LRESULT EDIT_WM_VScroll(EDITSTATE *es, INT action, INT pos);
+static void EDIT_UpdateText(EDITSTATE *es, LPRECT rc, BOOL bErase);
+static void EDIT_UpdateTextRegion(EDITSTATE *es, HRGN hrgn, BOOL bErase);
LRESULT WINAPI EditWndProcA(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam);
LRESULT WINAPI EditWndProcW(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam);
@@ -328,7 +319,7 @@
* WM_CLEAR
*
*/
-static inline void EDIT_WM_Clear(HWND hwnd, EDITSTATE *es)
+static inline void EDIT_WM_Clear(EDITSTATE *es)
{
static const WCHAR empty_stringW[] = {0};
@@ -336,7 +327,7 @@
if(es->style & ES_READONLY)
return;
- EDIT_EM_ReplaceSel(hwnd, es, TRUE, empty_stringW, TRUE);
+ EDIT_EM_ReplaceSel(es, TRUE, empty_stringW, TRUE);
}
@@ -345,10 +336,10 @@
* WM_CUT
*
*/
-static inline void EDIT_WM_Cut(HWND hwnd, EDITSTATE *es)
+static inline void EDIT_WM_Cut(EDITSTATE *es)
{
- EDIT_WM_Copy(hwnd, es);
- EDIT_WM_Clear(hwnd, es);
+ EDIT_WM_Copy(es);
+ EDIT_WM_Clear(es);
}
@@ -388,6 +379,19 @@
}
+static HBRUSH EDIT_NotifyCtlColor(EDITSTATE *es, HDC hdc)
+{
+ UINT msg;
+
+ if ( get_app_version() >= 0x40000 && (!es->bEnableState || (es->style & ES_READONLY)))
+ msg = WM_CTLCOLORSTATIC;
+ else
+ msg = WM_CTLCOLOREDIT;
+
+ /* why do we notify to es->hwndParent, and we send this one to GetParent()? */
+ return (HBRUSH)SendMessageW(GetParent(es->hwndSelf), msg, (WPARAM)hdc, (LPARAM)es->hwndSelf);
+}
+
/*********************************************************************
*
* EditWndProc_common
@@ -407,15 +411,25 @@
EDITSTATE *es = (EDITSTATE *)GetWindowLongA( hwnd, 0 );
LRESULT result = 0;
+ TRACE("hwnd=%x msg=%x wparam=%x lparam=%lx\n", hwnd, msg, wParam, lParam);
+
+ if (!es && msg != WM_NCCREATE)
+ {
+ if(unicode)
+ result = DefWindowProcW(hwnd, msg, wParam, lParam);
+ else
+ result = DefWindowProcA(hwnd, msg, wParam, lParam);
+ goto END;
+ }
+
+ if (es) EDIT_LockBuffer(es);
+
switch (msg) {
case WM_DESTROY:
- DPRINTF_EDIT_MSG32("WM_DESTROY");
- if (es) EDIT_WM_Destroy(hwnd, es);
- result = 0;
- goto END;
+ EDIT_WM_Destroy(es);
+ break;
case WM_NCCREATE:
- DPRINTF_EDIT_MSG32("WM_NCCREATE");
if(unicode)
{
LPCREATESTRUCTW cs = (LPCREATESTRUCTW)lParam;
@@ -426,130 +440,93 @@
LPCREATESTRUCTA cs = (LPCREATESTRUCTA)lParam;
result = EDIT_WM_NCCreate(hwnd, cs->style, cs->hwndParent, FALSE);
}
- goto END;
- }
-
- if (!es)
- {
- if(unicode)
- result = DefWindowProcW(hwnd, msg, wParam, lParam);
- else
- result = DefWindowProcA(hwnd, msg, wParam, lParam);
- goto END;
- }
-
-
- EDIT_LockBuffer(hwnd, es);
- switch (msg) {
+ break;
+
case EM_GETSEL16:
- DPRINTF_EDIT_MSG16("EM_GETSEL");
wParam = 0;
lParam = 0;
/* fall through */
case EM_GETSEL:
- DPRINTF_EDIT_MSG32("EM_GETSEL");
result = EDIT_EM_GetSel(es, (PUINT)wParam, (PUINT)lParam);
break;
case EM_SETSEL16:
- DPRINTF_EDIT_MSG16("EM_SETSEL");
if (SLOWORD(lParam) == -1)
- EDIT_EM_SetSel(hwnd, es, (UINT)-1, 0, FALSE);
+ EDIT_EM_SetSel(es, (UINT)-1, 0, FALSE);
else
- EDIT_EM_SetSel(hwnd, es, LOWORD(lParam), HIWORD(lParam), FALSE);
+ EDIT_EM_SetSel(es, LOWORD(lParam), HIWORD(lParam), FALSE);
if (!wParam)
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_ScrollCaret(es);
result = 1;
break;
case EM_SETSEL:
- DPRINTF_EDIT_MSG32("EM_SETSEL");
- EDIT_EM_SetSel(hwnd, es, wParam, lParam, FALSE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, wParam, lParam, FALSE);
+ EDIT_EM_ScrollCaret(es);
result = 1;
break;
case EM_GETRECT16:
- DPRINTF_EDIT_MSG16("EM_GETRECT");
if (lParam)
CONV_RECT32TO16(&es->format_rect, MapSL(lParam));
break;
case EM_GETRECT:
- DPRINTF_EDIT_MSG32("EM_GETRECT");
if (lParam)
CopyRect((LPRECT)lParam, &es->format_rect);
break;
case EM_SETRECT16:
- DPRINTF_EDIT_MSG16("EM_SETRECT");
if ((es->style & ES_MULTILINE) && lParam) {
RECT rc;
CONV_RECT16TO32(MapSL(lParam), &rc);
- EDIT_SetRectNP(hwnd, es, &rc);
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_SetRectNP(es, &rc);
+ EDIT_UpdateText(es, NULL, TRUE);
}
break;
case EM_SETRECT:
- DPRINTF_EDIT_MSG32("EM_SETRECT");
if ((es->style & ES_MULTILINE) && lParam) {
- EDIT_SetRectNP(hwnd, es, (LPRECT)lParam);
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_SetRectNP(es, (LPRECT)lParam);
+ EDIT_UpdateText(es, NULL, TRUE);
}
break;
case EM_SETRECTNP16:
- DPRINTF_EDIT_MSG16("EM_SETRECTNP");
if ((es->style & ES_MULTILINE) && lParam) {
RECT rc;
CONV_RECT16TO32(MapSL(lParam), &rc);
- EDIT_SetRectNP(hwnd, es, &rc);
+ EDIT_SetRectNP(es, &rc);
}
break;
case EM_SETRECTNP:
- DPRINTF_EDIT_MSG32("EM_SETRECTNP");
if ((es->style & ES_MULTILINE) && lParam)
- EDIT_SetRectNP(hwnd, es, (LPRECT)lParam);
+ EDIT_SetRectNP(es, (LPRECT)lParam);
break;
case EM_SCROLL16:
- DPRINTF_EDIT_MSG16("EM_SCROLL");
- /* fall through */
case EM_SCROLL:
- DPRINTF_EDIT_MSG32("EM_SCROLL");
- result = EDIT_EM_Scroll(hwnd, es, (INT)wParam);
+ result = EDIT_EM_Scroll(es, (INT)wParam);
break;
case EM_LINESCROLL16:
- DPRINTF_EDIT_MSG16("EM_LINESCROLL");
wParam = (WPARAM)(INT)SHIWORD(lParam);
lParam = (LPARAM)(INT)SLOWORD(lParam);
/* fall through */
case EM_LINESCROLL:
- DPRINTF_EDIT_MSG32("EM_LINESCROLL");
- result = (LRESULT)EDIT_EM_LineScroll(hwnd, es, (INT)wParam, (INT)lParam);
+ result = (LRESULT)EDIT_EM_LineScroll(es, (INT)wParam, (INT)lParam);
break;
case EM_SCROLLCARET16:
- DPRINTF_EDIT_MSG16("EM_SCROLLCARET");
- /* fall through */
case EM_SCROLLCARET:
- DPRINTF_EDIT_MSG32("EM_SCROLLCARET");
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_ScrollCaret(es);
result = 1;
break;
case EM_GETMODIFY16:
- DPRINTF_EDIT_MSG16("EM_GETMODIFY");
- /* fall through */
case EM_GETMODIFY:
- DPRINTF_EDIT_MSG32("EM_GETMODIFY");
result = ((es->flags & EF_MODIFIED) != 0);
break;
case EM_SETMODIFY16:
- DPRINTF_EDIT_MSG16("EM_SETMODIFY");
- /* fall through */
case EM_SETMODIFY:
- DPRINTF_EDIT_MSG32("EM_SETMODIFY");
if (wParam)
es->flags |= EF_MODIFIED;
else
@@ -557,84 +534,62 @@
break;
case EM_GETLINECOUNT16:
- DPRINTF_EDIT_MSG16("EM_GETLINECOUNT");
- /* fall through */
case EM_GETLINECOUNT:
- DPRINTF_EDIT_MSG32("EM_GETLINECOUNT");
result = (es->style & ES_MULTILINE) ? es->line_count : 1;
break;
case EM_LINEINDEX16:
- DPRINTF_EDIT_MSG16("EM_LINEINDEX");
if ((INT16)wParam == -1)
wParam = (WPARAM)-1;
/* fall through */
case EM_LINEINDEX:
- DPRINTF_EDIT_MSG32("EM_LINEINDEX");
result = (LRESULT)EDIT_EM_LineIndex(es, (INT)wParam);
break;
case EM_SETHANDLE16:
- DPRINTF_EDIT_MSG16("EM_SETHANDLE");
- EDIT_EM_SetHandle16(hwnd, es, (HLOCAL16)wParam);
+ EDIT_EM_SetHandle16(es, (HLOCAL16)wParam);
break;
case EM_SETHANDLE:
- DPRINTF_EDIT_MSG32("EM_SETHANDLE");
- EDIT_EM_SetHandle(hwnd, es, (HLOCAL)wParam);
+ EDIT_EM_SetHandle(es, (HLOCAL)wParam);
break;
case EM_GETHANDLE16:
- DPRINTF_EDIT_MSG16("EM_GETHANDLE");
- result = (LRESULT)EDIT_EM_GetHandle16(hwnd, es);
+ result = (LRESULT)EDIT_EM_GetHandle16(es);
break;
case EM_GETHANDLE:
- DPRINTF_EDIT_MSG32("EM_GETHANDLE");
result = (LRESULT)EDIT_EM_GetHandle(es);
break;
case EM_GETTHUMB16:
- DPRINTF_EDIT_MSG16("EM_GETTHUMB");
- /* fall through */
case EM_GETTHUMB:
- DPRINTF_EDIT_MSG32("EM_GETTHUMB");
- result = EDIT_EM_GetThumb(hwnd, es);
+ result = EDIT_EM_GetThumb(es);
break;
- /* messages 0x00bf and 0x00c0 missing from specs */
-
+ /* these messages missing from specs */
case WM_USER+15:
- DPRINTF_EDIT_MSG16("undocumented WM_USER+15, please report");
- /* fall through */
case 0x00bf:
- DPRINTF_EDIT_MSG32("undocumented 0x00bf, please report");
- result = DefWindowProcW(hwnd, msg, wParam, lParam);
- break;
-
case WM_USER+16:
- DPRINTF_EDIT_MSG16("undocumented WM_USER+16, please report");
- /* fall through */
case 0x00c0:
- DPRINTF_EDIT_MSG32("undocumented 0x00c0, please report");
+ case WM_USER+19:
+ case 0x00c3:
+ case WM_USER+26:
+ case 0x00ca:
+ FIXME("undocumented message 0x%x, please report\n", msg);
result = DefWindowProcW(hwnd, msg, wParam, lParam);
break;
-
+
case EM_LINELENGTH16:
- DPRINTF_EDIT_MSG16("EM_LINELENGTH");
- /* fall through */
case EM_LINELENGTH:
- DPRINTF_EDIT_MSG32("EM_LINELENGTH");
result = (LRESULT)EDIT_EM_LineLength(es, (INT)wParam);
break;
case EM_REPLACESEL16:
- DPRINTF_EDIT_MSG16("EM_REPLACESEL");
lParam = (LPARAM)MapSL(lParam);
unicode = FALSE; /* 16-bit message is always ascii */
/* fall through */
case EM_REPLACESEL:
{
LPWSTR textW;
- DPRINTF_EDIT_MSG32("EM_REPLACESEL");
if(unicode)
textW = (LPWSTR)lParam;
@@ -646,102 +601,61 @@
MultiByteToWideChar(CP_ACP, 0, textA, -1, textW, countW);
}
- EDIT_EM_ReplaceSel(hwnd, es, (BOOL)wParam, textW, TRUE);
+ EDIT_EM_ReplaceSel(es, (BOOL)wParam, textW, TRUE);
result = 1;
if(!unicode)
HeapFree(GetProcessHeap(), 0, textW);
break;
}
- /* message 0x00c3 missing from specs */
-
- case WM_USER+19:
- DPRINTF_EDIT_MSG16("undocumented WM_USER+19, please report");
- /* fall through */
- case 0x00c3:
- DPRINTF_EDIT_MSG32("undocumented 0x00c3, please report");
- result = DefWindowProcW(hwnd, msg, wParam, lParam);
- break;
case EM_GETLINE16:
- DPRINTF_EDIT_MSG16("EM_GETLINE");
lParam = (LPARAM)MapSL(lParam);
unicode = FALSE; /* 16-bit message is always ascii */
/* fall through */
case EM_GETLINE:
- DPRINTF_EDIT_MSG32("EM_GETLINE");
result = (LRESULT)EDIT_EM_GetLine(es, (INT)wParam, lParam, unicode);
break;
case EM_LIMITTEXT16:
- DPRINTF_EDIT_MSG16("EM_LIMITTEXT");
- /* fall through */
case EM_SETLIMITTEXT:
- DPRINTF_EDIT_MSG32("EM_SETLIMITTEXT");
EDIT_EM_SetLimitText(es, (INT)wParam);
break;
case EM_CANUNDO16:
- DPRINTF_EDIT_MSG16("EM_CANUNDO");
- /* fall through */
case EM_CANUNDO:
- DPRINTF_EDIT_MSG32("EM_CANUNDO");
result = (LRESULT)EDIT_EM_CanUndo(es);
break;
case EM_UNDO16:
- DPRINTF_EDIT_MSG16("EM_UNDO");
- /* fall through */
case EM_UNDO:
- /* fall through */
case WM_UNDO:
- DPRINTF_EDIT_MSG32("EM_UNDO / WM_UNDO");
- result = (LRESULT)EDIT_EM_Undo(hwnd, es);
+ result = (LRESULT)EDIT_EM_Undo(es);
break;
case EM_FMTLINES16:
- DPRINTF_EDIT_MSG16("EM_FMTLINES");
- /* fall through */
case EM_FMTLINES:
- DPRINTF_EDIT_MSG32("EM_FMTLINES");
result = (LRESULT)EDIT_EM_FmtLines(es, (BOOL)wParam);
break;
case EM_LINEFROMCHAR16:
- DPRINTF_EDIT_MSG16("EM_LINEFROMCHAR");
- /* fall through */
case EM_LINEFROMCHAR:
- DPRINTF_EDIT_MSG32("EM_LINEFROMCHAR");
result = (LRESULT)EDIT_EM_LineFromChar(es, (INT)wParam);
break;
- /* message 0x00ca missing from specs */
-
- case WM_USER+26:
- DPRINTF_EDIT_MSG16("undocumented WM_USER+26, please report");
- /* fall through */
- case 0x00ca:
- DPRINTF_EDIT_MSG32("undocumented 0x00ca, please report");
- result = DefWindowProcW(hwnd, msg, wParam, lParam);
- break;
-
case EM_SETTABSTOPS16:
- DPRINTF_EDIT_MSG16("EM_SETTABSTOPS");
result = (LRESULT)EDIT_EM_SetTabStops16(es, (INT)wParam, MapSL(lParam));
break;
case EM_SETTABSTOPS:
- DPRINTF_EDIT_MSG32("EM_SETTABSTOPS");
result = (LRESULT)EDIT_EM_SetTabStops(es, (INT)wParam, (LPINT)lParam);
break;
case EM_SETPASSWORDCHAR16:
- DPRINTF_EDIT_MSG16("EM_SETPASSWORDCHAR");
unicode = FALSE; /* 16-bit message is always ascii */
/* fall through */
case EM_SETPASSWORDCHAR:
{
WCHAR charW = 0;
- DPRINTF_EDIT_MSG32("EM_SETPASSWORDCHAR");
if(unicode)
charW = (WCHAR)wParam;
@@ -751,32 +665,24 @@
MultiByteToWideChar(CP_ACP, 0, &charA, 1, &charW, 1);
}
- EDIT_EM_SetPasswordChar(hwnd, es, charW);
+ EDIT_EM_SetPasswordChar(es, charW);
break;
}
case EM_EMPTYUNDOBUFFER16:
- DPRINTF_EDIT_MSG16("EM_EMPTYUNDOBUFFER");
- /* fall through */
case EM_EMPTYUNDOBUFFER:
- DPRINTF_EDIT_MSG32("EM_EMPTYUNDOBUFFER");
EDIT_EM_EmptyUndoBuffer(es);
break;
case EM_GETFIRSTVISIBLELINE16:
- DPRINTF_EDIT_MSG16("EM_GETFIRSTVISIBLELINE");
result = es->y_offset;
break;
case EM_GETFIRSTVISIBLELINE:
- DPRINTF_EDIT_MSG32("EM_GETFIRSTVISIBLELINE");
result = (es->style & ES_MULTILINE) ? es->y_offset : es->x_offset;
break;
case EM_SETREADONLY16:
- DPRINTF_EDIT_MSG16("EM_SETREADONLY");
- /* fall through */
case EM_SETREADONLY:
- DPRINTF_EDIT_MSG32("EM_SETREADONLY");
if (wParam) {
SetWindowLongA( hwnd, GWL_STYLE,
GetWindowLongA( hwnd, GWL_STYLE ) | ES_READONLY );
@@ -790,31 +696,24 @@
break;
case EM_SETWORDBREAKPROC16:
- DPRINTF_EDIT_MSG16("EM_SETWORDBREAKPROC");
- EDIT_EM_SetWordBreakProc16(hwnd, es, (EDITWORDBREAKPROC16)lParam);
+ EDIT_EM_SetWordBreakProc16(es, (EDITWORDBREAKPROC16)lParam);
break;
case EM_SETWORDBREAKPROC:
- DPRINTF_EDIT_MSG32("EM_SETWORDBREAKPROC");
- EDIT_EM_SetWordBreakProc(hwnd, es, lParam);
+ EDIT_EM_SetWordBreakProc(es, lParam);
break;
case EM_GETWORDBREAKPROC16:
- DPRINTF_EDIT_MSG16("EM_GETWORDBREAKPROC");
result = (LRESULT)es->word_break_proc16;
break;
case EM_GETWORDBREAKPROC:
- DPRINTF_EDIT_MSG32("EM_GETWORDBREAKPROC");
result = (LRESULT)es->word_break_proc;
break;
case EM_GETPASSWORDCHAR16:
- DPRINTF_EDIT_MSG16("EM_GETPASSWORDCHAR");
unicode = FALSE; /* 16-bit message is always ascii */
/* fall through */
case EM_GETPASSWORDCHAR:
{
- DPRINTF_EDIT_MSG32("EM_GETPASSWORDCHAR");
-
if(unicode)
result = es->password_char;
else
@@ -830,28 +729,23 @@
/* The following EM_xxx are new to win95 and don't exist for 16 bit */
case EM_SETMARGINS:
- DPRINTF_EDIT_MSG32("EM_SETMARGINS");
EDIT_EM_SetMargins(es, (INT)wParam, SLOWORD(lParam), SHIWORD(lParam));
break;
case EM_GETMARGINS:
- DPRINTF_EDIT_MSG32("EM_GETMARGINS");
result = MAKELONG(es->left_margin, es->right_margin);
break;
case EM_GETLIMITTEXT:
- DPRINTF_EDIT_MSG32("EM_GETLIMITTEXT");
result = es->buffer_limit;
break;
case EM_POSFROMCHAR:
- DPRINTF_EDIT_MSG32("EM_POSFROMCHAR");
- result = EDIT_EM_PosFromChar(hwnd, es, (INT)wParam, FALSE);
+ result = EDIT_EM_PosFromChar(es, (INT)wParam, FALSE);
break;
case EM_CHARFROMPOS:
- DPRINTF_EDIT_MSG32("EM_CHARFROMPOS");
- result = EDIT_EM_CharFromPos(hwnd, es, SLOWORD(lParam), SHIWORD(lParam));
+ result = EDIT_EM_CharFromPos(es, SLOWORD(lParam), SHIWORD(lParam));
break;
/* End of the EM_ messages which were in numerical order; what order
@@ -859,7 +753,6 @@
*/
case WM_GETDLGCODE:
- DPRINTF_EDIT_MSG32("WM_GETDLGCODE");
result = DLGC_HASSETSEL | DLGC_WANTCHARS | DLGC_WANTARROWS;
if (lParam && (((LPMSG)lParam)->message == WM_KEYDOWN))
@@ -881,7 +774,6 @@
case WM_CHAR:
{
WCHAR charW;
- DPRINTF_EDIT_MSG32("WM_CHAR");
if(unicode)
charW = wParam;
@@ -897,34 +789,29 @@
SendMessageW(GetParent(hwnd), WM_KEYDOWN, charW, 0);
break;
}
- EDIT_WM_Char(hwnd, es, charW);
+ EDIT_WM_Char(es, charW);
break;
}
case WM_CLEAR:
- DPRINTF_EDIT_MSG32("WM_CLEAR");
- EDIT_WM_Clear(hwnd, es);
+ EDIT_WM_Clear(es);
break;
case WM_COMMAND:
- DPRINTF_EDIT_MSG32("WM_COMMAND");
- EDIT_WM_Command(hwnd, es, HIWORD(wParam), LOWORD(wParam), (HWND)lParam);
+ EDIT_WM_Command(es, HIWORD(wParam), LOWORD(wParam), (HWND)lParam);
break;
case WM_CONTEXTMENU:
- DPRINTF_EDIT_MSG32("WM_CONTEXTMENU");
- EDIT_WM_ContextMenu(hwnd, es, SLOWORD(lParam), SHIWORD(lParam));
+ EDIT_WM_ContextMenu(es, SLOWORD(lParam), SHIWORD(lParam));
break;
case WM_COPY:
- DPRINTF_EDIT_MSG32("WM_COPY");
- EDIT_WM_Copy(hwnd, es);
+ EDIT_WM_Copy(es);
break;
case WM_CREATE:
- DPRINTF_EDIT_MSG32("WM_CREATE");
if(unicode)
- result = EDIT_WM_Create(hwnd, es, ((LPCREATESTRUCTW)lParam)->lpszName);
+ result = EDIT_WM_Create(es, ((LPCREATESTRUCTW)lParam)->lpszName);
else
{
LPCSTR nameA = ((LPCREATESTRUCTA)lParam)->lpszName;
@@ -935,78 +822,65 @@
if((nameW = HeapAlloc(GetProcessHeap(), 0, countW * sizeof(WCHAR))))
MultiByteToWideChar(CP_ACP, 0, nameA, -1, nameW, countW);
}
- result = EDIT_WM_Create(hwnd, es, nameW);
+ result = EDIT_WM_Create(es, nameW);
if(nameW)
HeapFree(GetProcessHeap(), 0, nameW);
}
break;
case WM_CUT:
- DPRINTF_EDIT_MSG32("WM_CUT");
- EDIT_WM_Cut(hwnd, es);
+ EDIT_WM_Cut(es);
break;
case WM_ENABLE:
- DPRINTF_EDIT_MSG32("WM_ENABLE");
es->bEnableState = (BOOL) wParam;
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_UpdateText(es, NULL, TRUE);
break;
case WM_ERASEBKGND:
- DPRINTF_EDIT_MSG32("WM_ERASEBKGND");
- result = EDIT_WM_EraseBkGnd(hwnd, es, (HDC)wParam);
+ result = EDIT_WM_EraseBkGnd(es, (HDC)wParam);
break;
case WM_GETFONT:
- DPRINTF_EDIT_MSG32("WM_GETFONT");
result = (LRESULT)es->font;
break;
case WM_GETTEXT:
- DPRINTF_EDIT_MSG32("WM_GETTEXT");
result = (LRESULT)EDIT_WM_GetText(es, (INT)wParam, lParam, unicode);
break;
case WM_GETTEXTLENGTH:
- DPRINTF_EDIT_MSG32("WM_GETTEXTLENGTH");
if (unicode) result = strlenW(es->text);
else result = WideCharToMultiByte( CP_ACP, 0, es->text, strlenW(es->text),
NULL, 0, NULL, NULL );
break;
case WM_HSCROLL:
- DPRINTF_EDIT_MSG32("WM_HSCROLL");
- result = EDIT_WM_HScroll(hwnd, es, LOWORD(wParam), SHIWORD(wParam));
+ result = EDIT_WM_HScroll(es, LOWORD(wParam), SHIWORD(wParam));
break;
case WM_KEYDOWN:
- DPRINTF_EDIT_MSG32("WM_KEYDOWN");
- result = EDIT_WM_KeyDown(hwnd, es, (INT)wParam);
+ result = EDIT_WM_KeyDown(es, (INT)wParam);
break;
case WM_KILLFOCUS:
- DPRINTF_EDIT_MSG32("WM_KILLFOCUS");
- result = EDIT_WM_KillFocus(hwnd, es);
+ result = EDIT_WM_KillFocus(es);
break;
case WM_LBUTTONDBLCLK:
- DPRINTF_EDIT_MSG32("WM_LBUTTONDBLCLK");
- result = EDIT_WM_LButtonDblClk(hwnd, es);
+ result = EDIT_WM_LButtonDblClk(es);
break;
case WM_LBUTTONDOWN:
- DPRINTF_EDIT_MSG32("WM_LBUTTONDOWN");
- result = EDIT_WM_LButtonDown(hwnd, es, (DWORD)wParam, SLOWORD(lParam), SHIWORD(lParam));
+ result = EDIT_WM_LButtonDown(es, (DWORD)wParam, SLOWORD(lParam), SHIWORD(lParam));
break;
case WM_LBUTTONUP:
- DPRINTF_EDIT_MSG32("WM_LBUTTONUP");
- result = EDIT_WM_LButtonUp(hwnd, es);
+ result = EDIT_WM_LButtonUp(es);
break;
case WM_MBUTTONDOWN:
- DPRINTF_EDIT_MSG32("WM_MBUTTONDOWN");
- result = EDIT_WM_MButtonDown(hwnd);
+ result = EDIT_WM_MButtonDown(es);
break;
case WM_MOUSEACTIVATE:
@@ -1016,36 +890,28 @@
* will _not_ be set by DefWindowProc() for edit controls in a
* modeless dialog box ???
*/
- DPRINTF_EDIT_MSG32("WM_MOUSEACTIVATE");
SetFocus(hwnd);
result = MA_ACTIVATE;
break;
case WM_MOUSEMOVE:
- /*
- * DPRINTF_EDIT_MSG32("WM_MOUSEMOVE");
- */
- result = EDIT_WM_MouseMove(hwnd, es, SLOWORD(lParam), SHIWORD(lParam));
+ result = EDIT_WM_MouseMove(es, SLOWORD(lParam), SHIWORD(lParam));
break;
case WM_PAINT:
- DPRINTF_EDIT_MSG32("WM_PAINT");
- EDIT_WM_Paint(hwnd, es, wParam);
+ EDIT_WM_Paint(es, wParam);
break;
case WM_PASTE:
- DPRINTF_EDIT_MSG32("WM_PASTE");
- EDIT_WM_Paste(hwnd, es);
+ EDIT_WM_Paste(es);
break;
case WM_SETFOCUS:
- DPRINTF_EDIT_MSG32("WM_SETFOCUS");
- EDIT_WM_SetFocus(hwnd, es);
+ EDIT_WM_SetFocus(es);
break;
case WM_SETFONT:
- DPRINTF_EDIT_MSG32("WM_SETFONT");
- EDIT_WM_SetFont(hwnd, es, (HFONT)wParam, LOWORD(lParam) != 0);
+ EDIT_WM_SetFont(es, (HFONT)wParam, LOWORD(lParam) != 0);
break;
case WM_SETREDRAW:
@@ -1053,39 +919,32 @@
break;
case WM_SETTEXT:
- DPRINTF_EDIT_MSG32("WM_SETTEXT");
- EDIT_WM_SetText(hwnd, es, lParam, unicode);
+ EDIT_WM_SetText(es, lParam, unicode);
result = TRUE;
break;
case WM_SIZE:
- DPRINTF_EDIT_MSG32("WM_SIZE");
- EDIT_WM_Size(hwnd, es, (UINT)wParam, LOWORD(lParam), HIWORD(lParam));
+ EDIT_WM_Size(es, (UINT)wParam, LOWORD(lParam), HIWORD(lParam));
break;
case WM_STYLECHANGED:
- DPRINTF_EDIT_MSG32("WM_STYLECHANGED");
- result = EDIT_WM_StyleChanged (hwnd, es, wParam, (const STYLESTRUCT *)lParam);
+ result = EDIT_WM_StyleChanged(es, wParam, (const STYLESTRUCT *)lParam);
break;
case WM_STYLECHANGING:
- DPRINTF_EDIT_MSG32("WM_STYLECHANGING");
result = 0; /* See EDIT_WM_StyleChanged */
break;
case WM_SYSKEYDOWN:
- DPRINTF_EDIT_MSG32("WM_SYSKEYDOWN");
- result = EDIT_WM_SysKeyDown(hwnd, es, (INT)wParam, (DWORD)lParam);
+ result = EDIT_WM_SysKeyDown(es, (INT)wParam, (DWORD)lParam);
break;
case WM_TIMER:
- DPRINTF_EDIT_MSG32("WM_TIMER");
- EDIT_WM_Timer(hwnd, es);
+ EDIT_WM_Timer(es);
break;
case WM_VSCROLL:
- DPRINTF_EDIT_MSG32("WM_VSCROLL");
- result = EDIT_WM_VScroll(hwnd, es, LOWORD(wParam), SHIWORD(wParam));
+ result = EDIT_WM_VScroll(es, LOWORD(wParam), SHIWORD(wParam));
break;
case WM_MOUSEWHEEL:
@@ -1103,7 +962,7 @@
{
int cLineScroll= (int) min((UINT) es->line_count, pulScrollLines);
cLineScroll *= (gcWheelDelta / WHEEL_DELTA);
- result = EDIT_EM_LineScroll(hwnd, es, 0, cLineScroll);
+ result = EDIT_EM_LineScroll(es, 0, cLineScroll);
}
}
break;
@@ -1114,7 +973,7 @@
result = DefWindowProcA(hwnd, msg, wParam, lParam);
break;
}
- EDIT_UnlockBuffer(hwnd, es, FALSE);
+ EDIT_UnlockBuffer(es, FALSE);
END:
return result;
}
@@ -1125,7 +984,6 @@
*/
LRESULT WINAPI EditWndProcW(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
- if (!IsWindow( hWnd )) return 0;
return EditWndProc_common(hWnd, uMsg, wParam, lParam, TRUE);
}
@@ -1135,7 +993,6 @@
*/
LRESULT WINAPI EditWndProcA(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
- if (!IsWindow( hWnd )) return 0;
return EditWndProc_common(hWnd, uMsg, wParam, lParam, FALSE);
}
@@ -1148,7 +1005,7 @@
* a soft return '\r\r\n' or a hard return '\r\n'
*
*/
-static void EDIT_BuildLineDefs_ML(HWND hwnd, EDITSTATE *es, INT istart, INT iend, INT delta, HRGN hrgn)
+static void EDIT_BuildLineDefs_ML(EDITSTATE *es, INT istart, INT iend, INT delta, HRGN hrgn)
{
HDC dc;
HFONT old_font = 0;
@@ -1165,7 +1022,7 @@
if (istart == iend && delta == 0)
return;
- dc = GetDC(hwnd);
+ dc = GetDC(es->hwndSelf);
if (es->font)
old_font = SelectObject(dc, es->font);
@@ -1399,7 +1256,7 @@
if (es->font)
SelectObject(dc, old_font);
- ReleaseDC(hwnd, dc);
+ ReleaseDC(es->hwndSelf, dc);
}
/*********************************************************************
@@ -1407,9 +1264,9 @@
* EDIT_CalcLineWidth_SL
*
*/
-static void EDIT_CalcLineWidth_SL(HWND hwnd, EDITSTATE *es)
+static void EDIT_CalcLineWidth_SL(EDITSTATE *es)
{
- es->text_width = SLOWORD(EDIT_EM_PosFromChar(hwnd, es, strlenW(es->text), FALSE));
+ es->text_width = SLOWORD(EDIT_EM_PosFromChar(es, strlenW(es->text), FALSE));
}
/*********************************************************************
@@ -1493,7 +1350,7 @@
* The return value is only the character index
*
*/
-static INT EDIT_CharFromPos(HWND hwnd, EDITSTATE *es, INT x, INT y, LPBOOL after_wrap)
+static INT EDIT_CharFromPos(EDITSTATE *es, INT x, INT y, LPBOOL after_wrap)
{
INT index;
HDC dc;
@@ -1520,7 +1377,7 @@
*after_wrap = FALSE;
return line_index;
}
- dc = GetDC(hwnd);
+ dc = GetDC(es->hwndSelf);
if (es->font)
old_font = SelectObject(dc, es->font);
low = line_index + 1;
@@ -1545,7 +1402,7 @@
if (!x)
return es->x_offset;
text = EDIT_GetPasswordPointer_SL(es);
- dc = GetDC(hwnd);
+ dc = GetDC(es->hwndSelf);
if (es->font)
old_font = SelectObject(dc, es->font);
if (x < 0)
@@ -1581,7 +1438,7 @@
}
if (es->font)
SelectObject(dc, old_font);
- ReleaseDC(hwnd, dc);
+ ReleaseDC(es->hwndSelf, dc);
return index;
}
@@ -1609,7 +1466,7 @@
* column to an ending column.
*
*/
-static void EDIT_GetLineRect(HWND hwnd, EDITSTATE *es, INT line, INT scol, INT ecol, LPRECT rc)
+static void EDIT_GetLineRect(EDITSTATE *es, INT line, INT scol, INT ecol, LPRECT rc)
{
INT line_index = EDIT_EM_LineIndex(es, line);
@@ -1618,8 +1475,8 @@
else
rc->top = es->format_rect.top;
rc->bottom = rc->top + es->line_height;
- rc->left = (scol == 0) ? es->format_rect.left : SLOWORD(EDIT_EM_PosFromChar(hwnd, es, line_index + scol, TRUE));
- rc->right = (ecol == -1) ? es->format_rect.right : SLOWORD(EDIT_EM_PosFromChar(hwnd, es, line_index + ecol, TRUE));
+ rc->left = (scol == 0) ? es->format_rect.left : SLOWORD(EDIT_EM_PosFromChar(es, line_index + scol, TRUE));
+ rc->right = (ecol == -1) ? es->format_rect.right : SLOWORD(EDIT_EM_PosFromChar(es, line_index + ecol, TRUE));
}
@@ -1650,10 +1507,18 @@
* This acts as a LOCAL_Lock(), but it locks only once. This way
* you can call it whenever you like, without unlocking.
*
+ * Initially the edit control allocates a HLOCAL32 buffer
+ * (32 bit linear memory handler). However, 16 bit application
+ * might send a EM_GETHANDLE message and expect a HLOCAL16 (16 bit SEG:OFF
+ * handler). From that moment on we have to keep using this 16 bit memory
+ * handler, because it is supposed to be valid at all times after EM_GETHANDLE.
+ * What we do is create a HLOCAL16 buffer, copy the text, and do pointer
+ * conversion.
+ *
*/
-static void EDIT_LockBuffer(HWND hwnd, EDITSTATE *es)
+static void EDIT_LockBuffer(EDITSTATE *es)
{
- HINSTANCE hInstance = GetWindowLongA( hwnd, GWL_HINSTANCE );
+ HINSTANCE hInstance = GetWindowLongA( es->hwndSelf, GWL_HINSTANCE );
if (!es) {
ERR("no EDITSTATE ... please report\n");
return;
@@ -1729,14 +1594,14 @@
* Does the job for single-line controls only.
*
*/
-static void EDIT_SL_InvalidateText(HWND hwnd, EDITSTATE *es, INT start, INT end)
+static void EDIT_SL_InvalidateText(EDITSTATE *es, INT start, INT end)
{
RECT line_rect;
RECT rc;
- EDIT_GetLineRect(hwnd, es, 0, start, end, &line_rect);
+ EDIT_GetLineRect(es, 0, start, end, &line_rect);
if (IntersectRect(&rc, &line_rect, &es->format_rect))
- EDIT_UpdateText(hwnd, es, &rc, TRUE);
+ EDIT_UpdateText(es, &rc, TRUE);
}
@@ -1748,7 +1613,7 @@
* Does the job for multi-line controls only.
*
*/
-static void EDIT_ML_InvalidateText(HWND hwnd, EDITSTATE *es, INT start, INT end)
+static void EDIT_ML_InvalidateText(EDITSTATE *es, INT start, INT end)
{
INT vlc = (es->format_rect.bottom - es->format_rect.top) / es->line_height;
INT sl = EDIT_EM_LineFromChar(es, start);
@@ -1774,30 +1639,30 @@
el = es->y_offset + vlc;
ec = EDIT_EM_LineLength(es, EDIT_EM_LineIndex(es, el));
}
- GetClientRect(hwnd, &rc1);
+ GetClientRect(es->hwndSelf, &rc1);
IntersectRect(&rcWnd, &rc1, &es->format_rect);
if (sl == el) {
- EDIT_GetLineRect(hwnd, es, sl, sc, ec, &rcLine);
+ EDIT_GetLineRect(es, sl, sc, ec, &rcLine);
if (IntersectRect(&rcUpdate, &rcWnd, &rcLine))
- EDIT_UpdateText(hwnd, es, &rcUpdate, TRUE);
+ EDIT_UpdateText(es, &rcUpdate, TRUE);
} else {
- EDIT_GetLineRect(hwnd, es, sl, sc,
+ EDIT_GetLineRect(es, sl, sc,
EDIT_EM_LineLength(es,
EDIT_EM_LineIndex(es, sl)),
&rcLine);
if (IntersectRect(&rcUpdate, &rcWnd, &rcLine))
- EDIT_UpdateText(hwnd, es, &rcUpdate, TRUE);
+ EDIT_UpdateText(es, &rcUpdate, TRUE);
for (l = sl + 1 ; l < el ; l++) {
- EDIT_GetLineRect(hwnd, es, l, 0,
+ EDIT_GetLineRect(es, l, 0,
EDIT_EM_LineLength(es,
EDIT_EM_LineIndex(es, l)),
&rcLine);
if (IntersectRect(&rcUpdate, &rcWnd, &rcLine))
- EDIT_UpdateText(hwnd, es, &rcUpdate, TRUE);
+ EDIT_UpdateText(es, &rcUpdate, TRUE);
}
- EDIT_GetLineRect(hwnd, es, el, 0, ec, &rcLine);
+ EDIT_GetLineRect(es, el, 0, ec, &rcLine);
if (IntersectRect(&rcUpdate, &rcWnd, &rcLine))
- EDIT_UpdateText(hwnd, es, &rcUpdate, TRUE);
+ EDIT_UpdateText(es, &rcUpdate, TRUE);
}
}
@@ -1813,7 +1678,7 @@
* start and end need not be ordered.
*
*/
-static void EDIT_InvalidateText(HWND hwnd, EDITSTATE *es, INT start, INT end)
+static void EDIT_InvalidateText(EDITSTATE *es, INT start, INT end)
{
if (end == start)
return;
@@ -1821,12 +1686,16 @@
if (end == -1)
end = strlenW(es->text);
- ORDER_INT(start, end);
+ if (end < start) {
+ INT tmp = start;
+ start = end;
+ end = tmp;
+ }
if (es->style & ES_MULTILINE)
- EDIT_ML_InvalidateText(hwnd, es, start, end);
+ EDIT_ML_InvalidateText(es, start, end);
else
- EDIT_SL_InvalidateText(hwnd, es, start, end);
+ EDIT_SL_InvalidateText(es, start, end);
}
@@ -1837,14 +1706,14 @@
* Try to fit size + 1 characters in the buffer. Constrain to limits.
*
*/
-static BOOL EDIT_MakeFit(HWND hwnd, EDITSTATE *es, UINT size)
+static BOOL EDIT_MakeFit(EDITSTATE *es, UINT size)
{
HLOCAL hNew32W;
if (size <= es->buffer_size)
return TRUE;
if ((es->buffer_limit > 0) && (size > es->buffer_limit)) {
- EDIT_NOTIFY_PARENT(hwnd, es, EN_MAXTEXT, "EN_MAXTEXT");
+ EDIT_NOTIFY_PARENT(es, EN_MAXTEXT, "EN_MAXTEXT");
return FALSE;
}
if ((es->buffer_limit > 0) && (size > es->buffer_limit))
@@ -1853,7 +1722,7 @@
TRACE("trying to ReAlloc to %d+1 characters\n", size);
/* Force edit to unlock it's buffer. es->text now NULL */
- EDIT_UnlockBuffer(hwnd, es, TRUE);
+ EDIT_UnlockBuffer(es, TRUE);
if (es->hloc32W) {
UINT alloc_size = ROUND_TO_GROW((size + 1) * sizeof(WCHAR));
@@ -1864,11 +1733,11 @@
}
}
- EDIT_LockBuffer(hwnd, es);
+ EDIT_LockBuffer(es);
if (es->buffer_size < size) {
WARN("FAILED ! We now have %d+1\n", es->buffer_size);
- EDIT_NOTIFY_PARENT(hwnd, es, EN_ERRSPACE, "EN_ERRSPACE");
+ EDIT_NOTIFY_PARENT(es, EN_ERRSPACE, "EN_ERRSPACE");
return FALSE;
} else {
TRACE("We now have %d+1\n", es->buffer_size);
@@ -1911,7 +1780,7 @@
* EDIT_MoveBackward
*
*/
-static void EDIT_MoveBackward(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MoveBackward(EDITSTATE *es, BOOL extend)
{
INT e = es->selection_end;
@@ -1924,8 +1793,8 @@
e--;
}
}
- EDIT_EM_SetSel(hwnd, es, extend ? es->selection_start : e, e, FALSE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, extend ? es->selection_start : e, e, FALSE);
+ EDIT_EM_ScrollCaret(es);
}
@@ -1938,20 +1807,20 @@
* x coordinate on the screen (might be a different column).
*
*/
-static void EDIT_MoveDown_ML(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MoveDown_ML(EDITSTATE *es, BOOL extend)
{
INT s = es->selection_start;
INT e = es->selection_end;
BOOL after_wrap = (es->flags & EF_AFTER_WRAP);
- LRESULT pos = EDIT_EM_PosFromChar(hwnd, es, e, after_wrap);
+ LRESULT pos = EDIT_EM_PosFromChar(es, e, after_wrap);
INT x = SLOWORD(pos);
INT y = SHIWORD(pos);
- e = EDIT_CharFromPos(hwnd, es, x, y + es->line_height, &after_wrap);
+ e = EDIT_CharFromPos(es, x, y + es->line_height, &after_wrap);
if (!extend)
s = e;
- EDIT_EM_SetSel(hwnd, es, s, e, after_wrap);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, s, e, after_wrap);
+ EDIT_EM_ScrollCaret(es);
}
@@ -1960,19 +1829,19 @@
* EDIT_MoveEnd
*
*/
-static void EDIT_MoveEnd(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MoveEnd(EDITSTATE *es, BOOL extend)
{
BOOL after_wrap = FALSE;
INT e;
/* Pass a high value in x to make sure of receiving the end of the line */
if (es->style & ES_MULTILINE)
- e = EDIT_CharFromPos(hwnd, es, 0x3fffffff,
- HIWORD(EDIT_EM_PosFromChar(hwnd, es, es->selection_end, es->flags & EF_AFTER_WRAP)), &after_wrap);
+ e = EDIT_CharFromPos(es, 0x3fffffff,
+ HIWORD(EDIT_EM_PosFromChar(es, es->selection_end, es->flags & EF_AFTER_WRAP)), &after_wrap);
else
e = strlenW(es->text);
- EDIT_EM_SetSel(hwnd, es, extend ? es->selection_start : e, e, after_wrap);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, extend ? es->selection_start : e, e, after_wrap);
+ EDIT_EM_ScrollCaret(es);
}
@@ -1981,7 +1850,7 @@
* EDIT_MoveForward
*
*/
-static void EDIT_MoveForward(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MoveForward(EDITSTATE *es, BOOL extend)
{
INT e = es->selection_end;
@@ -1994,8 +1863,8 @@
e += 2;
}
}
- EDIT_EM_SetSel(hwnd, es, extend ? es->selection_start : e, e, FALSE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, extend ? es->selection_start : e, e, FALSE);
+ EDIT_EM_ScrollCaret(es);
}
@@ -2006,18 +1875,18 @@
* Home key: move to beginning of line.
*
*/
-static void EDIT_MoveHome(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MoveHome(EDITSTATE *es, BOOL extend)
{
INT e;
/* Pass the x_offset in x to make sure of receiving the first position of the line */
if (es->style & ES_MULTILINE)
- e = EDIT_CharFromPos(hwnd, es, -es->x_offset,
- HIWORD(EDIT_EM_PosFromChar(hwnd, es, es->selection_end, es->flags & EF_AFTER_WRAP)), NULL);
+ e = EDIT_CharFromPos(es, -es->x_offset,
+ HIWORD(EDIT_EM_PosFromChar(es, es->selection_end, es->flags & EF_AFTER_WRAP)), NULL);
else
e = 0;
- EDIT_EM_SetSel(hwnd, es, extend ? es->selection_start : e, e, FALSE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, extend ? es->selection_start : e, e, FALSE);
+ EDIT_EM_ScrollCaret(es);
}
@@ -2030,22 +1899,22 @@
* x coordinate on the screen (might be a different column).
*
*/
-static void EDIT_MovePageDown_ML(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MovePageDown_ML(EDITSTATE *es, BOOL extend)
{
INT s = es->selection_start;
INT e = es->selection_end;
BOOL after_wrap = (es->flags & EF_AFTER_WRAP);
- LRESULT pos = EDIT_EM_PosFromChar(hwnd, es, e, after_wrap);
+ LRESULT pos = EDIT_EM_PosFromChar(es, e, after_wrap);
INT x = SLOWORD(pos);
INT y = SHIWORD(pos);
- e = EDIT_CharFromPos(hwnd, es, x,
+ e = EDIT_CharFromPos(es, x,
y + (es->format_rect.bottom - es->format_rect.top),
&after_wrap);
if (!extend)
s = e;
- EDIT_EM_SetSel(hwnd, es, s, e, after_wrap);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, s, e, after_wrap);
+ EDIT_EM_ScrollCaret(es);
}
@@ -2058,22 +1927,22 @@
* x coordinate on the screen (might be a different column).
*
*/
-static void EDIT_MovePageUp_ML(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MovePageUp_ML(EDITSTATE *es, BOOL extend)
{
INT s = es->selection_start;
INT e = es->selection_end;
BOOL after_wrap = (es->flags & EF_AFTER_WRAP);
- LRESULT pos = EDIT_EM_PosFromChar(hwnd, es, e, after_wrap);
+ LRESULT pos = EDIT_EM_PosFromChar(es, e, after_wrap);
INT x = SLOWORD(pos);
INT y = SHIWORD(pos);
- e = EDIT_CharFromPos(hwnd, es, x,
+ e = EDIT_CharFromPos(es, x,
y - (es->format_rect.bottom - es->format_rect.top),
&after_wrap);
if (!extend)
s = e;
- EDIT_EM_SetSel(hwnd, es, s, e, after_wrap);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, s, e, after_wrap);
+ EDIT_EM_ScrollCaret(es);
}
@@ -2086,20 +1955,20 @@
* x coordinate on the screen (might be a different column).
*
*/
-static void EDIT_MoveUp_ML(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MoveUp_ML(EDITSTATE *es, BOOL extend)
{
INT s = es->selection_start;
INT e = es->selection_end;
BOOL after_wrap = (es->flags & EF_AFTER_WRAP);
- LRESULT pos = EDIT_EM_PosFromChar(hwnd, es, e, after_wrap);
+ LRESULT pos = EDIT_EM_PosFromChar(es, e, after_wrap);
INT x = SLOWORD(pos);
INT y = SHIWORD(pos);
- e = EDIT_CharFromPos(hwnd, es, x, y - es->line_height, &after_wrap);
+ e = EDIT_CharFromPos(es, x, y - es->line_height, &after_wrap);
if (!extend)
s = e;
- EDIT_EM_SetSel(hwnd, es, s, e, after_wrap);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, s, e, after_wrap);
+ EDIT_EM_ScrollCaret(es);
}
@@ -2108,7 +1977,7 @@
* EDIT_MoveWordBackward
*
*/
-static void EDIT_MoveWordBackward(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MoveWordBackward(EDITSTATE *es, BOOL extend)
{
INT s = es->selection_start;
INT e = es->selection_end;
@@ -2130,8 +1999,8 @@
}
if (!extend)
s = e;
- EDIT_EM_SetSel(hwnd, es, s, e, FALSE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, s, e, FALSE);
+ EDIT_EM_ScrollCaret(es);
}
@@ -2140,7 +2009,7 @@
* EDIT_MoveWordForward
*
*/
-static void EDIT_MoveWordForward(HWND hwnd, EDITSTATE *es, BOOL extend)
+static void EDIT_MoveWordForward(EDITSTATE *es, BOOL extend)
{
INT s = es->selection_start;
INT e = es->selection_end;
@@ -2160,8 +2029,8 @@
}
if (!extend)
s = e;
- EDIT_EM_SetSel(hwnd, es, s, e, FALSE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, s, e, FALSE);
+ EDIT_EM_ScrollCaret(es);
}
@@ -2170,7 +2039,7 @@
* EDIT_PaintLine
*
*/
-static void EDIT_PaintLine(HWND hwnd, EDITSTATE *es, HDC dc, INT line, BOOL rev)
+static void EDIT_PaintLine(EDITSTATE *es, HDC dc, INT line, BOOL rev)
{
INT s = es->selection_start;
INT e = es->selection_end;
@@ -2189,14 +2058,13 @@
TRACE("line=%d\n", line);
- pos = EDIT_EM_PosFromChar(hwnd, es, EDIT_EM_LineIndex(es, line), FALSE);
+ pos = EDIT_EM_PosFromChar(es, EDIT_EM_LineIndex(es, line), FALSE);
x = SLOWORD(pos);
y = SHIWORD(pos);
li = EDIT_EM_LineIndex(es, line);
ll = EDIT_EM_LineLength(es, li);
- s = es->selection_start;
- e = es->selection_end;
- ORDER_INT(s, e);
+ s = min(es->selection_start, es->selection_end);
+ e = max(es->selection_start, es->selection_end);
s = min(li + ll, max(li, s));
e = min(li + ll, max(li, e));
if (rev && (s != e) &&
@@ -2259,10 +2127,10 @@
* EDIT_SetCaretPos
*
*/
-static void EDIT_SetCaretPos(HWND hwnd, EDITSTATE *es, INT pos,
+static void EDIT_SetCaretPos(EDITSTATE *es, INT pos,
BOOL after_wrap)
{
- LRESULT res = EDIT_EM_PosFromChar(hwnd, es, pos, after_wrap);
+ LRESULT res = EDIT_EM_PosFromChar(es, pos, after_wrap);
SetCaretPos(SLOWORD(res), SHIWORD(res));
}
@@ -2275,7 +2143,7 @@
* it is also used to set the rect of a single line control
*
*/
-static void EDIT_SetRectNP(HWND hwnd, EDITSTATE *es, LPRECT rc)
+static void EDIT_SetRectNP(EDITSTATE *es, LPRECT rc)
{
CopyRect(&es->format_rect, rc);
if (es->style & WS_BORDER) {
@@ -2311,14 +2179,14 @@
es->y_offset = max_y_offset;
/* force scroll info update */
- EDIT_UpdateScrollInfo(hwnd, es);
+ EDIT_UpdateScrollInfo(es);
}
else
/* Windows doesn't care to fix text placement for SL controls */
es->format_rect.bottom = es->format_rect.top + es->line_height;
if ((es->style & ES_MULTILINE) && !(es->style & ES_AUTOHSCROLL))
- EDIT_BuildLineDefs_ML(hwnd, es, 0, strlenW(es->text), 0, (HRGN)0);
+ EDIT_BuildLineDefs_ML(es, 0, strlenW(es->text), 0, (HRGN)0);
}
@@ -2327,14 +2195,14 @@
* EDIT_UnlockBuffer
*
*/
-static void EDIT_UnlockBuffer(HWND hwnd, EDITSTATE *es, BOOL force)
+static void EDIT_UnlockBuffer(EDITSTATE *es, BOOL force)
{
- HINSTANCE hInstance = GetWindowLongA( hwnd, GWL_HINSTANCE );
+ HINSTANCE hInstance = GetWindowLongA( es->hwndSelf, GWL_HINSTANCE );
/* Edit window might be already destroyed */
- if(!IsWindow(hwnd))
+ if(!IsWindow(es->hwndSelf))
{
- WARN("edit hwnd %04x already destroyed\n", hwnd);
+ WARN("edit hwnd %04x already destroyed\n", es->hwndSelf);
return;
}
@@ -2432,7 +2300,7 @@
* EDIT_UpdateScrollInfo
*
*/
-static void EDIT_UpdateScrollInfo(HWND hwnd, EDITSTATE *es)
+static void EDIT_UpdateScrollInfo(EDITSTATE *es)
{
if ((es->style & WS_VSCROLL) && !(es->flags & EF_VSCROLL_TRACK))
{
@@ -2445,7 +2313,7 @@
si.nPos = es->y_offset;
TRACE("SB_VERT, nMin=%d, nMax=%d, nPage=%d, nPos=%d\n",
si.nMin, si.nMax, si.nPage, si.nPos);
- SetScrollInfo(hwnd, SB_VERT, &si, TRUE);
+ SetScrollInfo(es->hwndSelf, SB_VERT, &si, TRUE);
}
if ((es->style & WS_HSCROLL) && !(es->flags & EF_HSCROLL_TRACK))
@@ -2459,7 +2327,7 @@
si.nPos = es->x_offset;
TRACE("SB_HORZ, nMin=%d, nMax=%d, nPage=%d, nPos=%d\n",
si.nMin, si.nMax, si.nPage, si.nPos);
- SetScrollInfo(hwnd, SB_HORZ, &si, TRUE);
+ SetScrollInfo(es->hwndSelf, SB_HORZ, &si, TRUE);
}
}
@@ -2541,7 +2409,7 @@
* if outside formatting rectangle ???
*
*/
-static LRESULT EDIT_EM_CharFromPos(HWND hwnd, EDITSTATE *es, INT x, INT y)
+static LRESULT EDIT_EM_CharFromPos(EDITSTATE *es, INT x, INT y)
{
POINT pt;
RECT rc;
@@ -2549,11 +2417,11 @@
pt.x = x;
pt.y = y;
- GetClientRect(hwnd, &rc);
+ GetClientRect(es->hwndSelf, &rc);
if (!PtInRect(&rc, pt))
return -1;
- index = EDIT_CharFromPos(hwnd, es, x, y, NULL);
+ index = EDIT_CharFromPos(es, x, y, NULL);
return MAKELONG(index, EDIT_EM_LineFromChar(es, index));
}
@@ -2563,6 +2431,11 @@
* EM_FMTLINES
*
* Enable or disable soft breaks.
+ *
+ * This means: insert or remove the soft linebreak character (\r\r\n).
+ * Take care to check if the text still fits the buffer after insertion.
+ * If not, notify with EN_ERRSPACE.
+ *
*/
static BOOL EDIT_EM_FmtLines(EDITSTATE *es, BOOL add_eol)
{
@@ -2636,9 +2509,9 @@
*
* In this function we'll try to switch to local heap.
*/
-static HLOCAL16 EDIT_EM_GetHandle16(HWND hwnd, EDITSTATE *es)
+static HLOCAL16 EDIT_EM_GetHandle16(EDITSTATE *es)
{
- HINSTANCE hInstance = GetWindowLongA( hwnd, GWL_HINSTANCE );
+ HINSTANCE hInstance = GetWindowLongA( es->hwndSelf, GWL_HINSTANCE );
CHAR *textA;
UINT countA, alloc_size;
@@ -2759,10 +2632,10 @@
* All in all: very poorly documented
*
*/
-static LRESULT EDIT_EM_GetThumb(HWND hwnd, EDITSTATE *es)
+static LRESULT EDIT_EM_GetThumb(EDITSTATE *es)
{
- return MAKELONG(EDIT_WM_VScroll(hwnd, es, EM_GETTHUMB16, 0),
- EDIT_WM_HScroll(hwnd, es, EM_GETTHUMB16, 0));
+ return MAKELONG(EDIT_WM_VScroll(es, EM_GETTHUMB16, 0),
+ EDIT_WM_HScroll(es, EM_GETTHUMB16, 0));
}
@@ -2873,13 +2746,13 @@
* NOTE: dx is in average character widths, dy - in lines;
*
*/
-static BOOL EDIT_EM_LineScroll(HWND hwnd, EDITSTATE *es, INT dx, INT dy)
+static BOOL EDIT_EM_LineScroll(EDITSTATE *es, INT dx, INT dy)
{
if (!(es->style & ES_MULTILINE))
return FALSE;
dx *= es->char_width;
- return EDIT_EM_LineScroll_internal(hwnd, es, dx, dy);
+ return EDIT_EM_LineScroll_internal(es, dx, dy);
}
/*********************************************************************
@@ -2891,7 +2764,7 @@
* dx is in pixels, dy - in lines.
*
*/
-static BOOL EDIT_EM_LineScroll_internal(HWND hwnd, EDITSTATE *es, INT dx, INT dy)
+static BOOL EDIT_EM_LineScroll_internal(EDITSTATE *es, INT dx, INT dy)
{
INT nyoff;
INT x_offset_in_pixels;
@@ -2903,7 +2776,7 @@
else
{
dy = 0;
- x_offset_in_pixels = SLOWORD(EDIT_EM_PosFromChar(hwnd, es, es->x_offset, FALSE));
+ x_offset_in_pixels = SLOWORD(EDIT_EM_PosFromChar(es, es->x_offset, FALSE));
}
if (-dx > x_offset_in_pixels)
@@ -2924,17 +2797,17 @@
else
es->x_offset += dx / es->char_width;
- GetClientRect(hwnd, &rc1);
+ GetClientRect(es->hwndSelf, &rc1);
IntersectRect(&rc, &rc1, &es->format_rect);
- ScrollWindowEx(hwnd, -dx, dy,
+ ScrollWindowEx(es->hwndSelf, -dx, dy,
NULL, &rc, (HRGN)NULL, NULL, SW_INVALIDATE);
/* force scroll info update */
- EDIT_UpdateScrollInfo(hwnd, es);
+ EDIT_UpdateScrollInfo(es);
}
if (dx && !(es->flags & EF_HSCROLL_TRACK))
- EDIT_NOTIFY_PARENT(hwnd, es, EN_HSCROLL, "EN_HSCROLL");
+ EDIT_NOTIFY_PARENT(es, EN_HSCROLL, "EN_HSCROLL");
if (dy && !(es->flags & EF_VSCROLL_TRACK))
- EDIT_NOTIFY_PARENT(hwnd, es, EN_VSCROLL, "EN_VSCROLL");
+ EDIT_NOTIFY_PARENT(es, EN_VSCROLL, "EN_VSCROLL");
return TRUE;
}
@@ -2944,7 +2817,7 @@
* EM_POSFROMCHAR
*
*/
-static LRESULT EDIT_EM_PosFromChar(HWND hwnd, EDITSTATE *es, INT index, BOOL after_wrap)
+static LRESULT EDIT_EM_PosFromChar(EDITSTATE *es, INT index, BOOL after_wrap)
{
INT len = strlenW(es->text);
INT l;
@@ -2956,7 +2829,7 @@
SIZE size;
index = min(index, len);
- dc = GetDC(hwnd);
+ dc = GetDC(es->hwndSelf);
if (es->font)
old_font = SelectObject(dc, es->font);
if (es->style & ES_MULTILINE) {
@@ -2997,7 +2870,7 @@
y += es->format_rect.top;
if (es->font)
SelectObject(dc, old_font);
- ReleaseDC(hwnd, dc);
+ ReleaseDC(es->hwndSelf, dc);
return MAKELONG((INT16)x, (INT16)y);
}
@@ -3009,7 +2882,7 @@
* FIXME: handle ES_NUMBER and ES_OEMCONVERT here
*
*/
-static void EDIT_EM_ReplaceSel(HWND hwnd, EDITSTATE *es, BOOL can_undo, LPCWSTR lpsz_replace, BOOL send_update)
+static void EDIT_EM_ReplaceSel(EDITSTATE *es, BOOL can_undo, LPCWSTR lpsz_replace, BOOL send_update)
{
UINT strl = strlenW(lpsz_replace);
UINT tl = strlenW(es->text);
@@ -3031,7 +2904,7 @@
ORDER_UINT(s, e);
- if (!EDIT_MakeFit(hwnd, es, tl - (e - s) + strl))
+ if (!EDIT_MakeFit(es, tl - (e - s) + strl))
return;
if (e != s) {
@@ -3106,32 +2979,32 @@
INT s = min(es->selection_start, es->selection_end);
hrgn = CreateRectRgn(0, 0, 0, 0);
- EDIT_BuildLineDefs_ML(hwnd, es, s, s + strl,
+ EDIT_BuildLineDefs_ML(es, s, s + strl,
strl - abs(es->selection_end - es->selection_start), hrgn);
}
else
- EDIT_CalcLineWidth_SL(hwnd, es);
+ EDIT_CalcLineWidth_SL(es);
- EDIT_EM_SetSel(hwnd, es, s, s, FALSE);
+ EDIT_EM_SetSel(es, s, s, FALSE);
es->flags |= EF_MODIFIED;
if (send_update) es->flags |= EF_UPDATE;
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_ScrollCaret(es);
/* force scroll info update */
- EDIT_UpdateScrollInfo(hwnd, es);
+ EDIT_UpdateScrollInfo(es);
if (hrgn)
{
- EDIT_UpdateTextRegion(hwnd, es, hrgn, TRUE);
+ EDIT_UpdateTextRegion(es, hrgn, TRUE);
DeleteObject(hrgn);
}
else
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_UpdateText(es, NULL, TRUE);
if(es->flags & EF_UPDATE)
{
es->flags &= ~EF_UPDATE;
- EDIT_NOTIFY_PARENT(hwnd, es, EN_CHANGE, "EN_CHANGE");
+ EDIT_NOTIFY_PARENT(es, EN_CHANGE, "EN_CHANGE");
}
}
@@ -3141,7 +3014,7 @@
* EM_SCROLL
*
*/
-static LRESULT EDIT_EM_Scroll(HWND hwnd, EDITSTATE *es, INT action)
+static LRESULT EDIT_EM_Scroll(EDITSTATE *es, INT action)
{
INT dy;
@@ -3178,7 +3051,7 @@
/* Notification is done in EDIT_EM_LineScroll */
if(dy)
- EDIT_EM_LineScroll(hwnd, es, 0, dy);
+ EDIT_EM_LineScroll(es, 0, dy);
}
return MAKELONG((INT16)dy, (BOOL16)TRUE);
}
@@ -3189,7 +3062,7 @@
* EM_SCROLLCARET
*
*/
-static void EDIT_EM_ScrollCaret(HWND hwnd, EDITSTATE *es)
+static void EDIT_EM_ScrollCaret(EDITSTATE *es)
{
if (es->style & ES_MULTILINE) {
INT l;
@@ -3203,7 +3076,7 @@
l = EDIT_EM_LineFromChar(es, es->selection_end);
li = EDIT_EM_LineIndex(es, l);
- x = SLOWORD(EDIT_EM_PosFromChar(hwnd, es, es->selection_end, es->flags & EF_AFTER_WRAP));
+ x = SLOWORD(EDIT_EM_PosFromChar(es, es->selection_end, es->flags & EF_AFTER_WRAP));
vlc = (es->format_rect.bottom - es->format_rect.top) / es->line_height;
if (l >= es->y_offset + vlc)
dy = l - vlc + 1 - es->y_offset;
@@ -3220,7 +3093,7 @@
if(es->x_offset + dx + ww > es->text_width)
dx = es->text_width - ww - es->x_offset;
if(dx || dy)
- EDIT_EM_LineScroll_internal(hwnd, es, dx, dy);
+ EDIT_EM_LineScroll_internal(es, dx, dy);
}
} else {
INT x;
@@ -3230,32 +3103,32 @@
if (!(es->style & ES_AUTOHSCROLL))
return;
- x = SLOWORD(EDIT_EM_PosFromChar(hwnd, es, es->selection_end, FALSE));
+ x = SLOWORD(EDIT_EM_PosFromChar(es, es->selection_end, FALSE));
format_width = es->format_rect.right - es->format_rect.left;
if (x < es->format_rect.left) {
goal = es->format_rect.left + format_width / HSCROLL_FRACTION;
do {
es->x_offset--;
- x = SLOWORD(EDIT_EM_PosFromChar(hwnd, es, es->selection_end, FALSE));
+ x = SLOWORD(EDIT_EM_PosFromChar(es, es->selection_end, FALSE));
} while ((x < goal) && es->x_offset);
/* FIXME: use ScrollWindow() somehow to improve performance */
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_UpdateText(es, NULL, TRUE);
} else if (x > es->format_rect.right) {
INT x_last;
INT len = strlenW(es->text);
goal = es->format_rect.right - format_width / HSCROLL_FRACTION;
do {
es->x_offset++;
- x = SLOWORD(EDIT_EM_PosFromChar(hwnd, es, es->selection_end, FALSE));
- x_last = SLOWORD(EDIT_EM_PosFromChar(hwnd, es, len, FALSE));
+ x = SLOWORD(EDIT_EM_PosFromChar(es, es->selection_end, FALSE));
+ x_last = SLOWORD(EDIT_EM_PosFromChar(es, len, FALSE));
} while ((x > goal) && (x_last > es->format_rect.right));
/* FIXME: use ScrollWindow() somehow to improve performance */
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_UpdateText(es, NULL, TRUE);
}
}
if(es->flags & EF_FOCUSED)
- EDIT_SetCaretPos(hwnd, es, es->selection_end, es->flags & EF_AFTER_WRAP);
+ EDIT_SetCaretPos(es, es->selection_end, es->flags & EF_AFTER_WRAP);
}
@@ -3266,9 +3139,9 @@
* FIXME: ES_LOWERCASE, ES_UPPERCASE, ES_OEMCONVERT, ES_NUMBER ???
*
*/
-static void EDIT_EM_SetHandle(HWND hwnd, EDITSTATE *es, HLOCAL hloc)
+static void EDIT_EM_SetHandle(EDITSTATE *es, HLOCAL hloc)
{
- HINSTANCE hInstance = GetWindowLongA( hwnd, GWL_HINSTANCE );
+ HINSTANCE hInstance = GetWindowLongA( es->hwndSelf, GWL_HINSTANCE );
if (!(es->style & ES_MULTILINE))
return;
@@ -3278,7 +3151,7 @@
return;
}
- EDIT_UnlockBuffer(hwnd, es, TRUE);
+ EDIT_UnlockBuffer(es, TRUE);
if(es->hloc16)
{
@@ -3324,18 +3197,18 @@
es->buffer_size = LocalSize(es->hloc32W)/sizeof(WCHAR) - 1;
- EDIT_LockBuffer(hwnd, es);
+ EDIT_LockBuffer(es);
es->x_offset = es->y_offset = 0;
es->selection_start = es->selection_end = 0;
EDIT_EM_EmptyUndoBuffer(es);
es->flags &= ~EF_MODIFIED;
es->flags &= ~EF_UPDATE;
- EDIT_BuildLineDefs_ML(hwnd, es, 0, strlenW(es->text), 0, (HRGN)0);
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_BuildLineDefs_ML(es, 0, strlenW(es->text), 0, (HRGN)0);
+ EDIT_UpdateText(es, NULL, TRUE);
+ EDIT_EM_ScrollCaret(es);
/* force scroll info update */
- EDIT_UpdateScrollInfo(hwnd, es);
+ EDIT_UpdateScrollInfo(es);
}
@@ -3346,9 +3219,9 @@
* FIXME: ES_LOWERCASE, ES_UPPERCASE, ES_OEMCONVERT, ES_NUMBER ???
*
*/
-static void EDIT_EM_SetHandle16(HWND hwnd, EDITSTATE *es, HLOCAL16 hloc)
+static void EDIT_EM_SetHandle16(EDITSTATE *es, HLOCAL16 hloc)
{
- HINSTANCE hInstance = GetWindowLongA( hwnd, GWL_HINSTANCE );
+ HINSTANCE hInstance = GetWindowLongA( es->hwndSelf, GWL_HINSTANCE );
INT countW, countA;
HLOCAL hloc32W_new;
WCHAR *textW;
@@ -3362,7 +3235,7 @@
return;
}
- EDIT_UnlockBuffer(hwnd, es, TRUE);
+ EDIT_UnlockBuffer(es, TRUE);
if(es->hloc32A)
{
@@ -3391,18 +3264,18 @@
es->buffer_size = LocalSize(es->hloc32W)/sizeof(WCHAR) - 1;
- EDIT_LockBuffer(hwnd, es);
+ EDIT_LockBuffer(es);
es->x_offset = es->y_offset = 0;
es->selection_start = es->selection_end = 0;
EDIT_EM_EmptyUndoBuffer(es);
es->flags &= ~EF_MODIFIED;
es->flags &= ~EF_UPDATE;
- EDIT_BuildLineDefs_ML(hwnd, es, 0, strlenW(es->text), 0, (HRGN)0);
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_BuildLineDefs_ML(es, 0, strlenW(es->text), 0, (HRGN)0);
+ EDIT_UpdateText(es, NULL, TRUE);
+ EDIT_EM_ScrollCaret(es);
/* force scroll info update */
- EDIT_UpdateScrollInfo(hwnd, es);
+ EDIT_UpdateScrollInfo(es);
}
@@ -3468,9 +3341,9 @@
* EM_SETPASSWORDCHAR
*
*/
-static void EDIT_EM_SetPasswordChar(HWND hwnd, EDITSTATE *es, WCHAR c)
+static void EDIT_EM_SetPasswordChar(EDITSTATE *es, WCHAR c)
{
- LONG style;
+ LONG style;
if (es->style & ES_MULTILINE)
return;
@@ -3478,16 +3351,16 @@
if (es->password_char == c)
return;
- style = GetWindowLongA( hwnd, GWL_STYLE );
+ style = GetWindowLongA( es->hwndSelf, GWL_STYLE );
es->password_char = c;
if (c) {
- SetWindowLongA( hwnd, GWL_STYLE, style | ES_PASSWORD );
+ SetWindowLongA( es->hwndSelf, GWL_STYLE, style | ES_PASSWORD );
es->style |= ES_PASSWORD;
} else {
- SetWindowLongA( hwnd, GWL_STYLE, style & ~ES_PASSWORD );
+ SetWindowLongA( es->hwndSelf, GWL_STYLE, style & ~ES_PASSWORD );
es->style &= ~ES_PASSWORD;
}
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_UpdateText(es, NULL, TRUE);
}
@@ -3500,7 +3373,7 @@
* In other words: this handler is OK
*
*/
-static void EDIT_EM_SetSel(HWND hwnd, EDITSTATE *es, UINT start, UINT end, BOOL after_wrap)
+static void EDIT_EM_SetSel(EDITSTATE *es, UINT start, UINT end, BOOL after_wrap)
{
UINT old_start = es->selection_start;
UINT old_end = es->selection_end;
@@ -3529,22 +3402,22 @@
/*
* One can also do
* ORDER_UINT32(end, old_start);
- * EDIT_InvalidateText(hwnd, es, start, end);
- * EDIT_InvalidateText(hwnd, es, old_start, old_end);
+ * EDIT_InvalidateText(es, start, end);
+ * EDIT_InvalidateText(es, old_start, old_end);
* in place of the following if statement.
*/
if (old_start > end )
{
- EDIT_InvalidateText(hwnd, es, start, end);
- EDIT_InvalidateText(hwnd, es, old_start, old_end);
+ EDIT_InvalidateText(es, start, end);
+ EDIT_InvalidateText(es, old_start, old_end);
}
else
{
- EDIT_InvalidateText(hwnd, es, start, old_start);
- EDIT_InvalidateText(hwnd, es, end, old_end);
+ EDIT_InvalidateText(es, start, old_start);
+ EDIT_InvalidateText(es, end, old_end);
}
}
- else EDIT_InvalidateText(hwnd, es, start, old_end);
+ else EDIT_InvalidateText(es, start, old_end);
}
@@ -3599,7 +3472,7 @@
* EM_SETWORDBREAKPROC
*
*/
-static void EDIT_EM_SetWordBreakProc(HWND hwnd, EDITSTATE *es, LPARAM lParam)
+static void EDIT_EM_SetWordBreakProc(EDITSTATE *es, LPARAM lParam)
{
if (es->word_break_proc == (void *)lParam)
return;
@@ -3608,8 +3481,8 @@
es->word_break_proc16 = NULL;
if ((es->style & ES_MULTILINE) && !(es->style & ES_AUTOHSCROLL)) {
- EDIT_BuildLineDefs_ML(hwnd, es, 0, strlenW(es->text), 0, (HRGN)0);
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_BuildLineDefs_ML(es, 0, strlenW(es->text), 0, (HRGN)0);
+ EDIT_UpdateText(es, NULL, TRUE);
}
}
@@ -3619,7 +3492,7 @@
* EM_SETWORDBREAKPROC16
*
*/
-static void EDIT_EM_SetWordBreakProc16(HWND hwnd, EDITSTATE *es, EDITWORDBREAKPROC16 wbp)
+static void EDIT_EM_SetWordBreakProc16(EDITSTATE *es, EDITWORDBREAKPROC16 wbp)
{
if (es->word_break_proc16 == wbp)
return;
@@ -3627,8 +3500,8 @@
es->word_break_proc = NULL;
es->word_break_proc16 = wbp;
if ((es->style & ES_MULTILINE) && !(es->style & ES_AUTOHSCROLL)) {
- EDIT_BuildLineDefs_ML(hwnd, es, 0, strlenW(es->text), 0, (HRGN)0);
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_BuildLineDefs_ML(es, 0, strlenW(es->text), 0, (HRGN)0);
+ EDIT_UpdateText(es, NULL, TRUE);
}
}
@@ -3638,7 +3511,7 @@
* EM_UNDO / WM_UNDO
*
*/
-static BOOL EDIT_EM_Undo(HWND hwnd, EDITSTATE *es)
+static BOOL EDIT_EM_Undo(EDITSTATE *es)
{
INT ulength;
LPWSTR utext;
@@ -3655,13 +3528,13 @@
TRACE("before UNDO:insertion length = %d, deletion buffer = %s\n",
es->undo_insert_count, debugstr_w(utext));
- EDIT_EM_SetSel(hwnd, es, es->undo_position, es->undo_position + es->undo_insert_count, FALSE);
+ EDIT_EM_SetSel(es, es->undo_position, es->undo_position + es->undo_insert_count, FALSE);
EDIT_EM_EmptyUndoBuffer(es);
- EDIT_EM_ReplaceSel(hwnd, es, TRUE, utext, FALSE);
- EDIT_EM_SetSel(hwnd, es, es->undo_position, es->undo_position + es->undo_insert_count, FALSE);
+ EDIT_EM_ReplaceSel(es, TRUE, utext, FALSE);
+ EDIT_EM_SetSel(es, es->undo_position, es->undo_position + es->undo_insert_count, FALSE);
/* send the notification after the selection start and end are set */
- EDIT_NOTIFY_PARENT(hwnd, es, EN_CHANGE, "EN_CHANGE");
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_NOTIFY_PARENT(es, EN_CHANGE, "EN_CHANGE");
+ EDIT_EM_ScrollCaret(es);
HeapFree(GetProcessHeap(), 0, utext);
TRACE("after UNDO:insertion length = %d, deletion buffer = %s\n",
@@ -3675,7 +3548,7 @@
* WM_CHAR
*
*/
-static void EDIT_WM_Char(HWND hwnd, EDITSTATE *es, WCHAR c)
+static void EDIT_WM_Char(EDITSTATE *es, WCHAR c)
{
BOOL control;
@@ -3693,11 +3566,11 @@
case '\n':
if (es->style & ES_MULTILINE) {
if (es->style & ES_READONLY) {
- EDIT_MoveHome(hwnd, es, FALSE);
- EDIT_MoveDown_ML(hwnd, es, FALSE);
+ EDIT_MoveHome(es, FALSE);
+ EDIT_MoveDown_ML(es, FALSE);
} else {
static const WCHAR cr_lfW[] = {'\r','\n',0};
- EDIT_EM_ReplaceSel(hwnd, es, TRUE, cr_lfW, TRUE);
+ EDIT_EM_ReplaceSel(es, TRUE, cr_lfW, TRUE);
}
}
break;
@@ -3705,29 +3578,29 @@
if ((es->style & ES_MULTILINE) && !(es->style & ES_READONLY))
{
static const WCHAR tabW[] = {'\t',0};
- EDIT_EM_ReplaceSel(hwnd, es, TRUE, tabW, TRUE);
+ EDIT_EM_ReplaceSel(es, TRUE, tabW, TRUE);
}
break;
case VK_BACK:
if (!(es->style & ES_READONLY) && !control) {
if (es->selection_start != es->selection_end)
- EDIT_WM_Clear(hwnd, es);
+ EDIT_WM_Clear(es);
else {
/* delete character left of caret */
- EDIT_EM_SetSel(hwnd, es, (UINT)-1, 0, FALSE);
- EDIT_MoveBackward(hwnd, es, TRUE);
- EDIT_WM_Clear(hwnd, es);
+ EDIT_EM_SetSel(es, (UINT)-1, 0, FALSE);
+ EDIT_MoveBackward(es, TRUE);
+ EDIT_WM_Clear(es);
}
}
break;
case 0x03: /* ^C */
- SendMessageW(hwnd, WM_COPY, 0, 0);
+ SendMessageW(es->hwndSelf, WM_COPY, 0, 0);
break;
case 0x16: /* ^V */
- SendMessageW(hwnd, WM_PASTE, 0, 0);
+ SendMessageW(es->hwndSelf, WM_PASTE, 0, 0);
break;
case 0x18: /* ^X */
- SendMessageW(hwnd, WM_CUT, 0, 0);
+ SendMessageW(es->hwndSelf, WM_CUT, 0, 0);
break;
default:
@@ -3735,7 +3608,7 @@
WCHAR str[2];
str[0] = c;
str[1] = '\0';
- EDIT_EM_ReplaceSel(hwnd, es, TRUE, str, TRUE);
+ EDIT_EM_ReplaceSel(es, TRUE, str, TRUE);
}
break;
}
@@ -3747,30 +3620,30 @@
* WM_COMMAND
*
*/
-static void EDIT_WM_Command(HWND hwnd, EDITSTATE *es, INT code, INT id, HWND control)
+static void EDIT_WM_Command(EDITSTATE *es, INT code, INT id, HWND control)
{
if (code || control)
return;
switch (id) {
case EM_UNDO:
- EDIT_EM_Undo(hwnd, es);
+ EDIT_EM_Undo(es);
break;
case WM_CUT:
- EDIT_WM_Cut(hwnd, es);
+ EDIT_WM_Cut(es);
break;
case WM_COPY:
- EDIT_WM_Copy(hwnd, es);
+ EDIT_WM_Copy(es);
break;
case WM_PASTE:
- EDIT_WM_Paste(hwnd, es);
+ EDIT_WM_Paste(es);
break;
case WM_CLEAR:
- EDIT_WM_Clear(hwnd, es);
+ EDIT_WM_Clear(es);
break;
case EM_SETSEL:
- EDIT_EM_SetSel(hwnd, es, 0, (UINT)-1, FALSE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, 0, (UINT)-1, FALSE);
+ EDIT_EM_ScrollCaret(es);
break;
default:
ERR("unknown menu item, please report\n");
@@ -3795,7 +3668,7 @@
* (as we do in EDIT_WM_Command()).
*
*/
-static void EDIT_WM_ContextMenu(HWND hwnd, EDITSTATE *es, INT x, INT y)
+static void EDIT_WM_ContextMenu(EDITSTATE *es, INT x, INT y)
{
HMENU menu = LoadMenuA(GetModuleHandleA("USER32"), "EDITMENU");
HMENU popup = GetSubMenu(menu, 0);
@@ -3817,7 +3690,7 @@
/* select all */
EnableMenuItem(popup, 7, MF_BYPOSITION | (start || (end != strlenW(es->text)) ? MF_ENABLED : MF_GRAYED));
- TrackPopupMenu(popup, TPM_LEFTALIGN | TPM_RIGHTBUTTON, x, y, 0, hwnd, NULL);
+ TrackPopupMenu(popup, TPM_LEFTALIGN | TPM_RIGHTBUTTON, x, y, 0, es->hwndSelf, NULL);
DestroyMenu(menu);
}
@@ -3827,23 +3700,22 @@
* WM_COPY
*
*/
-static void EDIT_WM_Copy(HWND hwnd, EDITSTATE *es)
+static void EDIT_WM_Copy(EDITSTATE *es)
{
- INT s = es->selection_start;
- INT e = es->selection_end;
+ INT s = min(es->selection_start, es->selection_end);
+ INT e = max(es->selection_start, es->selection_end);
HGLOBAL hdst;
LPWSTR dst;
- if (e == s)
- return;
- ORDER_INT(s, e);
+ if (e == s) return;
+
hdst = GlobalAlloc(GMEM_MOVEABLE | GMEM_DDESHARE, (DWORD)(e - s + 1) * sizeof(WCHAR));
dst = GlobalLock(hdst);
strncpyW(dst, es->text + s, e - s);
dst[e - s] = 0; /* ensure 0 termination */
TRACE("%s\n", debugstr_w(dst));
GlobalUnlock(hdst);
- OpenClipboard(hwnd);
+ OpenClipboard(es->hwndSelf);
EmptyClipboard();
SetClipboardData(CF_UNICODETEXT, hdst);
CloseClipboard();
@@ -3855,7 +3727,7 @@
* WM_CREATE
*
*/
-static LRESULT EDIT_WM_Create(HWND hwnd, EDITSTATE *es, LPCWSTR name)
+static LRESULT EDIT_WM_Create(EDITSTATE *es, LPCWSTR name)
{
TRACE("%s\n", debugstr_w(name));
/*
@@ -3864,11 +3736,11 @@
* not fully initialized), we should be very careful which
* functions can be called, and in what order.
*/
- EDIT_WM_SetFont(hwnd, es, 0, FALSE);
+ EDIT_WM_SetFont(es, 0, FALSE);
EDIT_EM_EmptyUndoBuffer(es);
if (name && *name) {
- EDIT_EM_ReplaceSel(hwnd, es, FALSE, name, FALSE);
+ EDIT_EM_ReplaceSel(es, FALSE, name, FALSE);
/* if we insert text to the editline, the text scrolls out
* of the window, as the caret is placed after the insert
* pos normally; thus we reset es->selection... to 0 and
@@ -3879,12 +3751,12 @@
* Messages are only to be sent when the USER does something to
* change the contents. So I am removing this EN_CHANGE
*
- * EDIT_NOTIFY_PARENT(hwnd, es, EN_CHANGE, "EN_CHANGE");
+ * EDIT_NOTIFY_PARENT(es, EN_CHANGE, "EN_CHANGE");
*/
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_ScrollCaret(es);
}
/* force scroll info update */
- EDIT_UpdateScrollInfo(hwnd, es);
+ EDIT_UpdateScrollInfo(es);
return 0;
}
@@ -3894,9 +3766,9 @@
* WM_DESTROY
*
*/
-static void EDIT_WM_Destroy(HWND hwnd, EDITSTATE *es)
+static void EDIT_WM_Destroy(EDITSTATE *es)
{
- HINSTANCE hInstance = GetWindowLongA( hwnd, GWL_HINSTANCE );
+ HINSTANCE hInstance = GetWindowLongA( es->hwndSelf, GWL_HINSTANCE );
LINEDEF *pc, *pp;
if (es->hloc32W) {
@@ -3920,7 +3792,7 @@
pc = pp;
}
- SetWindowLongA( hwnd, 0, 0 );
+ SetWindowLongA( es->hwndSelf, 0, 0 );
HeapFree(GetProcessHeap(), 0, es);
}
@@ -3930,21 +3802,15 @@
* WM_ERASEBKGND
*
*/
-static LRESULT EDIT_WM_EraseBkGnd(HWND hwnd, EDITSTATE *es, HDC dc)
+static LRESULT EDIT_WM_EraseBkGnd(EDITSTATE *es, HDC dc)
{
HBRUSH brush;
RECT rc;
- if ( get_app_version() >= 0x40000 &&(
- !es->bEnableState || (es->style & ES_READONLY)))
- brush = (HBRUSH)EDIT_SEND_CTLCOLORSTATIC(hwnd, dc);
- else
- brush = (HBRUSH)EDIT_SEND_CTLCOLOR(hwnd, dc);
-
- if (!brush)
+ if (!(brush = EDIT_NotifyCtlColor(es, dc)))
brush = (HBRUSH)GetStockObject(WHITE_BRUSH);
- GetClientRect(hwnd, &rc);
+ GetClientRect(es->hwndSelf, &rc);
IntersectClipRect(dc, rc.left, rc.top, rc.right, rc.bottom);
GetClipBox(dc, &rc);
/*
@@ -3987,7 +3853,7 @@
* WM_HSCROLL
*
*/
-static LRESULT EDIT_WM_HScroll(HWND hwnd, EDITSTATE *es, INT action, INT pos)
+static LRESULT EDIT_WM_HScroll(EDITSTATE *es, INT action, INT pos)
{
INT dx;
INT fw;
@@ -4050,7 +3916,7 @@
case SB_THUMBPOSITION:
TRACE("SB_THUMBPOSITION %d\n", pos);
es->flags &= ~EF_HSCROLL_TRACK;
- if(GetWindowLongA( hwnd, GWL_STYLE ) & WS_HSCROLL)
+ if(GetWindowLongA( es->hwndSelf, GWL_STYLE ) & WS_HSCROLL)
dx = pos - es->x_offset;
else
{
@@ -4064,8 +3930,8 @@
}
if (!dx) {
/* force scroll info update */
- EDIT_UpdateScrollInfo(hwnd, es);
- EDIT_NOTIFY_PARENT(hwnd, es, EN_HSCROLL, "EN_HSCROLL");
+ EDIT_UpdateScrollInfo(es);
+ EDIT_NOTIFY_PARENT(es, EN_HSCROLL, "EN_HSCROLL");
}
break;
case SB_ENDSCROLL:
@@ -4081,8 +3947,8 @@
case EM_GETTHUMB16:
{
LRESULT ret;
- if(GetWindowLongA( hwnd, GWL_STYLE ) & WS_HSCROLL)
- ret = GetScrollPos(hwnd, SB_HORZ);
+ if(GetWindowLongA( es->hwndSelf, GWL_STYLE ) & WS_HSCROLL)
+ ret = GetScrollPos(es->hwndSelf, SB_HORZ);
else
{
/* Assume default scroll range 0-100 */
@@ -4109,7 +3975,7 @@
if(es->x_offset + dx + fw > es->text_width)
dx = es->text_width - fw - es->x_offset;
if(dx)
- EDIT_EM_LineScroll_internal(hwnd, es, dx, 0);
+ EDIT_EM_LineScroll_internal(es, dx, 0);
}
return 0;
}
@@ -4120,7 +3986,7 @@
* EDIT_CheckCombo
*
*/
-static BOOL EDIT_CheckCombo(HWND hwnd, EDITSTATE *es, UINT msg, INT key)
+static BOOL EDIT_CheckCombo(EDITSTATE *es, UINT msg, INT key)
{
HWND hLBox = es->hwndListBox;
HWND hCombo;
@@ -4130,12 +3996,12 @@
if (!hLBox)
return FALSE;
- hCombo = GetParent(hwnd);
+ hCombo = GetParent(es->hwndSelf);
bDropped = TRUE;
nEUI = 0;
TRACE_(combo)("[%04x]: handling msg %04x (%04x)\n",
- hwnd, (UINT16)msg, (UINT16)key);
+ es->hwndSelf, (UINT16)msg, (UINT16)key);
if (key == VK_UP || key == VK_DOWN)
{
@@ -4183,7 +4049,7 @@
* (i.e. non-printable keys) & Backspace & Delete
*
*/
-static LRESULT EDIT_WM_KeyDown(HWND hwnd, EDITSTATE *es, INT key)
+static LRESULT EDIT_WM_KeyDown(EDITSTATE *es, INT key)
{
BOOL shift;
BOOL control;
@@ -4197,72 +4063,72 @@
switch (key) {
case VK_F4:
case VK_UP:
- if (EDIT_CheckCombo(hwnd, es, WM_KEYDOWN, key) || key == VK_F4)
+ if (EDIT_CheckCombo(es, WM_KEYDOWN, key) || key == VK_F4)
break;
/* fall through */
case VK_LEFT:
if ((es->style & ES_MULTILINE) && (key == VK_UP))
- EDIT_MoveUp_ML(hwnd, es, shift);
+ EDIT_MoveUp_ML(es, shift);
else
if (control)
- EDIT_MoveWordBackward(hwnd, es, shift);
+ EDIT_MoveWordBackward(es, shift);
else
- EDIT_MoveBackward(hwnd, es, shift);
+ EDIT_MoveBackward(es, shift);
break;
case VK_DOWN:
- if (EDIT_CheckCombo(hwnd, es, WM_KEYDOWN, key))
+ if (EDIT_CheckCombo(es, WM_KEYDOWN, key))
break;
/* fall through */
case VK_RIGHT:
if ((es->style & ES_MULTILINE) && (key == VK_DOWN))
- EDIT_MoveDown_ML(hwnd, es, shift);
+ EDIT_MoveDown_ML(es, shift);
else if (control)
- EDIT_MoveWordForward(hwnd, es, shift);
+ EDIT_MoveWordForward(es, shift);
else
- EDIT_MoveForward(hwnd, es, shift);
+ EDIT_MoveForward(es, shift);
break;
case VK_HOME:
- EDIT_MoveHome(hwnd, es, shift);
+ EDIT_MoveHome(es, shift);
break;
case VK_END:
- EDIT_MoveEnd(hwnd, es, shift);
+ EDIT_MoveEnd(es, shift);
break;
case VK_PRIOR:
if (es->style & ES_MULTILINE)
- EDIT_MovePageUp_ML(hwnd, es, shift);
+ EDIT_MovePageUp_ML(es, shift);
else
- EDIT_CheckCombo(hwnd, es, WM_KEYDOWN, key);
+ EDIT_CheckCombo(es, WM_KEYDOWN, key);
break;
case VK_NEXT:
if (es->style & ES_MULTILINE)
- EDIT_MovePageDown_ML(hwnd, es, shift);
+ EDIT_MovePageDown_ML(es, shift);
else
- EDIT_CheckCombo(hwnd, es, WM_KEYDOWN, key);
+ EDIT_CheckCombo(es, WM_KEYDOWN, key);
break;
case VK_DELETE:
if (!(es->style & ES_READONLY) && !(shift && control)) {
if (es->selection_start != es->selection_end) {
if (shift)
- EDIT_WM_Cut(hwnd, es);
+ EDIT_WM_Cut(es);
else
- EDIT_WM_Clear(hwnd, es);
+ EDIT_WM_Clear(es);
} else {
if (shift) {
/* delete character left of caret */
- EDIT_EM_SetSel(hwnd, es, (UINT)-1, 0, FALSE);
- EDIT_MoveBackward(hwnd, es, TRUE);
- EDIT_WM_Clear(hwnd, es);
+ EDIT_EM_SetSel(es, (UINT)-1, 0, FALSE);
+ EDIT_MoveBackward(es, TRUE);
+ EDIT_WM_Clear(es);
} else if (control) {
/* delete to end of line */
- EDIT_EM_SetSel(hwnd, es, (UINT)-1, 0, FALSE);
- EDIT_MoveEnd(hwnd, es, TRUE);
- EDIT_WM_Clear(hwnd, es);
+ EDIT_EM_SetSel(es, (UINT)-1, 0, FALSE);
+ EDIT_MoveEnd(es, TRUE);
+ EDIT_WM_Clear(es);
} else {
/* delete character right of caret */
- EDIT_EM_SetSel(hwnd, es, (UINT)-1, 0, FALSE);
- EDIT_MoveForward(hwnd, es, TRUE);
- EDIT_WM_Clear(hwnd, es);
+ EDIT_EM_SetSel(es, (UINT)-1, 0, FALSE);
+ EDIT_MoveForward(es, TRUE);
+ EDIT_WM_Clear(es);
}
}
}
@@ -4270,15 +4136,15 @@
case VK_INSERT:
if (shift) {
if (!(es->style & ES_READONLY))
- EDIT_WM_Paste(hwnd, es);
+ EDIT_WM_Paste(es);
} else if (control)
- EDIT_WM_Copy(hwnd, es);
+ EDIT_WM_Copy(es);
break;
case VK_RETURN:
/* If the edit doesn't want the return send a message to the default object */
if(!(es->style & ES_WANTRETURN))
{
- HWND hwndParent = GetParent(hwnd);
+ HWND hwndParent = GetParent(es->hwndSelf);
DWORD dw = SendMessageW( hwndParent, DM_GETDEFID, 0, 0 );
if (HIWORD(dw) == DC_HASDEFID)
{
@@ -4298,13 +4164,13 @@
* WM_KILLFOCUS
*
*/
-static LRESULT EDIT_WM_KillFocus(HWND hwnd, EDITSTATE *es)
+static LRESULT EDIT_WM_KillFocus(EDITSTATE *es)
{
es->flags &= ~EF_FOCUSED;
DestroyCaret();
if(!(es->style & ES_NOHIDESEL))
- EDIT_InvalidateText(hwnd, es, es->selection_start, es->selection_end);
- EDIT_NOTIFY_PARENT(hwnd, es, EN_KILLFOCUS, "EN_KILLFOCUS");
+ EDIT_InvalidateText(es, es->selection_start, es->selection_end);
+ EDIT_NOTIFY_PARENT(es, EN_KILLFOCUS, "EN_KILLFOCUS");
return 0;
}
@@ -4316,7 +4182,7 @@
* The caret position has been set on the WM_LBUTTONDOWN message
*
*/
-static LRESULT EDIT_WM_LButtonDblClk(HWND hwnd, EDITSTATE *es)
+static LRESULT EDIT_WM_LButtonDblClk(EDITSTATE *es)
{
INT s;
INT e = es->selection_end;
@@ -4332,8 +4198,8 @@
ll = EDIT_EM_LineLength(es, e);
s = li + EDIT_CallWordBreakProc(es, li, e - li, ll, WB_LEFT);
e = li + EDIT_CallWordBreakProc(es, li, e - li, ll, WB_RIGHT);
- EDIT_EM_SetSel(hwnd, es, s, e, FALSE);
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_SetSel(es, s, e, FALSE);
+ EDIT_EM_ScrollCaret(es);
return 0;
}
@@ -4343,7 +4209,7 @@
* WM_LBUTTONDOWN
*
*/
-static LRESULT EDIT_WM_LButtonDown(HWND hwnd, EDITSTATE *es, DWORD keys, INT x, INT y)
+static LRESULT EDIT_WM_LButtonDown(EDITSTATE *es, DWORD keys, INT x, INT y)
{
INT e;
BOOL after_wrap;
@@ -4352,13 +4218,13 @@
return 0;
es->bCaptureState = TRUE;
- SetCapture(hwnd);
+ SetCapture(es->hwndSelf);
EDIT_ConfinePoint(es, &x, &y);
- e = EDIT_CharFromPos(hwnd, es, x, y, &after_wrap);
- EDIT_EM_SetSel(hwnd, es, (keys & MK_SHIFT) ? es->selection_start : e, e, after_wrap);
- EDIT_EM_ScrollCaret(hwnd, es);
+ e = EDIT_CharFromPos(es, x, y, &after_wrap);
+ EDIT_EM_SetSel(es, (keys & MK_SHIFT) ? es->selection_start : e, e, after_wrap);
+ EDIT_EM_ScrollCaret(es);
es->region_posx = es->region_posy = 0;
- SetTimer(hwnd, 0, 100, NULL);
+ SetTimer(es->hwndSelf, 0, 100, NULL);
return 0;
}
@@ -4368,10 +4234,10 @@
* WM_LBUTTONUP
*
*/
-static LRESULT EDIT_WM_LButtonUp(HWND hwndSelf, EDITSTATE *es)
+static LRESULT EDIT_WM_LButtonUp(EDITSTATE *es)
{
- if (es->bCaptureState && GetCapture() == hwndSelf) {
- KillTimer(hwndSelf, 0);
+ if (es->bCaptureState && GetCapture() == es->hwndSelf) {
+ KillTimer(es->hwndSelf, 0);
ReleaseCapture();
}
es->bCaptureState = FALSE;
@@ -4384,9 +4250,9 @@
* WM_MBUTTONDOWN
*
*/
-static LRESULT EDIT_WM_MButtonDown(HWND hwnd)
+static LRESULT EDIT_WM_MButtonDown(EDITSTATE *es)
{
- SendMessageW(hwnd,WM_PASTE,0,0);
+ SendMessageW(es->hwndSelf, WM_PASTE, 0, 0);
return 0;
}
@@ -4396,13 +4262,13 @@
* WM_MOUSEMOVE
*
*/
-static LRESULT EDIT_WM_MouseMove(HWND hwnd, EDITSTATE *es, INT x, INT y)
+static LRESULT EDIT_WM_MouseMove(EDITSTATE *es, INT x, INT y)
{
INT e;
BOOL after_wrap;
INT prex, prey;
- if (GetCapture() != hwnd)
+ if (GetCapture() != es->hwndSelf)
return 0;
/*
@@ -4413,9 +4279,9 @@
EDIT_ConfinePoint(es, &x, &y);
es->region_posx = (prex < x) ? -1 : ((prex > x) ? 1 : 0);
es->region_posy = (prey < y) ? -1 : ((prey > y) ? 1 : 0);
- e = EDIT_CharFromPos(hwnd, es, x, y, &after_wrap);
- EDIT_EM_SetSel(hwnd, es, es->selection_start, e, after_wrap);
- EDIT_SetCaretPos(hwnd,es,es->selection_end,es->flags & EF_AFTER_WRAP);
+ e = EDIT_CharFromPos(es, x, y, &after_wrap);
+ EDIT_EM_SetSel(es, es->selection_start, e, after_wrap);
+ EDIT_SetCaretPos(es,es->selection_end,es->flags & EF_AFTER_WRAP);
return 0;
}
@@ -4449,6 +4315,7 @@
es->bEnableState = !(style & WS_DISABLED);
+ es->hwndSelf = hwnd;
/* Save parent, which will be notified by EN_* messages */
es->hwndParent = hwndParent;
@@ -4544,7 +4411,7 @@
* WM_PAINT
*
*/
-static void EDIT_WM_Paint(HWND hwnd, EDITSTATE *es, WPARAM wParam)
+static void EDIT_WM_Paint(EDITSTATE *es, WPARAM wParam)
{
PAINTSTRUCT ps;
INT i;
@@ -4557,11 +4424,11 @@
((es->flags & EF_FOCUSED) ||
(es->style & ES_NOHIDESEL));
if (!wParam)
- dc = BeginPaint(hwnd, &ps);
+ dc = BeginPaint(es->hwndSelf, &ps);
else
dc = (HDC) wParam;
if(es->style & WS_BORDER) {
- GetClientRect(hwnd, &rc);
+ GetClientRect(es->hwndSelf, &rc);
if(es->style & ES_MULTILINE) {
if(es->style & WS_HSCROLL) rc.bottom++;
if(es->style & WS_VSCROLL) rc.right++;
@@ -4573,16 +4440,12 @@
es->format_rect.right,
es->format_rect.bottom);
if (es->style & ES_MULTILINE) {
- GetClientRect(hwnd, &rc);
+ GetClientRect(es->hwndSelf, &rc);
IntersectClipRect(dc, rc.left, rc.top, rc.right, rc.bottom);
}
if (es->font)
old_font = SelectObject(dc, es->font);
- if ( get_app_version() >= 0x40000 &&(
- !es->bEnableState || (es->style & ES_READONLY)))
- EDIT_SEND_CTLCOLORSTATIC(hwnd, dc);
- else
- EDIT_SEND_CTLCOLOR(hwnd, dc);
+ EDIT_NotifyCtlColor(es, dc);
if (!es->bEnableState)
SetTextColor(dc, GetSysColor(COLOR_GRAYTEXT));
@@ -4590,20 +4453,20 @@
if (es->style & ES_MULTILINE) {
INT vlc = (es->format_rect.bottom - es->format_rect.top) / es->line_height;
for (i = es->y_offset ; i <= min(es->y_offset + vlc, es->y_offset + es->line_count - 1) ; i++) {
- EDIT_GetLineRect(hwnd, es, i, 0, -1, &rcLine);
+ EDIT_GetLineRect(es, i, 0, -1, &rcLine);
if (IntersectRect(&rc, &rcRgn, &rcLine))
- EDIT_PaintLine(hwnd, es, dc, i, rev);
+ EDIT_PaintLine(es, dc, i, rev);
}
} else {
- EDIT_GetLineRect(hwnd, es, 0, 0, -1, &rcLine);
+ EDIT_GetLineRect(es, 0, 0, -1, &rcLine);
if (IntersectRect(&rc, &rcRgn, &rcLine))
- EDIT_PaintLine(hwnd, es, dc, 0, rev);
+ EDIT_PaintLine(es, dc, 0, rev);
}
if (es->font)
SelectObject(dc, old_font);
if (!wParam)
- EndPaint(hwnd, &ps);
+ EndPaint(es->hwndSelf, &ps);
}
@@ -4612,7 +4475,7 @@
* WM_PASTE
*
*/
-static void EDIT_WM_Paste(HWND hwnd, EDITSTATE *es)
+static void EDIT_WM_Paste(EDITSTATE *es)
{
HGLOBAL hsrc;
LPWSTR src;
@@ -4621,10 +4484,10 @@
if(es->style & ES_READONLY)
return;
- OpenClipboard(hwnd);
+ OpenClipboard(es->hwndSelf);
if ((hsrc = GetClipboardData(CF_UNICODETEXT))) {
src = (LPWSTR)GlobalLock(hsrc);
- EDIT_EM_ReplaceSel(hwnd, es, TRUE, src, TRUE);
+ EDIT_EM_ReplaceSel(es, TRUE, src, TRUE);
GlobalUnlock(hsrc);
}
CloseClipboard();
@@ -4636,16 +4499,16 @@
* WM_SETFOCUS
*
*/
-static void EDIT_WM_SetFocus(HWND hwnd, EDITSTATE *es)
+static void EDIT_WM_SetFocus(EDITSTATE *es)
{
es->flags |= EF_FOCUSED;
- CreateCaret(hwnd, 0, 2, es->line_height);
- EDIT_SetCaretPos(hwnd, es, es->selection_end,
+ CreateCaret(es->hwndSelf, 0, 2, es->line_height);
+ EDIT_SetCaretPos(es, es->selection_end,
es->flags & EF_AFTER_WRAP);
if(!(es->style & ES_NOHIDESEL))
- EDIT_InvalidateText(hwnd, es, es->selection_start, es->selection_end);
- ShowCaret(hwnd);
- EDIT_NOTIFY_PARENT(hwnd, es, EN_SETFOCUS, "EN_SETFOCUS");
+ EDIT_InvalidateText(es, es->selection_start, es->selection_end);
+ ShowCaret(es->hwndSelf);
+ EDIT_NOTIFY_PARENT(es, EN_SETFOCUS, "EN_SETFOCUS");
}
@@ -4658,7 +4521,7 @@
* unchanged.
*
*/
-static void EDIT_WM_SetFont(HWND hwnd, EDITSTATE *es, HFONT font, BOOL redraw)
+static void EDIT_WM_SetFont(EDITSTATE *es, HFONT font, BOOL redraw)
{
TEXTMETRICW tm;
HDC dc;
@@ -4666,7 +4529,7 @@
RECT r;
es->font = font;
- dc = GetDC(hwnd);
+ dc = GetDC(es->hwndSelf);
if (font)
old_font = SelectObject(dc, font);
GetTextMetricsW(dc, &tm);
@@ -4674,28 +4537,28 @@
es->char_width = tm.tmAveCharWidth;
if (font)
SelectObject(dc, old_font);
- ReleaseDC(hwnd, dc);
+ ReleaseDC(es->hwndSelf, dc);
if (font && (TWEAK_WineLook > WIN31_LOOK))
EDIT_EM_SetMargins(es, EC_LEFTMARGIN | EC_RIGHTMARGIN,
EC_USEFONTINFO, EC_USEFONTINFO);
/* Force the recalculation of the format rect for each font change */
- GetClientRect(hwnd, &r);
- EDIT_SetRectNP(hwnd, es, &r);
+ GetClientRect(es->hwndSelf, &r);
+ EDIT_SetRectNP(es, &r);
if (es->style & ES_MULTILINE)
- EDIT_BuildLineDefs_ML(hwnd, es, 0, strlenW(es->text), 0, (HRGN)0);
+ EDIT_BuildLineDefs_ML(es, 0, strlenW(es->text), 0, (HRGN)0);
else
- EDIT_CalcLineWidth_SL(hwnd, es);
+ EDIT_CalcLineWidth_SL(es);
if (redraw)
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_UpdateText(es, NULL, TRUE);
if (es->flags & EF_FOCUSED) {
DestroyCaret();
- CreateCaret(hwnd, 0, 2, es->line_height);
- EDIT_SetCaretPos(hwnd, es, es->selection_end,
+ CreateCaret(es->hwndSelf, 0, 2, es->line_height);
+ EDIT_SetCaretPos(es, es->selection_end,
es->flags & EF_AFTER_WRAP);
- ShowCaret(hwnd);
+ ShowCaret(es->hwndSelf);
}
}
@@ -4712,7 +4575,7 @@
* The modified flag is reset. EN_UPDATE and EN_CHANGE notifications are sent.
*
*/
-static void EDIT_WM_SetText(HWND hwnd, EDITSTATE *es, LPARAM lParam, BOOL unicode)
+static void EDIT_WM_SetText(EDITSTATE *es, LPARAM lParam, BOOL unicode)
{
LPWSTR text = NULL;
@@ -4726,30 +4589,30 @@
MultiByteToWideChar(CP_ACP, 0, textA, -1, text, countW);
}
- EDIT_EM_SetSel(hwnd, es, 0, (UINT)-1, FALSE);
+ EDIT_EM_SetSel(es, 0, (UINT)-1, FALSE);
if (text) {
TRACE("%s\n", debugstr_w(text));
- EDIT_EM_ReplaceSel(hwnd, es, FALSE, text, FALSE);
+ EDIT_EM_ReplaceSel(es, FALSE, text, FALSE);
if(!unicode)
HeapFree(GetProcessHeap(), 0, text);
} else {
static const WCHAR empty_stringW[] = {0};
TRACE("<NULL>\n");
- EDIT_EM_ReplaceSel(hwnd, es, FALSE, empty_stringW, FALSE);
+ EDIT_EM_ReplaceSel(es, FALSE, empty_stringW, FALSE);
}
es->x_offset = 0;
es->flags &= ~EF_MODIFIED;
- EDIT_EM_SetSel(hwnd, es, 0, 0, FALSE);
+ EDIT_EM_SetSel(es, 0, 0, FALSE);
/* Send the notification after the selection start and end have been set
* edit control doesn't send notification on WM_SETTEXT
* if it is multiline, or it is part of combobox
*/
if( !((es->style & ES_MULTILINE) || es->hwndListBox))
{
- EDIT_NOTIFY_PARENT(hwnd, es, EN_CHANGE, "EN_CHANGE");
- EDIT_NOTIFY_PARENT(hwnd, es, EN_UPDATE, "EN_UPDATE");
+ EDIT_NOTIFY_PARENT(es, EN_CHANGE, "EN_CHANGE");
+ EDIT_NOTIFY_PARENT(es, EN_UPDATE, "EN_UPDATE");
}
- EDIT_EM_ScrollCaret(hwnd, es);
+ EDIT_EM_ScrollCaret(es);
}
@@ -4758,14 +4621,14 @@
* WM_SIZE
*
*/
-static void EDIT_WM_Size(HWND hwnd, EDITSTATE *es, UINT action, INT width, INT height)
+static void EDIT_WM_Size(EDITSTATE *es, UINT action, INT width, INT height)
{
if ((action == SIZE_MAXIMIZED) || (action == SIZE_RESTORED)) {
RECT rc;
TRACE("width = %d, height = %d\n", width, height);
SetRect(&rc, 0, 0, width, height);
- EDIT_SetRectNP(hwnd, es, &rc);
- EDIT_UpdateText(hwnd, es, NULL, TRUE);
+ EDIT_SetRectNP(es, &rc);
+ EDIT_UpdateText(es, NULL, TRUE);
}
}
@@ -4792,10 +4655,7 @@
* Windows User Interface -> Edit Controls -> Edit Control Reference ->
* Edit Control Styles
*/
-static LRESULT EDIT_WM_StyleChanged (HWND hwnd,
- EDITSTATE *es,
- WPARAM which,
- const STYLESTRUCT *style)
+static LRESULT EDIT_WM_StyleChanged ( EDITSTATE *es, WPARAM which, const STYLESTRUCT *style)
{
if (GWL_STYLE == which) {
DWORD style_change_mask;
@@ -4835,17 +4695,17 @@
* WM_SYSKEYDOWN
*
*/
-static LRESULT EDIT_WM_SysKeyDown(HWND hwnd, EDITSTATE *es, INT key, DWORD key_data)
+static LRESULT EDIT_WM_SysKeyDown(EDITSTATE *es, INT key, DWORD key_data)
{
if ((key == VK_BACK) && (key_data & 0x2000)) {
if (EDIT_EM_CanUndo(es))
- EDIT_EM_Undo(hwnd, es);
+ EDIT_EM_Undo(es);
return 0;
} else if (key == VK_UP || key == VK_DOWN) {
- if (EDIT_CheckCombo(hwnd, es, WM_SYSKEYDOWN, key))
+ if (EDIT_CheckCombo(es, WM_SYSKEYDOWN, key))
return 0;
}
- return DefWindowProcW(hwnd, WM_SYSKEYDOWN, (WPARAM)key, (LPARAM)key_data);
+ return DefWindowProcW(es->hwndSelf, WM_SYSKEYDOWN, (WPARAM)key, (LPARAM)key_data);
}
@@ -4854,12 +4714,12 @@
* WM_TIMER
*
*/
-static void EDIT_WM_Timer(HWND hwnd, EDITSTATE *es)
+static void EDIT_WM_Timer(EDITSTATE *es)
{
if (es->region_posx < 0) {
- EDIT_MoveBackward(hwnd, es, TRUE);
+ EDIT_MoveBackward(es, TRUE);
} else if (es->region_posx > 0) {
- EDIT_MoveForward(hwnd, es, TRUE);
+ EDIT_MoveForward(es, TRUE);
}
/*
* FIXME: gotta do some vertical scrolling here, like
@@ -4872,7 +4732,7 @@
* WM_VSCROLL
*
*/
-static LRESULT EDIT_WM_VScroll(HWND hwnd, EDITSTATE *es, INT action, INT pos)
+static LRESULT EDIT_WM_VScroll(EDITSTATE *es, INT action, INT pos)
{
INT dy;
@@ -4889,7 +4749,7 @@
case SB_PAGEUP:
case SB_PAGEDOWN:
TRACE("action %d\n", action);
- EDIT_EM_Scroll(hwnd, es, action);
+ EDIT_EM_Scroll(es, action);
return 0;
case SB_TOP:
TRACE("SB_TOP\n");
@@ -4937,8 +4797,8 @@
if (!dy)
{
/* force scroll info update */
- EDIT_UpdateScrollInfo(hwnd, es);
- EDIT_NOTIFY_PARENT(hwnd, es, EN_VSCROLL, "EN_VSCROLL");
+ EDIT_UpdateScrollInfo(es);
+ EDIT_NOTIFY_PARENT(es, EN_VSCROLL, "EN_VSCROLL");
}
break;
case SB_ENDSCROLL:
@@ -4954,8 +4814,8 @@
case EM_GETTHUMB16:
{
LRESULT ret;
- if(GetWindowLongA( hwnd, GWL_STYLE ) & WS_VSCROLL)
- ret = GetScrollPos(hwnd, SB_VERT);
+ if(GetWindowLongA( es->hwndSelf, GWL_STYLE ) & WS_VSCROLL)
+ ret = GetScrollPos(es->hwndSelf, SB_VERT);
else
{
/* Assume default scroll range 0-100 */
@@ -4976,7 +4836,7 @@
return 0;
}
if (dy)
- EDIT_EM_LineScroll(hwnd, es, 0, dy);
+ EDIT_EM_LineScroll(es, 0, dy);
return 0;
}
@@ -4985,10 +4845,10 @@
* EDIT_UpdateText
*
*/
-static void EDIT_UpdateTextRegion(HWND hwnd, EDITSTATE *es, HRGN hrgn, BOOL bErase)
+static void EDIT_UpdateTextRegion(EDITSTATE *es, HRGN hrgn, BOOL bErase)
{
- if (es->flags & EF_UPDATE) EDIT_NOTIFY_PARENT(hwnd, es, EN_UPDATE, "EN_UPDATE");
- InvalidateRgn(hwnd, hrgn, bErase);
+ if (es->flags & EF_UPDATE) EDIT_NOTIFY_PARENT(es, EN_UPDATE, "EN_UPDATE");
+ InvalidateRgn(es->hwndSelf, hrgn, bErase);
}
@@ -4997,8 +4857,8 @@
* EDIT_UpdateText
*
*/
-static void EDIT_UpdateText(HWND hwnd, EDITSTATE *es, LPRECT rc, BOOL bErase)
+static void EDIT_UpdateText(EDITSTATE *es, LPRECT rc, BOOL bErase)
{
- if (es->flags & EF_UPDATE) EDIT_NOTIFY_PARENT(hwnd, es, EN_UPDATE, "EN_UPDATE");
- InvalidateRect(hwnd, rc, bErase);
+ if (es->flags & EF_UPDATE) EDIT_NOTIFY_PARENT(es, EN_UPDATE, "EN_UPDATE");
+ InvalidateRect(es->hwndSelf, rc, bErase);
}
More information about the wine-patches
mailing list