Add game-list callbacks
[xboard.git] / nengineoutput.c
index c925792..774d63a 100644 (file)
@@ -69,26 +69,9 @@ extern char *getenv();
 int  windowMode = 1;
 
 char *mem1, *mem2; // dummies, as this dialog can never be OK'ed
+static int currentPV, highTextStart[2], highTextEnd[2];
 
-void
-MemoProc (Option *opt, int n, int x, int y)
-{
-    static int pressed; // keep track of button 3 state
-    switch(n) {
-      case 0: // pointer motion
-       if(!pressed) return;
-//     MovePV(x, y, lineGap + BOARD_HEIGHT * (squareSize + lineGap));
-       break;
-      case 3: // press button 3
-       pressed = 1;
-       SelectPV(opt, x, y);
-       break;
-      case -3: // release button 3
-       pressed = 0;
-       StopPV(opt);
-       break;
-    }
-}
+int MemoProc P((Option *opt, int n, int x, int y, char *text, int index));
 
 Option engoutOptions[] = {
 {  0,  LL|T2T,           17, NULL, NULL, NULL, NULL, Label, " " },
@@ -107,6 +90,37 @@ Option engoutOptions[] = {
 {   0,      NO_OK,       0, NULL, NULL, "", NULL, EndMark , "" }
 };
 
+int
+MemoProc (Option *opt, int n, int x, int y, char *text, int index)
+{   // user callback for mouse events in memo
+    static int pressed; // keep track of button 3 state
+    int start, end, currentPV = (opt != &engoutOptions[5]);
+
+    switch(n) {
+      case 0: // pointer motion
+       if(!pressed) return FALSE; // only motion with button 3 down is of interest
+       MovePV(x, y, 500/*lineGap + BOARD_HEIGHT * (squareSize + lineGap)*/);
+       break;
+      case 3: // press button 3
+       pressed = 1;
+       if(LoadMultiPV(x, y, text, index, &start, &end, currentPV)) {
+           highTextStart[currentPV] = start; highTextEnd[currentPV] = end;
+           HighlightText(&engoutOptions[currentPV ? 12 : 5], start, end, TRUE);
+       }
+       break;
+      case -3: // release button 3
+       pressed = 0;
+        if(highTextStart[currentPV] != highTextEnd[currentPV])
+            HighlightText(&engoutOptions[currentPV ? 12 : 5], highTextStart[currentPV], highTextEnd[currentPV], FALSE);
+        highTextStart[currentPV] = highTextEnd[currentPV] = 0;
+        UnLoadPV();
+       break;
+      default:
+       return FALSE; // not meant for us; do regular event handler
+    }
+    return TRUE;
+}
+
 void
 SetIcon (int which, int field, int nIcon)
 {   // first call into xengineoutput.c to pick up icon pixmap
@@ -141,8 +155,8 @@ EngineOutputPopUp ()
     if (GenericPopUp(engoutOptions, _(title), EngOutDlg, BoardWindow, NONMODAL, 1)) {
        if(engoutOptions[STRIDE-1].type != Break)
            DisplayFatalError(_("Mismatch of STRIDE in nengineoutput.c\nChange and recompile!"), 0, 2);
-       AddHandler(&engoutOptions[MEMO], 6);
-       AddHandler(&engoutOptions[MEMO+STRIDE], 6);
+       AddHandler(&engoutOptions[MEMO], EngOutDlg, 6);
+       AddHandler(&engoutOptions[MEMO+STRIDE], EngOutDlg, 6);
        if( needInit ) {
            InitEngineOutput(&engoutOptions[0], &engoutOptions[MEMO]); // make icon bitmaps
            needInit = FALSE;