#include <X11/Intrinsic.h>
#include <X11/StringDefs.h>
#include <X11/Shell.h>
+#include <X11/Xatom.h>
#include <X11/Xaw/Dialog.h>
#include <X11/Xaw/Form.h>
#include <X11/Xaw/List.h>
# define N_(s) s
#endif
-extern void SendToProgram P((char *message, ChessProgramState *cps));
-FILE * XsraSelFile P((Widget w, char *prompt, char *ok, char *cancel, char *failed,
- char *init_path, char *mode, int (*show_entry)(), char **name_return));
-
-extern Widget formWidget, shellWidget, boardWidget, menuBarWidget;
-extern Display *xDisplay;
-extern int squareSize;
-extern Pixmap xMarkPixmap;
-extern char *layoutName;
-extern Window xBoardWindow;
-extern Arg layoutArgs[2], formArgs[2];
-Pixel timerForegroundPixel, timerBackgroundPixel;
-extern int searchTime;
-extern int lineGap;
-
// [HGM] the following code for makng menu popups was cloned from the FileNamePopUp routines
static Widget previous = NULL;
{
Arg args[2];
char *s;
+ int j;
if(previous) {
XtSetArg(args[0], XtNdisplayCaret, False);
}
XtSetArg(args[0], XtNstring, &s);
XtGetValues(w, args, 1);
+ j = 1;
XtSetArg(args[0], XtNdisplayCaret, True);
- XtSetArg(args[1], XtNinsertPosition, strlen(s));
- XtSetValues(w, args, 2);
+ if(!strchr(s, '\n') && strlen(s) < 80) XtSetArg(args[1], XtNinsertPosition, strlen(s)), j++;
+ XtSetValues(w, args, j);
XtSetKeyboardFocus((Widget) data, w);
previous = w;
}
-//--------------------------- New Shuffle Game --------------------------------------------
-extern int shuffleOpenings;
-extern int startedFromPositionFile;
-int shuffleUp;
-Widget shuffleShell;
-
-void ShufflePopDown()
-{
- if (!shuffleUp) return;
- XtPopdown(shuffleShell);
- XtDestroyWidget(shuffleShell);
- shuffleUp = False;
- ModeHighlight();
-}
-
-void ShuffleCallback(w, client_data, call_data)
- Widget w;
- XtPointer client_data, call_data;
-{
- String name;
- Widget w2;
- Arg args[16];
- char buf[MSG_SIZ];
+//--------------------------- Engine-specific options menu ----------------------------------
- XtSetArg(args[0], XtNlabel, &name);
- XtGetValues(w, args, 1);
+typedef void ButtonCallback(int n);
+typedef int OKCallback(int n);
- if (strcmp(name, _("cancel")) == 0) {
- ShufflePopDown();
- return;
- }
- if (strcmp(name, _("off")) == 0) {
- ShufflePopDown();
- shuffleOpenings = False; // [HGM] should be moved to New Variant menu, once we have it!
- ResetGameEvent();
- return;
- }
- if (strcmp(name, _("random")) == 0) {
- snprintf(buf, MSG_SIZ, "%d", rand());
- XtSetArg(args[0],XtNvalue, buf); // erase bad (non-numeric) value
- XtSetValues(XtParent(w), args, 1);
- return;
- }
- if (strcmp(name, _("ok")) == 0) {
- int nr; String name;
- name = XawDialogGetValueString(w2 = XtParent(w));
- if(sscanf(name ,"%d",&nr) != 1) {
- snprintf(buf, MSG_SIZ, "%d", appData.defaultFrcPosition);
- XtSetArg(args[0],XtNvalue, buf); // erase bad (non-numeric) value
- XtSetValues(w2, args, 1);
- return;
- }
- appData.defaultFrcPosition = nr;
- shuffleOpenings = True;
- ShufflePopDown();
- ResetGameEvent();
- return;
- }
-}
+int values[MAX_OPTIONS];
+ChessProgramState *currentCps;
+static Option *currentOption;
+static Boolean browserUp;
+ButtonCallback *comboCallback;
-void ShufflePopUp()
+void GetWidgetText(Option *opt, char **buf)
{
- Arg args[16];
- Widget popup, layout, dialog, edit;
- Window root, child;
- int x, y, i;
- int win_x, win_y;
- unsigned int mask;
- char def[MSG_SIZ];
-
- i = 0;
- XtSetArg(args[i], XtNresizable, True); i++;
- XtSetArg(args[i], XtNwidth, DIALOG_SIZE); i++;
- shuffleShell = popup =
- XtCreatePopupShell(_("New Shuffle Game"), transientShellWidgetClass,
- shellWidget, args, i);
-
- layout =
- XtCreateManagedWidget(layoutName, formWidgetClass, popup,
- layoutArgs, XtNumber(layoutArgs));
-
- snprintf(def, MSG_SIZ, "%d\n", appData.defaultFrcPosition);
- i = 0;
- XtSetArg(args[i], XtNlabel, _("Start-position number:")); i++;
- XtSetArg(args[i], XtNvalue, def); i++;
- XtSetArg(args[i], XtNborderWidth, 0); i++;
- dialog = XtCreateManagedWidget(_("Shuffle"), dialogWidgetClass,
- layout, args, i);
-
-// XtSetArg(args[0], XtNeditType, XawtextEdit); // [HGM] can't get edit to work decently
-// XtSetArg(args[1], XtNuseStringInPlace, False);
-// XtSetValues(dialog, args, 2);
-
- XawDialogAddButton(dialog, _("ok"), ShuffleCallback, (XtPointer) dialog);
- XawDialogAddButton(dialog, _("cancel"), ShuffleCallback, (XtPointer) dialog);
- XawDialogAddButton(dialog, _("random"), ShuffleCallback, (XtPointer) dialog);
- XawDialogAddButton(dialog, _("off"), ShuffleCallback, (XtPointer) dialog);
-
- XtRealizeWidget(popup);
- CatchDeleteWindow(popup, "ShufflePopDown");
-
- XQueryPointer(xDisplay, xBoardWindow, &root, &child,
- &x, &y, &win_x, &win_y, &mask);
-
- XtSetArg(args[0], XtNx, x - 10);
- XtSetArg(args[1], XtNy, y - 30);
- XtSetValues(popup, args, 2);
-
- XtPopup(popup, XtGrabExclusive);
- shuffleUp = True;
-
- edit = XtNameToWidget(dialog, "*value");
-
- XtSetKeyboardFocus(popup, edit);
+ Arg arg;
+ XtSetArg(arg, XtNstring, buf);
+ XtGetValues(opt->handle, &arg, 1);
}
-void ShuffleMenuProc(w, event, prms, nprms)
- Widget w;
- XEvent *event;
- String *prms;
- Cardinal *nprms;
+void SetWidgetText(Option *opt, char *buf, int n)
{
-// if (gameMode == AnalyzeMode || gameMode == AnalyzeFile) {
-// Reset(FALSE, TRUE);
-// }
- ShufflePopUp();
+ Arg arg;
+ XtSetArg(arg, XtNstring, buf);
+ XtSetValues(opt->handle, &arg, 1);
+ SetFocus(opt->handle, shells[n], NULL, False);
}
-//--------------------------- Time-Control Menu Popup ----------------------------------
-int TimeControlUp;
-Widget TimeControlShell;
-int tcInc;
-Widget tcMess1, tcMess2, tcData, tcTime, tcOdds1, tcOdds2;
-int tcIncrement, tcMoves;
-
-void TimeControlPopDown()
+void SetWidgetState(Option *opt, int state)
{
- if (!TimeControlUp) return;
- previous = NULL;
- XtPopdown(TimeControlShell);
- XtDestroyWidget(TimeControlShell);
- TimeControlUp = False;
- ModeHighlight();
+ Arg arg;
+ XtSetArg(arg, XtNstate, state);
+ XtSetValues(opt->handle, &arg, 1);
}
-void TimeControlCallback(w, client_data, call_data)
- Widget w;
- XtPointer client_data, call_data;
+void CheckCallback(Widget ww, XtPointer data, XEvent *event, Boolean *b)
{
- String name, txt;
+ Widget w = currentOption[(int)(intptr_t)data].handle;
+ Boolean s;
Arg args[16];
- char buf[MSG_SIZ];
- int j;
- XtSetArg(args[0], XtNlabel, &name);
+ XtSetArg(args[0], XtNstate, &s);
XtGetValues(w, args, 1);
-
- if (strcmp(name, _("classical")) == 0) {
- if(tcInc == 0) return;
- j=0;
- XtSetArg(args[j], XtNlabel, _("minutes for each")); j++;
- XtSetValues(tcMess1, args, j);
- j=0;
- XtSetArg(args[j], XtNlabel, _("moves")); j++;
- XtSetValues(tcMess2, args, j);
- if(tcInc == 1) {
- j=0;
- XtSetArg(args[j], XtNstring, &name); j++;
- XtGetValues(tcData, args, j);
- tcIncrement = 0; sscanf(name, "%d", &tcIncrement);
- }
- snprintf(buf, MSG_SIZ, "%d", tcMoves);
- j=0;
- XtSetArg(args[j], XtNstring, buf); j++;
- XtSetValues(tcData, args, j);
- tcInc = 0;
- return;
- }
- if (strcmp(name, _("incremental")) == 0) {
- if(tcInc == 1) return;
- j=0;
- XtSetArg(args[j], XtNlabel, _("minutes, plus")); j++;
- XtSetValues(tcMess1, args, j);
- j=0;
- XtSetArg(args[j], XtNlabel, _("sec/move")); j++;
- XtSetValues(tcMess2, args, j);
- if(tcInc == 0) {
- j=0;
- XtSetArg(args[j], XtNstring, &name); j++;
- XtGetValues(tcData, args, j);
- tcMoves = appData.movesPerSession; sscanf(name, "%d", &tcMoves);
- }
- snprintf(buf, MSG_SIZ, "%d", tcIncrement);
- j=0;
- XtSetArg(args[j], XtNstring, buf); j++;
- XtSetValues(tcData, args, j);
- tcInc = 1;
- return;
- }
- if (strcmp(name, _("fixed time")) == 0) {
- if(tcInc == 2) return;
- j=0;
- XtSetArg(args[j], XtNlabel, _("sec/move (max)")); j++;
- XtSetValues(tcMess1, args, j);
- j=0;
- XtSetArg(args[j], XtNlabel, _("")); j++;
- XtSetValues(tcMess2, args, j);
- j=0;
- XtSetArg(args[j], XtNstring, ""); j++;
- XtSetValues(tcData, args, j);
- tcInc = 2;
- return;
- }
- if (strcmp(name, _(" OK ")) == 0) {
- int inc, mps, ok;
- XtSetArg(args[0], XtNstring, &txt);
- XtGetValues(tcData, args, 1);
- switch(tcInc) {
- case 1:
- ok = sscanf(txt, "%d", &inc); mps = 0;
- if(!ok && txt[0] == 0) { inc = 0; ok = 1; } // accept empty string as zero
- ok &= (inc >= 0);
- break;
- case 0:
- ok = sscanf(txt, "%d", &mps); inc = -1;
- ok &= (mps > 0);
- break;
- case 2:
- ok = 1; inc = -1; mps = 40;
- }
- if(ok != 1) {
- XtSetArg(args[0], XtNstring, ""); // erase any offending input
- XtSetValues(tcData, args, 1);
- return;
- }
- XtSetArg(args[0], XtNstring, &txt);
- XtGetValues(tcTime, args, 1);
- if(tcInc == 2) {
- if(sscanf(txt, "%d", &inc) != 1) {
- XtSetArg(args[0], XtNstring, ""); // erase any offending input
- XtSetValues(tcTime, args, 1);
- DisplayError(_("Bad Time-Control String"), 0);
- return;
- }
- searchTime = inc;
- } else {
- if(!ParseTimeControl(txt, inc, mps)) {
- XtSetArg(args[0], XtNstring, ""); // erase any offending input
- XtSetValues(tcTime, args, 1);
- DisplayError(_("Bad Time-Control String"), 0);
- return;
- }
- searchTime = 0;
- appData.movesPerSession = mps;
- appData.timeIncrement = inc;
- appData.timeControl = strdup(txt);
- }
- XtSetArg(args[0], XtNstring, &txt);
- XtGetValues(tcOdds1, args, 1);
- appData.firstTimeOdds = first.timeOdds
- = (sscanf(txt, "%d", &j) == 1 && j > 0) ? j : 1;
- XtGetValues(tcOdds2, args, 1);
- appData.secondTimeOdds = second.timeOdds
- = (sscanf(txt, "%d", &j) == 1 && j > 0) ? j : 1;
-
- Reset(True, True);
- TimeControlPopDown();
- return;
- }
-}
-
-void TimeControlPopUp()
-{
- Arg args[16];
- Widget popup, layout, form, b_ok, b_cancel, b_clas, b_inc, mess;
- Window root, child;
- int x, y, i, j;
- int win_x, win_y;
- unsigned int mask;
- char def[MSG_SIZ];
-
- tcInc = searchTime > 0 ? 2 : (appData.timeIncrement >= 0);
- tcMoves = appData.movesPerSession; tcIncrement = appData.timeIncrement;
- if(!tcInc) tcIncrement = 0;
- snprintf(def, MSG_SIZ, "%d", tcInc ? tcIncrement : tcMoves);
-
- i = 0;
- XtSetArg(args[i], XtNresizable, True); i++;
-// XtSetArg(args[i], XtNwidth, DIALOG_SIZE); i++;
- TimeControlShell = popup =
- XtCreatePopupShell(_("TimeControl Menu"), transientShellWidgetClass,
- shellWidget, args, i);
-
- layout =
- XtCreateManagedWidget(layoutName, formWidgetClass, popup,
- layoutArgs, XtNumber(layoutArgs));
-
- form =
- XtCreateManagedWidget(layoutName, formWidgetClass, layout,
- formArgs, XtNumber(formArgs));
-
- j = 0;
-// XtSetArg(args[j], XtNwidth, (XtArgVal) 300); j++;
-// XtSetArg(args[j], XtNheight, (XtArgVal) 85); j++;
- XtSetValues(popup, args, j);
-
- j= 0;
- XtSetArg(args[j], XtNborderWidth, 1); j++;
- XtSetArg(args[j], XtNeditType, XawtextEdit); j++;
- XtSetArg(args[j], XtNuseStringInPlace, False); j++;
- XtSetArg(args[j], XtNstring, appData.timeControl); j++;
- XtSetArg(args[j], XtNdisplayCaret, False); j++;
- XtSetArg(args[j], XtNtop, XtChainTop); j++;
- XtSetArg(args[j], XtNbottom, XtChainTop); j++;
- XtSetArg(args[j], XtNleft, XtChainLeft); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
- XtSetArg(args[j], XtNresizable, True); j++;
- XtSetArg(args[j], XtNwidth, 85); j++;
- XtSetArg(args[j], XtNinsertPosition, 9999); j++;
- tcTime = XtCreateManagedWidget("TC", asciiTextWidgetClass, form, args, j);
- XtAddEventHandler(tcTime, ButtonPressMask, False, SetFocus, (XtPointer) popup);
-
- j= 0;
- XtSetArg(args[j], XtNlabel, tcInc ? tcInc == 2 ? _("sec/move (max) ") : _(" minutes, plus ") : _("minutes for each")); j++;
- XtSetArg(args[j], XtNborderWidth, 0); j++;
- XtSetArg(args[j], XtNfromHoriz, tcTime); j++;
- XtSetArg(args[j], XtNtop, XtChainTop); j++;
- XtSetArg(args[j], XtNbottom, XtChainTop); j++;
- XtSetArg(args[j], XtNleft, XtChainRight); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
- // XtSetArg(args[j], XtNwidth, 100); j++;
- // XtSetArg(args[j], XtNheight, 20); j++;
- tcMess1 = XtCreateManagedWidget("TCtext", labelWidgetClass, form, args, j);
-
- j= 0;
- XtSetArg(args[j], XtNborderWidth, 1); j++;
- XtSetArg(args[j], XtNfromHoriz, tcMess1); j++;
- XtSetArg(args[j], XtNeditType, XawtextEdit); j++;
- XtSetArg(args[j], XtNuseStringInPlace, False); j++;
- XtSetArg(args[j], XtNstring, def); j++;
- XtSetArg(args[j], XtNdisplayCaret, False); j++;
- XtSetArg(args[j], XtNtop, XtChainTop); j++;
- XtSetArg(args[j], XtNbottom, XtChainTop); j++;
- XtSetArg(args[j], XtNleft, XtChainRight); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
- XtSetArg(args[j], XtNresizable, True); j++;
- XtSetArg(args[j], XtNwidth, 40); j++;
-// XtSetArg(args[j], XtNheight, 20); j++;
- tcData = XtCreateManagedWidget("MPS", asciiTextWidgetClass, form, args, j);
- XtAddEventHandler(tcData, ButtonPressMask, False, SetFocus, (XtPointer) popup);
-
- j= 0;
- XtSetArg(args[j], XtNlabel, tcInc ? tcInc == 2 ? _(" ") : _("sec/move") : _("moves ")); j++;
- XtSetArg(args[j], XtNjustify, XtJustifyLeft); j++;
- XtSetArg(args[j], XtNborderWidth, 0); j++;
- XtSetArg(args[j], XtNfromHoriz, tcData); j++;
- XtSetArg(args[j], XtNtop, XtChainTop); j++;
- XtSetArg(args[j], XtNbottom, XtChainTop); j++;
- XtSetArg(args[j], XtNleft, XtChainRight); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
-// XtSetArg(args[j], XtNwidth, 80); j++;
-// XtSetArg(args[j], XtNheight, 20); j++;
- tcMess2 = XtCreateManagedWidget("MPStext", labelWidgetClass,
- form, args, j);
-
- j= 0;
- XtSetArg(args[j], XtNborderWidth, 1); j++;
- XtSetArg(args[j], XtNfromVert, tcTime); j++;
- XtSetArg(args[j], XtNeditType, XawtextEdit); j++;
- XtSetArg(args[j], XtNuseStringInPlace, False); j++;
- XtSetArg(args[j], XtNstring, "1"); j++;
- XtSetArg(args[j], XtNdisplayCaret, False); j++;
- XtSetArg(args[j], XtNtop, XtChainTop); j++;
- XtSetArg(args[j], XtNbottom, XtChainTop); j++;
- XtSetArg(args[j], XtNleft, XtChainLeft); j++;
- XtSetArg(args[j], XtNright, XtChainLeft); j++;
- XtSetArg(args[j], XtNresizable, True); j++;
- XtSetArg(args[j], XtNwidth, 40); j++;
-// XtSetArg(args[j], XtNheight, 20); j++;
- tcOdds1 = XtCreateManagedWidget("Odds1", asciiTextWidgetClass, form, args, j);
- XtAddEventHandler(tcOdds1, ButtonPressMask, False, SetFocus, (XtPointer) popup);
-
- j= 0;
- XtSetArg(args[j], XtNborderWidth, 1); j++;
- XtSetArg(args[j], XtNfromVert, tcTime); j++;
- XtSetArg(args[j], XtNfromHoriz, tcOdds1); j++;
- XtSetArg(args[j], XtNeditType, XawtextEdit); j++;
- XtSetArg(args[j], XtNuseStringInPlace, False); j++;
- XtSetArg(args[j], XtNstring, "1"); j++;
- XtSetArg(args[j], XtNdisplayCaret, False); j++;
- XtSetArg(args[j], XtNtop, XtChainTop); j++;
- XtSetArg(args[j], XtNbottom, XtChainTop); j++;
- XtSetArg(args[j], XtNleft, XtChainLeft); j++;
- XtSetArg(args[j], XtNright, XtChainLeft); j++;
- XtSetArg(args[j], XtNresizable, True); j++;
- XtSetArg(args[j], XtNwidth, 40); j++;
-// XtSetArg(args[j], XtNheight, 20); j++;
- tcOdds2 = XtCreateManagedWidget("Odds2", asciiTextWidgetClass, form, args, j);
- XtAddEventHandler(tcOdds2, ButtonPressMask, False, SetFocus, (XtPointer) popup);
-
- j= 0;
- XtSetArg(args[j], XtNlabel, _("Engine #1 and #2 Time-Odds Factors")); j++;
- XtSetArg(args[j], XtNjustify, XtJustifyLeft); j++;
- XtSetArg(args[j], XtNborderWidth, 0); j++;
- XtSetArg(args[j], XtNfromVert, tcTime); j++;
- XtSetArg(args[j], XtNfromHoriz, tcOdds2); j++;
- XtSetArg(args[j], XtNtop, XtChainTop); j++;
- XtSetArg(args[j], XtNbottom, XtChainTop); j++;
- XtSetArg(args[j], XtNleft, XtChainLeft); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
-// XtSetArg(args[j], XtNwidth, 200); j++;
-// XtSetArg(args[j], XtNheight, 20); j++;
- mess = XtCreateManagedWidget("Oddstext", labelWidgetClass,
- form, args, j);
- j=0;
- XtSetArg(args[j], XtNfromVert, tcOdds1); j++;
- XtSetArg(args[j], XtNbottom, XtChainBottom); j++;
- XtSetArg(args[j], XtNtop, XtChainBottom); j++;
- XtSetArg(args[j], XtNleft, XtChainLeft); j++;
- XtSetArg(args[j], XtNright, XtChainLeft); j++;
- XtSetArg(args[j], XtNstate, tcInc==0); j++;
- b_clas= XtCreateManagedWidget(_("classical"), toggleWidgetClass,
- form, args, j);
- XtAddCallback(b_clas, XtNcallback, TimeControlCallback, (XtPointer) 0);
-
- j=0;
- XtSetArg(args[j], XtNradioGroup, b_clas); j++;
- XtSetArg(args[j], XtNfromVert, tcOdds1); j++;
- XtSetArg(args[j], XtNfromHoriz, b_clas); j++;
- XtSetArg(args[j], XtNbottom, XtChainBottom); j++;
- XtSetArg(args[j], XtNtop, XtChainBottom); j++;
- XtSetArg(args[j], XtNleft, XtChainLeft); j++;
- XtSetArg(args[j], XtNright, XtChainLeft); j++;
- XtSetArg(args[j], XtNstate, tcInc==1); j++;
- b_inc = XtCreateManagedWidget(_("incremental"), toggleWidgetClass,
- form, args, j);
- XtAddCallback(b_inc, XtNcallback, TimeControlCallback, (XtPointer) 0);
-
- j=0;
- XtSetArg(args[j], XtNradioGroup, b_inc); j++;
- XtSetArg(args[j], XtNfromVert, tcOdds1); j++;
- XtSetArg(args[j], XtNfromHoriz, b_inc); j++;
- XtSetArg(args[j], XtNbottom, XtChainBottom); j++;
- XtSetArg(args[j], XtNtop, XtChainBottom); j++;
- XtSetArg(args[j], XtNleft, XtChainLeft); j++;
- XtSetArg(args[j], XtNright, XtChainLeft); j++;
- XtSetArg(args[j], XtNstate, tcInc==2); j++;
- b_inc = XtCreateManagedWidget(_("fixed time"), toggleWidgetClass,
- form, args, j);
- XtAddCallback(b_inc, XtNcallback, TimeControlCallback, (XtPointer) 0);
-
- j=0;
- XtSetArg(args[j], XtNfromVert, tcOdds1); j++;
- XtSetArg(args[j], XtNfromHoriz, tcData); j++;
- XtSetArg(args[j], XtNbottom, XtChainBottom); j++;
- XtSetArg(args[j], XtNtop, XtChainBottom); j++;
- XtSetArg(args[j], XtNleft, XtChainRight); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
- b_ok= XtCreateManagedWidget(_(" OK "), commandWidgetClass,
- form, args, j);
- XtAddCallback(b_ok, XtNcallback, TimeControlCallback, (XtPointer) 0);
-
- j=0;
- XtSetArg(args[j], XtNfromVert, tcOdds1); j++;
- XtSetArg(args[j], XtNfromHoriz, b_ok); j++;
- XtSetArg(args[j], XtNbottom, XtChainBottom); j++;
- XtSetArg(args[j], XtNtop, XtChainBottom); j++;
- XtSetArg(args[j], XtNleft, XtChainRight); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
- b_cancel= XtCreateManagedWidget(_("cancel"), commandWidgetClass,
- form, args, j);
- XtAddCallback(b_cancel, XtNcallback, TimeControlPopDown, (XtPointer) 0);
-
- XtRealizeWidget(popup);
- CatchDeleteWindow(popup, "TimeControlPopDown");
-
- XQueryPointer(xDisplay, xBoardWindow, &root, &child,
- &x, &y, &win_x, &win_y, &mask);
-
- XtSetArg(args[0], XtNx, x - 10);
- XtSetArg(args[1], XtNy, y - 30);
- XtSetValues(popup, args, 2);
-
- XtPopup(popup, XtGrabExclusive);
- TimeControlUp = True;
-
- previous = NULL;
- SetFocus(tcTime, popup, (XEvent*) NULL, False);
-// XtSetKeyboardFocus(popup, tcTime);
-}
-
-void TimeControlProc(w, event, prms, nprms)
- Widget w;
- XEvent *event;
- String *prms;
- Cardinal *nprms;
-{
- TimeControlPopUp();
-}
-
-//--------------------------- Engine-specific options menu ----------------------------------
-
-int SettingsUp;
-Widget SettingsShell;
-int values[MAX_OPTIONS];
-ChessProgramState *currentCps;
-
-void SettingsPopDown()
-{
- if (!SettingsUp) return;
- previous = NULL;
- XtPopdown(SettingsShell);
- XtDestroyWidget(SettingsShell);
- SettingsUp = False;
- ModeHighlight();
+ SetWidgetState(¤tOption[(int)(intptr_t)data], !s);
}
void SpinCallback(w, client_data, call_data)
String name, val;
Arg args[16];
char buf[MSG_SIZ], *p;
- int j;
+ int j = 0; // Initialiasation is necessary because the text value may be non-numeric causing the scanf conversion to fail
int data = (intptr_t) client_data;
XtSetArg(args[0], XtNlabel, &name);
XtGetValues(w, args, 1);
- j = 0;
- XtSetArg(args[0], XtNstring, &val);
- XtGetValues(currentCps->option[data].handle, args, 1);
+ GetWidgetText(¤tOption[data], &val);
sscanf(val, "%d", &j);
- if (strcmp(name, "browse") == 0) {
- if(XsraSelFile(SettingsShell, currentCps->option[data].name, NULL, NULL, "", "",
- currentCps->option[data].type == PathName ? "p" : "f", NULL, &p)) {
+ if (strcmp(name, _("browse")) == 0) {
+ char *q=val, *r;
+ for(r = ""; *q; q++) if(*q == '.') r = q; else if(*q == '/') r = ""; // last dot after last slash
+ if(!strcmp(r, "") && !currentCps && currentOption[data].type == FileName && currentOption[data].textValue)
+ r = currentOption[data].textValue;
+ browserUp = True;
+ if(XsraSelFile(shells[0], currentOption[data].name, NULL, NULL, "", "", r,
+ currentOption[data].type == PathName ? "p" : "f", NULL, &p)) {
int len = strlen(p);
if(len && p[len-1] == '/') p[len-1] = NULLCHAR;
XtSetArg(args[0], XtNstring, p);
- XtSetValues(currentCps->option[data].handle, args, 1);
+ XtSetValues(currentOption[data].handle, args, 1);
}
- SetFocus(currentCps->option[data].handle, SettingsShell, (XEvent*) NULL, False);
+ browserUp = False;
+ SetFocus(currentOption[data].handle, shells[0], (XEvent*) NULL, False);
return;
} else
if (strcmp(name, "+") == 0) {
- if(++j > currentCps->option[data].max) return;
+ if(++j > currentOption[data].max) return;
} else
if (strcmp(name, "-") == 0) {
- if(--j < currentCps->option[data].min) return;
+ if(--j < currentOption[data].min) return;
} else return;
snprintf(buf, MSG_SIZ, "%d", j);
- XtSetArg(args[0], XtNstring, buf);
- XtSetValues(currentCps->option[data].handle, args, 1);
-}
-
-void SettingsCallback(w, client_data, call_data)
- Widget w;
- XtPointer client_data, call_data;
-{
- String name, val;
- Arg args[16];
- char buf[MSG_SIZ];
- int i, j;
- int data = (intptr_t) client_data;
-
- XtSetArg(args[0], XtNlabel, &name);
- XtGetValues(w, args, 1);
-
- if (strcmp(name, _("cancel")) == 0) {
- SettingsPopDown();
- return;
- }
- if (strcmp(name, _("OK")) == 0 || data) { // save buttons imply OK
- for(i=0; i<currentCps->nrOptions; i++) { // send all options that had to be OK-ed to engine
- switch(currentCps->option[i].type) {
- case TextBox:
- XtSetArg(args[0], XtNstring, &val);
- XtGetValues(currentCps->option[i].handle, args, 1);
- if(strcmp(currentCps->option[i].textValue, val)) {
- safeStrCpy(currentCps->option[i].textValue, val, MSG_SIZ - (currentCps->option[i].textValue - currentCps->option[i].name) );
- snprintf(buf, MSG_SIZ, "option %s=%s\n", currentCps->option[i].name, val);
- SendToProgram(buf, currentCps);
- }
- break;
- case Spin:
- XtSetArg(args[0], XtNstring, &val);
- XtGetValues(currentCps->option[i].handle, args, 1);
- sscanf(val, "%d", &j);
- if(j > currentCps->option[i].max) j = currentCps->option[i].max;
- if(j < currentCps->option[i].min) j = currentCps->option[i].min;
- if(currentCps->option[i].value != j) {
- currentCps->option[i].value = j;
- snprintf(buf, MSG_SIZ, "option %s=%d\n", currentCps->option[i].name, j);
- SendToProgram(buf, currentCps);
- }
- break;
- case CheckBox:
- j = 0;
- XtSetArg(args[0], XtNstate, &j);
- XtGetValues(currentCps->option[i].handle, args, 1);
- if(currentCps->option[i].value != j) {
- currentCps->option[i].value = j;
- snprintf(buf, MSG_SIZ, "option %s=%d\n", currentCps->option[i].name, j);
- SendToProgram(buf, currentCps);
- }
- break;
- case ComboBox:
- if(currentCps->option[i].value != values[i]) {
- currentCps->option[i].value = values[i];
- snprintf(buf, MSG_SIZ, "option %s=%s\n", currentCps->option[i].name,
- ((char**)currentCps->option[i].textValue)[values[i]]);
- SendToProgram(buf, currentCps);
- }
- break;
- default:
- if( appData.debugMode )
- fprintf(debugFP, "SettingsPopUp: unexpected case in switch.\n");
- break;
- }
- }
- if(data) { // send save-button command to engine
- snprintf(buf, MSG_SIZ, "option %s\n", name);
- SendToProgram(buf, currentCps);
- }
- SettingsPopDown();
- return;
- }
- snprintf(buf, MSG_SIZ, "option %s\n", name);
- SendToProgram(buf, currentCps);
+ SetWidgetText(¤tOption[data], buf, 0);
}
void ComboSelect(w, addr, index) // callback for all combo items
int j = 255 & (intptr_t) addr;
values[i] = j; // store in temporary, for transfer at OK
- XtSetArg(args[0], XtNlabel, ((char**)currentCps->option[i].textValue)[j]);
- XtSetValues(currentCps->option[i].handle, args, 1);
+
+ if(currentOption[i].min & NO_GETTEXT)
+ XtSetArg(args[0], XtNlabel, ((char**)currentOption[i].textValue)[j]);
+ else
+ XtSetArg(args[0], XtNlabel, _(((char**)currentOption[i].textValue)[j]));
+
+ XtSetValues(currentOption[i].handle, args, 1);
+
+ if(currentOption[i].min & COMBO_CALLBACK && !currentCps && comboCallback) (comboCallback)(i);
}
-void CreateComboPopup(parent, name, n, mb)
+void CreateComboPopup(parent, option, n)
Widget parent;
- String name;
+ Option *option;
int n;
- char *mb[];
{
int i=0, j;
Widget menu, entry;
Arg args[16];
- menu = XtCreatePopupShell(name, simpleMenuWidgetClass,
+ menu = XtCreatePopupShell(option->name, simpleMenuWidgetClass,
parent, NULL, 0);
j = 0;
XtSetArg(args[j], XtNwidth, 100); j++;
// XtSetArg(args[j], XtNright, XtChainRight); j++;
- while (mb[i] != NULL) {
- entry = XtCreateManagedWidget(mb[i], smeBSBObjectClass,
- menu, args, j);
- XtAddCallback(entry, XtNcallback,
- (XtCallbackProc) ComboSelect,
- (caddr_t)(intptr_t) (256*n+i));
+ char **mb = (char **) option->textValue;
+ while (mb[i] != NULL)
+ {
+ if (option->min & NO_GETTEXT)
+ XtSetArg(args[j], XtNlabel, mb[i]);
+ else
+ XtSetArg(args[j], XtNlabel, _(mb[i]));
+ entry = XtCreateManagedWidget((String) mb[i], smeBSBObjectClass,
+ menu, args, j+1);
+ XtAddCallback(entry, XtNcallback,
+ (XtCallbackProc) ComboSelect,
+ (caddr_t)(intptr_t) (256*n+i));
i++;
- }
+ }
}
-void
-SettingsPopUp(ChessProgramState *cps)
-{
- Arg args[16];
- Widget popup, layout, dialog, edit=NULL, form, last, b_ok, b_cancel, leftMargin = NULL, textField = NULL;
- Window root, child;
- int x, y, i, j, height, width, h, c;
- int win_x, win_y, maxWidth, maxTextWidth;
- unsigned int mask;
- char def[MSG_SIZ];
- static char pane[6] = "paneX";
- Widget texts[100], forelast = NULL, anchor, widest;
-
- // to do: start up second engine if needed
- if(!cps->initDone || !cps->nrOptions) return; // nothing to be done
- currentCps = cps;
-
- if(cps->nrOptions > 50) width = 4; else if(cps->nrOptions>24) width = 2; else width = 1;
- height = cps->nrOptions / width + 1;
- i = 0;
- XtSetArg(args[i], XtNresizable, True); i++;
- SettingsShell = popup =
- XtCreatePopupShell(_("Settings Menu"), transientShellWidgetClass,
- shellWidget, args, i);
-
- layout =
- XtCreateManagedWidget(layoutName, formWidgetClass, popup,
- layoutArgs, XtNumber(layoutArgs));
- for(c=0; c<width; c++) {
- pane[4] = 'A'+c;
- form =
- XtCreateManagedWidget(pane, formWidgetClass, layout,
- formArgs, XtNumber(formArgs));
- j=0;
- XtSetArg(args[j], XtNfromHoriz, leftMargin); j++;
- XtSetValues(form, args, j);
- leftMargin = form;
-
- last = widest = NULL; anchor = forelast;
- for(h=0; h<height; h++) {
- forelast = last;
- i = h + c*height;
- if(i >= cps->nrOptions) break;
- switch(cps->option[i].type) {
- case Spin:
- snprintf(def, MSG_SIZ, "%d", cps->option[i].value);
- case TextBox:
- j=0;
- XtSetArg(args[j], XtNfromVert, last); j++;
- XtSetArg(args[j], XtNborderWidth, 0); j++;
- XtSetArg(args[j], XtNjustify, XtJustifyLeft); j++;
- texts[h] =
- dialog = XtCreateManagedWidget(cps->option[i].name, labelWidgetClass, form, args, j);
- j=0;
- XtSetArg(args[j], XtNfromVert, last); j++;
- XtSetArg(args[j], XtNfromHoriz, dialog); j++;
- XtSetArg(args[j], XtNborderWidth, 1); j++;
- XtSetArg(args[j], XtNwidth, cps->option[i].type == Spin ? 40 : 175); j++;
- XtSetArg(args[j], XtNeditType, XawtextEdit); j++;
- XtSetArg(args[j], XtNuseStringInPlace, False); j++;
- XtSetArg(args[j], XtNdisplayCaret, False); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
- XtSetArg(args[j], XtNresizable, True); j++;
- XtSetArg(args[j], XtNstring, cps->option[i].type==Spin ? def : cps->option[i].textValue); j++;
- XtSetArg(args[j], XtNinsertPosition, 9999); j++;
- edit = last;
- cps->option[i].handle = (void*)
- (textField = last = XtCreateManagedWidget("text", asciiTextWidgetClass, form, args, j));
- XtAddEventHandler(last, ButtonPressMask, False, SetFocus, (XtPointer) popup);
- if(cps->option[i].type == TextBox) break;
- // add increment and decrement controls for spin
- j=0;
- XtSetArg(args[j], XtNfromVert, edit); j++;
- XtSetArg(args[j], XtNfromHoriz, last); j++;
- XtSetArg(args[j], XtNheight, 10); j++;
- XtSetArg(args[j], XtNwidth, 20); j++;
- edit = XtCreateManagedWidget("+", commandWidgetClass, form, args, j);
- XtAddCallback(edit, XtNcallback, SpinCallback,
- (XtPointer)(intptr_t) i);
+//----------------------------Generic dialog --------------------------------------------
- j=0;
- XtSetArg(args[j], XtNfromVert, edit); j++;
- XtSetArg(args[j], XtNfromHoriz, last); j++;
- XtSetArg(args[j], XtNheight, 10); j++;
- XtSetArg(args[j], XtNwidth, 20); j++;
- last = XtCreateManagedWidget("-", commandWidgetClass, form, args, j);
- XtAddCallback(last, XtNcallback, SpinCallback,
- (XtPointer)(intptr_t) i);
- break;
- case CheckBox:
- j=0;
- XtSetArg(args[j], XtNfromVert, last); j++;
- XtSetArg(args[j], XtNwidth, 10); j++;
- XtSetArg(args[j], XtNheight, 10); j++;
- XtSetArg(args[j], XtNstate, cps->option[i].value); j++;
- cps->option[i].handle = (void*)
- (dialog = XtCreateManagedWidget(" ", toggleWidgetClass, form, args, j));
- j=0;
- XtSetArg(args[j], XtNfromVert, last); j++;
- XtSetArg(args[j], XtNfromHoriz, dialog); j++;
- XtSetArg(args[j], XtNborderWidth, 0); j++;
- XtSetArg(args[j], XtNjustify, XtJustifyLeft); j++;
- last = XtCreateManagedWidget(cps->option[i].name, labelWidgetClass, form, args, j);
- break;
- case SaveButton:
- case Button:
- j=0;
- XtSetArg(args[j], XtNfromVert, last); j++;
- XtSetArg(args[j], XtNstate, cps->option[i].value); j++;
- cps->option[i].handle = (void*)
- (dialog = last = XtCreateManagedWidget(cps->option[i].name, commandWidgetClass, form, args, j));
- XtAddCallback(last, XtNcallback, SettingsCallback,
- (XtPointer)(intptr_t) (cps->option[i].type == SaveButton));
- break;
- case ComboBox:
- j=0;
- XtSetArg(args[j], XtNfromVert, last); j++;
- XtSetArg(args[j], XtNborderWidth, 0); j++;
- XtSetArg(args[j], XtNjustify, XtJustifyLeft); j++;
- dialog = XtCreateManagedWidget(cps->option[i].name, labelWidgetClass, form, args, j);
+// cloned from Engine Settings dialog (and later merged with it)
- j=0;
- XtSetArg(args[j], XtNfromVert, last); j++;
- XtSetArg(args[j], XtNfromHoriz, dialog); j++;
- XtSetArg(args[j], XtNwidth, 100); j++;
- XtSetArg(args[j], XtNmenuName, XtNewString(cps->option[i].name)); j++;
- XtSetArg(args[j], XtNlabel, ((char**)cps->option[i].textValue)[cps->option[i].value]); j++;
- cps->option[i].handle = (void*)
- (last = XtCreateManagedWidget(" ", menuButtonWidgetClass, form, args, j));
- CreateComboPopup(last, cps->option[i].name, i, (char **) cps->option[i].textValue);
- values[i] = cps->option[i].value;
- break;
- default:
- if( appData.debugMode )
- fprintf(debugFP, "SettingsPopUp: unexpected case in switch.\n");
- break;
- }
- }
+extern WindowPlacement wpComment, wpTags, wpMoveHistory;
+char *trialSound;
+static int oldCores, oldPonder;
+int MakeColors P((void));
+void CreateGCs P((int redo));
+void CreateAnyPieces P((void));
+int GenericReadout P((int selected));
+Widget shells[10];
+Widget marked[10];
+Boolean shellUp[10];
+WindowPlacement *wp[10] = { NULL, &wpComment, &wpTags, NULL, NULL, NULL, NULL, &wpMoveHistory };
+Option *dialogOptions[10];
+
+void MarkMenu(char *item, int dlgNr)
+{
+ Arg args[2];
+ XtSetArg(args[0], XtNleftBitmap, xMarkPixmap);
+ XtSetValues(marked[dlgNr] = XtNameToWidget(menuBarWidget, item), args, 1);
+}
- // make an attempt to align all spins and textbox controls
- maxWidth = maxTextWidth = 0;
- for(h=0; h<height; h++) {
- i = h + c*height;
- if(i >= cps->nrOptions) break;
- if(cps->option[i].type == Spin || cps->option[i].type == TextBox) {
- Dimension w;
- j=0;
- XtSetArg(args[j], XtNwidth, &w); j++;
- XtGetValues(texts[h], args, j);
- if(cps->option[i].type == Spin) {
- if(w > maxWidth) maxWidth = w;
- widest = texts[h];
- } else {
- if(w > maxTextWidth) maxTextWidth = w;
- if(!widest) widest = texts[h];
- }
- }
- }
- if(maxTextWidth + 110 < maxWidth)
- maxTextWidth = maxWidth - 110;
- else maxWidth = maxTextWidth + 110;
- for(h=0; h<height; h++) {
- i = h + c*height;
- if(i >= cps->nrOptions) break;
- j=0;
- if(cps->option[i].type == Spin) {
- XtSetArg(args[j], XtNwidth, maxWidth); j++;
- XtSetValues(texts[h], args, j);
- } else
- if(cps->option[i].type == TextBox) {
- XtSetArg(args[j], XtNwidth, maxTextWidth); j++;
- XtSetValues(texts[h], args, j);
- }
+int PopDown(int n)
+{
+ int j;
+ Arg args[10];
+ Dimension windowH, windowW; Position windowX, windowY;
+ if (!shellUp[n]) return 0;
+ if(n && wp[n]) { // remember position
+ j = 0;
+ XtSetArg(args[j], XtNx, &windowX); j++;
+ XtSetArg(args[j], XtNy, &windowY); j++;
+ XtSetArg(args[j], XtNheight, &windowH); j++;
+ XtSetArg(args[j], XtNwidth, &windowW); j++;
+ XtGetValues(shells[n], args, j);
+ wp[n]->x = windowX;
+ wp[n]->x = windowY;
+ wp[n]->width = windowW;
+ wp[n]->height = windowH;
}
- }
- j=0;
- XtSetArg(args[j], XtNfromVert, anchor ? anchor : last); j++;
- XtSetArg(args[j], XtNbottom, XtChainBottom); j++;
- XtSetArg(args[j], XtNtop, XtChainBottom); j++;
- XtSetArg(args[j], XtNleft, XtChainRight); j++;
- XtSetArg(args[j], XtNright, XtChainRight); j++;
- XtSetArg(args[j], XtNfromHoriz, widest ? widest : dialog); j++;
- b_ok = XtCreateManagedWidget(_("OK"), commandWidgetClass, form, args, j);
- XtAddCallback(b_ok, XtNcallback, SettingsCallback, (XtPointer) 0);
-
- XtSetArg(args[j-1], XtNfromHoriz, b_ok);
- b_cancel = XtCreateManagedWidget(_("cancel"), commandWidgetClass, form, args, j);
- XtAddCallback(b_cancel, XtNcallback, SettingsPopDown, (XtPointer) 0);
-
- XtRealizeWidget(popup);
- CatchDeleteWindow(popup, "SettingsPopDown");
-
- XQueryPointer(xDisplay, xBoardWindow, &root, &child,
- &x, &y, &win_x, &win_y, &mask);
-
- XtSetArg(args[0], XtNx, x - 10);
- XtSetArg(args[1], XtNy, y - 30);
- XtSetValues(popup, args, 2);
-
- XtPopup(popup, XtGrabExclusive);
- SettingsUp = True;
-
previous = NULL;
- if(textField)SetFocus(textField, popup, (XEvent*) NULL, False);
+ XtPopdown(shells[n]);
+ if(n == 0) XtDestroyWidget(shells[n]);
+ shellUp[n] = False;
+ if(marked[n]) {
+ XtSetArg(args[0], XtNleftBitmap, None);
+ XtSetValues(marked[n], args, 1);
+ }
+ if(!n) currentCps = NULL; // if an Engine Settings dialog was up, we must be popping it down now
+ return 1;
}
-void FirstSettingsProc(w, event, prms, nprms)
+void GenericPopDown(w, event, prms, nprms)
Widget w;
XEvent *event;
String *prms;
Cardinal *nprms;
{
- SettingsPopUp(&first);
+ if(browserUp) return; // prevent closing dialog when it has an open file-browse daughter
+ PopDown(prms[0][0] - '0');
}
-void SecondSettingsProc(w, event, prms, nprms)
- Widget w;
- XEvent *event;
- String *prms;
- Cardinal *nprms;
+char *engineName, *engineDir, *engineChoice, *engineLine, *nickName, *params, *tfName;
+Boolean isUCI, hasBook, storeVariant, v1, addToList, useNick;
+extern Option installOptions[], matchOptions[];
+char *engineNr[] = { N_("First Engine"), N_("Second Engine"), NULL };
+char *engineList[100] = {" "}, *engineMnemonic[100] = {""};
+
+int AppendText(Option *opt, char *s)
{
- if(WaitForSecond(SettingsMenuIfReady)) return;
- SettingsPopUp(&second);
+ XawTextBlock t;
+ char *v;
+ int len;
+ GetWidgetText(opt, &v);
+ len = strlen(v);
+ t.ptr = s; t.firstPos = 0; t.length = strlen(s); t.format = XawFmt8Bit;
+ XawTextReplace(opt->handle, len, len, &t);
+ return len;
}
-//----------------------------Generic dialog --------------------------------------------
+void AddLine(Option *opt, char *s)
+{
+ AppendText(opt, s);
+ AppendText(opt, "\n");
+}
-// cloned from Engine Settings dialog
+void AddToTourney(int n)
+{
+ GenericReadout(4); // selected engine
+ AddLine(&matchOptions[3], engineChoice);
+}
-#define CURR -2000000000 /* indicates control should start at actual value of target */
+int MatchOK(int n)
+{
+ ASSIGN(appData.participants, engineName);
+ if(!CreateTourney(tfName) || matchMode) return matchMode || !appData.participants[0];
+ PopDown(0); // early popdown to prevent FreezeUI called through MatchEvent from causing XtGrab warning
+ MatchEvent(2); // start tourney
+ return 1;
+}
-typedef void ButtonCallback(int n);
+void ReplaceParticipant()
+{
+ GenericReadout(3);
+ Substitute(strdup(engineName), True);
+}
-char *trialSound;
-static Option *currentOption;
-static int oldCores, oldPonder;
-int MakeColors P((void));
-void CreateGCs P((int redo));
-void CreateXPMBoard P((char *s, int kind));
-void CreateXPMPieces P((void));
-void GenericReadout();
+void UpgradeParticipant()
+{
+ GenericReadout(3);
+ Substitute(strdup(engineName), False);
+}
-void GeneralOptionsOK(int n)
+Option matchOptions[] = {
+{ 0, 0, 0, NULL, (void*) &tfName, ".trn", NULL, FileName, N_("Tournament file:") },
+{ 0, 0, 0, NULL, (void*) &appData.roundSync, "", NULL, CheckBox, N_("Sync after round (for concurrent playing of a single") },
+{ 0, 0, 0, NULL, (void*) &appData.cycleSync, "", NULL, CheckBox, N_("Sync after cycle tourney with multiple XBoards)") },
+{ 0xD, 150, 0, NULL, (void*) &engineName, "", NULL, TextBox, N_("Tourney participants:") },
+{ 0, COMBO_CALLBACK | NO_GETTEXT,
+ 0, NULL, (void*) &engineChoice, (char*) (engineMnemonic+1), (engineMnemonic+1), ComboBox, N_("Select Engine:") },
+{ 0, 0, 10, NULL, (void*) &appData.tourneyType, "", NULL, Spin, N_("Tourney type (0 = round-robin, 1 = gauntlet):") },
+{ 0, 1, 1000000000, NULL, (void*) &appData.tourneyCycles, "", NULL, Spin, N_("Number of tourney cycles (or Swiss rounds):") },
+{ 0, 1, 1000000000, NULL, (void*) &appData.defaultMatchGames, "", NULL, Spin, N_("Default Number of Games in Match (or Pairing):") },
+{ 0, 0, 1000000000, NULL, (void*) &appData.matchPause, "", NULL, Spin, N_("Pause between Match Games (msec):") },
+{ 0, 0, 0, NULL, (void*) &appData.saveGameFile, ".pgn", NULL, FileName, N_("Save Tourney Games on:") },
+{ 0, 0, 0, NULL, (void*) &appData.loadGameFile, ".pgn", NULL, FileName, N_("Game File with Opening Lines:") },
+{ 0, -2, 1000000000, NULL, (void*) &appData.loadGameIndex, "", NULL, Spin, N_("Game Number (-1 or -2 = Auto-Increment):") },
+{ 0, 0, 0, NULL, (void*) &appData.loadPositionFile, ".fen", NULL, FileName, N_("File with Start Positions:") },
+{ 0, -2, 1000000000, NULL, (void*) &appData.loadPositionIndex, "", NULL, Spin, N_("Position Number (-1 or -2 = Auto-Increment):") },
+{ 0, 0, 1000000000, NULL, (void*) &appData.rewindIndex, "", NULL, Spin, N_("Rewind Index after this many Games (0 = never):") },
+{ 0, 0, 0, NULL, (void*) &appData.defNoBook, "", NULL, CheckBox, N_("Disable own engine books by default") },
+{ 0, 0, 0, NULL, (void*) &ReplaceParticipant, NULL, NULL, Button, N_("Replace Engine") },
+{ 0, 1, 0, NULL, (void*) &UpgradeParticipant, NULL, NULL, Button, N_("Upgrade Engine") },
+{ 0, 1, 0, NULL, (void*) &MatchOK, "", NULL, EndMark , "" }
+};
+
+int GeneralOptionsOK(int n)
{
int newPonder = appData.ponderNextMove;
appData.ponderNextMove = oldPonder;
PonderNextMoveEvent(newPonder);
+ return 1;
}
Option generalOptions[] = {
-{ 0, 0, 0, NULL, (void*) &appData.alwaysPromoteToQueen, "", NULL, CheckBox, _("Always Queen") },
-{ 0, 0, 0, NULL, (void*) &appData.animateDragging, "", NULL, CheckBox, _("Animate Dragging") },
-{ 0, 0, 0, NULL, (void*) &appData.animate, "", NULL, CheckBox, _("Animate Moving") },
-{ 0, 0, 0, NULL, (void*) &appData.autoCallFlag, "", NULL, CheckBox, _("Auto Flag") },
-{ 0, 0, 0, NULL, (void*) &appData.autoFlipView, "", NULL, CheckBox, _("Auto Flip View") },
-{ 0, 0, 0, NULL, (void*) &appData.blindfold, "", NULL, CheckBox, _("Blindfold") },
-{ 0, 0, 0, NULL, (void*) &appData.dropMenu, "", NULL, CheckBox, _("Drop Menu") },
-{ 0, 0, 0, NULL, (void*) &appData.highlightDragging, "", NULL, CheckBox, _("Highlight Dragging (Show Move Targets)") },
-{ 0, 0, 0, NULL, (void*) &appData.highlightLastMove, "", NULL, CheckBox, _("Highlight Last Move") },
-{ 0, 0, 0, NULL, (void*) &appData.highlightMoveWithArrow, "", NULL, CheckBox, _("Highlight with Arrow") },
-{ 0, 0, 0, NULL, (void*) &appData.ringBellAfterMoves, "", NULL, CheckBox, _("Move Sound") },
-{ 0, 0, 0, NULL, (void*) &appData.oneClick, "", NULL, CheckBox, _("One-Click Moving") },
-{ 0, 0, 0, NULL, (void*) &appData.periodicUpdates, "", NULL, CheckBox, _("Periodic Updates (in Analysis Mode)") },
-{ 0, 0, 0, NULL, (void*) &appData.ponderNextMove, "", NULL, CheckBox, _("Ponder Next Move") },
-{ 0, 0, 0, NULL, (void*) &appData.popupExitMessage, "", NULL, CheckBox, _("Popup Exit Messages") },
-{ 0, 0, 0, NULL, (void*) &appData.popupMoveErrors, "", NULL, CheckBox, _("Popup Move Errors") },
-{ 0, 0, 0, NULL, (void*) &appData.showCoords, "", NULL, CheckBox, _("Show Coordinates") },
-{ 0, 0, 0, NULL, (void*) &appData.markers, "", NULL, CheckBox, _("Show Target Squares") },
-{ 0, 0, 0, NULL, (void*) &appData.hideThinkingFromHuman, "", NULL, CheckBox, _("Hide Thinking from Human") },
-{ 0, 0, 0, NULL, (void*) &appData.testLegality, "", NULL, CheckBox, _("Test Legality") },
-{ 0, 0, 10, NULL, (void*) &appData.flashCount, "", NULL, Spin, _("Flash Moves (0 = no flashing):") },
-{ 0, 1, 10, NULL, (void*) &appData.flashRate, "", NULL, Spin, _("Flash Rate (high = fast):") },
-{ 0, 5, 100,NULL, (void*) &appData.animSpeed, "", NULL, Spin, _("Animation Speed (high = slow):") },
+{ 0, 0, 0, NULL, (void*) &appData.whitePOV, "", NULL, CheckBox, N_("Absolute Analysis Scores") },
+{ 0, 0, 0, NULL, (void*) &appData.sweepSelect, "", NULL, CheckBox, N_("Almost Always Queen (Detour Under-Promote)") },
+{ 0, 0, 0, NULL, (void*) &appData.animateDragging, "", NULL, CheckBox, N_("Animate Dragging") },
+{ 0, 0, 0, NULL, (void*) &appData.animate, "", NULL, CheckBox, N_("Animate Moving") },
+{ 0, 0, 0, NULL, (void*) &appData.autoCallFlag, "", NULL, CheckBox, N_("Auto Flag") },
+{ 0, 0, 0, NULL, (void*) &appData.autoFlipView, "", NULL, CheckBox, N_("Auto Flip View") },
+{ 0, 0, 0, NULL, (void*) &appData.blindfold, "", NULL, CheckBox, N_("Blindfold") },
+{ 0, 0, 0, NULL, (void*) &appData.dropMenu, "", NULL, CheckBox, N_("Drop Menu") },
+{ 0, 0, 0, NULL, (void*) &appData.hideThinkingFromHuman, "", NULL, CheckBox, N_("Hide Thinking from Human") },
+{ 0, 0, 0, NULL, (void*) &appData.highlightDragging, "", NULL, CheckBox, N_("Highlight Dragging (Show Move Targets)") },
+{ 0, 0, 0, NULL, (void*) &appData.highlightLastMove, "", NULL, CheckBox, N_("Highlight Last Move") },
+{ 0, 0, 0, NULL, (void*) &appData.highlightMoveWithArrow, "", NULL, CheckBox, N_("Highlight with Arrow") },
+{ 0, 0, 0, NULL, (void*) &appData.ringBellAfterMoves, "", NULL, CheckBox, N_("Move Sound") },
+{ 0, 0, 0, NULL, (void*) &appData.oneClick, "", NULL, CheckBox, N_("One-Click Moving") },
+{ 0, 0, 0, NULL, (void*) &appData.periodicUpdates, "", NULL, CheckBox, N_("Periodic Updates (in Analysis Mode)") },
+{ 0, 0, 0, NULL, (void*) &appData.ponderNextMove, "", NULL, CheckBox, N_("Ponder Next Move") },
+{ 0, 0, 0, NULL, (void*) &appData.popupExitMessage, "", NULL, CheckBox, N_("Popup Exit Messages") },
+{ 0, 0, 0, NULL, (void*) &appData.popupMoveErrors, "", NULL, CheckBox, N_("Popup Move Errors") },
+{ 0, 0, 0, NULL, (void*) &appData.showEvalInMoveHistory, "", NULL, CheckBox, N_("Scores in Move List") },
+{ 0, 0, 0, NULL, (void*) &appData.showCoords, "", NULL, CheckBox, N_("Show Coordinates") },
+{ 0, 0, 0, NULL, (void*) &appData.markers, "", NULL, CheckBox, N_("Show Target Squares") },
+{ 0, 0, 0, NULL, (void*) &appData.testLegality, "", NULL, CheckBox, N_("Test Legality") },
+{ 0, 0, 10, NULL, (void*) &appData.flashCount, "", NULL, Spin, N_("Flash Moves (0 = no flashing):") },
+{ 0, 1, 10, NULL, (void*) &appData.flashRate, "", NULL, Spin, N_("Flash Rate (high = fast):") },
+{ 0, 5, 100,NULL, (void*) &appData.animSpeed, "", NULL, Spin, N_("Animation Speed (high = slow):") },
+{ 0, 1, 5, NULL, (void*) &appData.zoom, "", NULL, Spin, N_("Zoom factor in Evaluation Graph:") },
{ 0, 0, 0, NULL, (void*) &GeneralOptionsOK, "", NULL, EndMark , "" }
};
}
}
- GenericReadout(); // make sure ranks and file settings are read
+ GenericReadout(-1); // make sure ranks and file settings are read
gameInfo.variant = v;
appData.variant = VariantName(v);
appData.pieceNickNames = "";
appData.colorNickNames = "";
Reset(True, True);
- SettingsPopDown();
+ PopDown(0);
return;
}
{ VariantMakruk, 0, 135, NULL, (void*) &Pick, "#FFFFFF", NULL, Button, N_("makruk")},
{ VariantGreat, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("Great Shatranj (10x8)")},
{ VariantAtomic, 0, 135, NULL, (void*) &Pick, "#FFFFFF", NULL, Button, N_("atomic")},
-{ VariantCapablanca, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("Capablanca (10x8)")},
+{ VariantFalcon, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("falcon (10x8)")},
{ VariantTwoKings, 0, 135, NULL, (void*) &Pick, "#FFFFFF", NULL, Button, N_("two kings")},
-{ VariantGothic, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("Gothic (10x8)")},
+{ VariantCapablanca, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("Capablanca (10x8)")},
{ Variant3Check, 0, 135, NULL, (void*) &Pick, "#FFFFFF", NULL, Button, N_("3-checks")},
-{ VariantJanus, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("janus (10x8)")},
+{ VariantGothic, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("Gothic (10x8)")},
{ VariantSuicide, 0, 135, NULL, (void*) &Pick, "#FFFFBF", NULL, Button, N_("suicide")},
-{ VariantCapaRandom, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("CRC (10x8)")},
+{ VariantJanus, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("janus (10x8)")},
{ VariantGiveaway, 0, 135, NULL, (void*) &Pick, "#FFFFBF", NULL, Button, N_("give-away")},
-{ VariantSpartan, 1, 135, NULL, (void*) &Pick, "#FF0000", NULL, Button, N_("Spartan")},
+{ VariantCapaRandom, 1, 135, NULL, (void*) &Pick, "#BFBFFF", NULL, Button, N_("CRC (10x8)")},
{ VariantLosers, 0, 135, NULL, (void*) &Pick, "#FFFFBF", NULL, Button, N_("losers")},
-{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, _("Board size ( -1 = default for selected variant):")},
+{ VariantGrand, 1, 135, NULL, (void*) &Pick, "#5070FF", NULL, Button, N_("grand (10x10)")},
+{ VariantSpartan, 0, 135, NULL, (void*) &Pick, "#FF0000", NULL, Button, N_("Spartan")},
+{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, N_("Board size ( -1 = default for selected variant):")},
{ 0, -1, BOARD_RANKS-1, NULL, (void*) &appData.NrRanks, "", NULL, Spin, N_("Number of Board Ranks:") },
{ 0, -1, BOARD_FILES, NULL, (void*) &appData.NrFiles, "", NULL, Spin, N_("Number of Board Files:") },
{ 0, -1, BOARD_RANKS-1, NULL, (void*) &appData.holdingsSize, "", NULL, Spin, N_("Holdings Size:") },
{ 0, 0, 0, NULL, NULL, NULL, NULL, Label,
- _("WARNING: variants with un-orthodox\n"
+ N_("WARNING: variants with un-orthodox\n"
"pieces only have built-in bitmaps\n"
"for -boardSize middling, bulky and\n"
"petite, and substitute king or amazon\n"
{ 0, 2, 0, NULL, NULL, "", NULL, EndMark , "" }
};
-void CommonOptionsOK(int n)
+int CommonOptionsOK(int n)
{
int newPonder = appData.ponderNextMove;
// make sure changes are sent to first engine by re-initializing it
appData.ponderNextMove = oldPonder;
PonderNextMoveEvent(newPonder);
}
+ return 1;
}
Option commonEngineOptions[] = {
-{ 0, 0, 0, NULL, (void*) &appData.ponderNextMove, "", NULL, CheckBox, _("Ponder Next Move") },
-{ 0, 0, 1000, NULL, (void*) &appData.smpCores, "", NULL, Spin, _("Maximum Number of CPUs per Engine:") },
-{ 0, 0, 0, NULL, (void*) &appData.polyglotDir, "", NULL, PathName, _("Polygot Directory:") },
-{ 0, 0, 16000, NULL, (void*) &appData.defaultHashSize, "", NULL, Spin, _("Hash-Table Size (MB):") },
-{ 0, 0, 0, NULL, (void*) &appData.defaultPathEGTB, "", NULL, PathName, _("Nalimov EGTB Path:") },
-{ 0, 0, 1000, NULL, (void*) &appData.defaultCacheSizeEGTB, "", NULL, Spin, _("EGTB Cache Size (MB):") },
-{ 0, 0, 0, NULL, (void*) &appData.usePolyglotBook, "", NULL, CheckBox, _("Use GUI Book") },
-{ 0, 0, 0, NULL, (void*) &appData.polyglotBook, "", NULL, FileName, _("Opening-Book Filename:") },
-{ 0, 0, 100, NULL, (void*) &appData.bookDepth, "", NULL, Spin, _("Book Depth (moves):") },
-{ 0, 0, 100, NULL, (void*) &appData.bookStrength, "", NULL, Spin, _("Book Variety (0) vs. Strength (100):") },
-{ 0, 0, 0, NULL, (void*) &appData.firstHasOwnBookUCI, "", NULL, CheckBox, _("Engine #1 Has Own Book") },
-{ 0, 0, 0, NULL, (void*) &appData.secondHasOwnBookUCI, "", NULL, CheckBox, _("Engine #2 Has Own Book ") },
+{ 0, 0, 0, NULL, (void*) &appData.ponderNextMove, "", NULL, CheckBox, N_("Ponder Next Move") },
+{ 0, 0, 1000, NULL, (void*) &appData.smpCores, "", NULL, Spin, N_("Maximum Number of CPUs per Engine:") },
+{ 0, 0, 0, NULL, (void*) &appData.polyglotDir, "", NULL, PathName, N_("Polygot Directory:") },
+{ 0, 0, 16000, NULL, (void*) &appData.defaultHashSize, "", NULL, Spin, N_("Hash-Table Size (MB):") },
+{ 0, 0, 0, NULL, (void*) &appData.defaultPathEGTB, "", NULL, PathName, N_("Nalimov EGTB Path:") },
+{ 0, 0, 1000, NULL, (void*) &appData.defaultCacheSizeEGTB, "", NULL, Spin, N_("EGTB Cache Size (MB):") },
+{ 0, 0, 0, NULL, (void*) &appData.usePolyglotBook, "", NULL, CheckBox, N_("Use GUI Book") },
+{ 0, 0, 0, NULL, (void*) &appData.polyglotBook, ".bin", NULL, FileName, N_("Opening-Book Filename:") },
+{ 0, 0, 100, NULL, (void*) &appData.bookDepth, "", NULL, Spin, N_("Book Depth (moves):") },
+{ 0, 0, 100, NULL, (void*) &appData.bookStrength, "", NULL, Spin, N_("Book Variety (0) vs. Strength (100):") },
+{ 0, 0, 0, NULL, (void*) &appData.firstHasOwnBookUCI, "", NULL, CheckBox, N_("Engine #1 Has Own Book") },
+{ 0, 0, 0, NULL, (void*) &appData.secondHasOwnBookUCI, "", NULL, CheckBox, N_("Engine #2 Has Own Book ") },
{ 0, 1, 0, NULL, (void*) &CommonOptionsOK, "", NULL, EndMark , "" }
};
Option adjudicationOptions[] = {
-{ 0, 0, 0, NULL, (void*) &appData.checkMates, "", NULL, CheckBox, _("Detect all Mates") },
-{ 0, 0, 0, NULL, (void*) &appData.testClaims, "", NULL, CheckBox, _("Verify Engine Result Claims") },
-{ 0, 0, 0, NULL, (void*) &appData.materialDraws, "", NULL, CheckBox, _("Draw if Insufficient Mating Material") },
-{ 0, 0, 0, NULL, (void*) &appData.trivialDraws, "", NULL, CheckBox, _("Adjudicate Trivial Draws (3-Move Delay)") },
-{ 0, 0, 100, NULL, (void*) &appData.ruleMoves, "", NULL, Spin, _("N-Move Rule:") },
-{ 0, 0, 6, NULL, (void*) &appData.drawRepeats, "", NULL, Spin, _("N-fold Repeats:") },
-{ 0, 0, 1000, NULL, (void*) &appData.adjudicateDrawMoves, "", NULL, Spin, _("Draw after N Moves Total:") },
-{ 0,-5000, 0, NULL, (void*) &appData.adjudicateLossThreshold, "", NULL, Spin, _("Win / Loss Threshold:") },
-{ 0, 0, 0, NULL, (void*) &first.scoreIsAbsolute, "", NULL, CheckBox, _("Negate Score of Engine #1") },
-{ 0, 0, 0, NULL, (void*) &second.scoreIsAbsolute, "", NULL, CheckBox, _("Negate Score of Engine #2") },
+{ 0, 0, 0, NULL, (void*) &appData.checkMates, "", NULL, CheckBox, N_("Detect all Mates") },
+{ 0, 0, 0, NULL, (void*) &appData.testClaims, "", NULL, CheckBox, N_("Verify Engine Result Claims") },
+{ 0, 0, 0, NULL, (void*) &appData.materialDraws, "", NULL, CheckBox, N_("Draw if Insufficient Mating Material") },
+{ 0, 0, 0, NULL, (void*) &appData.trivialDraws, "", NULL, CheckBox, N_("Adjudicate Trivial Draws (3-Move Delay)") },
+{ 0, 0, 100, NULL, (void*) &appData.ruleMoves, "", NULL, Spin, N_("N-Move Rule:") },
+{ 0, 0, 6, NULL, (void*) &appData.drawRepeats, "", NULL, Spin, N_("N-fold Repeats:") },
+{ 0, 0, 1000, NULL, (void*) &appData.adjudicateDrawMoves, "", NULL, Spin, N_("Draw after N Moves Total:") },
+{ 0,-5000, 0, NULL, (void*) &appData.adjudicateLossThreshold, "", NULL, Spin, N_("Win / Loss Threshold:") },
+{ 0, 0, 0, NULL, (void*) &first.scoreIsAbsolute, "", NULL, CheckBox, N_("Negate Score of Engine #1") },
+{ 0, 0, 0, NULL, (void*) &second.scoreIsAbsolute, "", NULL, CheckBox, N_("Negate Score of Engine #2") },
{ 0, 1, 0, NULL, NULL, "", NULL, EndMark , "" }
};
-void IcsOptionsOK(int n)
+int IcsOptionsOK(int n)
{
ParseIcsTextColors();
+ return 1;
}
Option icsOptions[] = {
-{ 0, 0, 0, NULL, (void*) &appData.autoKibitz, "", NULL, CheckBox, _("Auto-Kibitz") },
-{ 0, 0, 0, NULL, (void*) &appData.autoComment, "", NULL, CheckBox, _("Auto-Comment") },
-{ 0, 0, 0, NULL, (void*) &appData.autoObserve, "", NULL, CheckBox, _("Auto-Observe") },
-{ 0, 0, 0, NULL, (void*) &appData.autoRaiseBoard, "", NULL, CheckBox, _("Auto-Raise Board") },
-{ 0, 0, 0, NULL, (void*) &appData.bgObserve, "", NULL, CheckBox, _("Background Observe while Playing") },
-{ 0, 0, 0, NULL, (void*) &appData.dualBoard, "", NULL, CheckBox, _("Dual Board for Background-Observed Game") },
-{ 0, 0, 0, NULL, (void*) &appData.getMoveList, "", NULL, CheckBox, _("Get Move List") },
-{ 0, 0, 0, NULL, (void*) &appData.quietPlay, "", NULL, CheckBox, _("Quiet Play") },
-{ 0, 0, 0, NULL, (void*) &appData.seekGraph, "", NULL, CheckBox, _("Seek Graph") },
-{ 0, 0, 0, NULL, (void*) &appData.autoRefresh, "", NULL, CheckBox, _("Auto-Refresh Seek Graph") },
-{ 0, 0, 0, NULL, (void*) &appData.premove, "", NULL, CheckBox, _("Premove") },
-{ 0, 0, 0, NULL, (void*) &appData.premoveWhite, "", NULL, CheckBox, _("Premove for White") },
-{ 0, 0, 0, NULL, (void*) &appData.premoveWhiteText, "", NULL, TextBox, _("First White Move:") },
-{ 0, 0, 0, NULL, (void*) &appData.premoveBlack, "", NULL, CheckBox, _("Premove for Black") },
-{ 0, 0, 0, NULL, (void*) &appData.premoveBlackText, "", NULL, TextBox, _("First Black Move:") },
+{ 0, 0, 0, NULL, (void*) &appData.autoKibitz, "", NULL, CheckBox, N_("Auto-Kibitz") },
+{ 0, 0, 0, NULL, (void*) &appData.autoComment, "", NULL, CheckBox, N_("Auto-Comment") },
+{ 0, 0, 0, NULL, (void*) &appData.autoObserve, "", NULL, CheckBox, N_("Auto-Observe") },
+{ 0, 0, 0, NULL, (void*) &appData.autoRaiseBoard, "", NULL, CheckBox, N_("Auto-Raise Board") },
+{ 0, 0, 0, NULL, (void*) &appData.bgObserve, "", NULL, CheckBox, N_("Background Observe while Playing") },
+{ 0, 0, 0, NULL, (void*) &appData.dualBoard, "", NULL, CheckBox, N_("Dual Board for Background-Observed Game") },
+{ 0, 0, 0, NULL, (void*) &appData.getMoveList, "", NULL, CheckBox, N_("Get Move List") },
+{ 0, 0, 0, NULL, (void*) &appData.quietPlay, "", NULL, CheckBox, N_("Quiet Play") },
+{ 0, 0, 0, NULL, (void*) &appData.seekGraph, "", NULL, CheckBox, N_("Seek Graph") },
+{ 0, 0, 0, NULL, (void*) &appData.autoRefresh, "", NULL, CheckBox, N_("Auto-Refresh Seek Graph") },
+{ 0, 0, 0, NULL, (void*) &appData.premove, "", NULL, CheckBox, N_("Premove") },
+{ 0, 0, 0, NULL, (void*) &appData.premoveWhite, "", NULL, CheckBox, N_("Premove for White") },
+{ 0, 0, 0, NULL, (void*) &appData.premoveWhiteText, "", NULL, TextBox, N_("First White Move:") },
+{ 0, 0, 0, NULL, (void*) &appData.premoveBlack, "", NULL, CheckBox, N_("Premove for Black") },
+{ 0, 0, 0, NULL, (void*) &appData.premoveBlackText, "", NULL, TextBox, N_("First Black Move:") },
{ 0, 0, 0, NULL, NULL, NULL, NULL, Break, "" },
-{ 0, 0, 0, NULL, (void*) &appData.icsAlarm, "", NULL, CheckBox, _("Alarm") },
-{ 0, 0, 100000000, NULL, (void*) &appData.icsAlarmTime, "", NULL, Spin, _("Alarm Time (msec):") },
-//{ 0, 0, 0, NULL, (void*) &appData.chatBoxes, "", NULL, TextBox, _("Startup Chat Boxes:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorize, "", NULL, CheckBox, _("Colorize Messages") },
-{ 0, 0, 0, NULL, (void*) &appData.colorShout, "", NULL, TextBox, _("Shout Text Colors:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorSShout, "", NULL, TextBox, _("S-Shout Text Colors:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorChannel1, "", NULL, TextBox, _("Channel #1 Text Colors:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorChannel, "", NULL, TextBox, _("Other Channel Text Colors:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorKibitz, "", NULL, TextBox, _("Kibitz Text Colors:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorTell, "", NULL, TextBox, _("Tell Text Colors:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorChallenge, "", NULL, TextBox, _("Challenge Text Colors:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorRequest, "", NULL, TextBox, _("Request Text Colors:") },
-{ 0, 0, 0, NULL, (void*) &appData.colorSeek, "", NULL, TextBox, _("Seek Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.icsAlarm, "", NULL, CheckBox, N_("Alarm") },
+{ 0, 0, 100000000, NULL, (void*) &appData.icsAlarmTime, "", NULL, Spin, N_("Alarm Time (msec):") },
+//{ 0, 0, 0, NULL, (void*) &appData.chatBoxes, "", NULL, TextBox, N_("Startup Chat Boxes:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorize, "", NULL, CheckBox, N_("Colorize Messages") },
+{ 0, 0, 0, NULL, (void*) &appData.colorShout, "", NULL, TextBox, N_("Shout Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorSShout, "", NULL, TextBox, N_("S-Shout Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorChannel1, "", NULL, TextBox, N_("Channel #1 Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorChannel, "", NULL, TextBox, N_("Other Channel Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorKibitz, "", NULL, TextBox, N_("Kibitz Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorTell, "", NULL, TextBox, N_("Tell Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorChallenge, "", NULL, TextBox, N_("Challenge Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorRequest, "", NULL, TextBox, N_("Request Text Colors:") },
+{ 0, 0, 0, NULL, (void*) &appData.colorSeek, "", NULL, TextBox, N_("Seek Text Colors:") },
{ 0, 0, 0, NULL, (void*) &IcsOptionsOK, "", NULL, EndMark , "" }
};
+char *modeNames[] = { N_("Exact position match"), N_("Shown position is subset"), N_("Same material with exactly same Pawn chain"),
+ N_("Same material"), N_("Material range (top board half optional)"), N_("Material difference (optional stuff balanced)"), NULL };
+char *modeValues[] = { "1", "2", "3", "4", "5", "6" };
+char *searchMode;
+
+int LoadOptionsOK()
+{
+ appData.searchMode = atoi(searchMode);
+ return 1;
+}
+
Option loadOptions[] = {
-{ 0, 0, 0, NULL, (void*) &appData.autoDisplayTags, "", NULL, CheckBox, _("Auto-Display Tags") },
-{ 0, 0, 0, NULL, (void*) &appData.autoDisplayComment, "", NULL, CheckBox, _("Auto-Display Comment") },
-{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, _("Auto-Play speed of loaded games\n(0 = instant, -1 = off):") },
-{ 0, -1, 10000000, NULL, (void*) &appData.timeDelay, "", NULL, Fractional, _("Seconds per Move:") },
-{ 0, 0, 0, NULL, NULL, "", NULL, EndMark , "" }
+{ 0, 0, 0, NULL, (void*) &appData.autoDisplayTags, "", NULL, CheckBox, N_("Auto-Display Tags") },
+{ 0, 0, 0, NULL, (void*) &appData.autoDisplayComment, "", NULL, CheckBox, N_("Auto-Display Comment") },
+{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, N_("Auto-Play speed of loaded games\n(0 = instant, -1 = off):") },
+{ 0, -1, 10000000, NULL, (void*) &appData.timeDelay, "", NULL, Fractional, N_("Seconds per Move:") },
+{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, N_("\nThresholds for position filtering in game list:") },
+{ 0, 0, 5000, NULL, (void*) &appData.eloThreshold1, "", NULL, Spin, N_("Elo of strongest player at least:") },
+{ 0, 0, 5000, NULL, (void*) &appData.eloThreshold2, "", NULL, Spin, N_("Elo of weakest player at least:") },
+{ 0, 0, 5000, NULL, (void*) &appData.dateThreshold, "", NULL, Spin, N_("No games before year:") },
+{ 0, 1, 50, NULL, (void*) &appData.stretch, "", NULL, Spin, N_("Minimum nr consecutive positions:") },
+{ 1, 0, 180, NULL, (void*) &searchMode, (char*) modeNames, modeValues, ComboBox, N_("Seach mode:") },
+{ 0, 0, 0, NULL, (void*) &appData.ignoreColors, "", NULL, CheckBox, N_("Also match reversed colors") },
+{ 0, 0, 0, NULL, (void*) &appData.findMirror, "", NULL, CheckBox, N_("Also match left-right flipped position") },
+{ 0, 0, 0, NULL, (void*) &LoadOptionsOK, "", NULL, EndMark , "" }
};
Option saveOptions[] = {
-{ 0, 0, 0, NULL, (void*) &appData.autoSaveGames, "", NULL, CheckBox, _("Auto-Save Games") },
-{ 0, 0, 0, NULL, (void*) &appData.saveGameFile, "", NULL, FileName, _("Save Games on File:") },
-{ 0, 0, 0, NULL, (void*) &appData.savePositionFile, "", NULL, FileName, _("Save Final Positions on File:") },
-{ 0, 0, 0, NULL, (void*) &appData.pgnEventHeader, "", NULL, TextBox, _("PGN Event Header:") },
-{ 0, 0, 0, NULL, (void*) &appData.oldSaveStyle, "", NULL, CheckBox, _("Old Save Style (as opposed to PGN)") },
-{ 0, 0, 0, NULL, (void*) &appData.saveExtendedInfoInPGN, "", NULL, CheckBox, _("Save Score/Depth Info in PGN") },
-{ 0, 0, 0, NULL, (void*) &appData.saveOutOfBookInfo, "", NULL, CheckBox, _("Save Out-of-Book Info in PGN ") },
+{ 0, 0, 0, NULL, (void*) &appData.autoSaveGames, "", NULL, CheckBox, N_("Auto-Save Games") },
+{ 0, 0, 0, NULL, (void*) &appData.saveGameFile, ".pgn", NULL, FileName, N_("Save Games on File:") },
+{ 0, 0, 0, NULL, (void*) &appData.savePositionFile, ".fen", NULL, FileName, N_("Save Final Positions on File:") },
+{ 0, 0, 0, NULL, (void*) &appData.pgnEventHeader, "", NULL, TextBox, N_("PGN Event Header:") },
+{ 0, 0, 0, NULL, (void*) &appData.oldSaveStyle, "", NULL, CheckBox, N_("Old Save Style (as opposed to PGN)") },
+{ 0, 0, 0, NULL, (void*) &appData.saveExtendedInfoInPGN, "", NULL, CheckBox, N_("Save Score/Depth Info in PGN") },
+{ 0, 0, 0, NULL, (void*) &appData.saveOutOfBookInfo, "", NULL, CheckBox, N_("Save Out-of-Book Info in PGN ") },
{ 0, 1, 0, NULL, NULL, "", NULL, EndMark , "" }
};
N_("No Sound"),
N_("Default Beep"),
N_("Above WAV File"),
- N_("Ching"),
- N_("Click"),
+ N_("Car Horn"),
+ N_("Cymbal"),
N_("Ding"),
N_("Gong"),
N_("Laser"),
N_("Penalty"),
N_("Phone"),
- N_("Thud"),
- N_("Challenge"),
- N_("Tell"),
+ N_("Pop"),
+ N_("Slap"),
+ N_("Wood Thunk"),
NULL,
N_("User File")
};
char *soundFiles[] = { // sound files corresponding to above names
"",
"$",
- "*", // kludge alert: as first thing in the dialog readout this is replaced with the user-given .WAV filename
- "ching.wav",
- "click.wav",
+ NULL, // kludge alert: as first thing in the dialog readout this is replaced with the user-given .WAV filename
+ "honkhonk.wav",
+ "cymbal.wav",
"ding1.wav",
"gong.wav",
"laser.wav",
"penalty.wav",
"phone.wav",
- "thud.wav",
- "challenge.wav",
- "tell.wav",
+ "pop2.wav",
+ "slap.wav",
+ "woodthunk.wav",
NULL,
NULL
};
void Test(int n)
{
+ GenericReadout(2);
if(soundFiles[values[3]]) PlaySound(soundFiles[values[3]]);
}
Option soundOptions[] = {
-{ 0, 0, 0, NULL, (void*) &appData.soundProgram, "", NULL, TextBox, _("Sound Program:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundDirectory, "", NULL, PathName, _("Sounds Directory:") },
-{ 0, 0, 0, NULL, (void*) (soundFiles+2) /* kludge! */, "", NULL, FileName, _("User WAV File:") },
-{ 0, 0, 0, NULL, (void*) &trialSound, (char*) soundNames, soundFiles, ComboBox, _("Try-Out Sound:") },
-{ 0, 1, 0, NULL, (void*) &Test, NULL, NULL, Button, _("Play") },
-{ 0, 0, 0, NULL, (void*) &appData.soundMove, (char*) soundNames, soundFiles, ComboBox, _("Move:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundIcsWin, (char*) soundNames, soundFiles, ComboBox, _("Win:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundIcsLoss, (char*) soundNames, soundFiles, ComboBox, _("Lose:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundIcsDraw, (char*) soundNames, soundFiles, ComboBox, _("Draw:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundIcsUnfinished, (char*) soundNames, soundFiles, ComboBox, _("Unfinished:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundIcsAlarm, (char*) soundNames, soundFiles, ComboBox, _("Alarm:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundShout, (char*) soundNames, soundFiles, ComboBox, _("Shout:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundSShout, (char*) soundNames, soundFiles, ComboBox, _("S-Shout:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundChannel, (char*) soundNames, soundFiles, ComboBox, _("Channel:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundChannel1, (char*) soundNames, soundFiles, ComboBox, _("Channel 1:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundTell, (char*) soundNames, soundFiles, ComboBox, _("Tell:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundKibitz, (char*) soundNames, soundFiles, ComboBox, _("Kibitz:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundChallenge, (char*) soundNames, soundFiles, ComboBox, _("Challenge:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundRequest, (char*) soundNames, soundFiles, ComboBox, _("Request:") },
-{ 0, 0, 0, NULL, (void*) &appData.soundSeek, (char*) soundNames, soundFiles, ComboBox, _("Seek:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundProgram, "", NULL, TextBox, N_("Sound Program:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundDirectory, "", NULL, PathName, N_("Sounds Directory:") },
+{ 0, 0, 0, NULL, (void*) (soundFiles+2) /* kludge! */, ".wav", NULL, FileName, N_("User WAV File:") },
+{ 0, 0, 0, NULL, (void*) &trialSound, (char*) soundNames, soundFiles, ComboBox, N_("Try-Out Sound:") },
+{ 0, 1, 0, NULL, (void*) &Test, NULL, NULL, Button, N_("Play") },
+{ 0, 0, 0, NULL, (void*) &appData.soundMove, (char*) soundNames, soundFiles, ComboBox, N_("Move:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundIcsWin, (char*) soundNames, soundFiles, ComboBox, N_("Win:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundIcsLoss, (char*) soundNames, soundFiles, ComboBox, N_("Lose:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundIcsDraw, (char*) soundNames, soundFiles, ComboBox, N_("Draw:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundIcsUnfinished, (char*) soundNames, soundFiles, ComboBox, N_("Unfinished:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundIcsAlarm, (char*) soundNames, soundFiles, ComboBox, N_("Alarm:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundShout, (char*) soundNames, soundFiles, ComboBox, N_("Shout:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundSShout, (char*) soundNames, soundFiles, ComboBox, N_("S-Shout:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundChannel, (char*) soundNames, soundFiles, ComboBox, N_("Channel:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundChannel1, (char*) soundNames, soundFiles, ComboBox, N_("Channel 1:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundTell, (char*) soundNames, soundFiles, ComboBox, N_("Tell:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundKibitz, (char*) soundNames, soundFiles, ComboBox, N_("Kibitz:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundChallenge, (char*) soundNames, soundFiles, ComboBox, N_("Challenge:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundRequest, (char*) soundNames, soundFiles, ComboBox, N_("Request:") },
+{ 0, 0, 0, NULL, (void*) &appData.soundSeek, (char*) soundNames, soundFiles, ComboBox, N_("Seek:") },
{ 0, 1, 0, NULL, NULL, "", NULL, EndMark , "" }
};
-void SetColor(char *colorName, Widget box)
+void SetColor(char *colorName, Option *box)
{
Arg args[5];
Pixel buttonColor;
} else {
buttonColor = *(Pixel *) vTo.addr;
}
- }
+ } else buttonColor = (Pixel) 0;
XtSetArg(args[0], XtNbackground, buttonColor);;
- XtSetValues(box, args, 1);
+ XtSetValues(box->handle, args, 1);
}
-void AdjustColor(int i)
+void SetColorText(int n, char *buf)
+{
+ SetWidgetText(¤tOption[n-1], buf, 0);
+ SetColor(buf, ¤tOption[n]);
+}
+
+void DefColor(int n)
+{
+ SetColorText(n, (char*) currentOption[n].choice);
+}
+
+void RefreshColor(int source, int n)
{
- int n = currentOption[i].value, col, j, r, g, b, step = 10;
+ int col, j, r, g, b, step = 10;
char *s, buf[MSG_SIZ]; // color string
- Arg args[5];
- XtSetArg(args[0], XtNstring, &s);
- XtGetValues(currentOption[i-n-1].handle, args, 1);
+ GetWidgetText(¤tOption[source], &s);
if(sscanf(s, "#%x", &col) != 1) return; // malformed
b = col & 0xFF; g = col & 0xFF00; r = col & 0xFF0000;
switch(n) {
- case 1: g -= 0x100*step; b -= step; break;
- case 2: r -= 0x10000*step; b -= step; break;
- case 3: g -= 0x100*step; r -= 0x10000*step; break;
- case 4: r += 0x10000*step; g += 0x100*step; b += step; break;
+ case 1: r += 0x10000*step;break;
+ case 2: g += 0x100*step; break;
+ case 3: b += step; break;
+ case 4: r -= 0x10000*step; g -= 0x100*step; b -= step; break;
}
if(r < 0) r = 0; if(g < 0) g = 0; if(b < 0) b = 0;
if(r > 0xFF0000) r = 0xFF0000; if(g > 0xFF00) g = 0xFF00; if(b > 0xFF) b = 0xFF;
col = r | g | b;
snprintf(buf, MSG_SIZ, "#%06x", col);
for(j=1; j<7; j++) if(buf[j] >= 'a') buf[j] -= 32; // capitalize
- SetColor(buf, currentOption[i-n].handle);
- XtSetArg(args[0], XtNstring, buf);
- XtSetValues(currentOption[i-n-1].handle, args, 1);
+ SetColorText(source+1, buf);
+}
+
+void ColorChanged(Widget w, XtPointer data, XEvent *event, Boolean *b)
+{
+ char buf[10];
+ if ( (XLookupString(&(event->xkey), buf, 2, NULL, NULL) == 1) && *buf == '\r' )
+ RefreshColor((int)(intptr_t) data, 0);
+}
+
+void AdjustColor(int i)
+{
+ int n = currentOption[i].value;
+ RefreshColor(i-n-1, n);
}
-void BoardOptionsOK(int n)
+int BoardOptionsOK(int n)
{
- if(appData.overrideLineGap >= 0) lineGap = appData.overrideLineGap;
+ if(appData.overrideLineGap >= 0) lineGap = appData.overrideLineGap; else lineGap = defaultLineGap;
+ useImages = useImageSqs = 0;
MakeColors(); CreateGCs(True);
- CreateXPMPieces();
- CreateXPMBoard(appData.liteBackTextureFile, 1);
- CreateXPMBoard(appData.darkBackTextureFile, 0);
+ CreateAnyPieces();
InitDrawingSizes(-1, 0);
DrawPosition(True, NULL);
+ return 1;
}
Option boardOptions[] = {
-{ 0, 0, 70, NULL, (void*) &appData.whitePieceColor, "", NULL, TextBox, _("White Piece Color:") },
-{ 1000, 1, 0, NULL, NULL, NULL, NULL, Button, " " },
-{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "R" },
-{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "G" },
-{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "B" },
-{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "W" },
-{ 0, 0, 70, NULL, (void*) &appData.blackPieceColor, "", NULL, TextBox, _("Black Piece Color:") },
-{ 1000, 1, 0, NULL, NULL, NULL, NULL, Button, " " },
-{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "R" },
-{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "G" },
-{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "B" },
-{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "W" },
-{ 0, 0, 70, NULL, (void*) &appData.lightSquareColor, "", NULL, TextBox, _("Light Square Color:") },
-{ 1000, 1, 0, NULL, NULL, NULL, NULL, Button, " " },
-{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "R" },
-{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "G" },
-{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "B" },
-{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "W" },
-{ 0, 0, 70, NULL, (void*) &appData.darkSquareColor, "", NULL, TextBox, _("Dark Square Color:") },
-{ 1000, 1, 0, NULL, NULL, NULL, NULL, Button, " " },
-{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "R" },
-{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "G" },
-{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "B" },
-{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "W" },
-{ 0, 0, 70, NULL, (void*) &appData.highlightSquareColor, "", NULL, TextBox, _("Highlight Color:") },
-{ 1000, 1, 0, NULL, NULL, NULL, NULL, Button, " " },
-{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "R" },
-{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "G" },
-{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "B" },
-{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "W" },
-{ 0, 0, 70, NULL, (void*) &appData.premoveHighlightColor, "", NULL, TextBox, _("Premove Highlight Color:") },
-{ 1000, 1, 0, NULL, NULL, NULL, NULL, Button, " " },
-{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "R" },
-{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "G" },
-{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "B" },
-{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, "W" },
-{ 0, 0, 0, NULL, (void*) &appData.upsideDown, "", NULL, CheckBox, _("Flip Pieces Shogi Style") },
-{ 0, 0, 0, NULL, (void*) &appData.allWhite, "", NULL, CheckBox, _("Use Outline Pieces for Black") },
-{ 0, 0, 0, NULL, (void*) &appData.monoMode, "", NULL, CheckBox, _("Mono Mode") },
-{ 0,-1, 5, NULL, (void*) &appData.overrideLineGap, "", NULL, Spin, _("Line Gap ( -1 = default for board size):") },
-{ 0, 0, 0, NULL, (void*) &appData.liteBackTextureFile, "", NULL, FileName, _("Light-Squares Texture File:") },
-{ 0, 0, 0, NULL, (void*) &appData.darkBackTextureFile, "", NULL, FileName, _("Dark-Squares Texture File:") },
-{ 0, 0, 0, NULL, (void*) &appData.bitmapDirectory, "", NULL, PathName, _("Directory with Bitmap Pieces:") },
-{ 0, 0, 0, NULL, (void*) &appData.pixmapDirectory, "", NULL, PathName, _("Directory with Pixmap Pieces:") },
+{ 0, 0, 70, NULL, (void*) &appData.whitePieceColor, "", NULL, TextBox, N_("White Piece Color:") },
+{ 1000, 1, 0, NULL, (void*) &DefColor, NULL, (char**) "#FFFFCC", Button, " " },
+{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("R") },
+{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("G") },
+{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("B") },
+{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("D") },
+{ 0, 0, 70, NULL, (void*) &appData.blackPieceColor, "", NULL, TextBox, N_("Black Piece Color:") },
+{ 1000, 1, 0, NULL, (void*) &DefColor, NULL, (char**) "#202020", Button, " " },
+{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("R") },
+{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("G") },
+{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("B") },
+{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("D") },
+{ 0, 0, 70, NULL, (void*) &appData.lightSquareColor, "", NULL, TextBox, N_("Light Square Color:") },
+{ 1000, 1, 0, NULL, (void*) &DefColor, NULL, (char**) "#C8C365", Button, " " },
+{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("R") },
+{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("G") },
+{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("B") },
+{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("D") },
+{ 0, 0, 70, NULL, (void*) &appData.darkSquareColor, "", NULL, TextBox, N_("Dark Square Color:") },
+{ 1000, 1, 0, NULL, (void*) &DefColor, NULL, (char**) "#77A26D", Button, " " },
+{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("R") },
+{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("G") },
+{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("B") },
+{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("D") },
+{ 0, 0, 70, NULL, (void*) &appData.highlightSquareColor, "", NULL, TextBox, N_("Highlight Color:") },
+{ 1000, 1, 0, NULL, (void*) &DefColor, NULL, (char**) "#FFFF00", Button, " " },
+{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("R") },
+{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("G") },
+{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("B") },
+{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("D") },
+{ 0, 0, 70, NULL, (void*) &appData.premoveHighlightColor, "", NULL, TextBox, N_("Premove Highlight Color:") },
+{ 1000, 1, 0, NULL, (void*) &DefColor, NULL, (char**) "#FF0000", Button, " " },
+{ 1, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("R") },
+{ 2, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("G") },
+{ 3, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("B") },
+{ 4, 1, 0, NULL, (void*) &AdjustColor, NULL, NULL, Button, N_("D") },
+{ 0, 0, 0, NULL, (void*) &appData.upsideDown, "", NULL, CheckBox, N_("Flip Pieces Shogi Style (Colored buttons restore default)") },
+//{ 0, 0, 0, NULL, (void*) &appData.allWhite, "", NULL, CheckBox, N_("Use Outline Pieces for Black") },
+{ 0, 0, 0, NULL, (void*) &appData.monoMode, "", NULL, CheckBox, N_("Mono Mode") },
+{ 0,-1, 5, NULL, (void*) &appData.overrideLineGap, "", NULL, Spin, N_("Line Gap ( -1 = default for board size):") },
+{ 0, 0, 0, NULL, (void*) &appData.useBitmaps, "", NULL, CheckBox, N_("Use Board Textures") },
+{ 0, 0, 0, NULL, (void*) &appData.liteBackTextureFile, ".xpm", NULL, FileName, N_("Light-Squares Texture File:") },
+{ 0, 0, 0, NULL, (void*) &appData.darkBackTextureFile, ".xpm", NULL, FileName, N_("Dark-Squares Texture File:") },
+{ 0, 0, 0, NULL, (void*) &appData.bitmapDirectory, "", NULL, PathName, N_("Directory with Bitmap Pieces:") },
+{ 0, 0, 0, NULL, (void*) &appData.pixmapDirectory, "", NULL, PathName, N_("Directory with Pixmap Pieces:") },
{ 0, 0, 0, NULL, (void*) &BoardOptionsOK, "", NULL, EndMark , "" }
};
-void GenericReadout()
+int GenericReadout(int selected)
{
- int i, j;
- String name, val;
+ int i, j, res=1;
+ String val;
Arg args[16];
- char buf[MSG_SIZ];
+ char buf[MSG_SIZ], **dest;
float x;
for(i=0; ; i++) { // send all options that had to be OK-ed to engine
+ if(selected >= 0) { if(i < selected) continue; else if(i > selected) break; }
switch(currentOption[i].type) {
case TextBox:
case FileName:
case PathName:
XtSetArg(args[0], XtNstring, &val);
XtGetValues(currentOption[i].handle, args, 1);
- if(*(char**) currentOption[i].target == NULL || strcmp(*(char**) currentOption[i].target, val)) {
- safeStrCpy(currentOption[i].name + 100, val, MSG_SIZ-100); // text value kept in pivate storage for each option
- *(char**) currentOption[i].target = currentOption[i].name + 100; // option gets to point to that
+ dest = currentCps ? &(currentOption[i].textValue) : (char**) currentOption[i].target;
+ if(*dest == NULL || strcmp(*dest, val)) {
+ if(currentCps) {
+ snprintf(buf, MSG_SIZ, "option %s=%s\n", currentOption[i].name, val);
+ SendToProgram(buf, currentCps);
+ } else {
+ if(*dest) free(*dest);
+ *dest = malloc(strlen(val)+1);
+ }
+ safeStrCpy(*dest, val, MSG_SIZ - (*dest - currentOption[i].name)); // copy text there
}
break;
case Spin:
case Fractional:
XtSetArg(args[0], XtNstring, &val);
XtGetValues(currentOption[i].handle, args, 1);
+ x = 0.0; // Initialise because sscanf() will fail if non-numeric text is entered
sscanf(val, "%f", &x);
if(x > currentOption[i].max) x = currentOption[i].max;
if(x < currentOption[i].min) x = currentOption[i].min;
- if(currentOption[i].value != x) {
+ if(currentOption[i].type == Fractional)
+ *(float*) currentOption[i].target = x; // engines never have float options!
+ else if(currentOption[i].value != x) {
currentOption[i].value = x;
- if(currentOption[i].type == Spin) *(int*) currentOption[i].target = x;
- else *(float*) currentOption[i].target = x;
+ if(currentCps) {
+ snprintf(buf, MSG_SIZ, "option %s=%.0f\n", currentOption[i].name, x);
+ SendToProgram(buf, currentCps);
+ } else *(int*) currentOption[i].target = x;
}
break;
case CheckBox:
XtGetValues(currentOption[i].handle, args, 1);
if(currentOption[i].value != j) {
currentOption[i].value = j;
- *(Boolean*) currentOption[i].target = j;
+ if(currentCps) {
+ snprintf(buf, MSG_SIZ, "option %s=%d\n", currentOption[i].name, j);
+ SendToProgram(buf, currentCps);
+ } else *(Boolean*) currentOption[i].target = j;
}
break;
case ComboBox:
val = ((char**)currentOption[i].choice)[values[i]];
- if(val && (*(char**) currentOption[i].target == NULL || strcmp(*(char**) currentOption[i].target, val))) {
+ if(currentCps) {
+ if(currentOption[i].value == values[i]) break; // not changed
+ currentOption[i].value = values[i];
+ snprintf(buf, MSG_SIZ, "option %s=%s\n", currentOption[i].name,
+ ((char**)currentOption[i].textValue)[values[i]]);
+ SendToProgram(buf, currentCps);
+ } else if(val && (*(char**) currentOption[i].target == NULL || strcmp(*(char**) currentOption[i].target, val))) {
if(*(char**) currentOption[i].target) free(*(char**) currentOption[i].target);
*(char**) currentOption[i].target = strdup(val);
}
break;
case EndMark:
if(currentOption[i].target) // callback for implementing necessary actions on OK (like redraw)
- ((ButtonCallback*) currentOption[i].target)(i);
+ res = ((OKCallback*) currentOption[i].target)(i);
break;
default:
printf("GenericReadout: unexpected case in switch.\n");
case Button:
+ case SaveButton:
case Label:
+ case Break:
break;
}
if(currentOption[i].type == EndMark) break;
}
+ return res;
}
void GenericCallback(w, client_data, call_data)
Widget w;
XtPointer client_data, call_data;
{
- String name, val;
+ String name;
Arg args[16];
char buf[MSG_SIZ];
- int i, j;
int data = (intptr_t) client_data;
+ currentOption = dialogOptions[data>>16]; data &= 0xFFFF;
+
XtSetArg(args[0], XtNlabel, &name);
XtGetValues(w, args, 1);
if (strcmp(name, _("cancel")) == 0) {
- SettingsPopDown();
+ PopDown(data);
return;
}
if (strcmp(name, _("OK")) == 0) { // save buttons imply OK
- GenericReadout();
- SettingsPopDown();
+ if(GenericReadout(-1)) PopDown(data);
return;
}
- if(currentOption[data].textValue);
- ((ButtonCallback*) currentOption[data].target)(data);
+ if(currentCps) {
+ if(currentOption[data].type == SaveButton) GenericReadout(-1);
+ snprintf(buf, MSG_SIZ, "option %s\n", name);
+ SendToProgram(buf, currentCps);
+ } else ((ButtonCallback*) currentOption[data].target)(data);
}
-void
-GenericPopUp(Option *option, char *title)
+static char *oneLiner = "<Key>Return: redraw-display()\n";
+
+int
+GenericPopUp(Option *option, char *title, int dlgNr)
{
Arg args[16];
- Widget popup, layout, dialog, edit=NULL, form, last, b_ok, b_cancel, leftMargin = NULL, textField = NULL;
+ Widget popup, layout, dialog=NULL, edit=NULL, form, last, b_ok, b_cancel, leftMargin = NULL, textField = NULL;
Window root, child;
int x, y, i, j, height=999, width=1, h, c, w;
int win_x, win_y, maxWidth, maxTextWidth;
unsigned int mask;
char def[MSG_SIZ], *msg;
static char pane[6] = "paneX";
- Widget texts[100], forelast = NULL, anchor, widest, lastrow = NULL;
-
- currentOption = option; // make available to callback
- // kludge: fake address of a ChessProgramState struct that contains the options, so Spin and Combo callbacks work on it
- currentCps = (ChessProgramState *) ((char *) option - ((char *)&first.option - (char *)&first));
+ Widget texts[100], forelast = NULL, anchor, widest, lastrow = NULL, browse = NULL;
+ Dimension bWidth = 50;
+
+ if(shellUp[dlgNr]) return 0; // already up
+ if(dlgNr && shells[dlgNr]) {
+ XtPopup(shells[dlgNr], XtGrabNone);
+ shellUp[dlgNr] = True;
+ return 0;
+ }
-// if(cps->nrOptions > 50) width = 4; else if(cps->nrOptions>24) width = 2; else width = 1;
-// height = cps->nrOptions / width + 1;
+ dialogOptions[dlgNr] = option; // make available to callback
+ // post currentOption globally, so Spin and Combo callbacks can already use it
+ // WARNING: this kludge does not work for persistent dialogs, so that these cannot have spin or combo controls!
+ currentOption = option;
+
+ if(currentCps) { // Settings popup for engine: format through heuristic
+ int n = currentCps->nrOptions;
+ if(!n) { DisplayNote(_("Engine has no options")); currentCps = NULL; return 0; }
+ if(n > 50) width = 4; else if(n>24) width = 2; else width = 1;
+ height = n / width + 1;
+ if(n && (currentOption[n-1].type == Button || currentOption[n-1].type == SaveButton)) currentOption[n].min = SAME_ROW; // OK on same line
+ currentOption[n].type = EndMark; currentOption[n].target = NULL; // delimit list by callback-less end mark
+ }
i = 0;
XtSetArg(args[i], XtNresizable, True); i++;
- SettingsShell = popup =
+ popup = shells[dlgNr] =
XtCreatePopupShell(title, transientShellWidgetClass,
shellWidget, args, i);
option[i].value = *(float*)option[i].target;
goto tBox;
case Spin:
- snprintf(def, MSG_SIZ, "%d", option[i].value = *(int*)option[i].target);
+ if(!currentCps) option[i].value = *(int*)option[i].target;
+ snprintf(def, MSG_SIZ, "%d", option[i].value);
case TextBox:
case FileName:
case PathName:
XtSetArg(args[j], XtNright, XtChainLeft); j++;
XtSetArg(args[j], XtNborderWidth, 0); j++;
XtSetArg(args[j], XtNjustify, XtJustifyLeft); j++;
+ XtSetArg(args[j], XtNlabel, _(option[i].name)); j++;
texts[h] =
dialog = XtCreateManagedWidget(option[i].name, labelWidgetClass, form, args, j);
} else texts[h] = dialog = NULL;
XtSetArg(args[j], XtNfromHoriz, dialog); j++;
XtSetArg(args[j], XtNborderWidth, 1); j++;
XtSetArg(args[j], XtNwidth, w); j++;
- if(option[i].type == TextBox && option[i].min) XtSetArg(args[j], XtNheight, option[i].min); j++;
+ if(option[i].type == TextBox && option[i].min) {
+ XtSetArg(args[j], XtNheight, option[i].min); j++;
+ if(option[i].value & 1) { XtSetArg(args[j], XtNscrollVertical, XawtextScrollAlways); j++; }
+ if(option[i].value & 2) { XtSetArg(args[j], XtNscrollHorizontal, XawtextScrollAlways); j++; }
+ if(option[i].value & 4) { XtSetArg(args[j], XtNautoFill, True); j++; }
+ if(option[i].value & 8) { XtSetArg(args[j], XtNwrap, XawtextWrapWord); j++; }
+ }
XtSetArg(args[j], XtNleft, XtChainLeft); j++;
XtSetArg(args[j], XtNeditType, XawtextEdit); j++;
XtSetArg(args[j], XtNuseStringInPlace, False); j++;
XtSetArg(args[j], XtNdisplayCaret, False); j++;
XtSetArg(args[j], XtNright, XtChainRight); j++;
XtSetArg(args[j], XtNresizable, True); j++;
- XtSetArg(args[j], XtNstring, option[i].type==Spin || option[i].type==Fractional ? def : *(char**)option[i].target); j++;
XtSetArg(args[j], XtNinsertPosition, 9999); j++;
+ XtSetArg(args[j], XtNstring, option[i].type==Spin || option[i].type==Fractional ? def :
+ currentCps ? option[i].textValue : *(char**)option[i].target); j++;
edit = last;
option[i].handle = (void*)
(textField = last = XtCreateManagedWidget("text", asciiTextWidgetClass, form, args, j));
XtAddEventHandler(last, ButtonPressMask, False, SetFocus, (XtPointer) popup);
+ if(option[i].min == 0 || option[i].type != TextBox)
+ XtOverrideTranslations(last, XtParseTranslationTable(oneLiner));
if(option[i].type == TextBox || option[i].type == Fractional) break;
XtSetArg(args[j], XtNleft, XtChainRight); j++;
XtSetArg(args[j], XtNright, XtChainRight); j++;
if(option[i].type == FileName || option[i].type == PathName) {
- w = 50; msg = "browse";
+ msg = _("browse"); w = 0;
+ /* automatically scale to width of text */
+ XtSetArg(args[j], XtNwidth, (XtArgVal) NULL ); j++;
} else {
- XtSetArg(args[j], XtNheight, 10); j++;
w = 20; msg = "+";
+ XtSetArg(args[j], XtNheight, 10); j++;
+ XtSetArg(args[j], XtNwidth, w); j++;
}
- XtSetArg(args[j], XtNwidth, w); j++;
edit = XtCreateManagedWidget(msg, commandWidgetClass, form, args, j);
- XtAddCallback(edit, XtNcallback, SpinCallback,
- (XtPointer)(intptr_t) i);
+ XtAddCallback(edit, XtNcallback, SpinCallback, (XtPointer)(intptr_t) i);
+ if(w == 0) browse = edit;
if(option[i].type != Spin) break;
XtSetArg(args[j], XtNleft, XtChainRight); j++;
XtSetArg(args[j], XtNright, XtChainRight); j++;
last = XtCreateManagedWidget("-", commandWidgetClass, form, args, j);
- XtAddCallback(last, XtNcallback, SpinCallback,
- (XtPointer)(intptr_t) i);
+ XtAddCallback(last, XtNcallback, SpinCallback, (XtPointer)(intptr_t) i);
break;
case CheckBox:
+ if(!currentCps) option[i].value = *(Boolean*)option[i].target;
j=0;
XtSetArg(args[j], XtNfromVert, last); j++;
XtSetArg(args[j], XtNwidth, 10); j++;
XtSetArg(args[j], XtNheight, 10); j++;
XtSetArg(args[j], XtNleft, XtChainLeft); j++;
XtSetArg(args[j], XtNright, XtChainLeft); j++;
- XtSetArg(args[j], XtNstate, option[i].value = *(Boolean*)option[i].target); j++;
+ XtSetArg(args[j], XtNstate, option[i].value); j++;
option[i].handle = (void*)
(dialog = XtCreateManagedWidget(" ", toggleWidgetClass, form, args, j));
case Label:
XtSetArg(args[j], XtNleft, XtChainLeft); j++;
XtSetArg(args[j], XtNborderWidth, 0); j++;
XtSetArg(args[j], XtNjustify, XtJustifyLeft); j++;
+ XtSetArg(args[j], XtNlabel, _(msg)); j++;
last = XtCreateManagedWidget(msg, labelWidgetClass, form, args, j);
+ if(option[i].type == CheckBox)
+ XtAddEventHandler(last, ButtonPressMask, False, CheckCallback, (XtPointer)(intptr_t) i);
break;
+ case SaveButton:
case Button:
j=0;
- XtSetArg(args[j], XtNfromVert, option[i].min & 1 ? lastrow : last); j++;
- if(option[i].min & 1) { XtSetArg(args[j], XtNfromHoriz, last); j++; }
- else { XtSetArg(args[j], XtNfromHoriz, NULL); j++; lastrow = forelast; }
- if(option[i].max) XtSetArg(args[j], XtNwidth, option[i].max); j++;
+ if(option[i].min & SAME_ROW) {
+ XtSetArg(args[j], XtNfromVert, lastrow); j++;
+ XtSetArg(args[j], XtNfromHoriz, last); j++;
+ } else {
+ XtSetArg(args[j], XtNfromVert, last); j++;
+ XtSetArg(args[j], XtNfromHoriz, NULL); j++; lastrow = forelast;
+ }
+ XtSetArg(args[j], XtNlabel, _(option[i].name)); j++;
+ if(option[i].max) { XtSetArg(args[j], XtNwidth, option[i].max); j++; }
if(option[i].textValue) { // special for buttons of New Variant dialog
XtSetArg(args[j], XtNsensitive, appData.noChessProgram || option[i].value < 0
|| strstr(first.variants, VariantName(option[i].value))); j++;
}
option[i].handle = (void*)
(dialog = last = XtCreateManagedWidget(option[i].name, commandWidgetClass, form, args, j));
- if(option[i].target == NULL) SetColor( *(char**) option[i-1].target, last); else
+ if(option[i].choice && ((char*)option[i].choice)[0] == '#' && !currentCps) {
+ SetColor( *(char**) option[i-1].target, &option[i]);
+ XtAddEventHandler(option[i-1].handle, KeyReleaseMask, False, ColorChanged, (XtPointer)(intptr_t) i-1);
+ }
XtAddCallback(last, XtNcallback, GenericCallback,
- (XtPointer)(intptr_t) i);
- if(option[i].textValue) SetColor( option[i].textValue, last);
+ (XtPointer)(intptr_t) i + (dlgNr<<16));
+ if(option[i].textValue) SetColor( option[i].textValue, &option[i]);
forelast = lastrow; // next button can go on same row
break;
case ComboBox:
XtSetArg(args[j], XtNright, XtChainLeft); j++;
XtSetArg(args[j], XtNborderWidth, 0); j++;
XtSetArg(args[j], XtNjustify, XtJustifyLeft); j++;
+ XtSetArg(args[j], XtNlabel, _(option[i].name)); j++;
texts[h] = dialog = XtCreateManagedWidget(option[i].name, labelWidgetClass, form, args, j);
- for(j=0; option[i].choice[j]; j++)
+ if(currentCps) option[i].choice = (char**) option[i].textValue; else {
+ for(j=0; option[i].choice[j]; j++)
if(*(char**)option[i].target && !strcmp(*(char**)option[i].target, option[i].choice[j])) break;
- option[i].value = j + (option[i].choice[j] == NULL);
+ option[i].value = j + (option[i].choice[j] == NULL);
+ }
j=0;
XtSetArg(args[j], XtNfromVert, last); j++;
XtSetArg(args[j], XtNfromHoriz, dialog); j++;
- XtSetArg(args[j], XtNwidth, option[i].max ? option[i].max : 100); j++;
+ XtSetArg(args[j], XtNwidth, option[i].max && !currentCps ? option[i].max : 100); j++;
XtSetArg(args[j], XtNleft, XtChainLeft); j++;
XtSetArg(args[j], XtNmenuName, XtNewString(option[i].name)); j++;
- XtSetArg(args[j], XtNlabel, ((char**)option[i].textValue)[option[i].value]); j++;
+ XtSetArg(args[j], XtNlabel, _(((char**)option[i].textValue)[option[i].value])); j++;
option[i].handle = (void*)
(last = XtCreateManagedWidget(" ", menuButtonWidgetClass, form, args, j));
- CreateComboPopup(last, option[i].name, i, (char **) option[i].textValue);
+ CreateComboPopup(last, option + i, i);
values[i] = option[i].value;
break;
case Break:
// make an attempt to align all spins and textbox controls
maxWidth = maxTextWidth = 0;
+ if(browse != NULL) {
+ j=0;
+ XtSetArg(args[j], XtNwidth, &bWidth); j++;
+ XtGetValues(browse, args, j);
+ }
for(h=0; h<height; h++) {
i = h + c*height;
if(option[i].type == EndMark) break;
for(h=0; h<height; h++) {
i = h + c*height;
if(option[i].type == EndMark) break;
- if(!texts[h]) continue;
+ if(!texts[h]) continue; // Note: texts[h] can be undefined (giving errors in valgrind), but then both if's below will be false.
j=0;
if(option[i].type == Spin) {
XtSetArg(args[j], XtNwidth, maxWidth); j++;
if(option[i].type == TextBox || option[i].type == ComboBox || option[i].type == PathName || option[i].type == FileName) {
XtSetArg(args[j], XtNwidth, maxTextWidth); j++;
XtSetValues(texts[h], args, j);
+ if(bWidth != 50 && (option[i].type == FileName || option[i].type == PathName)) {
+ int tWidth = (option[i].max ? option[i].max : 205) - 5 - bWidth;
+ j = 0;
+ XtSetArg(args[j], XtNwidth, tWidth); j++;
+ XtSetValues(option[i].handle, args, j);
+ }
}
}
}
- if(!(option[i].min & 2)) {
+ if(!(option[i].min & NO_OK)) {
j=0;
- if(option[i].min & 1) { XtSetArg(args[j], XtNfromHoriz, last); last = forelast; } else
+ if(option[i].min & SAME_ROW) {
+ for(j=i-1; option[j+1].min & SAME_ROW && option[j].type == Button; j--) {
+ XtSetArg(args[0], XtNtop, XtChainBottom);
+ XtSetArg(args[1], XtNbottom, XtChainBottom);
+ XtSetValues(option[j].handle, args, 2);
+ }
+ if(option[j].type == TextBox && option[j].name[0] == NULLCHAR) {
+ XtSetArg(args[0], XtNbottom, XtChainBottom);
+ XtSetValues(option[j].handle, args, 1);
+ }
+ j = 0;
+ XtSetArg(args[j], XtNfromHoriz, last); last = forelast;
+ } else
XtSetArg(args[j], XtNfromHoriz, widest ? widest : dialog); j++;
XtSetArg(args[j], XtNfromVert, anchor ? anchor : last); j++;
XtSetArg(args[j], XtNbottom, XtChainBottom); j++;
XtSetArg(args[j], XtNleft, XtChainRight); j++;
XtSetArg(args[j], XtNright, XtChainRight); j++;
b_ok = XtCreateManagedWidget(_("OK"), commandWidgetClass, form, args, j);
- XtAddCallback(b_ok, XtNcallback, GenericCallback, (XtPointer) 0);
+ XtAddCallback(b_ok, XtNcallback, GenericCallback, (XtPointer)(intptr_t) dlgNr + (dlgNr<<16));
XtSetArg(args[0], XtNfromHoriz, b_ok);
b_cancel = XtCreateManagedWidget(_("cancel"), commandWidgetClass, form, args, j);
- XtAddCallback(b_cancel, XtNcallback, SettingsPopDown, (XtPointer) 0);
+ XtAddCallback(b_cancel, XtNcallback, GenericCallback, (XtPointer)(intptr_t) dlgNr);
}
XtRealizeWidget(popup);
- CatchDeleteWindow(popup, "SettingsPopDown");
-
+ XSetWMProtocols(xDisplay, XtWindow(popup), &wm_delete_window, 1);
+ snprintf(def, MSG_SIZ, "<Message>WM_PROTOCOLS: GenericPopDown(\"%d\") \n", dlgNr);
+ XtAugmentTranslations(popup, XtParseTranslationTable(def));
XQueryPointer(xDisplay, xBoardWindow, &root, &child,
&x, &y, &win_x, &win_y, &mask);
XtSetArg(args[1], XtNy, y - 30);
XtSetValues(popup, args, 2);
- XtPopup(popup, XtGrabExclusive);
- SettingsUp = True;
-
+ XtPopup(popup, dlgNr ? XtGrabNone : XtGrabExclusive);
+ shellUp[dlgNr] = True;
previous = NULL;
if(textField)SetFocus(textField, popup, (XEvent*) NULL, False);
+ if(dlgNr && wp[dlgNr] && wp[dlgNr]->width > 0) { // if persistent window-info available, reposition
+ j = 0;
+ XtSetArg(args[j], XtNheight, (Dimension) (wp[dlgNr]->height)); j++;
+ XtSetArg(args[j], XtNwidth, (Dimension) (wp[dlgNr]->width)); j++;
+ XtSetArg(args[j], XtNx, (Position) (wp[dlgNr]->x)); j++;
+ XtSetArg(args[j], XtNy, (Position) (wp[dlgNr]->y)); j++;
+ XtSetValues(popup, args, j);
+ }
+ return 1;
}
String *prms;
Cardinal *nprms;
{
- GenericPopUp(icsOptions, _("ICS Options"));
+ GenericPopUp(icsOptions, _("ICS Options"), 0);
}
void LoadOptionsProc(w, event, prms, nprms)
String *prms;
Cardinal *nprms;
{
- GenericPopUp(loadOptions, _("Load Game Options"));
+ ASSIGN(searchMode, modeValues[appData.searchMode-1]);
+ GenericPopUp(loadOptions, _("Load Game Options"), 0);
}
void SaveOptionsProc(w, event, prms, nprms)
String *prms;
Cardinal *nprms;
{
- GenericPopUp(saveOptions, _("Save Game Options"));
+ GenericPopUp(saveOptions, _("Save Game Options"), 0);
}
void SoundOptionsProc(w, event, prms, nprms)
String *prms;
Cardinal *nprms;
{
- soundFiles[2] = "*";
- GenericPopUp(soundOptions, _("Sound Options"));
+ free(soundFiles[2]);
+ soundFiles[2] = strdup("*");
+ GenericPopUp(soundOptions, _("Sound Options"), 0);
}
void BoardOptionsProc(w, event, prms, nprms)
String *prms;
Cardinal *nprms;
{
- GenericPopUp(boardOptions, _("Board Options"));
+ GenericPopUp(boardOptions, _("Board Options"), 0);
}
void EngineMenuProc(w, event, prms, nprms)
String *prms;
Cardinal *nprms;
{
- GenericPopUp(adjudicationOptions, "Adjudicate non-ICS Games");
+ GenericPopUp(adjudicationOptions, _("Adjudicate non-ICS Games"), 0);
}
void UciMenuProc(w, event, prms, nprms)
{
oldCores = appData.smpCores;
oldPonder = appData.ponderNextMove;
- GenericPopUp(commonEngineOptions, _("Common Engine Settings"));
+ GenericPopUp(commonEngineOptions, _("Common Engine Settings"), 0);
}
void NewVariantProc(w, event, prms, nprms)
String *prms;
Cardinal *nprms;
{
- GenericPopUp(variantDescriptors, _("New Variant"));
+ GenericPopUp(variantDescriptors, _("New Variant"), 0);
}
void OptionsProc(w, event, prms, nprms)
Cardinal *nprms;
{
oldPonder = appData.ponderNextMove;
- GenericPopUp(generalOptions, _("General Options"));
+ GenericPopUp(generalOptions, _("General Options"), 0);
+}
+
+void MatchOptionsProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ NamesToList(firstChessProgramNames, engineList, engineMnemonic);
+ comboCallback = &AddToTourney;
+ matchOptions[5].min = -(appData.pairingEngine[0] != NULLCHAR); // with pairing engine, allow Swiss
+ ASSIGN(tfName, appData.tourneyFile[0] ? appData.tourneyFile : MakeName(appData.defName));
+ ASSIGN(engineName, appData.participants);
+ GenericPopUp(matchOptions, _("Match Options"), 0);
+}
+
+Option textOptions[100];
+void PutText P((char *text, int pos));
+
+void SendString(char *p)
+{
+ char buf[MSG_SIZ], *q;
+ if(q = strstr(p, "$input")) {
+ if(!shellUp[4]) return;
+ strncpy(buf, p, MSG_SIZ);
+ strncpy(buf + (q-p), q+6, MSG_SIZ-(q-p));
+ PutText(buf, q-p);
+ return;
+ }
+ snprintf(buf, MSG_SIZ, "%s\n", p);
+ SendToICS(buf);
+}
+
+/* function called when the data to Paste is ready */
+static void
+SendTextCB(Widget w, XtPointer client_data, Atom *selection,
+ Atom *type, XtPointer value, unsigned long *len, int *format)
+{
+ char buf[MSG_SIZ], *p = (char*) textOptions[(int)(intptr_t) client_data].choice, *name = (char*) value, *q;
+ if (value==NULL || *len==0) return; /* nothing selected, abort */
+ name[*len]='\0';
+ strncpy(buf, p, MSG_SIZ);
+ q = strstr(p, "$name");
+ snprintf(buf + (q-p), MSG_SIZ -(q-p), "%s%s", name, q+5);
+ SendString(buf);
+ XtFree(value);
+}
+
+void SendText(int n)
+{
+ char *p = (char*) textOptions[n].choice;
+ if(strstr(p, "$name")) {
+ XtGetSelectionValue(menuBarWidget,
+ XA_PRIMARY, XA_STRING,
+ /* (XtSelectionCallbackProc) */ SendTextCB,
+ (XtPointer) (intptr_t) n, /* client_data passed to PastePositionCB */
+ CurrentTime
+ );
+ } else SendString(p);
+}
+
+void IcsTextProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ int i=0, j;
+ char *p, *q, *r;
+ if((p = icsTextMenuString) == NULL) return;
+ do {
+ q = r = p; while(*p && *p != ';') p++;
+ for(j=0; j<p-q; j++) textOptions[i].name[j] = *r++;
+ textOptions[i].name[j++] = 0;
+ if(!*p) break;
+ if(*++p == '\n') p++; // optional linefeed after button-text terminating semicolon
+ q = p;
+ textOptions[i].choice = (char**) (r = textOptions[i].name + j);
+ while(*p && (*p != ';' || p[1] != '\n')) textOptions[i].name[j++] = *p++;
+ textOptions[i].name[j++] = 0;
+ if(*p) p += 2;
+ textOptions[i].max = 135;
+ textOptions[i].min = i&1;
+ textOptions[i].handle = NULL;
+ textOptions[i].target = &SendText;
+ textOptions[i].textValue = strstr(r, "$input") ? "#80FF80" : strstr(r, "$name") ? "#FF8080" : "#FFFFFF";
+ textOptions[i].type = Button;
+ } while(++i < 99 && *p);
+ if(i == 0) return;
+ textOptions[i].type = EndMark;
+ textOptions[i].target = NULL;
+ textOptions[i].min = 2;
+ MarkMenu("menuView.ICStex", 3);
+ GenericPopUp(textOptions, _("ICS text menu"), 3);
+}
+
+static char *commentText;
+static int commentIndex;
+void ClearComment P((int n));
+extern char commentTranslations[];
+
+int NewComCallback(int n)
+{
+ ReplaceComment(commentIndex, commentText);
+ return 1;
+}
+
+void SaveChanges(int n)
+{
+ GenericReadout(0);
+ ReplaceComment(commentIndex, commentText);
+}
+
+Option commentOptions[] = {
+{ 0xD, 200, 250, NULL, (void*) &commentText, "", NULL, TextBox, "" },
+{ 0, 0, 50, NULL, (void*) &ClearComment, NULL, NULL, Button, N_("clear") },
+{ 0, 1, 100, NULL, (void*) &SaveChanges, NULL, NULL, Button, N_("save changes") },
+{ 0, 1, 0, NULL, (void*) &NewComCallback, "", NULL, EndMark , "" }
+};
+
+void ClearTextWidget(Option *opt)
+{
+// XtCallActionProc(opt->handle, "select-all", NULL, NULL, 0);
+// XtCallActionProc(opt->handle, "kill-selection", NULL, NULL, 0);
+ Arg arg;
+ XtSetArg(arg, XtNstring, ""); // clear without disturbing selection!
+ XtSetValues(opt->handle, &arg, 1);
+}
+
+void ClearComment(int n)
+{
+ ClearTextWidget(&commentOptions[0]);
+}
+
+void NewCommentPopup(char *title, char *text, int index)
+{
+ Arg args[16];
+
+ if(shells[1]) { // if already exists, alter title and content
+ XtSetArg(args[0], XtNtitle, title);
+ XtSetValues(shells[1], args, 1);
+ SetWidgetText(&commentOptions[0], text, 1);
+ }
+ if(commentText) free(commentText); commentText = strdup(text);
+ commentIndex = index;
+ MarkMenu("menuView.Show Comments", 1);
+ if(GenericPopUp(commentOptions, title, 1))
+ XtOverrideTranslations(commentOptions[0].handle, XtParseTranslationTable(commentTranslations));
+}
+
+static char *tagsText;
+
+int NewTagsCallback(int n)
+{
+ ReplaceTags(tagsText, &gameInfo);
+ return 1;
+}
+
+void changeTags(int n)
+{
+ GenericReadout(1);
+ if(bookUp) SaveToBook(tagsText); else
+ ReplaceTags(tagsText, &gameInfo);
+}
+
+Option tagsOptions[] = {
+{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, "" },
+{ 0xD, 200, 200, NULL, (void*) &tagsText, "", NULL, TextBox, "" },
+{ 0, 0, 100, NULL, (void*) &changeTags, NULL, NULL, Button, N_("save changes") },
+{ 0, 1, 0, NULL, (void*) &NewTagsCallback, "", NULL, EndMark , "" }
+};
+
+void NewTagsPopup(char *text, char *msg)
+{
+ Arg args[16];
+ char *title = bookUp ? _("Edit book") : _("Tags");
+
+ if(shells[2]) { // if already exists, alter title and content
+ SetWidgetText(&tagsOptions[1], text, 2);
+ XtSetArg(args[0], XtNtitle, title);
+ XtSetValues(shells[2], args, 1);
+ }
+ if(tagsText) free(tagsText); tagsText = strdup(text);
+ tagsOptions[0].textValue = msg;
+ MarkMenu("menuView.Show Tags", 2);
+ GenericPopUp(tagsOptions, title, 2);
+}
+
+char *icsText;
+
+Option boxOptions[] = {
+{ 0, 30, 400, NULL, (void*) &icsText, "", NULL, TextBox, "" },
+{ 0, 3, 0, NULL, NULL, "", NULL, EndMark , "" }
+};
+
+void PutText(char *text, int pos)
+{
+ Arg args[16];
+ char buf[MSG_SIZ], *p;
+
+ if(strstr(text, "$add ") == text) {
+ GetWidgetText(&boxOptions[0], &p);
+ snprintf(buf, MSG_SIZ, "%s%s", p, text+5); text = buf;
+ pos += strlen(p) - 5;
+ }
+ SetWidgetText(&boxOptions[0], text, 4);
+ XtSetArg(args[0], XtNinsertPosition, pos);
+ XtSetValues(boxOptions[0].handle, args, 1);
+// SetFocus(boxOptions[0].handle, shells[4], NULL, False); // No idea why this does not work, and the following is needed:
+ XSetInputFocus(xDisplay, XtWindow(boxOptions[0].handle), RevertToPointerRoot, CurrentTime);
+}
+
+void InputBoxPopup()
+{
+ MarkMenu("menuView.ICS Input Box", 4);
+ if(GenericPopUp(boxOptions, _("ICS input box"), 4))
+ XtOverrideTranslations(boxOptions[0].handle, XtParseTranslationTable(ICSInputTranslations));
+}
+
+void TypeInProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ char *val;
+
+ if(prms[0][0] == '1') {
+ GetWidgetText(&boxOptions[0], &val);
+ TypeInDoneEvent(val);
+ }
+ PopDown(0);
+}
+
+char moveTypeInTranslations[] =
+ "<Key>Return: TypeInProc(1) \n"
+ "<Key>Escape: TypeInProc(0) \n";
+
+void PopUpMoveDialog(char firstchar)
+{
+ static char buf[2];
+ buf[0] = firstchar; icsText = buf;
+ if(GenericPopUp(boxOptions, _("Type a move"), 0))
+ XtOverrideTranslations(boxOptions[0].handle, XtParseTranslationTable(moveTypeInTranslations));
+}
+
+void MoveTypeInProc(Widget widget, caddr_t unused, XEvent *event)
+{
+ char buf[10], keys[32];
+ KeySym sym;
+ KeyCode metaL, metaR, ctrlL, ctrlR;
+ int n = XLookupString(&(event->xkey), buf, 10, &sym, NULL);
+ XQueryKeymap(xDisplay,keys);
+ metaL = XKeysymToKeycode(xDisplay, XK_Meta_L);
+ metaR = XKeysymToKeycode(xDisplay, XK_Meta_R);
+ ctrlL = XKeysymToKeycode(xDisplay, XK_Control_L);
+ ctrlR = XKeysymToKeycode(xDisplay, XK_Control_R);
+ if ( n == 1 && *buf >= 32 // printable
+ && !(keys[metaL>>3]&1<<(metaL&7)) && !(keys[metaR>>3]&1<<(metaR&7)) // no alt key pressed
+ && !(keys[ctrlL>>3]&1<<(ctrlL&7)) && !(keys[ctrlR>>3]&1<<(ctrlR&7)) // no ctrl key pressed
+ )
+ {
+ if(appData.icsActive) { // text typed to board in ICS mode: divert to ICS input box
+ if(shells[4]) { // box already exists: append to current contents
+ char *p, newText[MSG_SIZ];
+ GetWidgetText(&boxOptions[0], &p);
+ snprintf(newText, MSG_SIZ, "%s%c", p, *buf);
+ SetWidgetText(&boxOptions[0], newText, 4);
+ if(shellUp[4]) XSetInputFocus(xDisplay, XtWindow(boxOptions[0].handle), RevertToPointerRoot, CurrentTime); //why???
+ } else icsText = buf; // box did not exist: make sure it pops up with char in it
+ InputBoxPopup();
+ } else PopUpMoveDialog(*buf);
+ }
+}
+
+void
+SettingsPopUp(ChessProgramState *cps)
+{
+ currentCps = cps;
+ GenericPopUp(cps->option, _("Engine Settings"), 0);
+}
+
+void FirstSettingsProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ SettingsPopUp(&first);
+}
+
+void SecondSettingsProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ if(WaitForEngine(&second, SettingsMenuIfReady)) return;
+ SettingsPopUp(&second);
+}
+
+int InstallOK(int n)
+{
+ PopDown(0); // early popdown, to allow FreezeUI to instate grab
+ if(engineChoice[0] == engineNr[0][0]) Load(&first, 0); else Load(&second, 1);
+ return 1;
+}
+
+Option installOptions[] = {
+{ 0, NO_GETTEXT, 0, NULL, (void*) &engineLine, (char*) engineMnemonic, engineList, ComboBox, N_("Select engine from list:") },
+{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, N_("or specify one below:") },
+{ 0, 0, 0, NULL, (void*) &nickName, NULL, NULL, TextBox, N_("Nickname (optional):") },
+{ 0, 0, 0, NULL, (void*) &useNick, NULL, NULL, CheckBox, N_("Use nickname in PGN player tags of engine-engine games") },
+{ 0, 0, 0, NULL, (void*) &engineDir, NULL, NULL, PathName, N_("Engine Directory:") },
+{ 0, 0, 0, NULL, (void*) &engineName, NULL, NULL, FileName, N_("Engine Command:") },
+{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, N_("(Directory will be derived from engine path when empty)") },
+{ 0, 0, 0, NULL, (void*) &isUCI, NULL, NULL, CheckBox, N_("UCI") },
+{ 0, 0, 0, NULL, (void*) &v1, NULL, NULL, CheckBox, N_("WB protocol v1 (do not wait for engine features)") },
+{ 0, 0, 0, NULL, (void*) &hasBook, NULL, NULL, CheckBox, N_("Must not use GUI book") },
+{ 0, 0, 0, NULL, (void*) &addToList, NULL, NULL, CheckBox, N_("Add this engine to the list") },
+{ 0, 0, 0, NULL, (void*) &storeVariant, NULL, NULL, CheckBox, N_("Force current variant with this engine") },
+{ 0, 0, 0, NULL, (void*) &engineChoice, (char*) engineNr, engineNr, ComboBox, N_("Load mentioned engine as") },
+{ 0, 1, 0, NULL, (void*) &InstallOK, "", NULL, EndMark , "" }
+};
+
+void LoadEngineProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ isUCI = storeVariant = v1 = useNick = False; addToList = hasBook = True; // defaults
+ if(engineChoice) free(engineChoice); engineChoice = strdup(engineNr[0]);
+ if(engineLine) free(engineLine); engineLine = strdup("");
+ if(engineDir) free(engineDir); engineDir = strdup("");
+ if(nickName) free(nickName); nickName = strdup("");
+ if(params) free(params); params = strdup("");
+ NamesToList(firstChessProgramNames, engineList, engineMnemonic);
+ GenericPopUp(installOptions, _("Load engine"), 0);
+}
+
+void EditBookProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ EditBookEvent();
+}
+
+void SetRandom P((int n));
+
+int ShuffleOK(int n)
+{
+ ResetGameEvent();
+ return 1;
+}
+
+Option shuffleOptions[] = {
+ { 0, 0, 50, NULL, (void*) &shuffleOpenings, NULL, NULL, CheckBox, N_("shuffle") },
+ { 0,-1,2000000000, NULL, (void*) &appData.defaultFrcPosition, "", NULL, Spin, N_("Start-position number:") },
+ { 0, 0, 0, NULL, (void*) &SetRandom, NULL, NULL, Button, N_("randomize") },
+ { 0, 1, 0, NULL, (void*) &SetRandom, NULL, NULL, Button, N_("pick fixed") },
+ { 0, 1, 0, NULL, (void*) &ShuffleOK, "", NULL, EndMark , "" }
+};
+
+void SetRandom(int n)
+{
+ int r = n==2 ? -1 : random() & (1<<30)-1;
+ char buf[MSG_SIZ];
+ snprintf(buf, MSG_SIZ, "%d", r);
+ SetWidgetText(&shuffleOptions[1], buf, 0);
+ SetWidgetState(&shuffleOptions[0], True);
+}
+
+void ShuffleMenuProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ GenericPopUp(shuffleOptions, _("New Shuffle Game"), 0);
+}
+
+int tmpMoves, tmpTc, tmpInc, tmpOdds1, tmpOdds2, tcType;
+
+void ShowTC(int n)
+{
+}
+
+void SetTcType P((int n));
+
+char *Value(int n)
+{
+ static char buf[MSG_SIZ];
+ snprintf(buf, MSG_SIZ, "%d", n);
+ return buf;
+}
+
+int TcOK(int n)
+{
+ char *tc;
+ if(tcType == 0 && tmpMoves <= 0) return 0;
+ if(tcType == 2 && tmpInc <= 0) return 0;
+ GetWidgetText(¤tOption[4], &tc); // get original text, in case it is min:sec
+ searchTime = 0;
+ switch(tcType) {
+ case 0:
+ if(!ParseTimeControl(tc, -1, tmpMoves)) return 0;
+ appData.movesPerSession = tmpMoves;
+ ASSIGN(appData.timeControl, tc);
+ appData.timeIncrement = -1;
+ break;
+ case 1:
+ if(!ParseTimeControl(tc, tmpInc, 0)) return 0;
+ ASSIGN(appData.timeControl, tc);
+ appData.timeIncrement = tmpInc;
+ break;
+ case 2:
+ searchTime = tmpInc;
+ }
+ appData.firstTimeOdds = first.timeOdds = tmpOdds1;
+ appData.secondTimeOdds = second.timeOdds = tmpOdds2;
+ Reset(True, True);
+ return 1;
+}
+
+Option tcOptions[] = {
+{ 0, 0, 0, NULL, (void*) &SetTcType, NULL, NULL, Button, N_("classical") },
+{ 0, 1, 0, NULL, (void*) &SetTcType, NULL, NULL, Button, N_("incremental") },
+{ 0, 1, 0, NULL, (void*) &SetTcType, NULL, NULL, Button, N_("fixed max") },
+{ 0, 0, 200, NULL, (void*) &tmpMoves, NULL, NULL, Spin, N_("Moves per session:") },
+{ 0, 0,10000, NULL, (void*) &tmpTc, NULL, NULL, Spin, N_("Initial time (min):") },
+{ 0, 0, 10000, NULL, (void*) &tmpInc, NULL, NULL, Spin, N_("Increment or max (sec/move):") },
+{ 0, 0, 0, NULL, NULL, NULL, NULL, Label, N_("Time-Odds factors:") },
+{ 0, 1, 1000, NULL, (void*) &tmpOdds1, NULL, NULL, Spin, N_("Engine #1") },
+{ 0, 1, 1000, NULL, (void*) &tmpOdds2, NULL, NULL, Spin, N_("Engine #2 / Human") },
+{ 0, 0, 0, NULL, (void*) &TcOK, "", NULL, EndMark , "" }
+};
+
+void SetTcType(int n)
+{
+ switch(tcType = n) {
+ case 0:
+ SetWidgetText(&tcOptions[3], Value(tmpMoves), 0);
+ SetWidgetText(&tcOptions[4], Value(tmpTc), 0);
+ SetWidgetText(&tcOptions[5], _("Unused"), 0);
+ break;
+ case 1:
+ SetWidgetText(&tcOptions[3], _("Unused"), 0);
+ SetWidgetText(&tcOptions[4], Value(tmpTc), 0);
+ SetWidgetText(&tcOptions[5], Value(tmpInc), 0);
+ break;
+ case 2:
+ SetWidgetText(&tcOptions[3], _("Unused"), 0);
+ SetWidgetText(&tcOptions[4], _("Unused"), 0);
+ SetWidgetText(&tcOptions[5], Value(tmpInc), 0);
+ }
+}
+
+void TimeControlProc(w, event, prms, nprms)
+ Widget w;
+ XEvent *event;
+ String *prms;
+ Cardinal *nprms;
+{
+ tmpMoves = appData.movesPerSession;
+ tmpInc = appData.timeIncrement; if(tmpInc < 0) tmpInc = 0;
+ tmpOdds1 = tmpOdds2 = 1; tcType = 0;
+ tmpTc = atoi(appData.timeControl);
+ GenericPopUp(tcOptions, _("Time Control"), 0);
}
//---------------------------- Chat Windows ----------------------------------------------