mirror of
https://github.com/gryf/wmaker.git
synced 2025-12-20 12:58:08 +01:00
- fixed a bug with setting initial path in browsers.
- made the paths selector in WPrefs.app use the open file panel.
This commit is contained in:
@@ -30,6 +30,8 @@ Changes since version 0.53.0:
|
|||||||
- save state of all menus when exiting (Sebastien Bauer
|
- save state of all menus when exiting (Sebastien Bauer
|
||||||
seb_bauer@bigfoot.com)
|
seb_bauer@bigfoot.com)
|
||||||
- added GNUstep info panel (still needs beautification..)
|
- added GNUstep info panel (still needs beautification..)
|
||||||
|
- made the paths selector in WPrefs.app use the open file panel
|
||||||
|
|
||||||
|
|
||||||
Changes since version 0.52.0:
|
Changes since version 0.52.0:
|
||||||
.............................
|
.............................
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ changes since wmaker 0.53.0:
|
|||||||
............................
|
............................
|
||||||
|
|
||||||
- added balloon help
|
- added balloon help
|
||||||
|
- fixed a bug with setting initial path in browsers.
|
||||||
|
|
||||||
changes since wmaker 0.52.0:
|
changes since wmaker 0.52.0:
|
||||||
............................
|
............................
|
||||||
|
|||||||
@@ -690,6 +690,9 @@ WMSetBrowserPath(WMBrowser *bPtr, char *path)
|
|||||||
|
|
||||||
removeColumn(bPtr, 1);
|
removeColumn(bPtr, 1);
|
||||||
|
|
||||||
|
WMSelectListItem(bPtr->columns[0], -1);
|
||||||
|
WMSetListPosition(bPtr->columns[0], 0);
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
tmp = strtok(str, bPtr->pathSeparator);
|
tmp = strtok(str, bPtr->pathSeparator);
|
||||||
while (tmp) {
|
while (tmp) {
|
||||||
|
|||||||
@@ -38,13 +38,11 @@ typedef struct _Panel {
|
|||||||
WMList *pixL;
|
WMList *pixL;
|
||||||
WMButton *pixaB;
|
WMButton *pixaB;
|
||||||
WMButton *pixrB;
|
WMButton *pixrB;
|
||||||
WMTextField *pixT;
|
|
||||||
|
|
||||||
WMFrame *icoF;
|
WMFrame *icoF;
|
||||||
WMList *icoL;
|
WMList *icoL;
|
||||||
WMButton *icoaB;
|
WMButton *icoaB;
|
||||||
WMButton *icorB;
|
WMButton *icorB;
|
||||||
WMTextField *icoT;
|
|
||||||
|
|
||||||
WMColor *red;
|
WMColor *red;
|
||||||
WMColor *black;
|
WMColor *black;
|
||||||
@@ -118,21 +116,7 @@ pushButton(WMWidget *w, void *data)
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* icon paths */
|
/* icon paths */
|
||||||
if (w == panel->icoaB) {
|
if (w == panel->icorB) {
|
||||||
char *text = WMGetTextFieldText(panel->icoT);
|
|
||||||
|
|
||||||
if (text && strlen(text) > 0) {
|
|
||||||
i = WMGetListSelectedItemRow(panel->icoL);
|
|
||||||
if (i >= 0) i++;
|
|
||||||
addPathToList(panel->icoL, i, text);
|
|
||||||
WMSetListBottomPosition(panel->icoL,
|
|
||||||
WMGetListNumberOfRows(panel->icoL));
|
|
||||||
}
|
|
||||||
if (text)
|
|
||||||
free(text);
|
|
||||||
|
|
||||||
WMSetTextFieldText(panel->icoT, NULL);
|
|
||||||
} else if (w == panel->icorB) {
|
|
||||||
i = WMGetListSelectedItemRow(panel->icoL);
|
i = WMGetListSelectedItemRow(panel->icoL);
|
||||||
|
|
||||||
if (i>=0)
|
if (i>=0)
|
||||||
@@ -140,20 +124,7 @@ pushButton(WMWidget *w, void *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* pixmap paths */
|
/* pixmap paths */
|
||||||
if (w == panel->pixaB) {
|
if (w == panel->pixrB) {
|
||||||
char *text = WMGetTextFieldText(panel->pixT);
|
|
||||||
|
|
||||||
if (text && strlen(text) > 0) {
|
|
||||||
i = WMGetListSelectedItemRow(panel->pixL);
|
|
||||||
if (i >= 0) i++;
|
|
||||||
addPathToList(panel->pixL, i, text);
|
|
||||||
WMSetListBottomPosition(panel->pixL,
|
|
||||||
WMGetListNumberOfRows(panel->pixL));
|
|
||||||
}
|
|
||||||
if (text)
|
|
||||||
free(text);
|
|
||||||
WMSetTextFieldText(panel->pixT, NULL);
|
|
||||||
} else if (w == panel->pixrB) {
|
|
||||||
i = WMGetListSelectedItemRow(panel->pixL);
|
i = WMGetListSelectedItemRow(panel->pixL);
|
||||||
|
|
||||||
if (i>=0)
|
if (i>=0)
|
||||||
@@ -163,62 +134,44 @@ pushButton(WMWidget *w, void *data)
|
|||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
textEditedObserver(void *observerData, WMNotification *notification)
|
browseForFile(WMWidget *w, void *data)
|
||||||
{
|
|
||||||
_Panel *panel = (_Panel*)observerData;
|
|
||||||
|
|
||||||
switch ((int)WMGetNotificationClientData(notification)) {
|
|
||||||
case WMReturnTextMovement:
|
|
||||||
if (WMGetNotificationObject(notification) == panel->icoT)
|
|
||||||
WMPerformButtonClick(panel->icoaB);
|
|
||||||
else
|
|
||||||
WMPerformButtonClick(panel->pixaB);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case WMIllegalTextMovement:
|
|
||||||
if (WMGetNotificationObject(notification) == panel->icoT) {
|
|
||||||
WMSetButtonImage(panel->icoaB, NULL);
|
|
||||||
WMSetButtonAltImage(panel->icoaB, NULL);
|
|
||||||
} else {
|
|
||||||
WMSetButtonImage(panel->pixaB, NULL);
|
|
||||||
WMSetButtonAltImage(panel->pixaB, NULL);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static void
|
|
||||||
textBeginObserver(void *observerData, WMNotification *notification)
|
|
||||||
{
|
|
||||||
_Panel *panel = (_Panel*)observerData;
|
|
||||||
WMScreen *scr = WMWidgetScreen(panel->win);
|
|
||||||
WMPixmap *arrow1 = WMGetSystemPixmap(scr, WSIReturnArrow);
|
|
||||||
WMPixmap *arrow2 = WMGetSystemPixmap(scr, WSIHighlightedReturnArrow);
|
|
||||||
|
|
||||||
if (WMGetNotificationObject(notification)==panel->icoT) {
|
|
||||||
WMSetButtonImage(panel->icoaB, arrow1);
|
|
||||||
WMSetButtonAltImage(panel->icoaB, arrow2);
|
|
||||||
} else {
|
|
||||||
WMSetButtonImage(panel->pixaB, arrow1);
|
|
||||||
WMSetButtonAltImage(panel->pixaB, arrow2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static void
|
|
||||||
listClick(WMWidget *w, void *data)
|
|
||||||
{
|
{
|
||||||
_Panel *panel = (_Panel*)data;
|
_Panel *panel = (_Panel*)data;
|
||||||
char *t;
|
WMFilePanel *filePanel;
|
||||||
|
|
||||||
if (w == panel->icoL) {
|
filePanel = WMGetOpenPanel(WMWidgetScreen(w));
|
||||||
t = WMGetListSelectedItem(panel->icoL)->text;
|
|
||||||
WMSetTextFieldText(panel->icoT, t);
|
WMSetFilePanelCanChooseFiles(filePanel, False);
|
||||||
} else {
|
|
||||||
t = WMGetListSelectedItem(panel->pixL)->text;
|
if (WMRunModalFilePanelForDirectory(filePanel, panel->win, "/",
|
||||||
WMSetTextFieldText(panel->pixT, t);
|
_("Select path"), NULL) == True) {
|
||||||
|
char *str = WMGetFilePanelFileName(filePanel);
|
||||||
|
|
||||||
|
if (str) {
|
||||||
|
int len = strlen(str);
|
||||||
|
|
||||||
|
/* Remove the trailing '/' except if the path is exactly / */
|
||||||
|
if (len > 1 && str[len-1] == '/') {
|
||||||
|
str[len-1] = '\0';
|
||||||
|
len--;
|
||||||
|
}
|
||||||
|
if (len > 0) {
|
||||||
|
WMList *lPtr;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (w == panel->icoaB)
|
||||||
|
lPtr = panel->icoL;
|
||||||
|
else if (w == panel->pixaB)
|
||||||
|
lPtr = panel->pixL;
|
||||||
|
|
||||||
|
i = WMGetListSelectedItemRow(lPtr);
|
||||||
|
if (i >= 0) i++;
|
||||||
|
addPathToList(lPtr, i, str);
|
||||||
|
WMSetListBottomPosition(lPtr, WMGetListNumberOfRows(lPtr));
|
||||||
|
|
||||||
|
free(str);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -304,33 +257,24 @@ createPanel(Panel *p)
|
|||||||
WMSetFrameTitle(panel->icoF, _("Icon Search Paths"));
|
WMSetFrameTitle(panel->icoF, _("Icon Search Paths"));
|
||||||
|
|
||||||
panel->icoL = WMCreateList(panel->icoF);
|
panel->icoL = WMCreateList(panel->icoF);
|
||||||
WMResizeWidget(panel->icoL, 200, 120);
|
WMResizeWidget(panel->icoL, 200, 150);
|
||||||
WMMoveWidget(panel->icoL, 15, 20);
|
WMMoveWidget(panel->icoL, 15, 20);
|
||||||
WMSetListAction(panel->icoL, listClick, panel);
|
|
||||||
WMSetListUserDrawProc(panel->icoL, paintItem);
|
WMSetListUserDrawProc(panel->icoL, paintItem);
|
||||||
WMHangData(panel->icoL, panel);
|
WMHangData(panel->icoL, panel);
|
||||||
|
|
||||||
panel->icoaB = WMCreateCommandButton(panel->icoF);
|
panel->icoaB = WMCreateCommandButton(panel->icoF);
|
||||||
WMResizeWidget(panel->icoaB, 90, 24);
|
WMResizeWidget(panel->icoaB, 90, 24);
|
||||||
WMMoveWidget(panel->icoaB, 125, 145);
|
WMMoveWidget(panel->icoaB, 125, 176);
|
||||||
WMSetButtonText(panel->icoaB, _("Add"));
|
WMSetButtonText(panel->icoaB, _("Add"));
|
||||||
WMSetButtonAction(panel->icoaB, pushButton, panel);
|
WMSetButtonAction(panel->icoaB, browseForFile, panel);
|
||||||
WMSetButtonImagePosition(panel->icoaB, WIPRight);
|
WMSetButtonImagePosition(panel->icoaB, WIPRight);
|
||||||
|
|
||||||
panel->icorB = WMCreateCommandButton(panel->icoF);
|
panel->icorB = WMCreateCommandButton(panel->icoF);
|
||||||
WMResizeWidget(panel->icorB, 90, 24);
|
WMResizeWidget(panel->icorB, 90, 24);
|
||||||
WMMoveWidget(panel->icorB, 15, 145);
|
WMMoveWidget(panel->icorB, 15, 176);
|
||||||
WMSetButtonText(panel->icorB, _("Remove"));
|
WMSetButtonText(panel->icorB, _("Remove"));
|
||||||
WMSetButtonAction(panel->icorB, pushButton, panel);
|
WMSetButtonAction(panel->icorB, pushButton, panel);
|
||||||
|
|
||||||
panel->icoT = WMCreateTextField(panel->icoF);
|
|
||||||
WMResizeWidget(panel->icoT, 200, 20);
|
|
||||||
WMMoveWidget(panel->icoT, 15, 175);
|
|
||||||
WMAddNotificationObserver(textEditedObserver, panel,
|
|
||||||
WMTextDidEndEditingNotification, panel->icoT);
|
|
||||||
WMAddNotificationObserver(textBeginObserver, panel,
|
|
||||||
WMTextDidBeginEditingNotification, panel->icoT);
|
|
||||||
|
|
||||||
WMMapSubwidgets(panel->icoF);
|
WMMapSubwidgets(panel->icoF);
|
||||||
|
|
||||||
/* pixmap path */
|
/* pixmap path */
|
||||||
@@ -340,35 +284,24 @@ createPanel(Panel *p)
|
|||||||
WMSetFrameTitle(panel->pixF, _("Pixmap Search Paths"));
|
WMSetFrameTitle(panel->pixF, _("Pixmap Search Paths"));
|
||||||
|
|
||||||
panel->pixL = WMCreateList(panel->pixF);
|
panel->pixL = WMCreateList(panel->pixF);
|
||||||
WMResizeWidget(panel->pixL, 200, 120);
|
WMResizeWidget(panel->pixL, 200, 150);
|
||||||
WMMoveWidget(panel->pixL, 15, 20);
|
WMMoveWidget(panel->pixL, 15, 20);
|
||||||
WMSetListAction(panel->pixL, listClick, panel);
|
|
||||||
WMSetListUserDrawProc(panel->pixL, paintItem);
|
WMSetListUserDrawProc(panel->pixL, paintItem);
|
||||||
WMHangData(panel->pixL, panel);
|
WMHangData(panel->pixL, panel);
|
||||||
|
|
||||||
panel->pixaB = WMCreateCommandButton(panel->pixF);
|
panel->pixaB = WMCreateCommandButton(panel->pixF);
|
||||||
WMResizeWidget(panel->pixaB, 90, 24);
|
WMResizeWidget(panel->pixaB, 90, 24);
|
||||||
WMMoveWidget(panel->pixaB, 125, 145);
|
WMMoveWidget(panel->pixaB, 125, 176);
|
||||||
WMSetButtonText(panel->pixaB, _("Add"));
|
WMSetButtonText(panel->pixaB, _("Add"));
|
||||||
WMSetButtonAction(panel->pixaB, pushButton, panel);
|
WMSetButtonAction(panel->pixaB, browseForFile, panel);
|
||||||
WMSetButtonImagePosition(panel->pixaB, WIPRight);
|
WMSetButtonImagePosition(panel->pixaB, WIPRight);
|
||||||
|
|
||||||
panel->pixrB = WMCreateCommandButton(panel->pixF);
|
panel->pixrB = WMCreateCommandButton(panel->pixF);
|
||||||
WMResizeWidget(panel->pixrB, 90, 24);
|
WMResizeWidget(panel->pixrB, 90, 24);
|
||||||
WMMoveWidget(panel->pixrB, 15, 145);
|
WMMoveWidget(panel->pixrB, 15, 176);
|
||||||
WMSetButtonText(panel->pixrB, _("Remove"));
|
WMSetButtonText(panel->pixrB, _("Remove"));
|
||||||
WMSetButtonAction(panel->pixrB, pushButton, panel);
|
WMSetButtonAction(panel->pixrB, pushButton, panel);
|
||||||
|
|
||||||
panel->pixT= WMCreateTextField(panel->pixF);
|
|
||||||
WMResizeWidget(panel->pixT, 200, 20);
|
|
||||||
WMMoveWidget(panel->pixT, 15, 175);
|
|
||||||
WMAddNotificationObserver(textEditedObserver, panel,
|
|
||||||
WMTextDidEndEditingNotification, panel->pixT);
|
|
||||||
WMAddNotificationObserver(textBeginObserver, panel,
|
|
||||||
WMTextDidBeginEditingNotification, panel->pixT);
|
|
||||||
|
|
||||||
WMSetTextFieldNextTextField(panel->pixT, panel->icoT);
|
|
||||||
WMSetTextFieldPrevTextField(panel->pixT, panel->icoT);
|
|
||||||
|
|
||||||
WMMapSubwidgets(panel->pixF);
|
WMMapSubwidgets(panel->pixF);
|
||||||
|
|
||||||
|
|||||||
@@ -1,2 +1,3 @@
|
|||||||
Makefile
|
Makefile
|
||||||
wtest
|
wtest
|
||||||
|
.libs
|
||||||
|
|||||||
Reference in New Issue
Block a user