xref: /plan9/sys/src/libdraw/cloadimage.c (revision 9a747e4fd48b9f4522c70c07e8f882a15030f964)
180ee5cbfSDavid du Colombier #include <u.h>
280ee5cbfSDavid du Colombier #include <libc.h>
380ee5cbfSDavid du Colombier #include <draw.h>
480ee5cbfSDavid du Colombier 
580ee5cbfSDavid du Colombier int
cloadimage(Image * i,Rectangle r,uchar * data,int ndata)680ee5cbfSDavid du Colombier cloadimage(Image *i, Rectangle r, uchar *data, int ndata)
780ee5cbfSDavid du Colombier {
8*9a747e4fSDavid du Colombier 	int m, nb, miny, maxy, ncblock;
980ee5cbfSDavid du Colombier 	uchar *a;
1080ee5cbfSDavid du Colombier 
1180ee5cbfSDavid du Colombier 	if(!rectinrect(r, i->r)){
1280ee5cbfSDavid du Colombier 		werrstr("cloadimage: bad rectangle");
1380ee5cbfSDavid du Colombier 		return -1;
1480ee5cbfSDavid du Colombier 	}
1580ee5cbfSDavid du Colombier 
1680ee5cbfSDavid du Colombier 	miny = r.min.y;
1780ee5cbfSDavid du Colombier 	m = 0;
18*9a747e4fSDavid du Colombier 	ncblock = _compblocksize(r, i->depth);
1980ee5cbfSDavid du Colombier 	while(miny != r.max.y){
2080ee5cbfSDavid du Colombier 		maxy = atoi((char*)data+0*12);
2180ee5cbfSDavid du Colombier 		nb = atoi((char*)data+1*12);
2280ee5cbfSDavid du Colombier 		if(maxy<=miny || r.max.y<maxy){
2380ee5cbfSDavid du Colombier 			werrstr("creadimage: bad maxy %d", maxy);
2480ee5cbfSDavid du Colombier 			return -1;
2580ee5cbfSDavid du Colombier 		}
2680ee5cbfSDavid du Colombier 		data += 2*12;
2780ee5cbfSDavid du Colombier 		ndata -= 2*12;
2880ee5cbfSDavid du Colombier 		m += 2*12;
29*9a747e4fSDavid du Colombier 		if(nb<=0 || ncblock<nb || nb>ndata){
3080ee5cbfSDavid du Colombier 			werrstr("creadimage: bad count %d", nb);
3180ee5cbfSDavid du Colombier 			return -1;
3280ee5cbfSDavid du Colombier 		}
3380ee5cbfSDavid du Colombier 		a = bufimage(i->display, 21+nb);
3480ee5cbfSDavid du Colombier 		if(a == nil)
3580ee5cbfSDavid du Colombier 			return -1;
3680ee5cbfSDavid du Colombier 		a[0] = 'Y';
3780ee5cbfSDavid du Colombier 		BPLONG(a+1, i->id);
3880ee5cbfSDavid du Colombier 		BPLONG(a+5, r.min.x);
3980ee5cbfSDavid du Colombier 		BPLONG(a+9, miny);
4080ee5cbfSDavid du Colombier 		BPLONG(a+13, r.max.x);
4180ee5cbfSDavid du Colombier 		BPLONG(a+17, maxy);
4280ee5cbfSDavid du Colombier 		memmove(a+21, data, nb);
4380ee5cbfSDavid du Colombier 		miny = maxy;
4480ee5cbfSDavid du Colombier 		data += nb;
4580ee5cbfSDavid du Colombier 		ndata += nb;
4680ee5cbfSDavid du Colombier 		m += nb;
4780ee5cbfSDavid du Colombier 	}
4880ee5cbfSDavid du Colombier 	return m;
4980ee5cbfSDavid du Colombier }
50