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:
Jactry Zeng 2015-11-06 14:18:10 +08:00 committed by Alexandre Julliard
parent 36728f8b9e
commit dc6b2853f5
2 changed files with 26 additions and 10 deletions

View File

@ -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);

View File

@ -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;
} }