blob: a0964f90f4465d3cfcb86fd34c6c58ce40557139 [file] [log] [blame]
typedef struct{struct{char*d;int b;}*i;}*t;
double f();
g(p)t p;
{
short x,y,delta,s,w,h,fx,fy,tx,ty;
int q1,q2,q3,q4;
h=f((ty-fy)/2.0+0.5);
s=(((int)((short)(tx-fx))<(int)((short)(ty-fy)))?((short)(tx-fx)):((short)(ty-fy)))%2;
delta=(((int)(w)<(int)(h))?(w):(h))-s;
for(x=0;x<=delta;x++)
for(y=1-s;y<=delta;y++){
q1=((int)((*(p->i->d+(fx+w+x)/8+(fy+h+y)*p->i->b)&(1<<((fx+w+x)%8)))?1:0));
q2=((int)((*(p->i->d+(fx+w+y)/8+(fy+h-s-x)*p->i->b)&(1<<((fx+w+y)%8)))?1:0));
q3=((int)((*(p->i->d+(fx+w-s-x)/8+(fy+h-s-y)*p->i->b)&(1<<((fx+w-s-x)%8)))?1:0));
q4=((int)((*(p->i->d+(fx+w-s-y)/8+(fy+h+x)*p->i->b)&(1<<((fx+w-s-y)%8)))?1:0));
if(q4!=q1)
ff(p,fx+w-s-y,fy+h+x);
}
}