summaryrefslogtreecommitdiff
path: root/src/elements/legacy.c
diff options
context:
space:
mode:
authorjacksonmj <jacksonmj@jacksonmj.none>2011-01-10 14:41:03 (GMT)
committer jacksonmj <jacksonmj@jacksonmj.none>2011-01-10 14:41:03 (GMT)
commit54f9f872b9e4d5a0086d6de104e84d43b125c349 (patch)
treeb567fb9d3710acbce22f8193bfe2585bb2988bed /src/elements/legacy.c
parent855281295fbc23366e8b84d7c8e55816d6f47a87 (diff)
downloadpowder-54f9f872b9e4d5a0086d6de104e84d43b125c349.zip
powder-54f9f872b9e4d5a0086d6de104e84d43b125c349.tar.gz
Finish update function cleanup
Diffstat (limited to 'src/elements/legacy.c')
-rw-r--r--src/elements/legacy.c34
1 files changed, 33 insertions, 1 deletions
diff --git a/src/elements/legacy.c b/src/elements/legacy.c
index 70d4e99..4f678ab 100644
--- a/src/elements/legacy.c
+++ b/src/elements/legacy.c
@@ -23,7 +23,7 @@ int update_legacy_all(UPDATE_FUNC_ARGS) {
{
part_change_type(i,x,y,PT_WATR);
if (1>(rand()%1000))
- part_change_type(r>>8,x+nx,y+ny,PT_WATR);
+ part_change_type(r>>8,x+rx,y+ry,PT_WATR);
}
}
}
@@ -73,5 +73,37 @@ int update_legacy_all(UPDATE_FUNC_ARGS) {
}
}
}
+ else if (t==PT_ICEI) {
+ 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 (((r&0xFF)==PT_WATR || (r&0xFF)==PT_DSTW) && 1>(rand()%1000))
+ {
+ part_change_type(i,x,y,PT_ICEI);
+ part_change_type(r>>8,x+rx,y+ry,PT_ICEI);
+ }
+ }
+ }
+ else if (t==PT_SNOW) {
+ 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 (((r&0xFF)==PT_WATR || (r&0xFF)==PT_DSTW) && 1>(rand()%1000))
+ {
+ part_change_type(i,x,y,PT_ICEI);
+ part_change_type(r>>8,x+rx,y+ry,PT_ICEI);
+ }
+ if (((r&0xFF)==PT_WATR || (r&0xFF)==PT_DSTW) && 15>(rand()%1000))
+ part_change_type(i,x,y,PT_WATR);
+ }
+ }
return 0;
}