mirror of
https://github.com/leahneukirchen/cwm.git
synced 2023-08-10 21:13:12 +03:00
Rework group names: stash the group name inside the group_ctx as opposed
to having to manage an array outside in screen_ctx for group names and shortcuts. Simplifies (and moves bits for) reading, and constructing data for, EWMH's _NET_DESKTOP_NAMES.
This commit is contained in:
parent
87d604f119
commit
142f52a0aa
3
calmwm.h
3
calmwm.h
@ -204,6 +204,7 @@ TAILQ_HEAD(cycle_entry_q, client_ctx);
|
|||||||
struct group_ctx {
|
struct group_ctx {
|
||||||
TAILQ_ENTRY(group_ctx) entry;
|
TAILQ_ENTRY(group_ctx) entry;
|
||||||
struct client_ctx_q clients;
|
struct client_ctx_q clients;
|
||||||
|
char *name;
|
||||||
int num;
|
int num;
|
||||||
};
|
};
|
||||||
TAILQ_HEAD(group_ctx_q, group_ctx);
|
TAILQ_HEAD(group_ctx_q, group_ctx);
|
||||||
@ -242,9 +243,7 @@ struct screen_ctx {
|
|||||||
struct group_ctx groups[CALMWM_NGROUPS];
|
struct group_ctx groups[CALMWM_NGROUPS];
|
||||||
struct group_ctx_q groupq;
|
struct group_ctx_q groupq;
|
||||||
int group_hideall;
|
int group_hideall;
|
||||||
int group_nonames;
|
|
||||||
struct group_ctx *group_active;
|
struct group_ctx *group_active;
|
||||||
char **group_names;
|
|
||||||
};
|
};
|
||||||
TAILQ_HEAD(screen_ctx_q, screen_ctx);
|
TAILQ_HEAD(screen_ctx_q, screen_ctx);
|
||||||
|
|
||||||
|
54
group.c
54
group.c
@ -120,18 +120,15 @@ group_init(struct screen_ctx *sc)
|
|||||||
|
|
||||||
TAILQ_INIT(&sc->groupq);
|
TAILQ_INIT(&sc->groupq);
|
||||||
sc->group_hideall = 0;
|
sc->group_hideall = 0;
|
||||||
/*
|
|
||||||
* See if any group names have already been set and update the
|
|
||||||
* property with ours if they'll have changed.
|
|
||||||
*/
|
|
||||||
group_update_names(sc);
|
|
||||||
|
|
||||||
for (i = 0; i < CALMWM_NGROUPS; i++) {
|
for (i = 0; i < CALMWM_NGROUPS; i++) {
|
||||||
TAILQ_INIT(&sc->groups[i].clients);
|
TAILQ_INIT(&sc->groups[i].clients);
|
||||||
|
sc->groups[i].name = xstrdup(num_to_name[i]);
|
||||||
sc->groups[i].num = i;
|
sc->groups[i].num = i;
|
||||||
TAILQ_INSERT_TAIL(&sc->groupq, &sc->groups[i], entry);
|
TAILQ_INSERT_TAIL(&sc->groupq, &sc->groups[i], entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
xu_ewmh_net_desktop_names(sc);
|
||||||
xu_ewmh_net_wm_desktop_viewport(sc);
|
xu_ewmh_net_wm_desktop_viewport(sc);
|
||||||
xu_ewmh_net_wm_number_of_desktops(sc);
|
xu_ewmh_net_wm_number_of_desktops(sc);
|
||||||
xu_ewmh_net_showing_desktop(sc);
|
xu_ewmh_net_showing_desktop(sc);
|
||||||
@ -350,50 +347,3 @@ group_autogroup(struct client_ctx *cc)
|
|||||||
else
|
else
|
||||||
group_assign(NULL, cc);
|
group_assign(NULL, cc);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
group_update_names(struct screen_ctx *sc)
|
|
||||||
{
|
|
||||||
char **strings, *p;
|
|
||||||
unsigned char *prop_ret;
|
|
||||||
int i = 0, j = 0, nstrings = 0, n = 0, setnames = 0;
|
|
||||||
|
|
||||||
if ((j = xu_getprop(sc->rootwin, ewmh[_NET_DESKTOP_NAMES],
|
|
||||||
cwmh[UTF8_STRING], 0xffffff, (unsigned char **)&prop_ret)) > 0) {
|
|
||||||
prop_ret[j - 1] = '\0'; /* paranoia */
|
|
||||||
while (i < j) {
|
|
||||||
if (prop_ret[i++] == '\0')
|
|
||||||
nstrings++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
strings = xcalloc((nstrings < CALMWM_NGROUPS ? CALMWM_NGROUPS :
|
|
||||||
nstrings), sizeof(*strings));
|
|
||||||
|
|
||||||
p = (char *)prop_ret;
|
|
||||||
while (n < nstrings) {
|
|
||||||
strings[n++] = xstrdup(p);
|
|
||||||
p += strlen(p) + 1;
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
* make sure we always set our defaults if nothing is there to
|
|
||||||
* replace them.
|
|
||||||
*/
|
|
||||||
if (n < CALMWM_NGROUPS) {
|
|
||||||
setnames = 1;
|
|
||||||
i = 0;
|
|
||||||
while (n < CALMWM_NGROUPS)
|
|
||||||
strings[n++] = xstrdup(num_to_name[i++]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (prop_ret != NULL)
|
|
||||||
XFree(prop_ret);
|
|
||||||
if (sc->group_nonames != 0)
|
|
||||||
free(sc->group_names);
|
|
||||||
|
|
||||||
sc->group_names = strings;
|
|
||||||
sc->group_nonames = n;
|
|
||||||
|
|
||||||
if (setnames)
|
|
||||||
xu_ewmh_net_desktop_names(sc);
|
|
||||||
}
|
|
||||||
|
@ -192,7 +192,7 @@ mousefunc_menu_group(struct client_ctx *cc, union arg *arg)
|
|||||||
continue;
|
continue;
|
||||||
menuq_add(&menuq, gc,
|
menuq_add(&menuq, gc,
|
||||||
group_hidden_state(gc) ? "%d: [%s]" : "%d: %s",
|
group_hidden_state(gc) ? "%d: [%s]" : "%d: %s",
|
||||||
gc->num, sc->group_names[gc->num]);
|
gc->num, gc->name);
|
||||||
}
|
}
|
||||||
if (TAILQ_EMPTY(&menuq))
|
if (TAILQ_EMPTY(&menuq))
|
||||||
return;
|
return;
|
||||||
|
@ -196,7 +196,7 @@ xev_handle_propertynotify(XEvent *ee)
|
|||||||
TAILQ_FOREACH(sc, &Screenq, entry) {
|
TAILQ_FOREACH(sc, &Screenq, entry) {
|
||||||
if (sc->rootwin == e->window) {
|
if (sc->rootwin == e->window) {
|
||||||
if (e->atom == ewmh[_NET_DESKTOP_NAMES])
|
if (e->atom == ewmh[_NET_DESKTOP_NAMES])
|
||||||
group_update_names(sc);
|
xu_ewmh_net_desktop_names(sc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
40
xutil.c
40
xutil.c
@ -283,18 +283,46 @@ xu_ewmh_net_current_desktop(struct screen_ctx *sc, long idx)
|
|||||||
void
|
void
|
||||||
xu_ewmh_net_desktop_names(struct screen_ctx *sc)
|
xu_ewmh_net_desktop_names(struct screen_ctx *sc)
|
||||||
{
|
{
|
||||||
|
struct group_ctx *gc;
|
||||||
char *p, *q;
|
char *p, *q;
|
||||||
|
unsigned char *prop_ret;
|
||||||
|
int i = 0, j = 0, nstrings = 0, n = 0;
|
||||||
size_t len = 0, tlen, slen;
|
size_t len = 0, tlen, slen;
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i < sc->group_nonames; i++)
|
/* Let group names be overwritten if _NET_DESKTOP_NAMES is set. */
|
||||||
len += strlen(sc->group_names[i]) + 1;
|
|
||||||
|
if ((j = xu_getprop(sc->rootwin, ewmh[_NET_DESKTOP_NAMES],
|
||||||
|
cwmh[UTF8_STRING], 0xffffff, (unsigned char **)&prop_ret)) > 0) {
|
||||||
|
prop_ret[j - 1] = '\0'; /* paranoia */
|
||||||
|
while (i < j) {
|
||||||
|
if (prop_ret[i++] == '\0')
|
||||||
|
nstrings++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p = (char *)prop_ret;
|
||||||
|
while (n < nstrings) {
|
||||||
|
TAILQ_FOREACH(gc, &sc->groupq, entry) {
|
||||||
|
if (gc->num == n) {
|
||||||
|
free(gc->name);
|
||||||
|
gc->name = xstrdup(p);
|
||||||
|
p += strlen(p) + 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
n++;
|
||||||
|
}
|
||||||
|
if (prop_ret != NULL)
|
||||||
|
XFree(prop_ret);
|
||||||
|
|
||||||
|
TAILQ_FOREACH(gc, &sc->groupq, entry)
|
||||||
|
len += strlen(gc->name) + 1;
|
||||||
q = p = xcalloc(len, sizeof(*p));
|
q = p = xcalloc(len, sizeof(*p));
|
||||||
|
|
||||||
tlen = len;
|
tlen = len;
|
||||||
for (i = 0; i < sc->group_nonames; i++) {
|
TAILQ_FOREACH(gc, &sc->groupq, entry) {
|
||||||
slen = strlen(sc->group_names[i]) + 1;
|
slen = strlen(gc->name) + 1;
|
||||||
(void)strlcpy(q, sc->group_names[i], tlen);
|
(void)strlcpy(q, gc->name, tlen);
|
||||||
tlen -= slen;
|
tlen -= slen;
|
||||||
q += slen;
|
q += slen;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user