diff options
author | rsc <devnull@localhost> | 2005-08-11 03:38:16 +0000 |
---|---|---|
committer | rsc <devnull@localhost> | 2005-08-11 03:38:16 +0000 |
commit | d52fb463eeda2168b7b0135d758a1e2a57be9af7 (patch) | |
tree | 3bad38971b4a86a4558381b61204c8294670c597 | |
parent | b5b71ffbaee0a7a34b93f22541effe76a54c39b5 (diff) | |
download | plan9port-d52fb463eeda2168b7b0135d758a1e2a57be9af7.tar.gz plan9port-d52fb463eeda2168b7b0135d758a1e2a57be9af7.tar.bz2 plan9port-d52fb463eeda2168b7b0135d758a1e2a57be9af7.zip |
Fix crash reported by Andrey.
Make focus-follows-mouse easier to find for
those who want it (cough, Ron Minnich, cough).
-rw-r--r-- | src/cmd/rio/dat.h | 1 | ||||
-rw-r--r-- | src/cmd/rio/event.c | 10 | ||||
-rw-r--r-- | src/cmd/rio/main.c | 9 | ||||
-rw-r--r-- | src/cmd/rio/menu.c | 13 |
4 files changed, 25 insertions, 8 deletions
diff --git a/src/cmd/rio/dat.h b/src/cmd/rio/dat.h index b2b74eea..aa08fcf9 100644 --- a/src/cmd/rio/dat.h +++ b/src/cmd/rio/dat.h @@ -150,6 +150,7 @@ extern int debug; extern int solidsweep; extern int numvirtuals; extern int scrolling; +extern int ffm; /* focus follows mouse */ extern Atom exit_rio; extern Atom restart_rio; diff --git a/src/cmd/rio/event.c b/src/cmd/rio/event.c index 45642774..457153df 100644 --- a/src/cmd/rio/event.c +++ b/src/cmd/rio/event.c @@ -282,6 +282,7 @@ newwindow(XCreateWindowEvent *e) void destroy(Window w) { + int i; Client *c; curtime = CurrentTime; @@ -289,6 +290,11 @@ destroy(Window w) if(c == 0) return; + if(numvirtuals > 1) + for(i=0; i<numvirtuals; i++) + if(currents[i] == c) + currents[i] = 0; + rmclient(c); /* flush any errors generated by the window's sudden demise */ @@ -470,12 +476,14 @@ enter(XCrossingEvent *e) Client *c; curtime = e->time; + if(!ffm) if(e->mode != NotifyGrab || e->detail != NotifyNonlinearVirtual) return; c = getclient(e->window, 0); if(c != 0 && c != current){ /* someone grabbed the pointer; make them current */ - XMapRaised(dpy, c->parent); + if(!ffm) + XMapRaised(dpy, c->parent); top(c); active(c); } diff --git a/src/cmd/rio/main.c b/src/cmd/rio/main.c index bc43a99f..d20c3a00 100644 --- a/src/cmd/rio/main.c +++ b/src/cmd/rio/main.c @@ -40,6 +40,7 @@ int scrolling; int num_screens; int solidsweep = 0; int numvirtuals = 0; +int ffm = 0; Atom exit_rio; Atom restart_rio; @@ -95,6 +96,10 @@ main(int argc, char *argv[]) background = 1; else if(strcmp(argv[i], "-debug") == 0) debug++; + /* + else if(strcmp(argv[i], "-ffm") == 0) + ffm++; + */ else if(strcmp(argv[i], "-font") == 0 && i+1<argc){ i++; fname = argv[i]; @@ -335,8 +340,8 @@ initscreen(ScreenInfo *s, int i, int background) attr.cursor = s->arrow; attr.event_mask = SubstructureRedirectMask | SubstructureNotifyMask | ColormapChangeMask - | ButtonPressMask | ButtonReleaseMask | PropertyChangeMask | - KeyPressMask; + | ButtonPressMask | ButtonReleaseMask | PropertyChangeMask + | KeyPressMask | EnterWindowMask; mask = CWCursor|CWEventMask; XChangeWindowAttributes(dpy, s->root, mask, &attr); XSync(dpy, False); diff --git a/src/cmd/rio/menu.c b/src/cmd/rio/menu.c index 21195d2e..eb92b744 100644 --- a/src/cmd/rio/menu.c +++ b/src/cmd/rio/menu.c @@ -319,7 +319,7 @@ unhide(int n, int map) } numhidden--; - for(i = n; i < numhidden; i ++){ + for(i = n; i < numhidden; i++){ hiddenc[i] = hiddenc[i+1]; b3items[B3FIXED+i] = b3items[B3FIXED+i+1]; } @@ -368,8 +368,11 @@ button2(int n) void switch_to_c(int n, Client *c) { - if(c && c->next) - switch_to_c(n,c->next); + if(c == 0) + return; + + if(c->next) + switch_to_c(n, c->next); if(c->parent == DefaultRootWindow(dpy)) return; @@ -384,8 +387,8 @@ switch_to_c(int n, Client *c) int i; for(i = 0; i < numhidden; i++) - if(c == hiddenc[i]) - break; + if(c == hiddenc[i]) + break; if(i == numhidden){ XMapWindow(dpy, c->window); |