riched20: WM_CONTEXTMENU fix for custom context menus

Mark Lu excelblue at doomedearth.ath.cx
Sat Sep 2 16:12:30 CDT 2006


This is a resubmission of a previously rejected patch with a few 
corrections.

Author: Hippocrates Sendoukas <hsendoukas at hotmail.com>
Submitter: Mark Lu <excelblue at gmail.com>

ChangeLog:
* Fixed context menu display for editors with custom context menus.

---
dlls/riched20/editor.c |   8 +++++++---
1 files changed, 5 insertions(+), 3 deletions(-)

diff --git a/dlls/riched20/editor.c b/dlls/riched20/editor.c
index fa43e1f..2b20377 100644
--- a/dlls/riched20/editor.c
+++ b/dlls/riched20/editor.c
@@ -1077,13 +1077,13 @@ ME_KeyDown(ME_TextEditor *editor, WORD n
  return FALSE;
}

-static void ME_ShowContextMenu(ME_TextEditor *editor, int x, int y)
+static BOOL ME_ShowContextMenu(ME_TextEditor *editor, int x, int y)
{
  CHARRANGE selrange;
  HMENU menu;
  int seltype = 0;
  if(!editor->lpOleCallback)
-    return;
+    return FALSE;
  ME_GetSelection(editor, (int *)&selrange.cpMin, (int *)&selrange.cpMax);
  if(selrange.cpMin == selrange.cpMax)
    seltype |= SEL_EMPTY;
@@ -1099,6 +1099,7 @@ static void ME_ShowContextMenu(ME_TextEd
    TrackPopupMenu(menu, TPM_LEFTALIGN | TPM_RIGHTBUTTON, x, y, 0, 
GetParent(editor->hWnd), NULL);
    DestroyMenu(menu);
  }
+  return TRUE;
}

ME_TextEditor *ME_MakeEditor(HWND hWnd) {
@@ -2335,7 +2336,10 @@ LRESULT WINAPI RichEditANSIWndProc(HWND     
ME_SelectWord(editor);
    break;
  case WM_CONTEXTMENU:
-    ME_ShowContextMenu(editor, (short)LOWORD(lParam), 
(short)HIWORD(lParam));
+    if (!ME_ShowContextMenu(editor, (short)LOWORD(lParam), 
(short)HIWORD(lParam)))
+    goto do_default;
    break;
  case WM_PAINT:
    if (editor->bRedraw)
-- 
1.4.1.1






More information about the wine-patches mailing list