- Removed obsoleted options from WMGLOBAL and from the WINGs internal
[wmaker-crm.git] / WPrefs.app / WPrefs.c
blob862a85a4f283c5ab6026532d182c249ee1674d93
1 /* WPrefs.c- main window and other basic stuff
3 * WPrefs - Window Maker Preferences Program
5 * Copyright (c) 1998-2003 Alfredo K. Kojima
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
20 * USA.
24 #include "WPrefs.h"
25 #include <assert.h>
28 extern Panel *InitWindowHandling(WMScreen *scr, WMWidget *parent);
30 extern Panel *InitKeyboardSettings(WMScreen *scr, WMWidget *parent);
32 extern Panel *InitMouseSettings(WMScreen *scr, WMWidget *parent);
34 extern Panel *InitKeyboardShortcuts(WMScreen *scr, WMWidget *parent);
36 extern Panel *InitWorkspace(WMScreen *scr, WMWidget *parent);
38 extern Panel *InitFocus(WMScreen *scr, WMWidget *parent);
40 extern Panel *InitPreferences(WMScreen *scr, WMWidget *parent);
42 extern Panel *InitFont(WMScreen *scr, WMWidget *parent);
43 extern Panel *InitFontSimple(WMScreen *scr, WMWidget *parent);
45 extern Panel *InitConfigurations(WMScreen *scr, WMWidget *parent);
47 extern Panel *InitPaths(WMScreen *scr, WMWidget *parent);
49 extern Panel *InitMenu(WMScreen *scr, WMWidget *parent);
51 extern Panel *InitExpert(WMScreen *scr, WMWidget *parent);
53 extern Panel *InitMenuPreferences(WMScreen *scr, WMWidget *parent);
55 extern Panel *InitIcons(WMScreen *scr, WMWidget *parent);
57 extern Panel *InitThemes(WMScreen *scr, WMWidget *parent);
59 extern Panel *InitAppearance(WMScreen *scr, WMWidget *parent);
64 #define ICON_TITLE_FONT "-adobe-helvetica-bold-r-*-*-10-*"
65 #define ICON_TITLE_VFONT "-adobe-helvetica-bold-r-*-*-10-[]-*"
68 #define MAX_SECTIONS 16
71 typedef struct _WPrefs {
72 WMWindow *win;
74 WMScrollView *scrollV;
75 WMFrame *buttonF;
76 WMButton *sectionB[MAX_SECTIONS];
78 int sectionCount;
80 WMButton *saveBtn;
81 WMButton *closeBtn;
82 WMButton *undoBtn;
83 WMButton *undosBtn;
85 WMButton *balloonBtn;
87 WMFrame *banner;
88 WMLabel *nameL;
89 WMLabel *versionL;
90 WMLabel *creditsL;
91 WMLabel *statusL;
93 Panel *currentPanel;
94 } _WPrefs;
97 static _WPrefs WPrefs;
99 /* system wide defaults dictionary. Read-only */
100 static WMPropList *GlobalDB = NULL;
101 /* user defaults dictionary */
102 static WMPropList *WindowMakerDB = NULL;
103 static char *WindowMakerDBPath = NULL;
106 static Bool TIFFOK = False;
109 #define INITIALIZED_PANEL (1<<0)
114 static void loadConfigurations(WMScreen *scr, WMWindow *mainw);
116 static void savePanelData(Panel *panel);
118 static void prepareForClose();
120 void
121 quit(WMWidget *w, void *data)
123 prepareForClose();
125 exit(0);
129 static void
130 save(WMWidget *w, void *data)
132 int i;
133 WMPropList *p1, *p2;
134 WMPropList *keyList;
135 WMPropList *key;
136 char *msg = "Reconfigure";
137 XEvent ev;
140 /* puts("gathering data");*/
141 for (i=0; i<WPrefs.sectionCount; i++) {
142 PanelRec *rec = WMGetHangedData(WPrefs.sectionB[i]);
143 if ((rec->callbacks.flags & INITIALIZED_PANEL))
144 savePanelData((Panel*)rec);
146 /* puts("compressing data");*/
147 /* compare the user dictionary with the global and remove redundant data */
148 keyList = WMGetPLDictionaryKeys(GlobalDB);
149 /* puts(WMGetPropListDescription(WindowMakerDB, False));*/
150 for (i=0; i<WMGetPropListItemCount(keyList); i++) {
151 key = WMGetFromPLArray(keyList, i);
153 /* We don't have this value anyway, so no problem.
154 * Probably a new option */
155 p1 = WMGetFromPLDictionary(WindowMakerDB, key);
156 if (!p1)
157 continue;
158 /* The global doesn't have it, so no problem either. */
159 p2 = WMGetFromPLDictionary(GlobalDB, key);
160 if (!p2)
161 continue;
162 /* If both values are the same, don't save. */
163 if (WMIsPropListEqualTo(p1, p2))
164 WMRemoveFromPLDictionary(WindowMakerDB, key);
166 /* puts(WMGetPropListDescription(WindowMakerDB, False));*/
167 WMReleasePropList(keyList);
168 /* puts("storing data");*/
170 WMWritePropListToFile(WindowMakerDB, WindowMakerDBPath, True);
173 memset(&ev, 0, sizeof(XEvent));
175 ev.xclient.type = ClientMessage;
176 ev.xclient.message_type = XInternAtom(WMScreenDisplay(WMWidgetScreen(w)),
177 "_WINDOWMAKER_COMMAND", False);
178 ev.xclient.window = DefaultRootWindow(WMScreenDisplay(WMWidgetScreen(w)));
179 ev.xclient.format = 8;
181 for (i = 0; i <= strlen(msg); i++) {
182 ev.xclient.data.b[i] = msg[i];
184 XSendEvent(WMScreenDisplay(WMWidgetScreen(w)),
185 DefaultRootWindow(WMScreenDisplay(WMWidgetScreen(w))),
186 False, SubstructureRedirectMask, &ev);
187 XFlush(WMScreenDisplay(WMWidgetScreen(w)));
192 static void
193 undo(WMWidget *w, void *data)
195 PanelRec *rec = (PanelRec*)WPrefs.currentPanel;
197 if (!rec)
198 return;
200 if (rec->callbacks.undoChanges
201 && (rec->callbacks.flags & INITIALIZED_PANEL)) {
202 (*rec->callbacks.undoChanges)(WPrefs.currentPanel);
207 static void
208 undoAll(WMWidget *w, void *data)
210 int i;
212 for (i=0; i<WPrefs.sectionCount; i++) {
213 PanelRec *rec = WMGetHangedData(WPrefs.sectionB[i]);
215 if (rec->callbacks.undoChanges
216 && (rec->callbacks.flags & INITIALIZED_PANEL))
217 (*rec->callbacks.undoChanges)((Panel*)rec);
223 static void
224 prepareForClose()
226 int i;
228 for (i=0; i<WPrefs.sectionCount; i++) {
229 PanelRec *rec = WMGetHangedData(WPrefs.sectionB[i]);
231 if (rec->callbacks.prepareForClose
232 && (rec->callbacks.flags & INITIALIZED_PANEL))
233 (*rec->callbacks.prepareForClose)((Panel*)rec);
238 void
239 toggleBalloons(WMWidget *w, void *data)
241 WMUserDefaults *udb = WMGetStandardUserDefaults();
242 Bool flag;
244 flag = WMGetButtonSelected(WPrefs.balloonBtn);
246 WMSetBalloonEnabled(WMWidgetScreen(WPrefs.win), flag);
248 WMSetUDBoolForKey(udb, flag, "BalloonHelp");
252 static void
253 createMainWindow(WMScreen *scr)
255 WMScroller *scroller;
256 WMFont *font;
257 char buffer[128];
259 WPrefs.win = WMCreateWindow(scr, "wprefs");
260 WMResizeWidget(WPrefs.win, 520, 390);
261 WMSetWindowTitle(WPrefs.win, _("Window Maker Preferences"));
262 WMSetWindowCloseAction(WPrefs.win, quit, NULL);
263 WMSetWindowMaxSize(WPrefs.win, 520, 390);
264 WMSetWindowMinSize(WPrefs.win, 520, 390);
265 WMSetWindowMiniwindowTitle(WPrefs.win, "Preferences");
266 WMSetWindowMiniwindowPixmap(WPrefs.win, WMGetApplicationIconPixmap(scr));
268 WPrefs.scrollV = WMCreateScrollView(WPrefs.win);
269 WMResizeWidget(WPrefs.scrollV, 500, 87);
270 WMMoveWidget(WPrefs.scrollV, 10, 10);
271 WMSetScrollViewRelief(WPrefs.scrollV, WRSunken);
272 WMSetScrollViewHasHorizontalScroller(WPrefs.scrollV, True);
273 WMSetScrollViewHasVerticalScroller(WPrefs.scrollV, False);
274 scroller = WMGetScrollViewHorizontalScroller(WPrefs.scrollV);
275 WMSetScrollerArrowsPosition(scroller, WSANone);
277 WPrefs.buttonF = WMCreateFrame(WPrefs.win);
278 WMSetFrameRelief(WPrefs.buttonF, WRFlat);
280 WMSetScrollViewContentView(WPrefs.scrollV, WMWidgetView(WPrefs.buttonF));
282 WPrefs.undosBtn = WMCreateCommandButton(WPrefs.win);
283 WMResizeWidget(WPrefs.undosBtn, 90, 28);
284 WMMoveWidget(WPrefs.undosBtn, 135, 350);
285 WMSetButtonText(WPrefs.undosBtn, _("Revert Page"));
286 WMSetButtonAction(WPrefs.undosBtn, undo, NULL);
288 WPrefs.undoBtn = WMCreateCommandButton(WPrefs.win);
289 WMResizeWidget(WPrefs.undoBtn, 90, 28);
290 WMMoveWidget(WPrefs.undoBtn, 235, 350);
291 WMSetButtonText(WPrefs.undoBtn, _("Revert All"));
292 WMSetButtonAction(WPrefs.undoBtn, undoAll, NULL);
294 WPrefs.saveBtn = WMCreateCommandButton(WPrefs.win);
295 WMResizeWidget(WPrefs.saveBtn, 80, 28);
296 WMMoveWidget(WPrefs.saveBtn, 335, 350);
297 WMSetButtonText(WPrefs.saveBtn, _("Save"));
298 WMSetButtonAction(WPrefs.saveBtn, save, NULL);
300 WPrefs.closeBtn = WMCreateCommandButton(WPrefs.win);
301 WMResizeWidget(WPrefs.closeBtn, 80, 28);
302 WMMoveWidget(WPrefs.closeBtn, 425, 350);
303 WMSetButtonText(WPrefs.closeBtn, _("Close"));
304 WMSetButtonAction(WPrefs.closeBtn, quit, NULL);
307 WPrefs.balloonBtn = WMCreateSwitchButton(WPrefs.win);
308 WMResizeWidget(WPrefs.balloonBtn, 200, 28);
309 WMMoveWidget(WPrefs.balloonBtn, 15, 350);
310 WMSetButtonText(WPrefs.balloonBtn, _("Balloon Help"));
311 WMSetButtonAction(WPrefs.balloonBtn, toggleBalloons, NULL);
313 WMUserDefaults *udb = WMGetStandardUserDefaults();
314 Bool flag = WMGetUDBoolForKey(udb, "BalloonHelp");
316 WMSetButtonSelected(WPrefs.balloonBtn, flag);
317 WMSetBalloonEnabled(scr, flag);
320 /* banner */
321 WPrefs.banner = WMCreateFrame(WPrefs.win);
322 WMResizeWidget(WPrefs.banner, FRAME_WIDTH, FRAME_HEIGHT);
323 WMMoveWidget(WPrefs.banner, FRAME_LEFT, FRAME_TOP);
324 WMSetFrameRelief(WPrefs.banner, WRFlat);
326 font = WMCreateFont(scr, "Lucida Sans,Comic Sans MS,Times New Roman,serif:bold:pixelsize=24");
327 if (!font)
328 font = WMBoldSystemFontOfSize(scr, 24);
329 WPrefs.nameL = WMCreateLabel(WPrefs.banner);
330 WMSetLabelTextAlignment(WPrefs.nameL, WACenter);
331 WMResizeWidget(WPrefs.nameL, FRAME_WIDTH-20, 30);
332 WMMoveWidget(WPrefs.nameL, 10, 25);
333 WMSetLabelFont(WPrefs.nameL, font);
334 WMSetLabelText(WPrefs.nameL, _("Window Maker Preferences Utility"));
335 WMReleaseFont(font);
337 WPrefs.versionL = WMCreateLabel(WPrefs.banner);
338 WMResizeWidget(WPrefs.versionL, FRAME_WIDTH-20, 20);
339 WMMoveWidget(WPrefs.versionL, 10, 65);
340 WMSetLabelTextAlignment(WPrefs.versionL, WACenter);
341 sprintf(buffer, _("Version %s for Window Maker %s or newer"), WVERSION,
342 WMVERSION);
343 WMSetLabelText(WPrefs.versionL, buffer);
345 WPrefs.statusL = WMCreateLabel(WPrefs.banner);
346 WMResizeWidget(WPrefs.statusL, FRAME_WIDTH-20, 60);
347 WMMoveWidget(WPrefs.statusL, 10, 100);
348 WMSetLabelTextAlignment(WPrefs.statusL, WACenter);
349 WMSetLabelText(WPrefs.statusL, _("Starting..."));
351 WPrefs.creditsL = WMCreateLabel(WPrefs.banner);
352 WMResizeWidget(WPrefs.creditsL, FRAME_WIDTH-20, 60);
353 WMMoveWidget(WPrefs.creditsL, 10, FRAME_HEIGHT-60);
354 WMSetLabelTextAlignment(WPrefs.creditsL, WACenter);
355 WMSetLabelText(WPrefs.creditsL, _("Programming/Design: Alfredo K. Kojima\n"
356 "Artwork: Marco van Hylckama Vlieg, Largo et al\n"
357 "More Programming: James Thompson et al"));
360 WMMapSubwidgets(WPrefs.win);
362 WMUnmapWidget(WPrefs.undosBtn);
363 WMUnmapWidget(WPrefs.undoBtn);
364 WMUnmapWidget(WPrefs.saveBtn);
368 static void
369 showPanel(Panel *panel)
371 PanelRec *rec = (PanelRec*)panel;
373 if (!(rec->callbacks.flags & INITIALIZED_PANEL)) {
374 (*rec->callbacks.createWidgets)(panel);
375 rec->callbacks.flags |= INITIALIZED_PANEL;
378 WMSetWindowTitle(WPrefs.win, rec->sectionName);
380 if (rec->callbacks.showPanel)
381 (*rec->callbacks.showPanel)(panel);
383 WMMapWidget(rec->box);
388 static void
389 hidePanel(Panel *panel)
391 PanelRec *rec = (PanelRec*)panel;
393 WMUnmapWidget(rec->box);
395 if (rec->callbacks.hidePanel)
396 (*rec->callbacks.hidePanel)(panel);
400 static void
401 savePanelData(Panel *panel)
403 PanelRec *rec = (PanelRec*)panel;
405 if (rec->callbacks.updateDomain) {
406 (*rec->callbacks.updateDomain)(panel);
411 static void
412 changeSection(WMWidget *self, void *data)
414 if (WPrefs.currentPanel == data)
415 return;
417 if (WPrefs.currentPanel == NULL) {
418 WMDestroyWidget(WPrefs.nameL);
419 WMDestroyWidget(WPrefs.creditsL);
420 WMDestroyWidget(WPrefs.versionL);
421 WMDestroyWidget(WPrefs.statusL);
423 WMSetFrameRelief(WPrefs.banner, WRGroove);
425 /* WMMapWidget(WPrefs.undosBtn);
426 WMMapWidget(WPrefs.undoBtn);
428 WMMapWidget(WPrefs.saveBtn);
431 showPanel(data);
433 if (WPrefs.currentPanel)
434 hidePanel(WPrefs.currentPanel);
435 WPrefs.currentPanel = data;
440 char*
441 LocateImage(char *name)
443 char *path;
444 char *tmp = wmalloc(strlen(name)+8);
446 if (TIFFOK) {
447 sprintf(tmp, "%s.tiff", name);
448 path = WMPathForResourceOfType(tmp, "tiff");
449 } else {
450 sprintf(tmp, "%s.xpm", name);
451 path = WMPathForResourceOfType(tmp, "xpm");
453 wfree(tmp);
454 if (!path) {
455 wwarning(_("could not locate image file %s\n"), name);
458 return path;
463 static WMPixmap*
464 makeTitledIcon(WMScreen *scr, WMPixmap *icon, char *title1, char *title2)
466 return WMRetainPixmap(icon);
468 #if 0
469 static GC gc = NULL;
470 static XFontStruct *hfont = NULL;
471 static XFontStruct *vfont = NULL;
472 WMPixmap *tmp;
473 Pixmap pix, mask;
474 Display *dpy = WMScreenDisplay(scr);
475 WMColor *black = WMBlackColor(scr);
476 GC fgc;
477 WMSize size = WMGetPixmapSize(icon);
480 tmp = WMCreatePixmap(scr, 60, 60, WMScreenDepth(scr), True);
482 pix = WMGetPixmapXID(tmp);
483 mask = WMGetPixmapMaskXID(tmp);
485 if (gc == NULL) {
486 gc = XCreateGC(dpy, mask, 0, NULL);
488 hfont = XLoadQueryFont(dpy, ICON_TITLE_FONT);
489 vfont = XLoadQueryFont(dpy, ICON_TITLE_VFONT);
492 if (hfont == NULL) {
493 return WMRetainPixmap(icon);
496 XSetForeground(dpy, gc, 0);
497 XFillRectangle(dpy, mask, gc, 0, 0, 60, 60);
499 fgc = WMColorGC(black);
501 XSetForeground(dpy, gc, 1);
503 XCopyArea(dpy, WMGetPixmapXID(icon), pix, fgc, 0, 0,
504 size.width, size.height, 12, 12);
506 if (WMGetPixmapMaskXID(icon) != None)
507 XCopyPlane(dpy, WMGetPixmapMaskXID(icon), mask, gc, 0, 0,
508 size.width, size.height, 12, 12, 1);
509 else
510 XFillRectangle(dpy, mask, gc, 12, 12, 48, 48);
513 if (title1) {
514 XSetFont(dpy, fgc, vfont->fid);
515 XSetFont(dpy, gc, vfont->fid);
517 XDrawString(dpy, pix, fgc, 0, vfont->ascent,
518 title1, strlen(title1));
520 XDrawString(dpy, mask, gc, 0, vfont->ascent,
521 title1, strlen(title1));
524 if (title2) {
525 XSetFont(dpy, fgc, hfont->fid);
526 XSetFont(dpy, gc, hfont->fid);
528 XDrawString(dpy, pix, fgc, (title1 ? 12 : 0), hfont->ascent,
529 title2, strlen(title2));
531 XDrawString(dpy, mask, gc, (title1 ? 12 : 0), hfont->ascent,
532 title2, strlen(title2));
535 return tmp;
536 #endif
540 void
541 SetButtonAlphaImage(WMScreen *scr, WMButton *bPtr, char *file,
542 char *title1, char *title2)
544 WMPixmap *icon;
545 WMPixmap *icon2;
546 RColor color;
547 char *iconPath;
549 iconPath = LocateImage(file);
551 color.red = 0xae;
552 color.green = 0xaa;
553 color.blue = 0xae;
554 color.alpha = 0;
555 if (iconPath) {
556 icon = WMCreateBlendedPixmapFromFile(scr, iconPath, &color);
557 if (!icon)
558 wwarning(_("could not load icon file %s"), iconPath);
559 } else {
560 icon = NULL;
563 if (icon) {
564 icon2 = makeTitledIcon(scr, icon, title1, title2);
565 if (icon)
566 WMReleasePixmap(icon);
567 } else {
568 icon2 = NULL;
571 WMSetButtonImage(bPtr, icon2);
573 if (icon2)
574 WMReleasePixmap(icon2);
576 color.red = 0xff;
577 color.green = 0xff;
578 color.blue = 0xff;
579 color.alpha = 0;
580 if (iconPath) {
581 icon = WMCreateBlendedPixmapFromFile(scr, iconPath, &color);
582 if (!icon)
583 wwarning(_("could not load icon file %s"), iconPath);
584 } else {
585 icon = NULL;
588 WMSetButtonAltImage(bPtr, icon);
590 if (icon)
591 WMReleasePixmap(icon);
593 if (iconPath)
594 wfree(iconPath);
598 void
599 AddSection(Panel *panel, char *iconFile)
601 WMButton *bPtr;
603 assert(WPrefs.sectionCount < MAX_SECTIONS);
606 bPtr = WMCreateCustomButton(WPrefs.buttonF, WBBStateLightMask
607 |WBBStateChangeMask);
608 WMResizeWidget(bPtr, 64, 64);
609 WMMoveWidget(bPtr, WPrefs.sectionCount*64, 0);
610 WMSetButtonImagePosition(bPtr, WIPImageOnly);
611 WMSetButtonAction(bPtr, changeSection, panel);
612 WMHangData(bPtr, panel);
614 WMSetBalloonTextForView(((PanelRec*)panel)->description,
615 WMWidgetView(bPtr));
618 char *t1, *t2;
620 t1 = wstrdup(((PanelRec*)panel)->sectionName);
621 t2 = strchr(t1, ' ');
622 if (t2) {
623 *t2 = 0;
624 t2++;
626 SetButtonAlphaImage(WMWidgetScreen(bPtr), bPtr, iconFile,
627 t1, t2);
628 wfree(t1);
630 WMMapWidget(bPtr);
632 WPrefs.sectionB[WPrefs.sectionCount] = bPtr;
634 if (WPrefs.sectionCount > 0) {
635 WMGroupButtons(WPrefs.sectionB[0], bPtr);
638 WPrefs.sectionCount++;
640 WMResizeWidget(WPrefs.buttonF, WPrefs.sectionCount*64, 64);
644 void
645 Initialize(WMScreen *scr)
647 char **list;
648 int i;
649 char *path;
650 WMPixmap *icon;
653 list = RSupportedFileFormats();
654 for (i=0; list[i]!=NULL; i++) {
655 if (strcmp(list[i], "TIFF")==0) {
656 TIFFOK = True;
657 break;
661 if (TIFFOK)
662 path = WMPathForResourceOfType("WPrefs.tiff", NULL);
663 else
664 path = WMPathForResourceOfType("WPrefs.xpm", NULL);
665 if (path) {
666 RImage *tmp;
668 tmp = RLoadImage(WMScreenRContext(scr), path, 0);
669 if (!tmp) {
670 wwarning(_("could not load image file %s:%s"), path,
671 RMessageForError(RErrorCode));
672 } else {
673 icon = WMCreatePixmapFromRImage(scr, tmp, 0);
674 RReleaseImage(tmp);
675 if (icon) {
676 WMSetApplicationIconPixmap(scr, icon);
677 WMReleasePixmap(icon);
680 wfree(path);
683 memset(&WPrefs, 0, sizeof(_WPrefs));
684 createMainWindow(scr);
686 WMRealizeWidget(WPrefs.win);
687 WMMapWidget(WPrefs.win);
688 XFlush(WMScreenDisplay(scr));
689 WMSetLabelText(WPrefs.statusL, _("Loading Window Maker configuration files..."));
690 XFlush(WMScreenDisplay(scr));
691 loadConfigurations(scr, WPrefs.win);
693 WMSetLabelText(WPrefs.statusL, _("Initializing configuration panels..."));
695 InitFocus(scr, WPrefs.banner);
696 InitWindowHandling(scr, WPrefs.banner);
698 InitMenuPreferences(scr, WPrefs.banner);
699 InitIcons(scr, WPrefs.banner);
700 InitPreferences(scr, WPrefs.banner);
702 InitPaths(scr, WPrefs.banner);
703 InitWorkspace(scr, WPrefs.banner);
704 InitConfigurations(scr, WPrefs.banner);
706 InitMenu(scr, WPrefs.banner);
708 #ifdef not_yet_fully_implemented
709 InitKeyboardSettings(scr, WPrefs.banner);
710 #endif
711 InitKeyboardShortcuts(scr, WPrefs.banner);
712 InitMouseSettings(scr, WPrefs.banner);
714 InitAppearance(scr, WPrefs.banner);
716 InitFontSimple(scr, WPrefs.banner);
718 #ifdef not_yet_fully_implemented
719 InitThemes(scr, WPrefs.banner);
720 #endif
721 InitExpert(scr, WPrefs.banner);
723 WMRealizeWidget(WPrefs.scrollV);
725 WMSetLabelText(WPrefs.statusL,
726 _("WPrefs is free software and is distributed WITHOUT ANY\n"
727 "WARRANTY under the terms of the GNU General Public License."));
731 WMWindow*
732 GetWindow(Panel *panel)
734 return WPrefs.win;
738 static void
739 loadConfigurations(WMScreen *scr, WMWindow *mainw)
741 WMPropList *db, *gdb;
742 char *path;
743 FILE *file;
744 char buffer[1024];
745 char mbuf[1024];
746 int v1, v2, v3;
748 path = wdefaultspathfordomain("WindowMaker");
749 WindowMakerDBPath = path;
751 db = WMReadPropListFromFile(path);
752 if (db) {
753 if (!WMIsPLDictionary(db)) {
754 WMReleasePropList(db);
755 db = NULL;
756 sprintf(mbuf, _("Window Maker domain (%s) is corrupted!"), path);
757 WMRunAlertPanel(scr, mainw, _("Error"), mbuf, _("OK"), NULL, NULL);
759 } else {
760 sprintf(mbuf, _("Could not load Window Maker domain (%s) from defaults database."),
761 path);
762 WMRunAlertPanel(scr, mainw, _("Error"), mbuf, _("OK"), NULL, NULL);
765 path = getenv("WMAKER_BIN_NAME");
766 if (!path)
767 path = "wmaker";
769 char *command;
771 command = wstrconcat(path, " --version");
772 file = popen(command, "r");
773 wfree(command);
775 if (!file || !fgets(buffer, 1023, file)) {
776 wsyserror(_("could not extract version information from Window Maker"));
777 wfatal(_("Make sure wmaker is in your search path."));
779 WMRunAlertPanel(scr, mainw, _("Error"),
780 _("Could not extract version from Window Maker. Make sure it is correctly installed and is in your PATH environment variable."),
781 _("OK"), NULL, NULL);
782 exit(1);
784 if (file)
785 pclose(file);
787 if (sscanf(buffer, "Window Maker %i.%i.%i",&v1,&v2,&v3)!=3
788 && sscanf(buffer, "WindowMaker %i.%i.%i",&v1,&v2,&v3)!=3) {
789 WMRunAlertPanel(scr, mainw, _("Error"),
790 _("Could not extract version from Window Maker. "
791 "Make sure it is correctly installed and the path "
792 "where it installed is in the PATH environment "
793 "variable."), _("OK"), NULL, NULL);
794 exit(1);
796 if (v1 == 0 && (v2 < 18 || v3 < 0)) {
797 sprintf(mbuf, _("WPrefs only supports Window Maker 0.18.0 or newer.\n"
798 "The version installed is %i.%i.%i\n"), v1, v2, v3);
799 WMRunAlertPanel(scr, mainw, _("Error"), mbuf, _("OK"), NULL, NULL);
800 exit(1);
803 if (v1 > 1 || (v1 == 1 && (v2 > 0))) {
804 sprintf(mbuf, _("Window Maker %i.%i.%i, which is installed in your system, is not fully supported by this version of WPrefs."),
805 v1, v2, v3);
806 WMRunAlertPanel(scr, mainw, _("Warning"), mbuf, _("OK"), NULL, NULL);
810 char *command;
812 command = wstrconcat(path, " --global_defaults_path");
813 file = popen(command, "r");
814 wfree(command);
816 if (!file || !fgets(buffer, 1023, file)) {
817 wsyserror(_("could not run \"%s --global_defaults_path\"."), path);
818 exit(1);
819 } else {
820 char *ptr;
821 ptr = strchr(buffer, '\n');
822 if (ptr)
823 *ptr = 0;
824 strcat(buffer, "/WindowMaker");
827 if (file)
828 pclose(file);
830 gdb = WMReadPropListFromFile(buffer);
832 if (gdb) {
833 if (!WMIsPLDictionary(gdb)) {
834 WMReleasePropList(gdb);
835 gdb = NULL;
836 sprintf(mbuf, _("Window Maker domain (%s) is corrupted!"), buffer);
837 WMRunAlertPanel(scr, mainw, _("Error"), mbuf, _("OK"), NULL, NULL);
839 } else {
840 sprintf(mbuf, _("Could not load global Window Maker domain (%s)."),
841 buffer);
842 WMRunAlertPanel(scr, mainw, _("Error"), mbuf, _("OK"), NULL, NULL);
845 if (!db) {
846 db = WMCreatePLDictionary(NULL, NULL);
848 if (!gdb) {
849 gdb = WMCreatePLDictionary(NULL, NULL);
852 GlobalDB = gdb;
854 WindowMakerDB = db;
858 WMPropList*
859 GetObjectForKey(char *defaultName)
861 WMPropList *object = NULL;
862 WMPropList *key = WMCreatePLString(defaultName);
864 object = WMGetFromPLDictionary(WindowMakerDB, key);
865 if (!object)
866 object = WMGetFromPLDictionary(GlobalDB, key);
868 WMReleasePropList(key);
870 return object;
874 void
875 SetObjectForKey(WMPropList *object, char *defaultName)
877 WMPropList *key = WMCreatePLString(defaultName);
879 WMPutInPLDictionary(WindowMakerDB, key, object);
880 WMReleasePropList(key);
884 void
885 RemoveObjectForKey(char *defaultName)
887 WMPropList *key = WMCreatePLString(defaultName);
889 WMRemoveFromPLDictionary(WindowMakerDB, key);
891 WMReleasePropList(key);
895 char*
896 GetStringForKey(char *defaultName)
898 WMPropList *val;
900 val = GetObjectForKey(defaultName);
902 if (!val)
903 return NULL;
905 if (!WMIsPLString(val))
906 return NULL;
908 return WMGetFromPLString(val);
913 WMPropList*
914 GetArrayForKey(char *defaultName)
916 WMPropList *val;
918 val = GetObjectForKey(defaultName);
920 if (!val)
921 return NULL;
923 if (!WMIsPLArray(val))
924 return NULL;
926 return val;
930 WMPropList*
931 GetDictionaryForKey(char *defaultName)
933 WMPropList *val;
935 val = GetObjectForKey(defaultName);
937 if (!val)
938 return NULL;
940 if (!WMIsPLDictionary(val))
941 return NULL;
943 return val;
948 GetIntegerForKey(char *defaultName)
950 WMPropList *val;
951 char *str;
952 int value;
954 val = GetObjectForKey(defaultName);
956 if (!val)
957 return 0;
959 if (!WMIsPLString(val))
960 return 0;
962 str = WMGetFromPLString(val);
963 if (!str)
964 return 0;
966 if (sscanf(str, "%i", &value)!=1)
967 return 0;
969 return value;
973 Bool
974 GetBoolForKey(char *defaultName)
976 int value;
977 char *str;
979 str = GetStringForKey(defaultName);
981 if (!str)
982 return False;
984 if (sscanf(str, "%i", &value)==1 && value!=0)
985 return True;
987 if (strcasecmp(str, "YES")==0)
988 return True;
990 if (strcasecmp(str, "Y")==0)
991 return True;
993 return False;
997 void
998 SetIntegerForKey(int value, char *defaultName)
1000 WMPropList *object;
1001 char buffer[128];
1003 sprintf(buffer, "%i", value);
1004 object = WMCreatePLString(buffer);
1006 SetObjectForKey(object, defaultName);
1007 WMReleasePropList(object);
1012 void
1013 SetStringForKey(char *value, char *defaultName)
1015 WMPropList *object;
1017 object = WMCreatePLString(value);
1019 SetObjectForKey(object, defaultName);
1020 WMReleasePropList(object);
1024 void
1025 SetBoolForKey(Bool value, char *defaultName)
1027 static WMPropList *yes = NULL, *no = NULL;
1029 if (!yes) {
1030 yes = WMCreatePLString("YES");
1031 no = WMCreatePLString("NO");
1034 SetObjectForKey(value ? yes : no, defaultName);
1038 void
1039 SetSpeedForKey(int speed, char *defaultName)
1041 char *str;
1043 switch (speed) {
1044 case 0:
1045 str = "ultraslow";
1046 break;
1047 case 1:
1048 str = "slow";
1049 break;
1050 case 2:
1051 str = "medium";
1052 break;
1053 case 3:
1054 str = "fast";
1055 break;
1056 case 4:
1057 str = "ultrafast";
1058 break;
1059 default:
1060 str = NULL;
1063 if (str)
1064 SetStringForKey(str, defaultName);
1069 GetSpeedForKey(char *defaultName)
1071 char *str;
1072 int i;
1074 str = GetStringForKey(defaultName);
1075 if (!str)
1076 return 2;
1078 if (strcasecmp(str, "ultraslow")==0)
1079 i = 0;
1080 else if (strcasecmp(str, "slow")==0)
1081 i = 1;
1082 else if (strcasecmp(str, "medium")==0)
1083 i = 2;
1084 else if (strcasecmp(str, "fast")==0)
1085 i = 3;
1086 else if (strcasecmp(str, "ultrafast")==0)
1087 i = 4;
1088 else {
1089 wwarning(_("bad speed value for option %s\n. Using default Medium"),
1090 defaultName);
1091 i = 2;
1093 return i;