diff options
| author | Simon <simon@hardwired.org.uk> | 2011-01-27 20:32:34 (GMT) |
|---|---|---|
| committer | Simon <simon@hardwired.org.uk> | 2011-01-27 20:32:34 (GMT) |
| commit | e9ae32b0ccba9d19dd872da547db1ff23b34a431 (patch) | |
| tree | 3746dfe9e06940d3ff6c649696cd3a689012ca7b /src/elements/thdr.c | |
| parent | aedb16efb9601a6699201484064f13b61ba30b5c (diff) | |
| parent | 58a700fbb00e8ad82f239a0ea80d0e92fcb9eaf9 (diff) | |
| download | powder-e9ae32b0ccba9d19dd872da547db1ff23b34a431.zip powder-e9ae32b0ccba9d19dd872da547db1ff23b34a431.tar.gz | |
Merge with jacksonmj, Warning: potential for lot of bugs
Diffstat (limited to 'src/elements/thdr.c')
| -rw-r--r-- | src/elements/thdr.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/elements/thdr.c b/src/elements/thdr.c new file mode 100644 index 0000000..0f25ccd --- /dev/null +++ b/src/elements/thdr.c @@ -0,0 +1,38 @@ +#include <powder.h> + +int update_THDR(UPDATE_FUNC_ARGS) { + int r, rx, ry; + for (rx=-2; rx<3; rx++) + for (ry=-2; ry<3; ry++) + if (x+rx>=0 && y+ry>0 && x+rx<XRES && y+ry<YRES && (rx || ry)) + { + r = pmap[y+ry][x+rx]; + if ((r>>8)>=NPART || !r) + continue; + if ((ptypes[r&0xFF].properties&PROP_CONDUCTS) && parts[r>>8].life==0 && !((r&0xFF)==PT_WATR||(r&0xFF)==PT_SLTW) && parts[r>>8].ctype!=PT_SPRK) + { + parts[i].type = PT_NONE; + parts[r>>8].ctype = parts[r>>8].type; + part_change_type(r>>8,x+rx,y+ry,PT_SPRK); + parts[r>>8].life = 4; + } + else if ((r&0xFF)!=PT_CLNE&&(r&0xFF)!=PT_THDR&&(r&0xFF)!=PT_SPRK&&(r&0xFF)!=PT_DMND&&(r&0xFF)!=PT_FIRE&&(r&0xFF)!=PT_NEUT&&(r&0xFF)!=PT_PHOT&&(r&0xFF)) + { + pv[y/CELL][x/CELL] += 100.0f; + if (legacy_enable&&1>(rand()%200)) + { + parts[i].life = rand()%50+120; + part_change_type(i,x,y,PT_FIRE); + } + else + { + parts[i].type = PT_NONE; + } + } + } + if (parts[i].type==PT_NONE) { + kill_part(i); + return 1; + } + return 0; +} |
