mirror of
https://github.com/gryf/wmaker.git
synced 2025-12-22 05:48:01 +01:00
---------------
- Added retain/release mechanism to RImage by adding RRetainImage() and
RReleaseImage(). RDestroyImage() is an alias to RReleaseImage() now, but
will be removed in a future release because it no longer fits with the
semantics. Will be kept for a while to allow a smoother transition.
More about in wrlib/NEWS
For WINGs:
----------
- Small API change:
1. Renamed WMSetApplicationIconImage(), WMGetApplicationIconImage() and
WMSetWindowMiniwindowImage() to respectively WMSetApplicationIconPixmap(),
WMGetApplicationIconPixmap() and WMSetWindowMiniwindowPixmap()
They operate on a WMPixmap which is practically an X Pixmap with no alpha
channel information and the new name is more suggestive and also leaves
room for the new functions added for operating on images with alpha info.
2. Added WMSetApplicationIconImage() and WMGetApplicationIconImage() which
operate on an RImage and store alpha information too.
3. Added WMGetApplicationIconBlendedPixmap() which will take the image with
alpha set by WMSetApplicationIconImage() and will blend it with a color.
If color is NULL it will blend using the default panel color (#aeaaae)
All these changes will allow WINGs to handle images with alpha blending
correctly in panels and wherever else needed. More about in WINGs/NEWS.
- updated panels to use the newly available RImages if present and fallback
to old WMPixmaps if not, to properly show alpha blended images.
- replaced some still left malloc's with wmalloc's.
For Window Maker:
-----------------
- Fixed wrong mapping position of the "Docked Applications Panel" for some
icons.
- Smoother animation for the smiley =)
- Made images with alpha blending be shown correctly in the panels and the
icon chooser.
- The icon image set to be shown in panels ("Logo.WMPanel") will be
automatically updated if its entry in WMWindowAttributes changes (without
a need to restart as until now).
*** Note!!! ***
If you are developing applications with one of libwraster or libWINGs
then you should look to wrlib/NEWS and WINGs/NEWS to see what changed
and how should you update your code.
763 lines
17 KiB
C
763 lines
17 KiB
C
|
|
#include <X11/Xmd.h>
|
|
|
|
#include "WINGsP.h"
|
|
|
|
#include <X11/Xatom.h>
|
|
|
|
|
|
typedef struct W_Window {
|
|
W_Class widgetClass;
|
|
W_View *view;
|
|
|
|
struct W_Window *nextPtr; /* next in the window list */
|
|
|
|
struct W_Window *owner;
|
|
|
|
char *title;
|
|
|
|
WMPixmap *miniImage; /* miniwindow */
|
|
char *miniTitle;
|
|
|
|
char *wname;
|
|
|
|
WMSize resizeIncrement;
|
|
WMSize baseSize;
|
|
WMSize minSize;
|
|
WMSize maxSize;
|
|
WMPoint minAspect;
|
|
WMPoint maxAspect;
|
|
|
|
WMPoint upos;
|
|
WMPoint ppos;
|
|
|
|
WMAction *closeAction;
|
|
void *closeData;
|
|
|
|
int level;
|
|
|
|
struct {
|
|
unsigned style:4;
|
|
unsigned configured:1;
|
|
unsigned documentEdited:1;
|
|
|
|
unsigned setUPos:1;
|
|
unsigned setPPos:1;
|
|
unsigned setAspect:1;
|
|
} flags;
|
|
} _Window;
|
|
|
|
|
|
|
|
typedef struct {
|
|
CARD32 flags;
|
|
CARD32 window_style;
|
|
CARD32 window_level;
|
|
CARD32 reserved;
|
|
Pixmap miniaturize_pixmap; /* pixmap for miniaturize button */
|
|
Pixmap close_pixmap; /* pixmap for close button */
|
|
Pixmap miniaturize_mask; /* miniaturize pixmap mask */
|
|
Pixmap close_mask; /* close pixmap mask */
|
|
CARD32 extra_flags;
|
|
} GNUstepWMAttributes;
|
|
|
|
#define GSWindowStyleAttr (1<<0)
|
|
#define GSWindowLevelAttr (1<<1)
|
|
#define GSMiniaturizePixmapAttr (1<<3)
|
|
#define GSClosePixmapAttr (1<<4)
|
|
#define GSMiniaturizeMaskAttr (1<<5)
|
|
#define GSCloseMaskAttr (1<<6)
|
|
#define GSExtraFlagsAttr (1<<7)
|
|
|
|
/* extra flags */
|
|
#define GSDocumentEditedFlag (1<<0)
|
|
#define GSNoApplicationIconFlag (1<<5)
|
|
|
|
#define WMFHideOtherApplications 10
|
|
#define WMFHideApplication 12
|
|
|
|
|
|
|
|
static void willResizeWindow(W_ViewDelegate *, WMView *, unsigned*, unsigned*);
|
|
|
|
struct W_ViewDelegate _WindowViewDelegate = {
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
willResizeWindow
|
|
};
|
|
|
|
|
|
#define DEFAULT_WIDTH 400
|
|
#define DEFAULT_HEIGHT 180
|
|
#define DEFAULT_TITLE ""
|
|
|
|
|
|
static void destroyWindow(_Window *win);
|
|
|
|
static void handleEvents();
|
|
|
|
static void realizeWindow();
|
|
|
|
static void
|
|
realizeObserver(void *self, WMNotification *not)
|
|
{
|
|
realizeWindow(self);
|
|
}
|
|
|
|
|
|
WMWindow*
|
|
WMCreatePanelWithStyleForWindow(WMWindow *owner, char *name, int style)
|
|
{
|
|
WMWindow *win;
|
|
|
|
win = WMCreateWindowWithStyle(owner->view->screen, name, style);
|
|
win->owner = owner;
|
|
|
|
return win;
|
|
}
|
|
|
|
|
|
|
|
WMWindow*
|
|
WMCreatePanelForWindow(WMWindow *owner, char *name)
|
|
{
|
|
return WMCreatePanelWithStyleForWindow(owner, name,
|
|
WMTitledWindowMask
|
|
|WMClosableWindowMask
|
|
|WMResizableWindowMask);
|
|
}
|
|
|
|
|
|
void
|
|
WMChangePanelOwner(WMWindow *win, WMWindow *newOwner)
|
|
{
|
|
win->owner = newOwner;
|
|
|
|
if (win->view->flags.realized && newOwner) {
|
|
XSetTransientForHint(win->view->screen->display, win->view->window,
|
|
newOwner->view->window);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
WMWindow*
|
|
WMCreateWindow(WMScreen *screen, char *name)
|
|
{
|
|
return WMCreateWindowWithStyle(screen, name, WMTitledWindowMask
|
|
|WMClosableWindowMask
|
|
|WMMiniaturizableWindowMask
|
|
|WMResizableWindowMask);
|
|
}
|
|
|
|
|
|
|
|
WMWindow*
|
|
WMCreateWindowWithStyle(WMScreen *screen, char *name, int style)
|
|
{
|
|
_Window *win;
|
|
|
|
win = wmalloc(sizeof(_Window));
|
|
memset(win, 0, sizeof(_Window));
|
|
|
|
win->widgetClass = WC_Window;
|
|
|
|
win->view = W_CreateTopView(screen);
|
|
if (!win->view) {
|
|
wfree(win);
|
|
return NULL;
|
|
}
|
|
win->view->self = win;
|
|
|
|
win->view->delegate = &_WindowViewDelegate;
|
|
|
|
win->wname = wstrdup(name);
|
|
|
|
/* add to the window list of the screen (application) */
|
|
win->nextPtr = screen->windowList;
|
|
screen->windowList = win;
|
|
|
|
WMCreateEventHandler(win->view, ExposureMask|StructureNotifyMask
|
|
|ClientMessageMask|FocusChangeMask,
|
|
handleEvents, win);
|
|
|
|
W_ResizeView(win->view, DEFAULT_WIDTH, DEFAULT_HEIGHT);
|
|
|
|
WMAddNotificationObserver(realizeObserver, win,
|
|
WMViewRealizedNotification, win->view);
|
|
|
|
win->flags.style = style;
|
|
|
|
win->level = WMNormalWindowLevel;
|
|
|
|
/* kluge. Find a better solution */
|
|
W_SetFocusOfTopLevel(win->view, win->view);
|
|
|
|
return win;
|
|
}
|
|
|
|
|
|
void
|
|
WMSetWindowTitle(WMWindow *win, char *title)
|
|
{
|
|
XTextProperty property;
|
|
int result;
|
|
|
|
if (win->title!=NULL)
|
|
wfree(win->title);
|
|
if (title!=NULL)
|
|
win->title = wstrdup(title);
|
|
else
|
|
win->title = NULL;
|
|
|
|
if (win->view->flags.realized) {
|
|
result = XmbTextListToTextProperty (win->view->screen->display,
|
|
&title, 1, XStdICCTextStyle,
|
|
&property);
|
|
if (result == XNoMemory || result == XLocaleNotSupported) {
|
|
wwarning("window title conversion error... using STRING encoding");
|
|
XStoreName(win->view->screen->display, win->view->window, title);
|
|
} else {
|
|
XSetWMName(win->view->screen->display, win->view->window, &property);
|
|
if (property.value)
|
|
XFree(property.value);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
WMSetWindowCloseAction(WMWindow *win, WMAction *action, void *clientData)
|
|
{
|
|
Atom *atoms = NULL;
|
|
Atom *newAtoms;
|
|
int count;
|
|
WMScreen *scr = win->view->screen;
|
|
|
|
if (win->view->flags.realized) {
|
|
if (action && !win->closeAction) {
|
|
if (!XGetWMProtocols(scr->display, win->view->window, &atoms,
|
|
&count)) {
|
|
count = 0;
|
|
}
|
|
newAtoms = wmalloc((count+1)*sizeof(Atom));
|
|
if (count > 0)
|
|
memcpy(newAtoms, atoms, count*sizeof(Atom));
|
|
newAtoms[count++] = scr->deleteWindowAtom;
|
|
XSetWMProtocols(scr->display, win->view->window, newAtoms, count);
|
|
if (atoms)
|
|
XFree(atoms);
|
|
wfree(newAtoms);
|
|
} else if (!action && win->closeAction) {
|
|
int i, ncount;
|
|
|
|
if (XGetWMProtocols(scr->display, win->view->window, &atoms,
|
|
&count) && count>0) {
|
|
newAtoms = wmalloc((count-1)*sizeof(Atom));
|
|
ncount = 0;
|
|
for (i=0; i < count; i++) {
|
|
if (atoms[i]!=scr->deleteWindowAtom) {
|
|
newAtoms[i] = atoms[i];
|
|
ncount++;
|
|
}
|
|
}
|
|
XSetWMProtocols(scr->display, win->view->window, newAtoms,
|
|
ncount);
|
|
if (atoms)
|
|
XFree(atoms);
|
|
wfree(newAtoms);
|
|
}
|
|
}
|
|
}
|
|
win->closeAction = action;
|
|
win->closeData = clientData;
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
willResizeWindow(W_ViewDelegate *self, WMView *view,
|
|
unsigned *width, unsigned *height)
|
|
{
|
|
WMWindow *win = (WMWindow*)view->self;
|
|
|
|
if (win->minSize.width > 0 && win->minSize.height > 0) {
|
|
if (*width < win->minSize.width)
|
|
*width = win->minSize.width;
|
|
if (*height < win->minSize.height)
|
|
*height = win->minSize.height;
|
|
}
|
|
|
|
if (win->maxSize.width > 0 && win->maxSize.height > 0) {
|
|
if (*width > win->maxSize.width)
|
|
*width = win->maxSize.width;
|
|
if (*height > win->maxSize.height)
|
|
*height = win->maxSize.height;
|
|
}
|
|
}
|
|
|
|
|
|
static void
|
|
setSizeHints(WMWindow *win)
|
|
{
|
|
XSizeHints *hints;
|
|
|
|
hints = XAllocSizeHints();
|
|
if (!hints) {
|
|
wwarning("could not allocate memory for window size hints");
|
|
return;
|
|
}
|
|
|
|
hints->flags = 0;
|
|
|
|
if (win->flags.setPPos) {
|
|
hints->flags |= PPosition;
|
|
hints->x = win->ppos.x;
|
|
hints->y = win->ppos.y;
|
|
}
|
|
if (win->flags.setUPos) {
|
|
hints->flags |= USPosition;
|
|
hints->x = win->upos.x;
|
|
hints->y = win->upos.y;
|
|
}
|
|
if (win->minSize.width>0 && win->minSize.height>0) {
|
|
hints->flags |= PMinSize;
|
|
hints->min_width = win->minSize.width;
|
|
hints->min_height = win->minSize.height;
|
|
}
|
|
if (win->maxSize.width>0 && win->maxSize.height>0) {
|
|
hints->flags |= PMaxSize;
|
|
hints->max_width = win->maxSize.width;
|
|
hints->max_height = win->maxSize.height;
|
|
}
|
|
if (win->baseSize.width>0 && win->baseSize.height>0) {
|
|
hints->flags |= PBaseSize;
|
|
hints->base_width = win->baseSize.width;
|
|
hints->base_height = win->baseSize.height;
|
|
}
|
|
if (win->resizeIncrement.width>0 && win->resizeIncrement.height>0) {
|
|
hints->flags |= PResizeInc;
|
|
hints->width_inc = win->resizeIncrement.width;
|
|
hints->height_inc = win->resizeIncrement.height;
|
|
}
|
|
if (win->flags.setAspect) {
|
|
hints->flags |= PAspect;
|
|
hints->min_aspect.x = win->minAspect.x;
|
|
hints->min_aspect.y = win->minAspect.y;
|
|
hints->max_aspect.x = win->maxAspect.x;
|
|
hints->max_aspect.y = win->maxAspect.y;
|
|
}
|
|
|
|
|
|
if (hints->flags) {
|
|
XSetWMNormalHints(win->view->screen->display, win->view->window, hints);
|
|
}
|
|
XFree(hints);
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
writeGNUstepWMAttr(WMScreen *scr, Window window, GNUstepWMAttributes *attr)
|
|
{
|
|
unsigned long data[9];
|
|
|
|
/* handle idiot compilers where array of CARD32 != struct of CARD32 */
|
|
data[0] = attr->flags;
|
|
data[1] = attr->window_style;
|
|
data[2] = attr->window_level;
|
|
data[3] = 0; /* reserved */
|
|
/* The X protocol says XIDs are 32bit */
|
|
data[4] = attr->miniaturize_pixmap;
|
|
data[5] = attr->close_pixmap;
|
|
data[6] = attr->miniaturize_mask;
|
|
data[7] = attr->close_mask;
|
|
data[8] = attr->extra_flags;
|
|
XChangeProperty(scr->display, window, scr->attribsAtom, scr->attribsAtom,
|
|
32, PropModeReplace, (unsigned char *)data, 9);
|
|
}
|
|
|
|
|
|
static void
|
|
setWindowMakerHints(WMWindow *win)
|
|
{
|
|
GNUstepWMAttributes attribs;
|
|
WMScreen *scr = WMWidgetScreen(win);
|
|
|
|
memset(&attribs, 0, sizeof(GNUstepWMAttributes));
|
|
attribs.flags = GSWindowStyleAttr|GSWindowLevelAttr|GSExtraFlagsAttr;
|
|
attribs.window_style = win->flags.style;
|
|
attribs.window_level = win->level;
|
|
if (win->flags.documentEdited)
|
|
attribs.extra_flags = GSDocumentEditedFlag;
|
|
else
|
|
attribs.extra_flags = 0;
|
|
|
|
writeGNUstepWMAttr(scr, win->view->window, &attribs);
|
|
}
|
|
|
|
|
|
static void
|
|
realizeWindow(WMWindow *win)
|
|
{
|
|
XWMHints *hints;
|
|
XClassHint *classHint;
|
|
WMScreen *scr = win->view->screen;
|
|
Atom atoms[4];
|
|
int count;
|
|
|
|
classHint = XAllocClassHint();
|
|
classHint->res_name = win->wname;
|
|
classHint->res_class = WMGetApplicationName();
|
|
XSetClassHint(scr->display, win->view->window, classHint);
|
|
XFree(classHint);
|
|
|
|
hints = XAllocWMHints();
|
|
hints->flags = 0;
|
|
if (!scr->aflags.simpleApplication) {
|
|
hints->flags |= WindowGroupHint;
|
|
hints->window_group = scr->groupLeader;
|
|
}
|
|
if (win->miniImage) {
|
|
hints->flags |= IconPixmapHint;
|
|
hints->icon_pixmap = WMGetPixmapXID(win->miniImage);
|
|
hints->icon_mask = WMGetPixmapMaskXID(win->miniImage);
|
|
if (hints->icon_mask != None) {
|
|
hints->flags |= IconMaskHint;
|
|
}
|
|
}
|
|
if (hints->flags != 0)
|
|
XSetWMHints(scr->display, win->view->window, hints);
|
|
XFree(hints);
|
|
|
|
count = 0;
|
|
if (win->closeAction) {
|
|
atoms[count++] = scr->deleteWindowAtom;
|
|
}
|
|
|
|
if (count>0)
|
|
XSetWMProtocols(scr->display, win->view->window, atoms, count);
|
|
|
|
if (win->title || win->miniTitle)
|
|
XmbSetWMProperties(scr->display, win->view->window, win->title,
|
|
win->miniTitle, NULL, 0, NULL, NULL, NULL);
|
|
|
|
setWindowMakerHints(win);
|
|
|
|
setSizeHints(win);
|
|
|
|
if (win->owner) {
|
|
XSetTransientForHint(scr->display, win->view->window,
|
|
win->owner->view->window);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
void
|
|
WMSetWindowAspectRatio(WMWindow *win, int minX, int minY,
|
|
int maxX, int maxY)
|
|
{
|
|
win->flags.setAspect = 1;
|
|
win->minAspect.x = minX;
|
|
win->minAspect.y = minY;
|
|
win->maxAspect.x = maxX;
|
|
win->maxAspect.y = maxY;
|
|
if (win->view->flags.realized)
|
|
setSizeHints(win);
|
|
}
|
|
|
|
|
|
|
|
void
|
|
WMSetWindowInitialPosition(WMWindow *win, int x, int y)
|
|
{
|
|
win->flags.setPPos = 1;
|
|
win->ppos.x = x;
|
|
win->ppos.y = y;
|
|
if (win->view->flags.realized)
|
|
setSizeHints(win);
|
|
WMMoveWidget(win, x, y);
|
|
}
|
|
|
|
|
|
|
|
void
|
|
WMSetWindowUserPosition(WMWindow *win, int x, int y)
|
|
{
|
|
win->flags.setUPos = 1;
|
|
win->upos.x = x;
|
|
win->upos.y = y;
|
|
if (win->view->flags.realized)
|
|
setSizeHints(win);
|
|
WMMoveWidget(win, x, y);
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
WMSetWindowMinSize(WMWindow *win, unsigned width, unsigned height)
|
|
{
|
|
win->minSize.width = width;
|
|
win->minSize.height = height;
|
|
if (win->view->flags.realized)
|
|
setSizeHints(win);
|
|
}
|
|
|
|
|
|
|
|
void
|
|
WMSetWindowMaxSize(WMWindow *win, unsigned width, unsigned height)
|
|
{
|
|
win->maxSize.width = width;
|
|
win->maxSize.height = height;
|
|
if (win->view->flags.realized)
|
|
setSizeHints(win);
|
|
}
|
|
|
|
|
|
void
|
|
WMSetWindowBaseSize(WMWindow *win, unsigned width, unsigned height)
|
|
{
|
|
/* TODO: validate sizes */
|
|
win->baseSize.width = width;
|
|
win->baseSize.height = height;
|
|
if (win->view->flags.realized)
|
|
setSizeHints(win);
|
|
}
|
|
|
|
|
|
void
|
|
WMSetWindowResizeIncrements(WMWindow *win, unsigned wIncr, unsigned hIncr)
|
|
{
|
|
win->resizeIncrement.width = wIncr;
|
|
win->resizeIncrement.height = hIncr;
|
|
if (win->view->flags.realized)
|
|
setSizeHints(win);
|
|
}
|
|
|
|
|
|
void
|
|
WMSetWindowLevel(WMWindow *win, int level)
|
|
{
|
|
win->level = level;
|
|
if (win->view->flags.realized)
|
|
setWindowMakerHints(win);
|
|
}
|
|
|
|
|
|
void
|
|
WMSetWindowDocumentEdited(WMWindow *win, Bool flag)
|
|
{
|
|
if (win->flags.documentEdited != flag) {
|
|
win->flags.documentEdited = flag;
|
|
if (win->view->flags.realized)
|
|
setWindowMakerHints(win);
|
|
}
|
|
}
|
|
|
|
|
|
void
|
|
WMSetWindowMiniwindowPixmap(WMWindow *win, WMPixmap *pixmap)
|
|
{
|
|
if ((win->miniImage && !pixmap) || (!win->miniImage && pixmap)) {
|
|
if (win->miniImage)
|
|
WMReleasePixmap(win->miniImage);
|
|
|
|
if (pixmap)
|
|
win->miniImage = WMRetainPixmap(pixmap);
|
|
else
|
|
win->miniImage = NULL;
|
|
|
|
if (win->view->flags.realized) {
|
|
XWMHints *hints;
|
|
|
|
hints = XGetWMHints(win->view->screen->display, win->view->window);
|
|
if (!hints) {
|
|
hints = XAllocWMHints();
|
|
if (!hints) {
|
|
wwarning("could not allocate memory for WM hints");
|
|
return;
|
|
}
|
|
hints->flags = 0;
|
|
}
|
|
if (pixmap) {
|
|
hints->flags |= IconPixmapHint;
|
|
hints->icon_pixmap = WMGetPixmapXID(pixmap);
|
|
hints->icon_mask = WMGetPixmapMaskXID(pixmap);
|
|
if (hints->icon_mask != None) {
|
|
hints->flags |= IconMaskHint;
|
|
}
|
|
}
|
|
XSetWMHints(win->view->screen->display, win->view->window, hints);
|
|
XFree(hints);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
void
|
|
WMSetWindowMiniwindowTitle(WMWindow *win, char *title)
|
|
{
|
|
XTextProperty property;
|
|
int result;
|
|
|
|
if ((win->miniTitle && !title) || (!win->miniTitle && title)
|
|
|| (title && win->miniTitle && strcoll(title, win->miniTitle)!=0)) {
|
|
if (win->miniTitle)
|
|
wfree(win->miniTitle);
|
|
|
|
if (title)
|
|
win->miniTitle = wstrdup(title);
|
|
else
|
|
win->miniTitle = NULL;
|
|
|
|
if (win->view->flags.realized) {
|
|
result = XmbTextListToTextProperty (win->view->screen->display,
|
|
&title, 1, XStdICCTextStyle,
|
|
&property);
|
|
if (result == XNoMemory || result == XLocaleNotSupported) {
|
|
wwarning("icon title conversion error..using STRING encoding");
|
|
XSetIconName(win->view->screen->display, win->view->window,
|
|
title);
|
|
} else {
|
|
XSetWMIconName(win->view->screen->display, win->view->window,
|
|
&property);
|
|
if (property.value)
|
|
XFree(property.value);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
void
|
|
WMCloseWindow(WMWindow *win)
|
|
{
|
|
WMUnmapWidget(win);
|
|
/* withdraw the window */
|
|
if (win->view->flags.realized)
|
|
XWithdrawWindow(win->view->screen->display, win->view->window,
|
|
win->view->screen->screen);
|
|
}
|
|
|
|
|
|
static void
|
|
handleEvents(XEvent *event, void *clientData)
|
|
{
|
|
_Window *win = (_Window*)clientData;
|
|
W_View *view = win->view;
|
|
|
|
|
|
switch (event->type) {
|
|
case ClientMessage:
|
|
if (event->xclient.message_type == win->view->screen->protocolsAtom
|
|
&& event->xclient.format == 32
|
|
&& event->xclient.data.l[0]==win->view->screen->deleteWindowAtom) {
|
|
|
|
if (win->closeAction) {
|
|
(*win->closeAction)(win, win->closeData);
|
|
}
|
|
}
|
|
break;
|
|
/*
|
|
// was causing windows to ignore commands like closeWindow
|
|
* // after the windows is iconized/restored or a workspace change
|
|
* // if this is really needed, put the MapNotify portion too and
|
|
* // fix the restack bug in wmaker
|
|
case UnmapNotify:
|
|
WMUnmapWidget(win);
|
|
break;
|
|
*
|
|
case MapNotify:
|
|
WMMapWidget(win);
|
|
break;
|
|
|
|
*/
|
|
case DestroyNotify:
|
|
destroyWindow(win);
|
|
break;
|
|
|
|
case ConfigureNotify:
|
|
if (event->xconfigure.width != view->size.width
|
|
|| event->xconfigure.height != view->size.height) {
|
|
|
|
view->size.width = event->xconfigure.width;
|
|
view->size.height = event->xconfigure.height;
|
|
|
|
if (view->flags.notifySizeChanged) {
|
|
WMPostNotificationName(WMViewSizeDidChangeNotification,
|
|
view, NULL);
|
|
}
|
|
}
|
|
if (event->xconfigure.x != view->pos.x
|
|
|| event->xconfigure.y != view->pos.y) {
|
|
|
|
if (event->xconfigure.send_event) {
|
|
view->pos.x = event->xconfigure.x;
|
|
view->pos.y = event->xconfigure.y;
|
|
} else {
|
|
Window foo;
|
|
|
|
XTranslateCoordinates(view->screen->display,
|
|
view->window, view->screen->rootWin,
|
|
event->xconfigure.x, event->xconfigure.y,
|
|
&view->pos.x, &view->pos.y, &foo);
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
destroyWindow(_Window *win)
|
|
{
|
|
WMScreen *scr = win->view->screen;
|
|
|
|
WMRemoveNotificationObserver(win);
|
|
|
|
if (scr->windowList == win) {
|
|
scr->windowList = scr->windowList->nextPtr;
|
|
} else {
|
|
WMWindow *ptr;
|
|
ptr = scr->windowList;
|
|
|
|
if (ptr) {
|
|
while (ptr->nextPtr) {
|
|
if (ptr->nextPtr==win) {
|
|
ptr->nextPtr = ptr->nextPtr->nextPtr;
|
|
break;
|
|
}
|
|
ptr = ptr->nextPtr;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (win->title) {
|
|
wfree(win->title);
|
|
}
|
|
|
|
if (win->miniTitle) {
|
|
wfree(win->miniTitle);
|
|
}
|
|
|
|
if (win->miniImage) {
|
|
WMReleasePixmap(win->miniImage);
|
|
}
|
|
|
|
if (win->wname)
|
|
wfree(win->wname);
|
|
|
|
wfree(win);
|
|
}
|
|
|
|
|