summaryrefslogtreecommitdiff
path: root/src/elements/thdr.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/elements/thdr.c')
-rw-r--r--src/elements/thdr.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/src/elements/thdr.c b/src/elements/thdr.c
index 3d46f9d..0f25ccd 100644
--- a/src/elements/thdr.c
+++ b/src/elements/thdr.c
@@ -1,20 +1,19 @@
#include <powder.h>
int update_THDR(UPDATE_FUNC_ARGS) {
- int r;
- for (nx=-2; nx<3; nx++)
- for (ny=-2; ny<3; ny++)
- if (x+nx>=0 && y+ny>0 &&
- x+nx<XRES && y+ny<YRES && (nx || ny))
+ 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+ny][x+nx];
+ 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;
- parts[r>>8].type = PT_SPRK;
+ 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))
@@ -23,7 +22,7 @@ int update_THDR(UPDATE_FUNC_ARGS) {
if (legacy_enable&&1>(rand()%200))
{
parts[i].life = rand()%50+120;
- parts[i].type = PT_FIRE;
+ part_change_type(i,x,y,PT_FIRE);
}
else
{
@@ -31,5 +30,9 @@ int update_THDR(UPDATE_FUNC_ARGS) {
}
}
}
+ if (parts[i].type==PT_NONE) {
+ kill_part(i);
+ return 1;
+ }
return 0;
}