#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; } } 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 && y+ry>0 && x+rx>8)>=NPART || !r) continue; if ((r&0xFF)==PT_PBCN) { if (parts[r>>8].life<10&&parts[r>>8].life>0) parts[i].life = 9; else if (parts[r>>8].life==0) parts[r>>8].life = 10; } } } if (parts[i].ctype>0 && parts[i].ctype