diff options
| author | rsc <devnull@localhost> | 2004-04-25 20:26:27 +0000 |
|---|---|---|
| committer | rsc <devnull@localhost> | 2004-04-25 20:26:27 +0000 |
| commit | 4e206880423db866dd1db0622a9b4d5b0881fee1 (patch) | |
| tree | c4a2b577708093741962ca07a0ffcb8cf14ce6cc /src/libdraw/creadimage.c | |
| parent | a2c2caaafe37e119078bc88f6ebee6d338cbff46 (diff) | |
| download | plan9port-4e206880423db866dd1db0622a9b4d5b0881fee1.tar.gz plan9port-4e206880423db866dd1db0622a9b4d5b0881fee1.zip | |
make it possible to access fonts without a display.
Diffstat (limited to 'src/libdraw/creadimage.c')
| -rw-r--r-- | src/libdraw/creadimage.c | 56 |
1 files changed, 32 insertions, 24 deletions
diff --git a/src/libdraw/creadimage.c b/src/libdraw/creadimage.c index 99c42752..16dcd1e8 100644 --- a/src/libdraw/creadimage.c +++ b/src/libdraw/creadimage.c @@ -54,14 +54,20 @@ creadimage(Display *d, int fd, int dolock) return nil; } - if(dolock) - lockdisplay(d); - i = allocimage(d, r, chan, 0, 0); - if(dolock) - unlockdisplay(d); - if(i == nil) - return nil; - ncblock = _compblocksize(r, i->depth); + if(d){ + if(dolock) + lockdisplay(d); + i = allocimage(d, r, chan, 0, 0); + if(dolock) + unlockdisplay(d); + if(i == nil) + return nil; + }else{ + i = mallocz(sizeof(Image), 1); + if(i == nil) + return nil; + } + ncblock = _compblocksize(r, chantodepth(chan)); buf = malloc(ncblock); if(buf == nil) goto Errout; @@ -90,22 +96,24 @@ creadimage(Display *d, int fd, int dolock) } if(readn(fd, buf, nb)!=nb) goto Errout; - if(dolock) - lockdisplay(d); - a = bufimage(i->display, 21+nb); - if(a == nil) - goto Erroutlock; - a[0] = 'Y'; - BPLONG(a+1, i->id); - BPLONG(a+5, r.min.x); - BPLONG(a+9, miny); - BPLONG(a+13, r.max.x); - BPLONG(a+17, maxy); - if(!new) /* old image: flip the data bits */ - _twiddlecompressed(buf, nb); - memmove(a+21, buf, nb); - if(dolock) - unlockdisplay(d); + if(d){ + if(dolock) + lockdisplay(d); + a = bufimage(i->display, 21+nb); + if(a == nil) + goto Erroutlock; + a[0] = 'Y'; + BPLONG(a+1, i->id); + BPLONG(a+5, r.min.x); + BPLONG(a+9, miny); + BPLONG(a+13, r.max.x); + BPLONG(a+17, maxy); + if(!new) /* old image: flip the data bits */ + _twiddlecompressed(buf, nb); + memmove(a+21, buf, nb); + if(dolock) + unlockdisplay(d); + } miny = maxy; } free(buf); |
