diff options
author | Taru Karttunen <taruti@taruti.net> | 2011-03-30 15:46:40 +0300 |
---|---|---|
committer | Taru Karttunen <taruti@taruti.net> | 2011-03-30 15:46:40 +0300 |
commit | e5888a1ffdae813d7575f5fb02275c6bb07e5199 (patch) | |
tree | d8d51eac403f07814b9e936eed0c9a79195e2450 /sys/src/libmemdraw/load.c |
Import sources from 2011-03-30 iso image
Diffstat (limited to 'sys/src/libmemdraw/load.c')
-rwxr-xr-x | sys/src/libmemdraw/load.c | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/sys/src/libmemdraw/load.c b/sys/src/libmemdraw/load.c new file mode 100755 index 000000000..5095c15c3 --- /dev/null +++ b/sys/src/libmemdraw/load.c @@ -0,0 +1,72 @@ +#include <u.h> +#include <libc.h> +#include <draw.h> +#include <memdraw.h> + +int +loadmemimage(Memimage *i, Rectangle r, uchar *data, int ndata) +{ + int y, l, lpart, rpart, mx, m, mr; + uchar *q; + + if(!rectinrect(r, i->r)) + return -1; + l = bytesperline(r, i->depth); + if(ndata < l*Dy(r)) + return -1; + ndata = l*Dy(r); + q = byteaddr(i, r.min); + mx = 7/i->depth; + lpart = (r.min.x & mx) * i->depth; + rpart = (r.max.x & mx) * i->depth; + m = 0xFF >> lpart; + /* may need to do bit insertion on edges */ + if(l == 1){ /* all in one byte */ + if(rpart) + m ^= 0xFF >> rpart; + for(y=r.min.y; y<r.max.y; y++){ + *q ^= (*data^*q) & m; + q += i->width*sizeof(ulong); + data++; + } + return ndata; + } + if(lpart==0 && rpart==0){ /* easy case */ + for(y=r.min.y; y<r.max.y; y++){ + memmove(q, data, l); + q += i->width*sizeof(ulong); + data += l; + } + return ndata; + } + mr = 0xFF ^ (0xFF >> rpart); + if(lpart!=0 && rpart==0){ + for(y=r.min.y; y<r.max.y; y++){ + *q ^= (*data^*q) & m; + if(l > 1) + memmove(q+1, data+1, l-1); + q += i->width*sizeof(ulong); + data += l; + } + return ndata; + } + if(lpart==0 && rpart!=0){ + for(y=r.min.y; y<r.max.y; y++){ + if(l > 1) + memmove(q, data, l-1); + q[l-1] ^= (data[l-1]^q[l-1]) & mr; + q += i->width*sizeof(ulong); + data += l; + } + return ndata; + } + for(y=r.min.y; y<r.max.y; y++){ + *q ^= (*data^*q) & m; + if(l > 2) + memmove(q+1, data+1, l-2); + q[l-1] ^= (data[l-1]^q[l-1]) & mr; + q += i->width*sizeof(ulong); + data += l; + } + return ndata; +} |