first working scratchpad version

This commit is contained in:
Alexander Bocken 2021-11-22 21:39:58 +01:00
parent 42e6f73f47
commit fcac49f9de
Signed by: Alexander
GPG Key ID: 1D237BE83F9B05E8

39
dwm.c
View File

@ -1915,13 +1915,12 @@ void
togglescratch(const Arg *arg)
{
Client *c;
Client *cfound;
Monitor *m;
unsigned int found = 0;
unsigned int scratchtag = SPTAG(arg->ui);
Arg sparg = {.v = scratchpads[arg->ui].cmd};
for (m = mons; m; m = m->next){
for (m = mons; m && ! found; m = m->next){
fprintf(stderr,"searching monitor %d\n", m->num);
for (c = m->clients; c && !(found = c->tags & scratchtag); c = c->next){
fprintf(stderr, "client: %s\n", c->name);
@ -1929,12 +1928,11 @@ togglescratch(const Arg *arg)
}
if (found){
cfound=c;
fprintf(stderr, "found client %s\n", cfound->name);
fprintf(stderr, "tags of scratchpad: %d\n", cfound->tags);
fprintf(stderr, "found client %s\n", c->name);
fprintf(stderr, "tags of scratchpad: %d\n", c->tags);
fprintf(stderr, "scratchtag: %d\n", scratchtag);
fprintf(stderr, "num of monitor: %d\n", cfound->mon->num);
if (cfound->mon == selmon) {
fprintf(stderr, "num of monitor: %d\n", c->mon->num);
if (c->mon == selmon) {
unsigned int newtagset = selmon->tagset[selmon->seltags] ^ scratchtag;
if (newtagset) {
selmon->tagset[selmon->seltags] = newtagset;
@ -1950,18 +1948,33 @@ togglescratch(const Arg *arg)
fprintf(stderr, "we should move to selmon\n");
//move client from cfound->mon to selmon but still in scratchtag
// remove scratchtag from tagset of cfound->mon ->
unsigned int newtagset = cfound->mon->tagset[cfound->mon->seltags] ^ scratchtag;
unsigned int newtagset = c->mon->tagset[c->mon->seltags] ^ scratchtag;
if (newtagset)
cfound->mon->tagset[cfound->mon->seltags] = newtagset;
c->mon->tagset[c->mon->seltags] = newtagset;
//add scratchtag to monitor where client is sent to
selmon->tagset[selmon->seltags] |= scratchtag;
sendmontags(cfound, selmon, scratchtag);
fprintf(stderr, "tags of scratchpad: %d\n", cfound->tags);
fprintf(stderr, "num of monitor: %d\n", cfound->mon->num);
sendmontags(c, selmon, scratchtag);
fprintf(stderr, "tags of scratchpad: %d\n", c->tags);
fprintf(stderr, "num of monitor: %d\n", c->mon->num);
//if(cfound->next->mon->num){
// fprintf(stderr, "monitor of next client: %d\n", cfound->next->mon->num);
//}
//else{
// fprintf(stderr, "monitor of next client: NULL");
//}
//if(cfound->snext->mon->num){
// //fprintf(stderr, "monitor of snext client: %d\n", cfound->snext->mon->num);}
// int a = 1;
//}
//else
//{
// fprintf(stderr, "monitor of snext client: NULL");
//}
}
}
else {
fprintf(stderr, "Did not find client");
fprintf(stderr, "Did not find client\n");
selmon->tagset[selmon->seltags] |= scratchtag;
spawn(&sparg);
}