riched20: Set pStream->written in ME_StreamOutFlush.
Superseded patch 115907. ChangeLog: - Add tests. Signed-off-by: Jactry Zeng <jzeng@codeweavers.com> Signed-off-by: Huw Davies <huw@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
36728f8b9e
commit
dc6b2853f5
|
@ -3307,6 +3307,8 @@ static void test_ES_PASSWORD(void)
|
||||||
DestroyWindow(hwndRichEdit);
|
DestroyWindow(hwndRichEdit);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LONG streamout_written = 0;
|
||||||
|
|
||||||
static DWORD CALLBACK test_WM_SETTEXT_esCallback(DWORD_PTR dwCookie,
|
static DWORD CALLBACK test_WM_SETTEXT_esCallback(DWORD_PTR dwCookie,
|
||||||
LPBYTE pbBuff,
|
LPBYTE pbBuff,
|
||||||
LONG cb,
|
LONG cb,
|
||||||
|
@ -3318,6 +3320,7 @@ static DWORD CALLBACK test_WM_SETTEXT_esCallback(DWORD_PTR dwCookie,
|
||||||
memcpy(*str, pbBuff, *pcb);
|
memcpy(*str, pbBuff, *pcb);
|
||||||
*str += *pcb;
|
*str += *pcb;
|
||||||
}
|
}
|
||||||
|
streamout_written = *pcb;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3442,6 +3445,7 @@ static void test_EM_STREAMOUT(void)
|
||||||
EDITSTREAM es;
|
EDITSTREAM es;
|
||||||
char buf[1024] = {0};
|
char buf[1024] = {0};
|
||||||
char * p;
|
char * p;
|
||||||
|
LRESULT result;
|
||||||
|
|
||||||
const char * TestItem1 = "TestSomeText";
|
const char * TestItem1 = "TestSomeText";
|
||||||
const char * TestItem2 = "TestSomeText\r";
|
const char * TestItem2 = "TestSomeText\r";
|
||||||
|
@ -3453,24 +3457,28 @@ static void test_EM_STREAMOUT(void)
|
||||||
es.dwError = 0;
|
es.dwError = 0;
|
||||||
es.pfnCallback = test_WM_SETTEXT_esCallback;
|
es.pfnCallback = test_WM_SETTEXT_esCallback;
|
||||||
memset(buf, 0, sizeof(buf));
|
memset(buf, 0, sizeof(buf));
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_TEXT, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_TEXT, (LPARAM)&es);
|
||||||
r = strlen(buf);
|
r = strlen(buf);
|
||||||
ok(r == 12, "streamed text length is %d, expecting 12\n", r);
|
ok(r == 12, "streamed text length is %d, expecting 12\n", r);
|
||||||
ok(strcmp(buf, TestItem1) == 0,
|
ok(strcmp(buf, TestItem1) == 0,
|
||||||
"streamed text different, got %s\n", buf);
|
"streamed text different, got %s\n", buf);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
|
|
||||||
/* RTF mode writes the final end of para \r if it's part of the selection */
|
/* RTF mode writes the final end of para \r if it's part of the selection */
|
||||||
p = buf;
|
p = buf;
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF, (LPARAM)&es);
|
||||||
ok (count_pars(buf) == 1, "got %s\n", buf);
|
ok (count_pars(buf) == 1, "got %s\n", buf);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
p = buf;
|
p = buf;
|
||||||
SendMessageA(hwndRichEdit, EM_SETSEL, 0, 12);
|
SendMessageA(hwndRichEdit, EM_SETSEL, 0, 12);
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF|SFF_SELECTION, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF|SFF_SELECTION, (LPARAM)&es);
|
||||||
ok (count_pars(buf) == 0, "got %s\n", buf);
|
ok (count_pars(buf) == 0, "got %s\n", buf);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
p = buf;
|
p = buf;
|
||||||
SendMessageA(hwndRichEdit, EM_SETSEL, 0, -1);
|
SendMessageA(hwndRichEdit, EM_SETSEL, 0, -1);
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF|SFF_SELECTION, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF|SFF_SELECTION, (LPARAM)&es);
|
||||||
ok (count_pars(buf) == 1, "got %s\n", buf);
|
ok (count_pars(buf) == 1, "got %s\n", buf);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
|
|
||||||
SendMessageA(hwndRichEdit, WM_SETTEXT, 0, (LPARAM)TestItem2);
|
SendMessageA(hwndRichEdit, WM_SETTEXT, 0, (LPARAM)TestItem2);
|
||||||
p = buf;
|
p = buf;
|
||||||
|
@ -3478,7 +3486,8 @@ static void test_EM_STREAMOUT(void)
|
||||||
es.dwError = 0;
|
es.dwError = 0;
|
||||||
es.pfnCallback = test_WM_SETTEXT_esCallback;
|
es.pfnCallback = test_WM_SETTEXT_esCallback;
|
||||||
memset(buf, 0, sizeof(buf));
|
memset(buf, 0, sizeof(buf));
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_TEXT, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_TEXT, (LPARAM)&es);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
r = strlen(buf);
|
r = strlen(buf);
|
||||||
/* Here again, \r gets converted to \r\n, like WM_GETTEXT */
|
/* Here again, \r gets converted to \r\n, like WM_GETTEXT */
|
||||||
ok(r == 14, "streamed text length is %d, expecting 14\n", r);
|
ok(r == 14, "streamed text length is %d, expecting 14\n", r);
|
||||||
|
@ -3487,16 +3496,19 @@ static void test_EM_STREAMOUT(void)
|
||||||
|
|
||||||
/* And again RTF mode writes the final end of para \r if it's part of the selection */
|
/* And again RTF mode writes the final end of para \r if it's part of the selection */
|
||||||
p = buf;
|
p = buf;
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF, (LPARAM)&es);
|
||||||
ok (count_pars(buf) == 2, "got %s\n", buf);
|
ok (count_pars(buf) == 2, "got %s\n", buf);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
p = buf;
|
p = buf;
|
||||||
SendMessageA(hwndRichEdit, EM_SETSEL, 0, 13);
|
SendMessageA(hwndRichEdit, EM_SETSEL, 0, 13);
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF|SFF_SELECTION, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF|SFF_SELECTION, (LPARAM)&es);
|
||||||
ok (count_pars(buf) == 1, "got %s\n", buf);
|
ok (count_pars(buf) == 1, "got %s\n", buf);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
p = buf;
|
p = buf;
|
||||||
SendMessageA(hwndRichEdit, EM_SETSEL, 0, -1);
|
SendMessageA(hwndRichEdit, EM_SETSEL, 0, -1);
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF|SFF_SELECTION, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_RTF|SFF_SELECTION, (LPARAM)&es);
|
||||||
ok (count_pars(buf) == 2, "got %s\n", buf);
|
ok (count_pars(buf) == 2, "got %s\n", buf);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
|
|
||||||
SendMessageA(hwndRichEdit, WM_SETTEXT, 0, (LPARAM)TestItem3);
|
SendMessageA(hwndRichEdit, WM_SETTEXT, 0, (LPARAM)TestItem3);
|
||||||
p = buf;
|
p = buf;
|
||||||
|
@ -3504,7 +3516,8 @@ static void test_EM_STREAMOUT(void)
|
||||||
es.dwError = 0;
|
es.dwError = 0;
|
||||||
es.pfnCallback = test_WM_SETTEXT_esCallback;
|
es.pfnCallback = test_WM_SETTEXT_esCallback;
|
||||||
memset(buf, 0, sizeof(buf));
|
memset(buf, 0, sizeof(buf));
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_TEXT, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_TEXT, (LPARAM)&es);
|
||||||
|
ok(result == streamout_written, "got %ld expected %d\n", result, streamout_written);
|
||||||
r = strlen(buf);
|
r = strlen(buf);
|
||||||
ok(r == 14, "streamed text length is %d, expecting 14\n", r);
|
ok(r == 14, "streamed text length is %d, expecting 14\n", r);
|
||||||
ok(strcmp(buf, TestItem3) == 0,
|
ok(strcmp(buf, TestItem3) == 0,
|
||||||
|
@ -3516,11 +3529,12 @@ static void test_EM_STREAMOUT(void)
|
||||||
es.dwError = 0;
|
es.dwError = 0;
|
||||||
es.pfnCallback = test_esCallback_written_1;
|
es.pfnCallback = test_esCallback_written_1;
|
||||||
memset(buf, 0, sizeof(buf));
|
memset(buf, 0, sizeof(buf));
|
||||||
SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_TEXT, (LPARAM)&es);
|
result = SendMessageA(hwndRichEdit, EM_STREAMOUT, SF_TEXT, (LPARAM)&es);
|
||||||
r = strlen(buf);
|
r = strlen(buf);
|
||||||
ok(r == 14, "streamed text length is %d, expecting 14\n", r);
|
ok(r == 14, "streamed text length is %d, expecting 14\n", r);
|
||||||
ok(strcmp(buf, TestItem3) == 0,
|
ok(strcmp(buf, TestItem3) == 0,
|
||||||
"streamed text different, got %s\n", buf);
|
"streamed text different, got %s\n", buf);
|
||||||
|
ok(result == 0, "got %ld expected 0\n", result);
|
||||||
|
|
||||||
|
|
||||||
DestroyWindow(hwndRichEdit);
|
DestroyWindow(hwndRichEdit);
|
||||||
|
|
|
@ -62,6 +62,8 @@ ME_StreamOutFlush(ME_OutStream *pStream)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
/* Don't resend partial chunks if nWritten < pStream->pos */
|
/* Don't resend partial chunks if nWritten < pStream->pos */
|
||||||
}
|
}
|
||||||
|
if (nWritten == pStream->pos)
|
||||||
|
pStream->written += nWritten;
|
||||||
pStream->pos = 0;
|
pStream->pos = 0;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue