#include int update_PBCN(UPDATE_FUNC_ARGS) { int r, rx, ry; if (parts[i].life>0 && parts[i].life!=10) parts[i].life--; if (!parts[i].tmp && pv[y/CELL][x/CELL]>4.0f) parts[i].tmp = rand()%40+80; if (parts[i].tmp) { float advection = 0.1f; parts[i].vx += advection*vx[y/CELL][x/CELL]; parts[i].vy += advection*vy[y/CELL][x/CELL]; parts[i].tmp--; if(!parts[i].tmp){ kill_part(i); return 1; } } for (rx=-2; rx<3; rx++) for (ry=-2; ry<3; ry++) if (x+rx>=0 && y+ry>0 && x+rx>8)>=NPART || !r) continue; if ((r&0xFF)==PT_SPRK) { if (parts[r>>8].ctype==PT_PSCN) parts[i].life = 10; else if (parts[r>>8].ctype==PT_NSCN) parts[i].life = 9; } if ((r&0xFF)==PT_PBCN) { if (parts[i].life==10&&parts[r>>8].life<10&&parts[r>>8].life>0) parts[i].life = 9; else if (parts[i].life==0&&parts[r>>8].life==10) parts[i].life = 10; } } if (parts[i].ctype<=0 || parts[i].ctype>=PT_NUM) for (rx=-1; rx<2; rx++) for (ry=-1; ry<2; ry++) if (x+rx>=0 && y+ry>=0 && x+rx>8)>=NPART) r = pmap[y+ry][x+rx]; if (!r || (r>>8)>=NPART) continue; if ((r&0xFF)!=PT_CLNE && (r&0xFF)!=PT_PCLN && (r&0xFF)!=PT_BCLN && (r&0xFF)!=PT_SPRK && (r&0xFF)!=PT_NSCN && (r&0xFF)!=PT_PSCN && (r&0xFF)!=PT_STKM && (r&0xFF)!=PT_STKM2 && (r&0xFF)!=PT_PBCN && (r&0xFF)0 && parts[i].ctype