aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/faces/main.c
diff options
context:
space:
mode:
authorrsc <devnull@localhost>2006-02-08 22:39:54 +0000
committerrsc <devnull@localhost>2006-02-08 22:39:54 +0000
commit605c0ea102e334b6c05d635ca0e5b93bad0031ec (patch)
tree47733670b8c009cd358046ad7b6cdefc7096644a /src/cmd/faces/main.c
parent5a1e9de7b160033e85a77ad4c60193186364a2fb (diff)
downloadplan9port-605c0ea102e334b6c05d635ca0e5b93bad0031ec.tar.gz
plan9port-605c0ea102e334b6c05d635ca0e5b93bad0031ec.tar.bz2
plan9port-605c0ea102e334b6c05d635ca0e5b93bad0031ec.zip
cleanup
Diffstat (limited to 'src/cmd/faces/main.c')
-rw-r--r--src/cmd/faces/main.c137
1 files changed, 35 insertions, 102 deletions
diff --git a/src/cmd/faces/main.c b/src/cmd/faces/main.c
index 4be56230..86218849 100644
--- a/src/cmd/faces/main.c
+++ b/src/cmd/faces/main.c
@@ -3,7 +3,6 @@
#include <draw.h>
#include <plumb.h>
#include <regexp.h>
-//jpc #include <event.h> /* for support routines only */
#include <bio.h>
#include <thread.h>
#include <mouse.h>
@@ -20,6 +19,8 @@ enum
Infolines = 9,
HhmmTime = 18*60*60, /* max age of face to display hh:mm time */
+
+ STACK = 32768
};
enum
@@ -27,6 +28,7 @@ enum
Mainp,
Timep,
Mousep,
+ Resizep,
NPROC
};
@@ -34,7 +36,8 @@ int pids[NPROC];
char *procnames[] = {
"main",
"time",
- "mouse"
+ "mouse",
+ "resize",
};
Rectangle leftright = {0, 0, 20, 15};
@@ -57,7 +60,7 @@ uchar rightdata[] = {
0x18, 0x00, 0x00, 0x10, 0x00
};
-CFsys *upasfs;
+CFsys *mailfs;
Mousectl *mousectl;
Image *blue; /* full arrow */
Image *bgrnd; /* pale blue background color */
@@ -74,7 +77,7 @@ int ndown;
char date[64];
Face **faces;
-char *maildir = "/mail/fs/mbox";
+char *maildir = "INBOX";
ulong now;
Point datep = { 8, 6 };
@@ -83,6 +86,7 @@ Point enddate; /* where date ends on display; used to place arrows */
Rectangle leftr; /* location of left arrow on display */
Rectangle rightr; /* location of right arrow on display */
void updatetimes(void);
+void eresized(int);
void
setdate(void)
@@ -95,15 +99,12 @@ setdate(void)
void
init(void)
{
-#if 0
- mousefd = open("/dev/mouse", OREAD);
- if(mousefd < 0){
- fprint(2, "faces: can't open mouse: %r\n");
- threadexitsall("mouse");
- }
-#endif
- upasfs = nsmount("upasfs",nil);
- mousectl = initmouse(nil,screen);
+ mailfs = nsmount("mail", nil);
+ if(mailfs == nil)
+ sysfatal("mount mail: %r");
+ mousectl = initmouse(nil, screen);
+ if(mousectl == nil)
+ sysfatal("initmouse: %r");
initplumb();
/* make background color */
@@ -332,7 +333,7 @@ addface(Face *f) /* always adds at 0 */
lockdisplay(display);
if(first != 0){
first = 0;
- resized();
+ eresized(0);
}
findbit(f);
@@ -366,27 +367,6 @@ addface(Face *f) /* always adds at 0 */
unlockdisplay(display);
}
-#if 0
-void
-loadmboxfaces(char *maildir)
-{
- int dirfd;
- Dir *d;
- int i, n;
-
- dirfd = open(maildir, OREAD);
- if(dirfd >= 0){
- chdir(maildir);
- while((n = dirread(dirfd, &d)) > 0){
- for(i=0; i<n; i++)
- addface(dirface(maildir, d[i].name));
- free(d);
- }
- close(dirfd);
- }
-}
-#endif
-
void
loadmboxfaces(char *maildir)
{
@@ -394,20 +374,16 @@ loadmboxfaces(char *maildir)
Dir *d;
int i, n;
- dirfd = fsopen(upasfs,maildir, OREAD);
+ dirfd = fsopen(mailfs, maildir, OREAD);
if(dirfd != nil){
- //jpc chdir(maildir);
while((n = fsdirread(dirfd, &d)) > 0){
- for(i=0; i<n; i++) {
+ for(i=0; i<n; i++)
addface(dirface(maildir, d[i].name));
- }
free(d);
}
fsclose(dirfd);
- }
- else {
- error("cannot open %s: %r",maildir);
- }
+ }else
+ sysfatal("open %s: %r", maildir);
}
void
@@ -542,30 +518,15 @@ eresized(int new)
unlockdisplay(display);
}
-#if 0
-int
-getmouse(Mouse *m)
+void
+resizeproc(void *v)
{
- int n;
- static int eof;
- char buf[128];
+ USED(v);
- if(eof)
- return 0;
- for(;;){
- n = read(mousefd, buf, sizeof(buf));
- if(n <= 0){
- /* so callers needn't check return value every time */
- eof = 1;
- m->buttons = 0;
- return 0;
- }
- //jpc n = eatomouse(m, buf, n);
- if(n > 0)
- return 1;
- }
+ while(recv(mousectl->resizec, 0) == 1)
+ eresized(1);
}
-#endif
+
int
getmouse(Mouse *m)
{
@@ -573,19 +534,13 @@ getmouse(Mouse *m)
if(eof)
return 0;
- if( readmouse(mousectl) < 0 ) {
+ if(readmouse(mousectl) < 0){
eof = 1;
m->buttons = 0;
return 0;
}
- else {
- *m = mousectl->m;
-/* m->buttons = mousectl->m.buttons;
- m->xy.x = mousectl->m.xy.x;
- m->xy.y = mousectl->m.xy.y;
- m->msec = mousectl->m.msec; */
- return 1;
- }
+ *m = mousectl->m;
+ return 1;
}
enum
@@ -680,9 +635,10 @@ click(int button, Mouse *m)
}
void
-mouseproc(void *dummy)
+mouseproc(void *v)
{
Mouse mouse;
+ USED(v);
while(getmouse(&mouse)){
if(mouse.buttons == 1)
@@ -700,36 +656,10 @@ mouseproc(void *dummy)
void
killall(char *s)
{
- int i, pid;
-
- pid = getpid();
- for(i=0; i<NPROC; i++)
- if(pids[i] && pids[i]!=pid)
- postnote(PNPROC, pids[i], "kill");
threadexitsall(s);
}
void
-startproc(void (*f)(void), int index)
-{
- int pid;
-
- switch(pid = rfork(RFPROC|RFNOWAIT)){ //jpc removed |RFMEM
- case -1:
- fprint(2, "faces: fork failed: %r\n");
- killall("fork failed");
- case 0:
- f();
- fprint(2, "faces: %s process exits\n", procnames[index]);
- if(index >= 0)
- killall("process died");
- threadexitsall(nil);
- }
- if(index >= 0)
- pids[index] = pid;
-}
-
-void
usage(void)
{
fprint(2, "usage: faces [-hi] [-m maildir] -W winsize\n");
@@ -741,6 +671,8 @@ threadmain(int argc, char *argv[])
{
int i;
+ rfork(RFNOTEG);
+
ARGBEGIN{
case 'h':
history++;
@@ -772,8 +704,9 @@ threadmain(int argc, char *argv[])
eresized(0);
pids[Mainp] = getpid();
- pids[Timep] = proccreate(timeproc, nil, 16000);
- pids[Mousep] = proccreate(mouseproc, nil, 16000);
+ pids[Timep] = proccreate(timeproc, nil, STACK);
+ pids[Mousep] = proccreate(mouseproc, nil, STACK);
+ pids[Resizep] = proccreate(resizeproc, nil, STACK);
if(initload)
for(i = 0; i < nmaildirs; i++)
loadmboxfaces(maildirs[i]);