void
GenericUpdate (Option *opts, int selected)
{
- int i, j;
+ int i;
char buf[MSG_SIZ];
- float x;
- for(i=0; ; i++) {
- if(selected >= 0) { if(i < selected) continue; else if(i > selected) break; }
- switch(opts[i].type) {
- case TextBox:
- case FileName:
- case PathName:
- SetWidgetText(&opts[i], *(char**) opts[i].target, -1);
- break;
- case Spin:
- sprintf(buf, "%d", *(int*) opts[i].target);
- SetWidgetText(&opts[i], buf, -1);
- break;
- case Fractional:
- sprintf(buf, "%4.2f", *(float*) opts[i].target);
- SetWidgetText(&opts[i], buf, -1);
- break;
- case CheckBox:
- SetWidgetState(&opts[i], *(Boolean*) opts[i].target);
- break;
- case ComboBox:
- if(opts[i].min & COMBO_CALLBACK) break;
- SetCurrentComboSelection(opts+i);
- // TODO: actually display this (but it is never used that way...)
- break;
- case EndMark:
- return;
- default:
- printf("GenericUpdate: unexpected case in switch.\n");
- case ListBox:
- case Button:
- case SaveButton:
- case Label:
- case Break:
- break;
- }
- }
+
+ for(i=0; ; i++)
+ {
+ if(selected >= 0) { if(i < selected) continue; else if(i > selected) break; }
+ switch(opts[i].type)
+ {
+ case TextBox:
+ case FileName:
+ case PathName:
+ SetWidgetText(&opts[i], *(char**) opts[i].target, -1);
+ break;
+ case Spin:
+ sprintf(buf, "%d", *(int*) opts[i].target);
+ SetWidgetText(&opts[i], buf, -1);
+ break;
+ case Fractional:
+ sprintf(buf, "%4.2f", *(float*) opts[i].target);
+ SetWidgetText(&opts[i], buf, -1);
+ break;
+ case CheckBox:
+ SetWidgetState(&opts[i], *(Boolean*) opts[i].target);
+ break;
+ case ComboBox:
+ if(opts[i].min & COMBO_CALLBACK) break;
+ SetCurrentComboSelection(opts+i);
+ // TODO: actually display this (but it is never used that way...)
+ break;
+ case EndMark:
+ return;
+ default:
+ printf("GenericUpdate: unexpected case in switch.\n");
+ case ListBox:
+ case Button:
+ case SaveButton:
+ case Label:
+ case Break:
+ break;
+ }
+ }
}
//------------------------------------------- Read out dialog controls ------------------------------------
break;
case ComboBox:
if(opts[i].min & COMBO_CALLBACK) break;
- if(!opts[i].textValue) { *(int*)opts[i].target == opts[i].value; break; } // numeric
+ if(!opts[i].textValue) { *(int*)opts[i].target = values[i]; break; } // numeric
val = ((char**)opts[i].textValue)[values[i]];
if(currentCps) {
if(opts[i].value == values[i]) break; // not changed
Test (int n)
{
GenericReadout(soundOptions, 2);
- if(soundFiles[values[3]]) PlaySound(soundFiles[values[3]]);
+ if(soundFiles[values[3]]) PlaySoundFile(soundFiles[values[3]]);
}
void
if((p = icsTextMenuString) == NULL) return;
do {
q = r = p; while(*p && *p != ';') p++;
+ if(textOptions[i].name == NULL) textOptions[i].name = (char*) malloc(MSG_SIZ);
for(j=0; j<p-q; j++) textOptions[i].name[j] = *r++;
textOptions[i].name[j++] = 0;
if(!*p) break;
void
EditCommentProc ()
{
- int j;
if (PopDown(CommentDlg)) { // popdown succesful
// MarkMenuItem("Edit.EditComment", False);
// MarkMenuItem("View.Comments", False);
// end of borrowed code
Option boxOptions[] = {
-{ 30, 0, 400, NULL, (void*) &icsText, "", NULL, TextBox, "" },
-{ 0,SAME_ROW | NO_OK, 0, NULL, NULL, "", NULL, EndMark , "" }
+{ 30, T_TOP, 400, NULL, (void*) &icsText, "", NULL, TextBox, "" },
+{ 0, NO_OK, 0, NULL, NULL, "", NULL, EndMark , "" }
};
void
GetWidgetText(&boxOptions[0], &val);
SaveInHistory(val);
SendMultiLineToICS(val);
- SetWidgetText(&boxOptions[0], val, InputBoxDlg);
+ SetWidgetText(&boxOptions[0], "", InputBoxDlg);
}
void
}
SetWidgetText(&boxOptions[0], text, TextMenuDlg);
SetInsertPos(&boxOptions[0], pos);
+ HardSetFocus(&boxOptions[0]);
}
void
static int TypeInOK P((int n));
Option typeOptions[] = {
-{ 30, 0, 400, NULL, (void*) &icsText, "", NULL, TextBox, "" },
-{ 0, SAME_ROW | NO_OK, 0, NULL, (void*) &TypeInOK, "", NULL, EndMark , "" }
+{ 30, T_TOP, 400, NULL, (void*) &icsText, "", NULL, TextBox, "" },
+{ 0, NO_OK, 0, NULL, (void*) &TypeInOK, "", NULL, EndMark , "" }
};
static int
static int TcOK P((int n));
int tmpMoves, tmpTc, tmpInc, tmpOdds1, tmpOdds2, tcType;
-static void
-ShowTC (int n)
-{
-}
-
static void SetTcType P((int n));
static char *
static void PromoPick P((int n));
static Option promoOptions[] = {
-{ 0, 0, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, "" },
-{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, "" },
-{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, "" },
-{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, "" },
-{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, "" },
-{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, "" },
-{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, "" },
+{ 0, 0, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, NULL },
+{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, NULL },
+{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, NULL },
+{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, NULL },
+{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, NULL },
+{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, NULL },
+{ 0, SAME_ROW, 0, NULL, (void*) &PromoPick, NULL, NULL, Button, NULL },
{ 0, SAME_ROW | NO_OK, 0, NULL, NULL, "", NULL, EndMark , "" }
};
static void
SetPromo (char *name, int nr, char promoChar)
{
- safeStrCpy(promoOptions[nr].name, name, MSG_SIZ);
+ ASSIGN(promoOptions[nr].name, name);
promoOptions[nr].value = promoChar;
+ promoOptions[nr].min = SAME_ROW;
}
void
SetPromo(_("Defer"), --count, '=');
SetPromo(_("Promote"), --count, '+');
}
+ promoOptions[count].min = 0;
GenericPopUp(promoOptions + count, "Promotion", PromoDlg, BoardWindow, NONMODAL, 0);
}
//---------------------------- Chat Windows ----------------------------------------------
+static char *line, *memo, *partner, *texts[MAX_CHAT], dirty[MAX_CHAT];
+static int activePartner;
+
+void ChatSwitch P((int n));
+int ChatOK P((int n));
+
+Option chatOptions[] = {
+{ 0, T_TOP, 100, NULL, (void*) &partner, NULL, NULL, TextBox, N_("Chat partner:") },
+{ 1, SAME_ROW|TT, 75, NULL, (void*) &ChatSwitch, NULL, NULL, Button, "" },
+{ 2, SAME_ROW|TT, 75, NULL, (void*) &ChatSwitch, NULL, NULL, Button, "" },
+{ 3, SAME_ROW|TT, 75, NULL, (void*) &ChatSwitch, NULL, NULL, Button, "" },
+{ 4, SAME_ROW|TT, 75, NULL, (void*) &ChatSwitch, NULL, NULL, Button, "" },
+{ 100, T_VSCRL | T_FILL | T_WRAP | T_TOP, 510, NULL, (void*) &memo, NULL, NULL, TextBox, "" },
+{ 0, 0, 510, NULL, (void*) &line, NULL, NULL, TextBox, "" },
+{ 0, NO_OK|SAME_ROW, 0, NULL, (void*) &ChatOK, NULL, NULL, EndMark , "" }
+};
+
void
OutputChatMessage (int partner, char *mess)
{
- return; // dummy
+ char *p = texts[partner];
+ int len = strlen(mess) + 1;
+
+ if(p) len += strlen(p);
+ texts[partner] = (char*) malloc(len);
+ snprintf(texts[partner], len, "%s%s", p ? p : "", mess);
+ FREE(p);
+ if(partner == activePartner) {
+ AppendText(&chatOptions[5], mess);
+ SetInsertPos(&chatOptions[5], len-2);
+ } else {
+ SetColor("#FFC000", &chatOptions[partner + (partner < activePartner)]);
+ dirty[partner] = 1;
+ }
+}
+
+int
+ChatOK (int n)
+{ // can only be called through <Enter> in chat-partner text-edit, as there is no OK button
+ char buf[MSG_SIZ];
+ if(!partner || strcmp(partner, chatPartner[activePartner])) {
+ safeStrCpy(chatPartner[activePartner], partner, MSG_SIZ);
+ SetWidgetText(&chatOptions[5], "", -1); // clear text if we alter partner
+ SetWidgetText(&chatOptions[6], "", ChatDlg); // clear text if we alter partner
+ HardSetFocus(&chatOptions[6]);
+ }
+ if(line[0]) { // something was typed
+ SetWidgetText(&chatOptions[6], "", ChatDlg);
+ // from here on it could be back-end
+ if(line[strlen(line)-1] == '\n') line[strlen(line)-1] = NULLCHAR;
+ SaveInHistory(line);
+ if(!strcmp("whispers", chatPartner[activePartner]))
+ snprintf(buf, MSG_SIZ, "whisper %s\n", line); // WHISPER box uses "whisper" to send
+ else if(!strcmp("shouts", chatPartner[activePartner]))
+ snprintf(buf, MSG_SIZ, "shout %s\n", line); // SHOUT box uses "shout" to send
+ else {
+ if(!atoi(chatPartner[activePartner])) {
+ snprintf(buf, MSG_SIZ, "> %s\n", line); // echo only tells to handle, not channel
+ OutputChatMessage(activePartner, buf);
+ snprintf(buf, MSG_SIZ, "xtell %s %s\n", chatPartner[activePartner], line);
+ } else
+ snprintf(buf, MSG_SIZ, "tell %s %s\n", chatPartner[activePartner], line);
+ }
+ SendToICS(buf);
+ }
+ return FALSE; // never pop down
+}
+
+void
+ChatSwitch (int n)
+{
+ int i, j;
+ if(n <= activePartner) n--;
+ activePartner = n;
+ if(!texts[n]) texts[n] = strdup("");
+ dirty[n] = 0;
+ SetWidgetText(&chatOptions[5], texts[n], ChatDlg);
+ SetInsertPos(&chatOptions[5], strlen(texts[n]));
+ SetWidgetText(&chatOptions[0], chatPartner[n], ChatDlg);
+ for(i=j=0; i<MAX_CHAT; i++) {
+ if(i == activePartner) continue;
+ SetWidgetLabel(&chatOptions[++j], chatPartner[i]);
+ SetColor(dirty[i] ? "#FFC000" : "#FFFFFF", &chatOptions[j]);
+ }
+ SetWidgetText(&chatOptions[6], "", ChatDlg);
+ HardSetFocus(&chatOptions[6]);
+}
+
+void
+ChatProc ()
+{
+ if(GenericPopUp(chatOptions, _("Chat box"), ChatDlg, BoardWindow, NONMODAL, 0))
+ AddHandler(&chatOptions[0], 2), AddHandler(&chatOptions[6], 2); // treats return as OK
+ MarkMenu("View.OpenChatWindow", ChatDlg);
}
//--------------------------------- Game-List options dialog ------------------------------------------
if (text == NULL) text = "";
+ if(partnerUp) { SetDialogTitle(DummyDlg, text); return; }
+
if (*text != NULLCHAR) {
safeStrCpy(icon, text, sizeof(icon)/sizeof(icon[0]) );
safeStrCpy(title, text, sizeof(title)/sizeof(title[0]) );
static Option *Exp P((int n, int x, int y));
void MenuCallback P((int n));
void SizeKludge P((int n));
+static Option *LogoW P((int n, int x, int y));
+static Option *LogoB P((int n, int x, int y));
static int pmFromX = -1, pmFromY = -1;
+void *userLogo;
+
+void
+DisplayLogos (void *w1, void *w2)
+{
+ void *whiteLogo = first.programLogo, *blackLogo = second.programLogo;
+ if(appData.autoLogo) {
+
+ switch(gameMode) { // pick logos based on game mode
+ case IcsObserving:
+ whiteLogo = second.programLogo; // ICS logo
+ blackLogo = second.programLogo;
+ default:
+ break;
+ case IcsPlayingWhite:
+ if(!appData.zippyPlay) whiteLogo = userLogo;
+ blackLogo = second.programLogo; // ICS logo
+ break;
+ case IcsPlayingBlack:
+ whiteLogo = second.programLogo; // ICS logo
+ blackLogo = appData.zippyPlay ? first.programLogo : userLogo;
+ break;
+ case TwoMachinesPlay:
+ if(first.twoMachinesColor[0] == 'b') {
+ whiteLogo = second.programLogo;
+ blackLogo = first.programLogo;
+ }
+ break;
+ case MachinePlaysWhite:
+ blackLogo = userLogo;
+ break;
+ case MachinePlaysBlack:
+ whiteLogo = userLogo;
+ blackLogo = first.programLogo;
+ }
+ }
+ DrawLogo(w1, whiteLogo);
+ DrawLogo(w2, blackLogo);
+}
static void
PMSelect (int n)
{ // user callback for board context menus
if (pmFromX < 0 || pmFromY < 0) return;
- if(n == 25) DropMenuEvent(dropMenuTranslation[values[n]], pmFromX, pmFromY);
- else EditPositionMenuEvent(pieceMenuTranslation[n-23][values[n]], pmFromX, pmFromY);
+ if(n == W_DROP) DropMenuEvent(dropMenuTranslation[values[n]], pmFromX, pmFromY);
+ else EditPositionMenuEvent(pieceMenuTranslation[n - W_MENUW][values[n]], pmFromX, pmFromY);
}
-int
+static void
CCB (int n)
{
shiftKey = (ShiftKeys() & 3) != 0;
- ClockClick(n == 12);
+ ClockClick(n == W_BLACK);
}
Option mainOptions[] = { // description of main window in terms of generic dialog creator
{ 0, COMBO_CALLBACK, 0, NULL, (void*)&MenuCallback, NULL, NULL, DropDown, N_("Help") },
{ 0, 0, 0, NULL, (void*)&SizeKludge, "", NULL, BoxEnd, "" },
{ 0, LR|T2T|BORDER|SAME_ROW, 0, NULL, NULL, "", NULL, Label, "1" }, // optional title in window
-{ 0, L2L|T2T, 200, NULL, (void*) &CCB, NULL, NULL, Label, "White" }, // white clock
-{ 0, R2R|T2T|SAME_ROW, 200, NULL, (void*) &CCB, NULL, NULL, Label, "Black" }, // black clock
+{ 50, LL|TT, 100, NULL, (void*) &LogoW, NULL, NULL, -1, "LogoW" }, // white logo
+{ 0, L2L|T2T, 200, NULL, (void*) &CCB, NULL, NULL, Label, "White" }, // white clock
+{ 0, R2R|T2T|SAME_ROW, 200, NULL, (void*) &CCB, NULL, NULL, Label, "Black" }, // black clock
+{ 50, RR|TT|SAME_ROW, 100, NULL, (void*) &LogoB, NULL, NULL, -1, "LogoB" }, // black logo
{ 0, LR|T2T|BORDER, 401, NULL, NULL, "", NULL, -1, "2" }, // backup for title in window (if no room for other)
{ 0, LR|T2T|BORDER, 270, NULL, NULL, "", NULL, Label, "message" }, // message field
{ 0, RR|TT|SAME_ROW, 125, NULL, NULL, "", NULL, BoxBegin, "" }, // (optional) button bar
{ 0, SAME_ROW, 0, NULL, (void*) &ForwardEvent, NULL, NULL, Button, N_(">") },
{ 0, SAME_ROW, 0, NULL, (void*) &ToEndEvent, NULL, NULL, Button, N_(">>") },
{ 0, 0, 0, NULL, NULL, "", NULL, BoxEnd, "" },
-{ 401, LR|TT, 401, NULL, (char*) &Exp, NULL, NULL, Graph, "shadow board" }, // board
+{ 401, LR|TB, 401, NULL, (char*) &Exp, NULL, NULL, Graph, "shadow board" }, // board
{ 2, COMBO_CALLBACK, 0, NULL, (void*) &PMSelect, NULL, pieceMenuStrings[0], PopUp, "menuW" },
{ 2, COMBO_CALLBACK, 0, NULL, (void*) &PMSelect, NULL, pieceMenuStrings[1], PopUp, "menuB" },
{ -1, COMBO_CALLBACK, 0, NULL, (void*) &PMSelect, NULL, dropMenuStrings, PopUp, "menuD" },
{ 0, NO_OK, 0, NULL, NULL, "", NULL, EndMark , "" }
};
+Option *
+LogoW (int n, int x, int y)
+{
+ if(n == 10) DisplayLogos(mainOptions[W_WHITE-1].handle, NULL);
+ return NULL;
+}
+
+Option *
+LogoB (int n, int x, int y)
+{
+ if(n == 10) DisplayLogos(NULL, mainOptions[W_BLACK+1].handle);
+ return NULL;
+}
+
void
SizeKludge (int n)
{ // callback called by GenericPopUp immediately after sizing the menu bar
if(but3) MovePV(x, y, lineGap + BOARD_HEIGHT * (squareSize + lineGap));
return NULL;
}
+ if(n != 10 && PopDown(PromoDlg)) fromX = fromY = -1; // user starts fiddling with board when promotion dialog is up
shiftKey = ShiftKeys();
controlKey = (shiftKey & 0xC) != 0;
shiftKey = (shiftKey & 3) != 0;
Option *
BoardPopUp (int squareSize, int lineGap, void *clockFontThingy)
{
- extern Option *dialogOptions[];
- int i, size = BOARD_WIDTH*(squareSize + lineGap) + lineGap;
+ int i, size = BOARD_WIDTH*(squareSize + lineGap) + lineGap, logo = appData.logoSize;
mainOptions[W_WHITE].choice = (char**) clockFontThingy;
mainOptions[W_BLACK].choice = (char**) clockFontThingy;
mainOptions[W_BOARD].value = BOARD_HEIGHT*(squareSize + lineGap) + lineGap;
mainOptions[W_MESSG].max = appData.showButtonBar ? size-130 : size-2; // message
mainOptions[W_MENU].max = size-40; // menu bar
mainOptions[W_TITLE].type = appData.titleInWindow ? Label : -1 ;
+ if(logo && logo <= size/4) { // Activate logos
+ mainOptions[W_WHITE-1].type = mainOptions[W_BLACK+1].type = Graph;
+ mainOptions[W_WHITE-1].max = mainOptions[W_BLACK+1].max = logo;
+ mainOptions[W_WHITE-1].value= mainOptions[W_BLACK+1].value= logo/2;
+ mainOptions[W_WHITE].min |= SAME_ROW;
+ mainOptions[W_WHITE].max = mainOptions[W_BLACK].max -= logo + 4;
+ mainOptions[W_WHITE].name = mainOptions[W_BLACK].name = "Double\nHeight";
+ }
if(!appData.showButtonBar) for(i=W_BUTTON; i<W_BOARD; i++) mainOptions[i].type = -1;
for(i=0; i<8; i++) mainOptions[i+1].choice = (char**) menuBar[i].mi;
GenericPopUp(mainOptions, "XBoard", BoardWindow, BoardWindow, NONMODAL, 1);
void
SlavePopUp ()
{
+ int size = BOARD_WIDTH*(squareSize + lineGap) + lineGap;
// copy params from main board
dualOptions[0].choice = mainOptions[W_WHITE].choice;
dualOptions[1].choice = mainOptions[W_BLACK].choice;
- dualOptions[3].value = mainOptions[W_BOARD].value;
- dualOptions[3].max = dualOptions[2].max = mainOptions[W_BOARD].max; // board size
- dualOptions[0].max = dualOptions[1].max = mainOptions[W_WHITE].max; // clock width
+ dualOptions[3].value = BOARD_HEIGHT*(squareSize + lineGap) + lineGap;
+ dualOptions[3].max = dualOptions[2].max = size; // board width
+ dualOptions[0].max = dualOptions[1].max = size/2 - 3; // clock width
GenericPopUp(dualOptions, "XBoard", DummyDlg, BoardWindow, NONMODAL, 1);
}
#include <sys/stat.h>
+#define MAXFILES 1000
+
static ChessProgramState *savCps;
static FILE **savFP;
-static char *fileName, *extFilter, *dirListing, *savMode, **namePtr;
-static int folderPtr, filePtr, oldVal, byExtension, extFlag;
-static char curDir[MSG_SIZ], title[MSG_SIZ], *folderList[1000], *fileList[1000];
+static char *fileName, *extFilter, *savMode, **namePtr;
+static int folderPtr, filePtr, oldVal, byExtension, extFlag, pageStart, cnt;
+static char curDir[MSG_SIZ], title[MSG_SIZ], *folderList[MAXFILES], *fileList[MAXFILES];
static char *FileTypes[] = {
"Chess Games",
"Chess Positions",
"Tournaments",
"Opening Books",
+"Sound files",
+"Images",
"Settings (*.ini)",
"Log files",
"All files",
".fen .epd .pos",
".trn",
".bin",
+".wav",
+".xpm",
".ini",
".log",
"",
void SetTypeFilter P((int n));
int BrowseOK P((int n));
void Switch P((int n));
+void CreateDir P((int n));
Option browseOptions[] = {
{ 0, LR|T2T, 500, NULL, NULL, NULL, NULL, Label, title },
{ 0, R2R|TT|SAME_ROW, 70, NULL, (void*) &Switch, NULL, NULL, Button, N_("by type") },
{ 300, L2L|TB, 250, NULL, (void*) folderList, (char*) &DirSelProc, NULL, ListBox, "" },
{ 300, R2R|TB|SAME_ROW,250, NULL, (void*) fileList, (char*) &FileSelProc, NULL, ListBox, "" },
-{ 0, 0, 350, NULL, (void*) &fileName, NULL, NULL, TextBox, N_("Filename:") },
+{ 0, 0, 300, NULL, (void*) &fileName, NULL, NULL, TextBox, N_("Filename:") },
+{ 0, SAME_ROW, 120, NULL, (void*) &CreateDir, NULL, NULL, Button, N_("New directory") },
{ 0, COMBO_CALLBACK, 150, NULL, (void*) &SetTypeFilter, NULL, FileTypes, ComboBox, N_("File type:") },
{ 0, SAME_ROW, 0, NULL, (void*) &BrowseOK, "", NULL, EndMark , "" }
};
return TRUE;
}
-void
-FileSelProc (int n, int sel)
-{
- if(sel<0) return;
- ASSIGN(fileName, fileList[sel]);
- if(BrowseOK(0)) PopDown(BrowserDlg);
-}
-
int
AlphaNumCompare (char *p, char *q)
{
struct dirent *dp;
struct stat statBuf;
static int lastFlag;
- char buf[MSG_SIZ];
if(pathFlag < 0) pathFlag = lastFlag;
lastFlag = pathFlag;
dir = opendir(".");
getcwd(curDir, MSG_SIZ);
snprintf(title, MSG_SIZ, "%s %s", _("Contents of"), curDir);
- folderPtr = filePtr = 0; // clear listing
+ folderPtr = filePtr = cnt = 0; // clear listing
while (dp = readdir(dir)) { // pass 1: list foders
- char *s = dp->d_name, match;
+ char *s = dp->d_name;
if(!stat(s, &statBuf) && S_ISDIR(statBuf.st_mode)) { // stat succeeds and tells us it is directory
if(s[0] == '.' && strcmp(s, "..")) continue; // suppress hidden, except ".."
- ASSIGN(folderList[folderPtr], s); folderPtr++;
+ ASSIGN(folderList[folderPtr], s); if(folderPtr < MAXFILES-2) folderPtr++;
} else if(!pathFlag) {
char *s = dp->d_name, match=0;
+// if(cnt == pageStart) { ASSIGN }
if(s[0] == '.') continue; // suppress hidden files
if(extFilter[0]) { // [HGM] filter on extension
char *p = extFilter, *q;
} while(q && (p = q+1));
if(!match) continue;
}
+ if(filePtr == MAXFILES-2) continue;
+ if(cnt++ < pageStart) continue;
ASSIGN(fileList[filePtr], s); filePtr++;
}
}
+ if(filePtr == MAXFILES-2) { ASSIGN(fileList[filePtr], _("\177 next page")); filePtr++; }
FREE(folderList[folderPtr]); folderList[folderPtr] = NULL;
FREE(fileList[filePtr]); fileList[filePtr] = NULL;
closedir(dir);
ListDir(pathFlag); // and make new one
LoadListBox(&browseOptions[5], "");
LoadListBox(&browseOptions[6], "");
+ SetWidgetLabel(&browseOptions[0], title);
+}
+
+void
+CreateDir (int n)
+{
+ char *name, *errmsg = "";
+ GetWidgetText(&browseOptions[n-1], &name);
+ if(!name[0]) errmsg = _("FIRST TYPE DIRECTORY NAME HERE"); else
+ if(mkdir(name, 0755)) errmsg = _("TRY ANOTHER NAME");
+ else {
+ chdir(name);
+ Refresh(-1);
+ }
+ SetWidgetText(&browseOptions[n-1], errmsg, BrowserDlg);
}
void
browseOptions[n].value = j;
SetWidgetLabel(&browseOptions[n], FileTypes[j]);
ASSIGN(extFilter, Extensions[j]);
+ pageStart = 0;
Refresh(-1); // uses pathflag remembered by ListDir
values[n] = oldVal; // do not disturb combo settings of underlying dialog
}
void
+FileSelProc (int n, int sel)
+{
+ if(sel<0) return;
+ if(sel == MAXFILES-2) { pageStart = cnt; Refresh(-1); return; }
+ ASSIGN(fileName, fileList[sel]);
+ if(BrowseOK(0)) PopDown(BrowserDlg);
+}
+
+void
DirSelProc (int n, int sel)
{
if(!chdir(folderList[sel])) { // cd succeeded, so we are in new directory now
Refresh(-1);
- SetWidgetLabel(&browseOptions[0], title);
}
}
-FILE *
+void
Browse (DialogClass dlg, char *label, char *proposed, char *ext, Boolean pathFlag, char *mode, char **name, FILE **fp)
{
int j=0;
- savFP = fp; savMode = mode, namePtr = name, savCps = currentCps, oldVal = values[8]; // save params, for use in callback
+ savFP = fp; savMode = mode, namePtr = name, savCps = currentCps, oldVal = values[9]; // save params, for use in callback
ASSIGN(extFilter, ext);
ASSIGN(fileName, proposed ? proposed : "");
for(j=0; Extensions[j]; j++) // look up actual value in list of possible values, to get selection nr
if(extFilter && !strcmp(extFilter, Extensions[j])) break;
if(Extensions[j] == NULL) { j++; ASSIGN(FileTypes[j], extFilter); }
- browseOptions[8].value = j;
+ browseOptions[9].value = j;
browseOptions[6].textValue = (char*) (pathFlag ? NULL : &FileSelProc); // disable file listbox during path browsing
- ListDir(pathFlag);
+ pageStart = 0; ListDir(pathFlag);
currentCps = NULL;
- if(GenericPopUp(browseOptions, label, BrowserDlg, dlg, MODAL, 0)) {
+ GenericPopUp(browseOptions, label, BrowserDlg, dlg, MODAL, 0);
+ SetWidgetLabel(&browseOptions[9], FileTypes[j]);
+}
+
+static char *openName;
+FileProc fileProc;
+char *fileOpenMode;
+FILE *openFP;
+
+void
+DelayedLoad ()
+{
+ (void) (*fileProc)(openFP, 0, openName);
+}
+
+void
+FileNamePopUp (char *label, char *def, char *filter, FileProc proc, char *openMode)
+{
+ fileProc = proc; /* I can't see a way not */
+ fileOpenMode = openMode; /* to use globals here */
+ { // [HGM] use file-selector dialog stolen from Ghostview
+ // int index; // this is not supported yet
+ Browse(BoardWindow, label, (def[0] ? def : NULL), filter, False, openMode, &openName, &openFP);
}
- SetWidgetLabel(&browseOptions[8], FileTypes[j]);
}