richedit: Set bEmulateVersion10 initially to avoid retroactive changes.

Previously the WM_NCCREATE was handled by the as if it was always for
later versions, then the window proc for version 1.0 would make
appropriate changes afterwards.  Instead both versions should call the
same function (e.g. ME_MakeEditor) and provide the value for
bEmulateVersion10 to make the code clearer.
This commit is contained in:
Dylan Smith 2009-01-11 02:59:31 -05:00 committed by Alexandre Julliard
parent 603be645d2
commit 8089d980d1
3 changed files with 21 additions and 23 deletions

View File

@ -2620,11 +2620,12 @@ static BOOL ME_ShowContextMenu(ME_TextEditor *editor, int x, int y)
return TRUE; return TRUE;
} }
ME_TextEditor *ME_MakeEditor(HWND hWnd) { ME_TextEditor *ME_MakeEditor(HWND hWnd, BOOL bEmulateVersion10)
{
ME_TextEditor *ed = ALLOC_OBJ(ME_TextEditor); ME_TextEditor *ed = ALLOC_OBJ(ME_TextEditor);
int i; int i;
ed->hWnd = hWnd; ed->hWnd = hWnd;
ed->bEmulateVersion10 = FALSE; ed->bEmulateVersion10 = bEmulateVersion10;
ed->pBuffer = ME_MakeText(); ed->pBuffer = ME_MakeText();
ed->nZoomNumerator = ed->nZoomDenominator = 0; ed->nZoomNumerator = ed->nZoomDenominator = 0;
ME_MakeFirstParagraph(ed); ME_MakeFirstParagraph(ed);
@ -2658,7 +2659,10 @@ ME_TextEditor *ME_MakeEditor(HWND hWnd) {
ed->nParagraphs = 1; ed->nParagraphs = 1;
ed->nLastSelStart = ed->nLastSelEnd = 0; ed->nLastSelStart = ed->nLastSelEnd = 0;
ed->pLastSelStartPara = ed->pLastSelEndPara = ME_FindItemFwd(ed->pBuffer->pFirst, diParagraph); ed->pLastSelStartPara = ed->pLastSelEndPara = ME_FindItemFwd(ed->pBuffer->pFirst, diParagraph);
ed->bWordWrap = (GetWindowLongW(hWnd, GWL_STYLE) & (WS_HSCROLL|ES_AUTOHSCROLL)) ? FALSE : TRUE; if (ed->bEmulateVersion10)
ed->bWordWrap = (GetWindowLongW(hWnd, GWL_STYLE) & ES_AUTOHSCROLL) ? FALSE : TRUE;
else
ed->bWordWrap = (GetWindowLongW(hWnd, GWL_STYLE) & (WS_HSCROLL|ES_AUTOHSCROLL)) ? FALSE : TRUE;
ed->bHideSelection = FALSE; ed->bHideSelection = FALSE;
ed->nInvalidOfs = -1; ed->nInvalidOfs = -1;
ed->pfnWordBreak = NULL; ed->pfnWordBreak = NULL;
@ -2915,8 +2919,8 @@ static LRESULT RichEditWndProc_common(HWND hWnd, UINT msg, WPARAM wParam,
if (msg == WM_NCCREATE) if (msg == WM_NCCREATE)
{ {
CREATESTRUCTW *pcs = (CREATESTRUCTW *)lParam; CREATESTRUCTW *pcs = (CREATESTRUCTW *)lParam;
TRACE("WM_NCCREATE: style 0x%08x\n", pcs->style); TRACE("WM_NCCREATE: hWnd %p style 0x%08x\n", hWnd, pcs->style);
editor = ME_MakeEditor(hWnd); editor = ME_MakeEditor(hWnd, FALSE);
SetWindowLongPtrW(hWnd, 0, (LONG_PTR)editor); SetWindowLongPtrW(hWnd, 0, (LONG_PTR)editor);
return TRUE; return TRUE;
} }
@ -4309,23 +4313,17 @@ LRESULT WINAPI RichEditANSIWndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lP
*/ */
LRESULT WINAPI RichEdit10ANSIWndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam) LRESULT WINAPI RichEdit10ANSIWndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
{ {
LRESULT result; if (msg == WM_NCCREATE && !GetWindowLongPtrW(hWnd, 0))
/* FIXME: this is NOT the same as 2.0 version */
result = RichEditANSIWndProc(hWnd, msg, wParam, lParam);
if (msg == WM_NCCREATE)
{ {
ME_TextEditor *editor = (ME_TextEditor *)GetWindowLongPtrW(hWnd, 0); ME_TextEditor *editor;
CREATESTRUCTW *pcs = (CREATESTRUCTW *)lParam;
TRACE("Emulating version 1.0 (hWnd=%p)\n", hWnd); TRACE("WM_NCCREATE: hWnd %p style 0x%08x\n", hWnd, pcs->style);
editor->bEmulateVersion10 = TRUE; editor = ME_MakeEditor(hWnd, TRUE);
editor->bWordWrap = (GetWindowLongW(hWnd, GWL_STYLE) & ES_AUTOHSCROLL) ? FALSE : TRUE; SetWindowLongPtrW(hWnd, 0, (LONG_PTR)editor);
editor->pBuffer->pLast->member.para.nCharOfs = 2; return TRUE;
assert(editor->pBuffer->pLast->prev->type == diRun);
assert(editor->pBuffer->pLast->prev->member.run.nFlags & MERF_ENDPARA);
editor->pBuffer->pLast->prev->member.run.nLF = 1;
} }
return result; return RichEditANSIWndProc(hWnd, msg, wParam, lParam);
} }
void ME_SendOldNotify(ME_TextEditor *editor, int nCode) void ME_SendOldNotify(ME_TextEditor *editor, int nCode)

View File

@ -269,7 +269,7 @@ void ME_CopyReObject(REOBJECT* dst, const REOBJECT* src);
void ME_DeleteReObject(REOBJECT* reo); void ME_DeleteReObject(REOBJECT* reo);
/* editor.c */ /* editor.c */
ME_TextEditor *ME_MakeEditor(HWND hWnd); ME_TextEditor *ME_MakeEditor(HWND hWnd, BOOL bEmulateVersion10);
void ME_DestroyEditor(ME_TextEditor *editor); void ME_DestroyEditor(ME_TextEditor *editor);
LRESULT ME_HandleMessage(ME_TextEditor *editor, UINT msg, WPARAM wParam, LRESULT ME_HandleMessage(ME_TextEditor *editor, UINT msg, WPARAM wParam,
LPARAM lParam, BOOL unicode, HRESULT* phresult); LPARAM lParam, BOOL unicode, HRESULT* phresult);

View File

@ -67,7 +67,7 @@ void ME_MakeFirstParagraph(ME_TextEditor *editor)
run = ME_MakeRun(style, ME_MakeString(wszParagraphSign), MERF_ENDPARA); run = ME_MakeRun(style, ME_MakeString(wszParagraphSign), MERF_ENDPARA);
run->member.run.nCharOfs = 0; run->member.run.nCharOfs = 0;
run->member.run.nCR = 1; run->member.run.nCR = 1;
run->member.run.nLF = (editor->bEmulateVersion10) ? 1 : 0; run->member.run.nLF = editor->bEmulateVersion10 ? 1 : 0;
ME_InsertBefore(text->pLast, para); ME_InsertBefore(text->pLast, para);
ME_InsertBefore(text->pLast, run); ME_InsertBefore(text->pLast, run);
@ -76,7 +76,7 @@ void ME_MakeFirstParagraph(ME_TextEditor *editor)
text->pFirst->member.para.next_para = para; text->pFirst->member.para.next_para = para;
text->pLast->member.para.prev_para = para; text->pLast->member.para.prev_para = para;
text->pLast->member.para.nCharOfs = 1; text->pLast->member.para.nCharOfs = editor->bEmulateVersion10 ? 2 : 1;
ME_DestroyContext(&c, editor->hWnd); ME_DestroyContext(&c, editor->hWnd);
} }