2 * client.c - client management
4 * Copyright © 2007 Julien Danjou <julien@danjou.info>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
23 #include <X11/Xatom.h>
24 #include <X11/Xutil.h>
25 #include <X11/extensions/shape.h>
32 #include "statusbar.h"
34 #include "layouts/floating.h"
37 extern Client
*clients
, *sel
, *stack
; /* global client list and stack */
39 /** Attach client stack to clients stacks
43 attachstack(Client
* c
)
49 /** Detach client from stack
53 detachstack(Client
* c
)
57 for(tc
= &stack
; *tc
&& *tc
!= c
; tc
= &(*tc
)->snext
);
61 /** Grab or ungrab buttons when a client is focused
63 * \param focused True if client is focused
64 * \param modkey Mod key mask
65 * \param numlockmask Numlock mask
68 grabbuttons(Client
* c
, Bool focused
, KeySym modkey
, unsigned int numlockmask
)
70 XUngrabButton(c
->display
, AnyButton
, AnyModifier
, c
->win
);
74 XGrabButton(c
->display
, Button1
, modkey
, c
->win
, False
, BUTTONMASK
,
75 GrabModeAsync
, GrabModeSync
, None
, None
);
76 XGrabButton(c
->display
, Button1
, modkey
| LockMask
, c
->win
, False
,
77 BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
78 XGrabButton(c
->display
, Button1
, modkey
| numlockmask
, c
->win
, False
,
79 BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
80 XGrabButton(c
->display
, Button1
, modkey
| numlockmask
| LockMask
,
81 c
->win
, False
, BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
83 XGrabButton(c
->display
, Button2
, modkey
, c
->win
, False
, BUTTONMASK
,
84 GrabModeAsync
, GrabModeSync
, None
, None
);
85 XGrabButton(c
->display
, Button2
, modkey
| LockMask
, c
->win
, False
,
86 BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
87 XGrabButton(c
->display
, Button2
, modkey
| numlockmask
, c
->win
, False
,
88 BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
89 XGrabButton(c
->display
, Button2
, modkey
| numlockmask
| LockMask
,
90 c
->win
, False
, BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
92 XGrabButton(c
->display
, Button3
, modkey
, c
->win
, False
, BUTTONMASK
,
93 GrabModeAsync
, GrabModeSync
, None
, None
);
94 XGrabButton(c
->display
, Button3
, modkey
| LockMask
, c
->win
, False
,
95 BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
96 XGrabButton(c
->display
, Button3
, modkey
| numlockmask
, c
->win
, False
,
97 BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
98 XGrabButton(c
->display
, Button3
, modkey
| numlockmask
| LockMask
,
99 c
->win
, False
, BUTTONMASK
, GrabModeAsync
, GrabModeSync
, None
, None
);
101 XUngrabButton(c
->display
, AnyButton
, AnyModifier
, RootWindow(c
->display
, c
->screen
));
105 XGrabButton(c
->display
, AnyButton
, AnyModifier
, c
->win
, False
, BUTTONMASK
,
106 GrabModeAsync
, GrabModeSync
, None
, None
);
107 XGrabButton(c
->display
, Button4
, NoSymbol
, RootWindow(c
->display
, c
->screen
), False
, BUTTONMASK
,
108 GrabModeAsync
, GrabModeSync
, None
, None
);
109 XGrabButton(c
->display
, Button4
, LockMask
, RootWindow(c
->display
, c
->screen
), False
, BUTTONMASK
,
110 GrabModeAsync
, GrabModeSync
, None
, None
);
111 XGrabButton(c
->display
, Button4
, numlockmask
, RootWindow(c
->display
, c
->screen
), False
, BUTTONMASK
,
112 GrabModeAsync
, GrabModeSync
, None
, None
);
113 XGrabButton(c
->display
, Button4
, numlockmask
| LockMask
, RootWindow(c
->display
, c
->screen
), False
, BUTTONMASK
,
114 GrabModeAsync
, GrabModeSync
, None
, None
);
116 XGrabButton(c
->display
, Button5
, NoSymbol
, RootWindow(c
->display
, c
->screen
), False
, BUTTONMASK
,
117 GrabModeAsync
, GrabModeSync
, None
, None
);
118 XGrabButton(c
->display
, Button5
, LockMask
, RootWindow(c
->display
, c
->screen
), False
, BUTTONMASK
,
119 GrabModeAsync
, GrabModeSync
, None
, None
);
120 XGrabButton(c
->display
, Button5
, numlockmask
, RootWindow(c
->display
, c
->screen
), False
, BUTTONMASK
,
121 GrabModeAsync
, GrabModeSync
, None
, None
);
122 XGrabButton(c
->display
, Button5
, numlockmask
| LockMask
, RootWindow(c
->display
, c
->screen
), False
, BUTTONMASK
,
123 GrabModeAsync
, GrabModeSync
, None
, None
);
128 /** Check if client supports protocol WM_DELETE_WINDOW
129 * \param c the client
130 * \return True if client has WM_DELETE_WINDOW
133 isprotodel(Client
* c
)
139 if(XGetWMProtocols(c
->display
, c
->win
, &protocols
, &n
))
141 for(i
= 0; !ret
&& i
< n
; i
++)
142 if(protocols
[i
] == XInternAtom(c
->display
, "WM_DELETE_WINDOW", False
))
149 /** Set client WM_STATE property
150 * \param c the client
151 * \param state no idea
154 setclientstate(Client
* c
, long state
)
156 long data
[] = { state
, None
};
158 XChangeProperty(c
->display
, c
->win
, XInternAtom(c
->display
, "WM_STATE", False
),
159 XInternAtom(c
->display
, "WM_STATE", False
), 32,
160 PropModeReplace
, (unsigned char *) data
, 2);
163 /** Set client transparency using composite
165 * \param opacity opacity percentage
168 setclienttrans(Client
*c
, double opacity
)
170 unsigned int real_opacity
= 0xffffffff;
172 if(opacity
>= 0 && opacity
<= 100)
174 real_opacity
= ((opacity
/ 100.0) * 0xffffffff);
175 XChangeProperty(c
->display
, c
->win
,
176 XInternAtom(c
->display
, "_NET_WM_WINDOW_OPACITY", False
),
177 XA_CARDINAL
, 32, PropModeReplace
, (unsigned char *) &real_opacity
, 1L);
180 XDeleteProperty(c
->display
, c
->win
, XInternAtom(c
->display
, "_NET_WM_WINDOW_OPACITY", False
));
182 XSync(c
->display
, False
);
185 /** Attach client to the beginning of the clients stack
186 * \param c the client
198 updatetitle(Client
* c
)
200 if(!xgettextprop(c
->display
, c
->win
, XInternAtom(c
->display
, "_NET_WM_NAME", False
), c
->name
, sizeof c
->name
))
201 xgettextprop(c
->display
, c
->win
, XInternAtom(c
->display
, "WM_NAME", False
), c
->name
, sizeof c
->name
);
204 /** Ban client and unmapped it
205 * \param c the client
210 XUnmapWindow(c
->display
, c
->win
);
211 setclientstate(c
, IconicState
);
217 * \param c the client
220 configure(Client
* c
)
224 ce
.type
= ConfigureNotify
;
225 ce
.display
= c
->display
;
232 ce
.border_width
= c
->border
;
234 ce
.override_redirect
= False
;
235 XSendEvent(c
->display
, c
->win
, False
, StructureNotifyMask
, (XEvent
*) & ce
);
242 c
->prev
->next
= c
->next
;
244 c
->next
->prev
= c
->prev
;
247 c
->next
= c
->prev
= NULL
;
250 /** Give focus to client, or to first client if c is NULL
251 * \param disp Display ref
252 * \param drawcontext drawcontext ref
254 * \param selscreen True if current screen is selected
255 * \param awesomeconf awesome config
258 focus(Display
*disp
, DC
*drawcontext
, Client
* c
, Bool selscreen
, awesome_config
*awesomeconf
)
260 /* if c is NULL or invisible, take next client in the stack */
261 if((!c
&& selscreen
) || (c
&& !isvisible(c
, awesomeconf
->screen
, awesomeconf
->tags
, awesomeconf
->ntags
)))
262 for(c
= stack
; c
&& !isvisible(c
, awesomeconf
->screen
, awesomeconf
->tags
, awesomeconf
->ntags
); c
= c
->snext
);
264 /* if a client was selected but it's not the current client, unfocus it */
267 grabbuttons(sel
, False
, awesomeconf
->modkey
, awesomeconf
->numlockmask
);
268 XSetWindowBorder(sel
->display
, sel
->win
, drawcontext
->norm
[ColBorder
]);
269 setclienttrans(sel
, awesomeconf
->opacity_unfocused
);
275 grabbuttons(c
, True
, awesomeconf
->modkey
, awesomeconf
->numlockmask
);
280 drawstatusbar(disp
, drawcontext
, awesomeconf
);
283 XSetWindowBorder(sel
->display
, sel
->win
, drawcontext
->sel
[ColBorder
]);
284 XSetInputFocus(sel
->display
, sel
->win
, RevertToPointerRoot
, CurrentTime
);
285 for(c
= stack
; c
; c
= c
->snext
)
287 setclienttrans(c
, awesomeconf
->opacity_unfocused
);
288 setclienttrans(sel
, -1);
291 XSetInputFocus(disp
, RootWindow(disp
, awesomeconf
->screen
), RevertToPointerRoot
, CurrentTime
);
294 /** Kill selected client
295 * \param disp Display ref
296 * \param drawcontext Drawcontext ref
297 * \param awesomeconf awesome config
299 * \ingroup ui_callback
302 uicb_killclient(Display
*disp
__attribute__ ((unused
)),
303 DC
*drawcontext
__attribute__ ((unused
)),
304 awesome_config
*awesomeconf
__attribute__ ((unused
)),
305 const char *arg
__attribute__ ((unused
)))
313 ev
.type
= ClientMessage
;
314 ev
.xclient
.window
= sel
->win
;
315 ev
.xclient
.message_type
= XInternAtom(disp
, "WM_PROTOCOLS", False
);
316 ev
.xclient
.format
= 32;
317 ev
.xclient
.data
.l
[0] = XInternAtom(disp
, "WM_DELETE_WINDOW", False
);
318 ev
.xclient
.data
.l
[1] = CurrentTime
;
319 XSendEvent(sel
->display
, sel
->win
, False
, NoEventMask
, &ev
);
322 XKillClient(sel
->display
, sel
->win
);
326 /** Load windows properties, restoring client's tag
327 * and floating state before awesome was restarted if any
328 * \todo this may bug if number of tags is != than before
329 * \param c Client ref
330 * \param ntags tags number
333 loadprops(Client
* c
, int ntags
)
339 prop
= p_new(char, ntags
+ 2);
341 if(xgettextprop(c
->display
, c
->win
, AWESOMEPROPS_ATOM(c
->display
), prop
, ntags
+ 2))
343 for(i
= 0; i
< ntags
&& prop
[i
]; i
++)
344 if((c
->tags
[i
] = prop
[i
] == '1'))
346 if(i
<= ntags
&& prop
[i
])
347 c
->isfloating
= prop
[i
] == '1';
355 /** Manage a new client
356 * \param disp Display ref
357 * \param drawcontext Drawcontext ref
358 * \param w The window
359 * \param wa Window attributes
360 * \param awesomeconf awesome config
363 manage(Display
* disp
, DC
*drawcontext
, Window w
, XWindowAttributes
* wa
, awesome_config
*awesomeconf
)
366 Client
*c
, *t
= NULL
;
371 c
= p_new(Client
, 1);
372 c
->tags
= p_new(Bool
, awesomeconf
->ntags
);
375 c
->x
= c
->rw
= wa
->x
;
376 c
->y
= c
->ry
= wa
->y
;
377 c
->w
= c
->rw
= wa
->width
;
378 c
->h
= c
->rh
= wa
->height
;
379 c
->oldborder
= wa
->border_width
;
381 c
->screen
= awesomeconf
->screen
;
382 if(c
->w
== DisplayWidth(disp
, c
->screen
)
383 && c
->h
== DisplayHeight(disp
, c
->screen
))
387 c
->border
= wa
->border_width
;
391 ScreenInfo
*si
= get_display_info(disp
, c
->screen
, awesomeconf
->statusbar
);
393 if(c
->x
+ c
->w
+ 2 * c
->border
> si
->x_org
+ si
->width
)
394 c
->x
= c
->rx
= si
->x_org
+ si
->width
- c
->w
- 2 * c
->border
;
395 if(c
->y
+ c
->h
+ 2 * c
->border
> si
->y_org
+ si
->height
)
396 c
->y
= c
->ry
= si
->y_org
+ si
->height
- c
->h
- 2 * c
->border
;
398 c
->x
= c
->rx
= si
->x_org
;
400 c
->y
= c
->ry
= si
->y_org
;
401 c
->border
= awesomeconf
->borderpx
;
404 wc
.border_width
= c
->border
;
405 XConfigureWindow(disp
, w
, CWBorderWidth
, &wc
);
406 XSetWindowBorder(disp
, w
, drawcontext
->norm
[ColBorder
]);
407 configure(c
); /* propagates border_width, if size doesn't change */
409 XSelectInput(disp
, w
, StructureNotifyMask
| PropertyChangeMask
| EnterWindowMask
);
410 if(awesomeconf
->have_shape
)
412 XShapeSelectInput(disp
, w
, ShapeNotifyMask
);
415 grabbuttons(c
, False
, awesomeconf
->modkey
, awesomeconf
->numlockmask
);
417 if((rettrans
= XGetTransientForHint(disp
, w
, &trans
) == Success
))
418 for(t
= clients
; t
&& t
->win
!= trans
; t
= t
->next
);
420 for(i
= 0; i
< awesomeconf
->ntags
; i
++)
421 c
->tags
[i
] = t
->tags
[i
];
422 if(!loadprops(c
, awesomeconf
->ntags
))
423 applyrules(c
, awesomeconf
);
425 c
->isfloating
= (rettrans
== Success
) || c
->isfixed
;
426 saveprops(c
, awesomeconf
->ntags
);
429 XMoveResizeWindow(disp
, c
->win
, c
->x
, c
->y
, c
->w
, c
->h
); /* some windows require this */
431 arrange(disp
, drawcontext
, awesomeconf
);
435 resize(Client
* c
, int x
, int y
, int w
, int h
, Bool sizehints
)
437 double dx
, dy
, max
, min
, ratio
;
442 if(c
->minay
> 0 && c
->maxay
> 0 && (h
- c
->baseh
) > 0 && (w
- c
->basew
) > 0)
444 dx
= (double) (w
- c
->basew
);
445 dy
= (double) (h
- c
->baseh
);
446 min
= (double) (c
->minax
) / (double) (c
->minay
);
447 max
= (double) (c
->maxax
) / (double) (c
->maxay
);
449 if(max
> 0 && min
> 0 && ratio
> 0)
453 dy
= (dx
* min
+ dy
) / (min
* min
+ 1);
455 w
= (int) dx
+ c
->basew
;
456 h
= (int) dy
+ c
->baseh
;
460 dy
= (dx
* min
+ dy
) / (max
* max
+ 1);
462 w
= (int) dx
+ c
->basew
;
463 h
= (int) dy
+ c
->baseh
;
467 if(c
->minw
&& w
< c
->minw
)
469 if(c
->minh
&& h
< c
->minh
)
471 if(c
->maxw
&& w
> c
->maxw
)
473 if(c
->maxh
&& h
> c
->maxh
)
476 w
-= (w
- c
->basew
) % c
->incw
;
478 h
-= (h
- c
->baseh
) % c
->inch
;
482 /* offscreen appearance fixes */
483 if(x
> DisplayWidth(c
->display
, c
->screen
))
484 x
= DisplayWidth(c
->display
, c
->screen
) - w
- 2 * c
->border
;
485 if(y
> DisplayHeight(c
->display
, c
->screen
))
486 y
= DisplayHeight(c
->display
, c
->screen
) - h
- 2 * c
->border
;
487 if(x
+ w
+ 2 * c
->border
< 0)
489 if(y
+ h
+ 2 * c
->border
< 0)
491 if(c
->x
!= x
|| c
->y
!= y
|| c
->w
!= w
|| c
->h
!= h
)
496 c
->h
= wc
.height
= h
;
497 wc
.border_width
= c
->border
;
498 XConfigureWindow(c
->display
, c
->win
, CWX
| CWY
| CWWidth
| CWHeight
| CWBorderWidth
, &wc
);
500 XSync(c
->display
, False
);
505 uicb_moveresize(Display
*disp
__attribute__ ((unused
)),
506 DC
*drawcontext
__attribute__ ((unused
)),
507 awesome_config
*awesomeconf
,
510 int x
, y
, w
, h
, nx
, ny
, nw
, nh
, ox
, oy
, ow
, oh
;
511 char xabs
, yabs
, wabs
, habs
;
512 int mx
, my
, dx
, dy
, nmx
, nmy
;
516 if(!IS_ARRANGE(layout_floating
))
517 if(!sel
|| !sel
->isfloating
|| sel
->isfixed
|| !arg
)
519 if(sscanf(arg
, "%d%c %d%c %d%c %d%c", &x
, &xabs
, &y
, &yabs
, &w
, &wabs
, &h
, &habs
) != 8)
521 nx
= xabs
== 'x' ? sel
->x
+ x
: x
;
522 ny
= yabs
== 'y' ? sel
->y
+ y
: y
;
523 nw
= wabs
== 'w' ? sel
->w
+ w
: w
;
524 nh
= habs
== 'h' ? sel
->h
+ h
: h
;
531 Bool xqp
= XQueryPointer(sel
->display
, RootWindow(sel
->display
, sel
->screen
), &dummy
, &dummy
, &mx
, &my
, &dx
, &dy
, &dui
);
532 resize(sel
, nx
, ny
, nw
, nh
, True
);
533 if (xqp
&& ox
<= mx
&& (ox
+ ow
) >= mx
&& oy
<= my
&& (oy
+ oh
) >= my
)
535 nmx
= mx
-ox
+sel
->w
-ow
-1 < 0 ? 0 : mx
-ox
+sel
->w
-ow
-1;
536 nmy
= my
-oy
+sel
->h
-oh
-1 < 0 ? 0 : my
-oy
+sel
->h
-oh
-1;
537 XWarpPointer(sel
->display
, None
, sel
->win
, 0, 0, 0, 0, nmx
, nmy
);
542 saveprops(Client
* c
, int ntags
)
547 prop
= p_new(char, ntags
+ 2);
549 for(i
= 0; i
< ntags
; i
++)
550 prop
[i
] = c
->tags
[i
] ? '1' : '0';
553 prop
[i
] = c
->isfloating
? '1' : '0';
557 XChangeProperty(c
->display
, c
->win
, AWESOMEPROPS_ATOM(c
->display
), XA_STRING
, 8,
558 PropModeReplace
, (unsigned char *) prop
, i
);
566 XMapWindow(c
->display
, c
->win
);
567 setclientstate(c
, NormalState
);
573 unmanage(Client
* c
, DC
*drawcontext
, long state
, awesome_config
*awesomeconf
)
578 wc
.border_width
= c
->oldborder
;
579 /* The server grab construct avoids race conditions. */
580 XGrabServer(c
->display
);
581 XConfigureWindow(c
->display
, c
->win
, CWBorderWidth
, &wc
); /* restore border */
585 focus(c
->display
, drawcontext
, NULL
, True
, awesomeconf
);
586 XUngrabButton(c
->display
, AnyButton
, AnyModifier
, c
->win
);
587 setclientstate(c
, state
);
588 XSync(c
->display
, False
);
589 XSetErrorHandler(xerror
);
590 XUngrabServer(c
->display
);
591 if(state
!= NormalState
)
592 arrange(c
->display
, drawcontext
, awesomeconf
);
598 updatesizehints(Client
* c
)
603 if(!XGetWMNormalHints(c
->display
, c
->win
, &size
, &msize
) || !size
.flags
)
605 c
->flags
= size
.flags
;
606 if(c
->flags
& PBaseSize
)
608 c
->basew
= size
.base_width
;
609 c
->baseh
= size
.base_height
;
611 else if(c
->flags
& PMinSize
)
613 c
->basew
= size
.min_width
;
614 c
->baseh
= size
.min_height
;
617 c
->basew
= c
->baseh
= 0;
618 if(c
->flags
& PResizeInc
)
620 c
->incw
= size
.width_inc
;
621 c
->inch
= size
.height_inc
;
624 c
->incw
= c
->inch
= 0;
626 if(c
->flags
& PMaxSize
)
628 c
->maxw
= size
.max_width
;
629 c
->maxh
= size
.max_height
;
632 c
->maxw
= c
->maxh
= 0;
634 if(c
->flags
& PMinSize
)
636 c
->minw
= size
.min_width
;
637 c
->minh
= size
.min_height
;
639 else if(c
->flags
& PBaseSize
)
641 c
->minw
= size
.base_width
;
642 c
->minh
= size
.base_height
;
645 c
->minw
= c
->minh
= 0;
647 if(c
->flags
& PAspect
)
649 c
->minax
= size
.min_aspect
.x
;
650 c
->maxax
= size
.max_aspect
.x
;
651 c
->minay
= size
.min_aspect
.y
;
652 c
->maxay
= size
.max_aspect
.y
;
655 c
->minax
= c
->maxax
= c
->minay
= c
->maxay
= 0;
657 c
->isfixed
= (c
->maxw
&& c
->minw
&& c
->maxh
&& c
->minh
658 && c
->maxw
== c
->minw
&& c
->maxh
== c
->minh
);
665 int i
, b
; unsigned int u
; /* dummies */
666 /* Logic to decide if we have a shaped window cribbed from fvwm-2.5.10. */
667 if (XShapeQueryExtents(c
->display
, c
->win
, &bounding_shaped
, &i
, &i
,
668 &u
, &u
, &b
, &i
, &i
, &u
, &u
) && bounding_shaped
)
669 XShapeCombineShape(c
->display
, RootWindow(c
->display
, c
->screen
), ShapeBounding
, 0, 0, c
->win
, ShapeBounding
, ShapeSet
);
672 /** Set selected client transparency
673 * \param disp Display ref
674 * \param drawcontext Drawcontext ref
675 * \param awesomeconf awesome config
676 * \param arg unused arg
677 * \ingroup ui_callback
680 uicb_settrans(Display
*disp
__attribute__ ((unused
)),
681 DC
*drawcontext
__attribute__ ((unused
)),
682 awesome_config
*awesomeconf
__attribute__ ((unused
)),
685 double delta
= 100.0, current_opacity
= 0.0;
689 unsigned long n
, left
;
690 unsigned int current_opacity_raw
= 0;
696 XGetWindowProperty(sel
->display
, sel
->win
, XInternAtom(sel
->display
, "_NET_WM_WINDOW_OPACITY", False
),
697 0L, 1L, False
, XA_CARDINAL
, &actual
, &format
, &n
, &left
,
698 (unsigned char **) &data
);
701 memcpy(¤t_opacity_raw
, data
, sizeof(unsigned int));
703 current_opacity
= (current_opacity_raw
* 100.0) / 0xffffffff;
708 delta
= compute_new_value_from_arg(arg
, current_opacity
);
712 else if(delta
> 100.0)
718 if(delta
== 100.0 && !set_prop
)
719 setclienttrans(sel
, -1);
721 setclienttrans(sel
, delta
);
726 * \param disp Display ref
727 * \param drawcontext Drawcontext ref
728 * \param awesomeconf awesome config
729 * \param arg X, +X or -X
730 * \ingroup ui_callback
733 uicb_setborder(Display
*disp
__attribute__ ((unused
)),
734 DC
*drawcontext
__attribute__ ((unused
)),
735 awesome_config
*awesomeconf
,
741 if((awesomeconf
->borderpx
= (int) compute_new_value_from_arg(arg
, (double) awesomeconf
->borderpx
)) < 0)
742 awesomeconf
->borderpx
= 0;