riched20: Use a run ptr in the link notify function.

Signed-off-by: Huw Davies <huw@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Huw Davies 2020-11-02 08:23:15 +00:00 committed by Alexandre Julliard
parent 50c8fe4560
commit 8046b5bc96
1 changed files with 8 additions and 9 deletions

View File

@ -3451,8 +3451,9 @@ static void ME_LinkNotify(ME_TextEditor *editor, UINT msg, WPARAM wParam, LPARAM
int x,y; int x,y;
BOOL isExact; BOOL isExact;
ME_Cursor cursor; /* The start of the clicked text. */ ME_Cursor cursor; /* The start of the clicked text. */
ME_Run *run;
ENLINK info; ENLINK info;
x = (short)LOWORD(lParam); x = (short)LOWORD(lParam);
y = (short)HIWORD(lParam); y = (short)HIWORD(lParam);
ME_CharFromPos(editor, x, y, &cursor, &isExact); ME_CharFromPos(editor, x, y, &cursor, &isExact);
@ -3460,8 +3461,6 @@ static void ME_LinkNotify(ME_TextEditor *editor, UINT msg, WPARAM wParam, LPARAM
if (is_link( &cursor.pRun->member.run )) if (is_link( &cursor.pRun->member.run ))
{ /* The clicked run has CFE_LINK set */ { /* The clicked run has CFE_LINK set */
ME_DisplayItem *di;
info.nmhdr.hwndFrom = NULL; info.nmhdr.hwndFrom = NULL;
info.nmhdr.idFrom = 0; info.nmhdr.idFrom = 0;
info.nmhdr.code = EN_LINK; info.nmhdr.code = EN_LINK;
@ -3472,15 +3471,15 @@ static void ME_LinkNotify(ME_TextEditor *editor, UINT msg, WPARAM wParam, LPARAM
/* find the first contiguous run with CFE_LINK set */ /* find the first contiguous run with CFE_LINK set */
info.chrg.cpMin = ME_GetCursorOfs(&cursor); info.chrg.cpMin = ME_GetCursorOfs(&cursor);
di = cursor.pRun; run = &cursor.pRun->member.run;
while (ME_PrevRun( NULL, &di, FALSE ) && is_link( &di->member.run )) while ((run = run_prev( run )) && is_link( run ))
info.chrg.cpMin -= di->member.run.len; info.chrg.cpMin -= run->len;
/* find the last contiguous run with CFE_LINK set */ /* find the last contiguous run with CFE_LINK set */
info.chrg.cpMax = ME_GetCursorOfs(&cursor) + cursor.pRun->member.run.len; info.chrg.cpMax = ME_GetCursorOfs(&cursor) + cursor.pRun->member.run.len;
di = cursor.pRun; run = &cursor.pRun->member.run;
while (ME_NextRun( NULL, &di, FALSE ) && is_link( &di->member.run )) while ((run = run_next( run )) && is_link( run ))
info.chrg.cpMax += di->member.run.len; info.chrg.cpMax += run->len;
ITextHost_TxNotify(editor->texthost, info.nmhdr.code, &info); ITextHost_TxNotify(editor->texthost, info.nmhdr.code, &info);
} }