aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/faces
diff options
context:
space:
mode:
Diffstat (limited to 'src/cmd/faces')
-rw-r--r--src/cmd/faces/facedb.c191
-rw-r--r--src/cmd/faces/main.c4
-rw-r--r--src/cmd/faces/mkfile2
-rw-r--r--src/cmd/faces/plumb.c16
4 files changed, 119 insertions, 94 deletions
diff --git a/src/cmd/faces/facedb.c b/src/cmd/faces/facedb.c
index eecaf26d..b52dcbbb 100644
--- a/src/cmd/faces/facedb.c
+++ b/src/cmd/faces/facedb.c
@@ -15,6 +15,9 @@ enum /* number of deleted faces to cache */
static Facefile *facefiles;
static int nsaved;
static char *facedom;
+static char *libface;
+static char *homeface;
+static char *machinelist;
/*
* Loading the files is slow enough on a dial-up line to be worth this trouble
@@ -148,9 +151,8 @@ readfile(char *s)
return strdup(r->data);
}
-
static char*
-translatedomain(char *dom)
+translatedomain(char *dom, char *list)
{
static char buf[200];
char *p, *ep, *q, *nextp, *file;
@@ -160,7 +162,7 @@ translatedomain(char *dom)
if(dom == nil || *dom == 0)
return nil;
- if((file = readfile(unsharp("#9/face/.machinelist"))) == nil)
+ if(list == nil || (file = readfile(list)) == nil)
return dom;
for(p=file; p; p=nextp) {
@@ -210,26 +212,17 @@ translatedomain(char *dom)
}
static char*
-tryfindpicture_user(char *dom, char *user, int depth)
+tryfindpicture(char *dom, char *user, char *dir, char *dict)
{
- static char buf[200];
- char *p, *q, *nextp, *file;
- static char *home;
-
- if(home == nil)
- home = getenv("home");
- if(home == nil)
- home = getenv("HOME");
- if(home == nil)
- return nil;
-
- sprint(buf, "%s/lib/face/48x48x%d/.dict", home, depth);
- if((file = readfile(buf)) == nil)
+ static char buf[1024];
+ char *file, *p, *nextp, *q;
+
+ if((file = readfile(dict)) == nil)
return nil;
snprint(buf, sizeof buf, "%s/%s", dom, user);
- for(p=file; p; p=nextp) {
+ for(p=file; p; p=nextp){
if(nextp = strchr(p, '\n'))
*nextp++ = '\0';
@@ -237,75 +230,114 @@ tryfindpicture_user(char *dom, char *user, int depth)
continue;
*q++ = 0;
- if(strcmp(buf, p) == 0) {
+ if(strcmp(buf, p) == 0){
q += strspn(q, " \t");
- q = buf+snprint(buf, sizeof buf, "%s/lib/face/48x48x%d/%s", home, depth, q);
+ snprint(buf, sizeof buf, "%s/%s", dir, q);
+ q = buf+strlen(buf);
while(q > buf && (q[-1] == ' ' || q[-1] == '\t'))
*--q = 0;
free(file);
- return buf;
+ return estrdup(buf);
}
}
free(file);
- return nil;
+ return nil;
}
static char*
-tryfindpicture_global(char *dom, char *user, int depth)
+estrstrdup(char *a, char *b)
{
- static char buf[200];
- char *p, *q, *nextp, *file;
+ char *t;
+
+ t = emalloc(strlen(a)+strlen(b)+1);
+ strcpy(t, a);
+ strcat(t, b);
+ return t;
+}
- sprint(buf, "#9/face/48x48x%d/.dict", depth);
- if((file = readfile(unsharp(buf))) == nil)
+static char*
+tryfindfiledir(char *dom, char *user, char *dir)
+{
+ char *dict, *ndir, *x;
+ int fd;
+ int i, n;
+ Dir *d;
+
+ /*
+ * If this directory has a .machinelist, use it.
+ */
+ x = estrstrdup(dir, "/.machinelist");
+ dom = estrdup(translatedomain(dom, x));
+ free(x);
+
+ /*
+ * If this directory has a .dict, use it.
+ */
+ dict = estrstrdup(dir, "/.dict");
+ if(access(dict, AEXIST) >= 0){
+ x = tryfindpicture(dom, user, dir, dict);
+ free(dict);
+ free(dom);
+ return x;
+ }
+ free(dict);
+
+ /*
+ * If not, recurse into subdirectories.
+ * Ignore 48x48xN directories for now.
+ */
+ if((fd = open(dir, OREAD)) < 0)
return nil;
-
- snprint(buf, sizeof buf, "%s/%s", dom, user);
-
- for(p=file; p; p=nextp) {
- if(nextp = strchr(p, '\n'))
- *nextp++ = '\0';
-
- if(*p == '#' || (q = strpbrk(p, " \t")) == nil)
- continue;
- *q++ = 0;
-
- if(strcmp(buf, p) == 0) {
- q += strspn(q, " \t");
- q = buf+snprint(buf, sizeof buf, "#9/face/48x48x%d/%s", depth, q);
- while(q > buf && (q[-1] == ' ' || q[-1] == '\t'))
- *--q = 0;
- free(file);
- return unsharp(buf);
+ while((n = dirread(fd, &d)) > 0){
+ for(i=0; i<n; i++){
+ if((d[i].mode&DMDIR)&& strncmp(d[i].name, "48x48x", 6) != 0){
+ ndir = emalloc(strlen(dir)+1+strlen(d[i].name)+1);
+ strcpy(ndir, dir);
+ strcat(ndir, "/");
+ strcat(ndir, d[i].name);
+ if((x = tryfindfiledir(dom, user, ndir)) != nil){
+ free(ndir);
+ free(d);
+ close(fd);
+ free(dom);
+ return x;
+ }
+ }
}
+ free(d);
}
- free(file);
- return nil;
+ close(fd);
+
+ /*
+ * Handle 48x48xN directories in the right order.
+ */
+ ndir = estrstrdup(dir, "/48x48x8");
+ for(i=8; i>0; i>>=1){
+ ndir[strlen(ndir)-1] = i+'0';
+ if(access(ndir, AEXIST) >= 0 && (x = tryfindfiledir(dom, user, ndir)) != nil){
+ free(ndir);
+ free(dom);
+ return x;
+ }
+ }
+ free(ndir);
+ free(dom);
+ return nil;
}
static char*
-tryfindpicture(char *dom, char *user, int depth)
+tryfindfile(char *dom, char *user)
{
- char* result;
-
- if((result = tryfindpicture_user(dom, user, depth)) != nil)
- return result;
-
- return tryfindpicture_global(dom, user, depth);
-}
+ char *p;
-static char*
-tryfindfile(char *dom, char *user, int depth)
-{
- char *p, *q;
-
- for(;;){
- for(p=dom; p; (p=strchr(p, '.')) && p++)
- if(q = tryfindpicture(p, user, depth))
- return q;
- depth >>= 1;
- if(depth == 0)
+ while(dom && *dom){
+ if(homeface && (p = tryfindfiledir(dom, user, homeface)) != nil)
+ return p;
+ if((p = tryfindfiledir(dom, user, libface)) != nil)
+ return p;
+ if((dom = strchr(dom, '.')) == nil)
break;
+ dom++;
}
return nil;
}
@@ -314,34 +346,31 @@ char*
findfile(Face *f, char *dom, char *user)
{
char *p;
- int depth;
if(facedom == nil){
facedom = getenv("facedom");
if(facedom == nil)
facedom = DEFAULT;
}
-
- dom = translatedomain(dom);
+ if(libface == nil)
+ libface = unsharp("#9/face");
+ if(machinelist == nil)
+ machinelist = estrstrdup(libface, "/.machinelist");
+ if(homeface == nil)
+ homeface = smprint("%s/lib/face", getenv("HOME"));
+
+ dom = translatedomain(dom, machinelist);
if(dom == nil)
dom = facedom;
- if(screen == nil)
- depth = 8;
- else
- depth = screen->depth;
-
- if(depth > 8)
- depth = 8;
-
f->unknown = 0;
- if(p = tryfindfile(dom, user, depth))
+ if((p = tryfindfile(dom, user)) != nil)
return p;
f->unknown = 1;
- p = tryfindfile(dom, "unknown", depth);
- if(p != nil || strcmp(dom, facedom)==0)
+ p = tryfindfile(dom, "unknown");
+ if(p != nil || strcmp(dom, facedom) == 0)
return p;
- return tryfindfile("unknown", "unknown", depth);
+ return tryfindfile("unknown", "unknown");
}
static
diff --git a/src/cmd/faces/main.c b/src/cmd/faces/main.c
index 86218849..c1fbecf5 100644
--- a/src/cmd/faces/main.c
+++ b/src/cmd/faces/main.c
@@ -77,7 +77,7 @@ int ndown;
char date[64];
Face **faces;
-char *maildir = "INBOX";
+char *maildir = "mbox";
ulong now;
Point datep = { 8, 6 };
@@ -108,7 +108,7 @@ init(void)
initplumb();
/* make background color */
- bgrnd = allocimagemix(display, DPalebluegreen, DWhite);
+ bgrnd = allocimage(display, Rect(0,0,1,1), screen->chan, 1, DWhite);
blue = allocimage(display, Rect(0,0,1,1), screen->chan, 1, 0x008888FF); /* blue-green */
left = allocimage(display, leftright, GREY1, 0, DWhite);
right = allocimage(display, leftright, GREY1, 0, DWhite);
diff --git a/src/cmd/faces/mkfile b/src/cmd/faces/mkfile
index 58cc4d25..d7dc5ab7 100644
--- a/src/cmd/faces/mkfile
+++ b/src/cmd/faces/mkfile
@@ -22,5 +22,5 @@ UPDATE=\
<$PLAN9/src/mkone
CFLAGS=$CFLAGS '-DDEFAULT='$DEFAULT
-$O.dblook: dblook.$O facedb.$O util.$O
+dblook: dblook.$O facedb.$O util.$O
$LD -o $target $prereq
diff --git a/src/cmd/faces/plumb.c b/src/cmd/faces/plumb.c
index 1807fd38..4d246b5c 100644
--- a/src/cmd/faces/plumb.c
+++ b/src/cmd/faces/plumb.c
@@ -45,24 +45,23 @@ attr(Face *f)
void
showmail(Face *f)
{
+ char buf[256];
Plumbmsg pm;
Plumbattr a;
- char *s;
if(showfd<0 || f->str[Sshow]==nil || f->str[Sshow][0]=='\0')
return;
- s = emalloc(strlen("/mail/fs")+1+strlen(f->str[Sshow]));
- sprint(s,"/mail/fs/%s",f->str[Sshow]);
+ snprint(buf, sizeof buf, "Mail/%s", f->str[Sshow]);
pm.src = "faces";
pm.dst = "showmail";
- pm.wdir = "/mail/fs";
+ pm.wdir = "/";
pm.type = "text";
a.name = "digest";
a.value = f->str[Sdigest];
a.next = nil;
pm.attr = &a;
- pm.ndata = strlen(s);
- pm.data = s;
+ pm.ndata = strlen(buf);
+ pm.data = buf;
plumbsendtofid(showfd, &pm);
}
@@ -203,12 +202,9 @@ nextface(void)
delete(m->data, value(m->attr, "digest", nil));
else if(strcmp(t, "new") != 0)
fprint(2, "faces: unknown plumb message type %s\n", t);
- else for(i=0; i<nmaildirs; i++) { /* XXX */
- if(strncmp(m->data,"/mail/fs/",strlen("/mail/fs/")) == 0)
- m->data += strlen("/mail/fs/");
+ else for(i=0; i<nmaildirs; i++)
if(strncmp(m->data, maildirs[i], strlen(maildirs[i])) == 0)
goto Found;
- }
plumbfree(m);
continue;