Bug fix: Dynamic inactive dim & client window changes
- Make inactive_dim opacity change according to window opacity by default, so it looks better when fading. --inactive-dim-fixed restores the old behavior. - Make client window default to the window itself. Add w->wmwin to represent whether the window looks like a WM window instead. A side effect is, the window type of WM windows are changed from unknown to normal, making it necessary to use --mark-wmwin-active to avoid considering them unfocused. - Add check of PointerRoot to recheck_focus() to avoid BadWindow errors when the root window is focused. - Add a few macros to simplify debugging code. - Add DEBUG_FRAME.
This commit is contained in:
parent
9e66fd5b3f
commit
983803aa9f
@ -20,6 +20,8 @@ inactive-opacity = 0.8;
|
|||||||
frame-opacity = 0.7;
|
frame-opacity = 0.7;
|
||||||
inactive-opacity-override = false;
|
inactive-opacity-override = false;
|
||||||
alpha-step = 0.06;
|
alpha-step = 0.06;
|
||||||
|
# inactive-dim = 0.2;
|
||||||
|
# inactive-dim-fixed = true;
|
||||||
|
|
||||||
# Fading
|
# Fading
|
||||||
fading = true;
|
fading = true;
|
||||||
|
@ -15,6 +15,13 @@
|
|||||||
// #define MSTR_(s) #s
|
// #define MSTR_(s) #s
|
||||||
// #define MSTR(s) MSTR_(s)
|
// #define MSTR(s) MSTR_(s)
|
||||||
|
|
||||||
|
#define printf_dbg(format, ...) \
|
||||||
|
printf(format, ## __VA_ARGS__); \
|
||||||
|
fflush(stdout)
|
||||||
|
|
||||||
|
#define printf_dbgf(format, ...) \
|
||||||
|
printf_dbg("%s" format, __func__, ## __VA_ARGS__)
|
||||||
|
|
||||||
// Use #s here to prevent macro expansion
|
// Use #s here to prevent macro expansion
|
||||||
/// Macro used for shortening some debugging code.
|
/// Macro used for shortening some debugging code.
|
||||||
#define CASESTRRET(s) case s: return #s
|
#define CASESTRRET(s) case s: return #s
|
||||||
@ -941,6 +948,9 @@ recheck_focus(session_t *ps) {
|
|||||||
|
|
||||||
XGetInputFocus(ps->dpy, &wid, &revert_to);
|
XGetInputFocus(ps->dpy, &wid, &revert_to);
|
||||||
|
|
||||||
|
if (!wid || PointerRoot == wid)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
// Fallback to the old method if find_toplevel() fails
|
// Fallback to the old method if find_toplevel() fails
|
||||||
if (!(w = find_toplevel(ps, wid))) {
|
if (!(w = find_toplevel(ps, wid))) {
|
||||||
w = find_toplevel2(ps, wid);
|
w = find_toplevel2(ps, wid);
|
||||||
@ -989,7 +999,7 @@ root_tile_f(session_t *ps) {
|
|||||||
fill = true;
|
fill = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
pa.repeat = true;
|
pa.repeat = True;
|
||||||
picture = XRenderCreatePicture(
|
picture = XRenderCreatePicture(
|
||||||
ps->dpy, pixmap, XRenderFindVisualFormat(ps->dpy, ps->vis),
|
ps->dpy, pixmap, XRenderFindVisualFormat(ps->dpy, ps->vis),
|
||||||
CPRepeat, &pa);
|
CPRepeat, &pa);
|
||||||
@ -1190,6 +1200,11 @@ get_frame_extents(session_t *ps, win *w, Window client) {
|
|||||||
update_reg_ignore_expire(ps, w);
|
update_reg_ignore_expire(ps, w);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef DEBUG_FRAME
|
||||||
|
printf_dbgf("(%#010lx): %d, %d, %d, %d\n", w->id,
|
||||||
|
w->left_width, w->right_width, w->top_width, w->bottom_width);
|
||||||
|
#endif
|
||||||
|
|
||||||
free_winprop(&prop);
|
free_winprop(&prop);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1323,6 +1338,16 @@ paint_preprocess(session_t *ps, win *list) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
w->shadow_alpha_pict = get_alpha_pict_d(ps, w->shadow_opacity);
|
w->shadow_alpha_pict = get_alpha_pict_d(ps, w->shadow_opacity);
|
||||||
|
|
||||||
|
// Dimming preprocessing
|
||||||
|
if (w->dim) {
|
||||||
|
double dim_opacity = ps->o.inactive_dim;
|
||||||
|
if (!ps->o.inactive_dim_fixed)
|
||||||
|
dim_opacity *= get_opacity_percent(w);
|
||||||
|
|
||||||
|
w->dim_alpha_pict = get_alpha_pict_d(ps, dim_opacity);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((to_paint && WINDOW_SOLID == w->mode)
|
if ((to_paint && WINDOW_SOLID == w->mode)
|
||||||
@ -1512,9 +1537,9 @@ win_paint_win(session_t *ps, win *w, Picture tgt_buffer) {
|
|||||||
#undef COMP_BDR
|
#undef COMP_BDR
|
||||||
|
|
||||||
// Dimming the window if needed
|
// Dimming the window if needed
|
||||||
if (w->dim) {
|
if (w->dim && w->dim_alpha_pict != ps->alpha_picts[0]) {
|
||||||
XRenderComposite(ps->dpy, PictOpOver, ps->dim_picture, None,
|
XRenderComposite(ps->dpy, PictOpOver, ps->black_picture,
|
||||||
tgt_buffer, 0, 0, 0, 0, x, y, wid, hei);
|
w->dim_alpha_pict, tgt_buffer, 0, 0, 0, 0, x, y, wid, hei);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1802,41 +1827,43 @@ map_win(session_t *ps, Window id) {
|
|||||||
XShapeSelectInput(ps->dpy, id, ShapeNotifyMask);
|
XShapeSelectInput(ps->dpy, id, ShapeNotifyMask);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Make sure the XSelectInput() requests are sent
|
||||||
|
XSync(ps->dpy, False);
|
||||||
|
|
||||||
// Detect client window here instead of in add_win() as the client
|
// Detect client window here instead of in add_win() as the client
|
||||||
// window should have been prepared at this point
|
// window should have been prepared at this point
|
||||||
if (!w->client_win) {
|
if (!w->client_win) {
|
||||||
Window cw = 0;
|
w->wmwin = false;
|
||||||
|
|
||||||
|
Window cw = None;
|
||||||
// Always recursively look for a window with WM_STATE, as Fluxbox
|
// Always recursively look for a window with WM_STATE, as Fluxbox
|
||||||
// sets override-redirect flags on all frame windows.
|
// sets override-redirect flags on all frame windows.
|
||||||
cw = find_client_win(ps, w->id);
|
cw = find_client_win(ps, w->id);
|
||||||
#ifdef DEBUG_CLIENTWIN
|
#ifdef DEBUG_CLIENTWIN
|
||||||
|
if (cw)
|
||||||
printf("find_client_win(%#010lx): client %#010lx\n", w->id, cw);
|
printf("find_client_win(%#010lx): client %#010lx\n", w->id, cw);
|
||||||
#endif
|
#endif
|
||||||
// Set a window's client window to itself only if we didn't find a
|
// Set a window's client window to itself if we couldn't find a
|
||||||
// client window and the window has override-redirect flag
|
// client window
|
||||||
if (!cw && w->a.override_redirect) {
|
if (!cw) {
|
||||||
cw = w->id;
|
cw = w->id;
|
||||||
|
w->wmwin = !w->a.override_redirect;
|
||||||
#ifdef DEBUG_CLIENTWIN
|
#ifdef DEBUG_CLIENTWIN
|
||||||
printf("find_client_win(%#010lx): client self (override-redirected)\n", w->id);
|
printf("find_client_win(%#010lx): client self (%s)\n", w->id,
|
||||||
|
(w->wmwin ? "wmwin": "override-redirected"));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
if (cw) {
|
|
||||||
mark_client_win(ps, w, cw);
|
mark_client_win(ps, w, cw);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else {
|
else {
|
||||||
// Re-mark client window here
|
// Re-mark client window here
|
||||||
mark_client_win(ps, w, w->client_win);
|
mark_client_win(ps, w, w->client_win);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Workaround for _NET_WM_WINDOW_TYPE for Openbox menus, which is
|
assert(w->client_win);
|
||||||
// set on a non-override-redirect window with no WM_STATE either
|
|
||||||
if (!w->client_win && WINTYPE_UNKNOWN == w->window_type)
|
|
||||||
w->window_type = wid_get_prop_wintype(ps, w->id);
|
|
||||||
|
|
||||||
#ifdef DEBUG_WINTYPE
|
#ifdef DEBUG_WINTYPE
|
||||||
printf("map_win(%#010lx): type %s\n",
|
printf_dbgf("(%#010lx): type %s\n", w->id, WINTYPES[w->window_type]);
|
||||||
w->id, WINTYPES[w->window_type]);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Detect if the window is shaped or has rounded corners
|
// Detect if the window is shaped or has rounded corners
|
||||||
@ -2290,7 +2317,10 @@ add_win(session_t *ps, Window id, Window prev) {
|
|||||||
new->alpha_pict = None;
|
new->alpha_pict = None;
|
||||||
new->frame_opacity = 1.0;
|
new->frame_opacity = 1.0;
|
||||||
new->frame_alpha_pict = None;
|
new->frame_alpha_pict = None;
|
||||||
|
|
||||||
new->dim = false;
|
new->dim = false;
|
||||||
|
new->dim_alpha_pict = None;
|
||||||
|
|
||||||
new->focused = false;
|
new->focused = false;
|
||||||
new->focused_real = false;
|
new->focused_real = false;
|
||||||
new->destroyed = false;
|
new->destroyed = false;
|
||||||
@ -2307,6 +2337,7 @@ add_win(session_t *ps, Window id, Window prev) {
|
|||||||
new->bottom_width = 0;
|
new->bottom_width = 0;
|
||||||
|
|
||||||
new->client_win = 0;
|
new->client_win = 0;
|
||||||
|
new->wmwin = false;
|
||||||
|
|
||||||
new->flags = 0;
|
new->flags = 0;
|
||||||
|
|
||||||
@ -2358,7 +2389,7 @@ restack_win(session_t *ps, win *w, Window new_above) {
|
|||||||
bool to_free;
|
bool to_free;
|
||||||
win* c = ps->list;
|
win* c = ps->list;
|
||||||
|
|
||||||
printf("restack_win(%#010lx, %#010lx): "
|
printf_dbgf("(%#010lx, %#010lx): "
|
||||||
"Window stack modified. Current stack:\n", w->id, new_above);
|
"Window stack modified. Current stack:\n", w->id, new_above);
|
||||||
|
|
||||||
for (; c; c = c->next) {
|
for (; c; c = c->next) {
|
||||||
@ -2665,7 +2696,7 @@ wid_get_name(session_t *ps, Window wid, char **name) {
|
|||||||
&& text_prop.value)) {
|
&& text_prop.value)) {
|
||||||
// set_ignore_next(ps);
|
// set_ignore_next(ps);
|
||||||
#ifdef DEBUG_WINDATA
|
#ifdef DEBUG_WINDATA
|
||||||
printf("wid_get_name(%#010lx): _NET_WM_NAME unset, falling back to WM_NAME.\n", wid);
|
printf_dbgf("(%#010lx): _NET_WM_NAME unset, falling back to WM_NAME.\n", wid);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!(XGetWMName(ps->dpy, wid, &text_prop) && text_prop.value)) {
|
if (!(XGetWMName(ps->dpy, wid, &text_prop) && text_prop.value)) {
|
||||||
@ -2716,7 +2747,7 @@ win_get_name(session_t *ps, win *w) {
|
|||||||
free(name_old);
|
free(name_old);
|
||||||
|
|
||||||
#ifdef DEBUG_WINDATA
|
#ifdef DEBUG_WINDATA
|
||||||
printf("win_get_name(%#010lx): client = %#010lx, name = \"%s\", "
|
printf_dbgf("(%#010lx): client = %#010lx, name = \"%s\", "
|
||||||
"ret = %d\n", w->id, w->client_win, w->name, ret);
|
"ret = %d\n", w->id, w->client_win, w->name, ret);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2755,7 +2786,7 @@ win_get_class(session_t *ps, win *w) {
|
|||||||
XFreeStringList(strlst);
|
XFreeStringList(strlst);
|
||||||
|
|
||||||
#ifdef DEBUG_WINDATA
|
#ifdef DEBUG_WINDATA
|
||||||
printf("win_get_class(%#010lx): client = %#010lx, "
|
printf_dbgf("(%#010lx): client = %#010lx, "
|
||||||
"instance = \"%s\", general = \"%s\"\n",
|
"instance = \"%s\", general = \"%s\"\n",
|
||||||
w->id, w->client_win, w->class_instance, w->class_general);
|
w->id, w->client_win, w->class_instance, w->class_general);
|
||||||
#endif
|
#endif
|
||||||
@ -3389,6 +3420,8 @@ usage(void) {
|
|||||||
"--focus-exclude condition\n"
|
"--focus-exclude condition\n"
|
||||||
" Specify a list of conditions of windows that should always be\n"
|
" Specify a list of conditions of windows that should always be\n"
|
||||||
" considered focused.\n"
|
" considered focused.\n"
|
||||||
|
"--inactive-dim-fixed\n"
|
||||||
|
" Use fixed inactive dim value.\n"
|
||||||
"\n"
|
"\n"
|
||||||
"Format of a condition:\n"
|
"Format of a condition:\n"
|
||||||
"\n"
|
"\n"
|
||||||
@ -3783,6 +3816,8 @@ parse_config(session_t *ps, char *cpath, struct options_tmp *pcfgtmp) {
|
|||||||
// --unredir-if-possible
|
// --unredir-if-possible
|
||||||
lcfg_lookup_bool(&cfg, "unredir-if-possible",
|
lcfg_lookup_bool(&cfg, "unredir-if-possible",
|
||||||
&ps->o.unredir_if_possible);
|
&ps->o.unredir_if_possible);
|
||||||
|
// --inactive-dim-fixed
|
||||||
|
lcfg_lookup_bool(&cfg, "inactive-dim-fixed", &ps->o.inactive_dim_fixed);
|
||||||
// --shadow-exclude
|
// --shadow-exclude
|
||||||
parse_cfg_condlst(&cfg, &ps->o.shadow_blacklist, "shadow-exclude");
|
parse_cfg_condlst(&cfg, &ps->o.shadow_blacklist, "shadow-exclude");
|
||||||
// --focus-exclude
|
// --focus-exclude
|
||||||
@ -3841,6 +3876,7 @@ get_cfg(session_t *ps, int argc, char *const *argv) {
|
|||||||
{ "respect-prop-shadow", no_argument, NULL, 277 },
|
{ "respect-prop-shadow", no_argument, NULL, 277 },
|
||||||
{ "unredir-if-possible", no_argument, NULL, 278 },
|
{ "unredir-if-possible", no_argument, NULL, 278 },
|
||||||
{ "focus-exclude", required_argument, NULL, 279 },
|
{ "focus-exclude", required_argument, NULL, 279 },
|
||||||
|
{ "inactive-dim-fixed", no_argument, NULL, 280 },
|
||||||
// Must terminate with a NULL entry
|
// Must terminate with a NULL entry
|
||||||
{ NULL, 0, NULL, 0 },
|
{ NULL, 0, NULL, 0 },
|
||||||
};
|
};
|
||||||
@ -4046,6 +4082,10 @@ get_cfg(session_t *ps, int argc, char *const *argv) {
|
|||||||
// --focus-exclude
|
// --focus-exclude
|
||||||
condlst_add(&ps->o.focus_blacklist, optarg);
|
condlst_add(&ps->o.focus_blacklist, optarg);
|
||||||
break;
|
break;
|
||||||
|
case 280:
|
||||||
|
// --inactive-dim-fixed
|
||||||
|
ps->o.inactive_dim_fixed = true;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
usage();
|
usage();
|
||||||
}
|
}
|
||||||
@ -4573,6 +4613,7 @@ session_init(session_t *ps_old, int argc, char **argv) {
|
|||||||
.frame_opacity = 0.0,
|
.frame_opacity = 0.0,
|
||||||
.detect_client_opacity = false,
|
.detect_client_opacity = false,
|
||||||
.inactive_dim = 0.0,
|
.inactive_dim = 0.0,
|
||||||
|
.inactive_dim_fixed = false,
|
||||||
.alpha_step = 0.03,
|
.alpha_step = 0.03,
|
||||||
.use_ewmh_active_win = false,
|
.use_ewmh_active_win = false,
|
||||||
.focus_blacklist = NULL,
|
.focus_blacklist = NULL,
|
||||||
@ -4600,7 +4641,6 @@ session_init(session_t *ps_old, int argc, char **argv) {
|
|||||||
.list = NULL,
|
.list = NULL,
|
||||||
.active_win = NULL,
|
.active_win = NULL,
|
||||||
.black_picture = None,
|
.black_picture = None,
|
||||||
.dim_picture = None,
|
|
||||||
.cshadow_picture = None,
|
.cshadow_picture = None,
|
||||||
.gaussian_map = NULL,
|
.gaussian_map = NULL,
|
||||||
.cgsize = 0,
|
.cgsize = 0,
|
||||||
@ -4817,11 +4857,6 @@ session_init(session_t *ps_old, int argc, char **argv) {
|
|||||||
ps->o.shadow_red, ps->o.shadow_green, ps->o.shadow_blue);
|
ps->o.shadow_red, ps->o.shadow_green, ps->o.shadow_blue);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Generates a picture for inactive_dim
|
|
||||||
if (ps->o.inactive_dim) {
|
|
||||||
ps->dim_picture = solid_picture(ps, true, ps->o.inactive_dim, 0, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
ps->all_damage = None;
|
ps->all_damage = None;
|
||||||
XGrabServer(ps->dpy);
|
XGrabServer(ps->dpy);
|
||||||
|
|
||||||
@ -4943,7 +4978,6 @@ session_destroy(session_t *ps) {
|
|||||||
free_picture(ps, &ps->root_picture);
|
free_picture(ps, &ps->root_picture);
|
||||||
|
|
||||||
// Free other X resources
|
// Free other X resources
|
||||||
free_picture(ps, &ps->dim_picture);
|
|
||||||
free_picture(ps, &ps->root_tile);
|
free_picture(ps, &ps->root_tile);
|
||||||
free_region(ps, &ps->screen_reg);
|
free_region(ps, &ps->screen_reg);
|
||||||
free_region(ps, &ps->all_damage);
|
free_region(ps, &ps->all_damage);
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
// #define DEBUG_WINMATCH 1
|
// #define DEBUG_WINMATCH 1
|
||||||
// #define DEBUG_REDIR 1
|
// #define DEBUG_REDIR 1
|
||||||
// #define DEBUG_ALLOC_REG 1
|
// #define DEBUG_ALLOC_REG 1
|
||||||
|
// #define DEBUG_FRAME 1
|
||||||
// #define MONITOR_REPAINT 1
|
// #define MONITOR_REPAINT 1
|
||||||
|
|
||||||
// Whether to enable PCRE regular expression support in blacklists, enabled
|
// Whether to enable PCRE regular expression support in blacklists, enabled
|
||||||
@ -119,9 +120,7 @@
|
|||||||
// Window opacity / dim state changed
|
// Window opacity / dim state changed
|
||||||
#define WFLAG_OPCT_CHANGE 0x0004
|
#define WFLAG_OPCT_CHANGE 0x0004
|
||||||
|
|
||||||
/**
|
// === Types ===
|
||||||
* Types
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef uint32_t opacity_t;
|
typedef uint32_t opacity_t;
|
||||||
|
|
||||||
@ -290,6 +289,9 @@ typedef struct {
|
|||||||
bool detect_client_opacity;
|
bool detect_client_opacity;
|
||||||
/// How much to dim an inactive window. 0.0 - 1.0, 0 to disable.
|
/// How much to dim an inactive window. 0.0 - 1.0, 0 to disable.
|
||||||
double inactive_dim;
|
double inactive_dim;
|
||||||
|
/// Whether to use fixed inactive dim opacity, instead of deciding
|
||||||
|
/// based on window opacity.
|
||||||
|
bool inactive_dim_fixed;
|
||||||
/// Step for pregenerating alpha pictures. 0.01 - 1.0.
|
/// Step for pregenerating alpha pictures. 0.01 - 1.0.
|
||||||
double alpha_step;
|
double alpha_step;
|
||||||
|
|
||||||
@ -394,8 +396,6 @@ typedef struct {
|
|||||||
// === Shadow/dimming related ===
|
// === Shadow/dimming related ===
|
||||||
/// 1x1 black Picture.
|
/// 1x1 black Picture.
|
||||||
Picture black_picture;
|
Picture black_picture;
|
||||||
/// Picture used for dimming inactive windows.
|
|
||||||
Picture dim_picture;
|
|
||||||
/// 1x1 Picture of the shadow color.
|
/// 1x1 Picture of the shadow color.
|
||||||
Picture cshadow_picture;
|
Picture cshadow_picture;
|
||||||
/// Gaussian map of shadow.
|
/// Gaussian map of shadow.
|
||||||
@ -507,7 +507,12 @@ typedef struct {
|
|||||||
typedef struct _win {
|
typedef struct _win {
|
||||||
struct _win *next;
|
struct _win *next;
|
||||||
Window id;
|
Window id;
|
||||||
|
/// ID of the top-level client window of the window.
|
||||||
Window client_win;
|
Window client_win;
|
||||||
|
/// Whether it looks like a WM window. We consider a window WM window if
|
||||||
|
/// it does not have a decedent with WM_STATE and it is not override-
|
||||||
|
/// redirected itself.
|
||||||
|
bool wmwin;
|
||||||
Pixmap pixmap;
|
Pixmap pixmap;
|
||||||
XWindowAttributes a;
|
XWindowAttributes a;
|
||||||
winmode mode;
|
winmode mode;
|
||||||
@ -594,6 +599,9 @@ typedef struct _win {
|
|||||||
// Dim-related members
|
// Dim-related members
|
||||||
/// Whether the window is to be dimmed.
|
/// Whether the window is to be dimmed.
|
||||||
bool dim;
|
bool dim;
|
||||||
|
/// Picture for dimming. Affected by user-specified inactive dim
|
||||||
|
/// opacity and window opacity.
|
||||||
|
Picture dim_alpha_pict;
|
||||||
|
|
||||||
/// Window flags. Definitions above.
|
/// Window flags. Definitions above.
|
||||||
int_fast16_t flags;
|
int_fast16_t flags;
|
||||||
@ -1398,11 +1406,10 @@ win_update_focused(session_t *ps, win *w) {
|
|||||||
|
|
||||||
w->focused = w->focused_real;
|
w->focused = w->focused_real;
|
||||||
|
|
||||||
// Consider a window without client window a WM window and mark it
|
// Treat WM windows and override-redirected windows specially
|
||||||
// focused if mark_wmwin_focused is on, or it's over-redirected and
|
if ((ps->o.mark_wmwin_focused && w->wmwin)
|
||||||
// mark_ovredir_focused is on
|
|| (ps->o.mark_ovredir_focused
|
||||||
if ((ps->o.mark_wmwin_focused && !w->client_win)
|
&& w->id == w->client_win && !w->wmwin)
|
||||||
|| (ps->o.mark_ovredir_focused && w->id == w->client_win)
|
|
||||||
|| win_match(w, ps->o.focus_blacklist, &w->cache_fcblst))
|
|| win_match(w, ps->o.focus_blacklist, &w->cache_fcblst))
|
||||||
w->focused = true;
|
w->focused = true;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user