summaryrefslogtreecommitdiff
path: root/src/elements/co2.c
diff options
context:
space:
mode:
authorjacksonmj <mj-pt@jacksonmj.co.uk>2012-06-17 23:44:37 (GMT)
committer jacksonmj <mj-pt@jacksonmj.co.uk>2012-06-17 23:44:37 (GMT)
commitae5470ca7878543f5079877c40f16060261cd6fa (patch)
treea5ec93b1a00110827dc1fe7d789e8bbc55346372 /src/elements/co2.c
parentc14704ae492834d9a888537b973a9b5a8585e3b3 (diff)
downloadpowder-ae5470ca7878543f5079877c40f16060261cd6fa.zip
powder-ae5470ca7878543f5079877c40f16060261cd6fa.tar.gz
Prevent stacking from ELEC+NEUT, ELEC+water, and CO2 from BUBW
Also conserve number of particles when CO2 from BUBW is absorbed by water, and when splitting water into H2+O2 using ELEC.
Diffstat (limited to 'src/elements/co2.c')
-rw-r--r--src/elements/co2.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/src/elements/co2.c b/src/elements/co2.c
index acdbc99..adf85f5 100644
--- a/src/elements/co2.c
+++ b/src/elements/co2.c
@@ -22,10 +22,10 @@ int update_CO2(UPDATE_FUNC_ARGS) {
if (x+rx>=0 && y+ry>0 && x+rx<XRES && y+ry<YRES && (rx || ry))
{
r = pmap[y+ry][x+rx];
- if (20>(rand()%40000)&&parts[i].ctype==5)
+ if (parts[i].ctype==5 && 20>(rand()%40000))
{
- parts[i].ctype = 0;
- create_part(-3, x, y, PT_WATR);
+ if (create_part(-1, x+rx, y+ry, PT_WATR)>=0)
+ parts[i].ctype = 0;
}
if ((r>>8)>=NPART || !r)
continue;
@@ -39,7 +39,10 @@ int update_CO2(UPDATE_FUNC_ARGS) {
if (((r&0xFF)==PT_WATR || (r&0xFF)==PT_DSTW) && 1>(rand()%250))
{
part_change_type(i,x,y,PT_CBNW);
- kill_part(r>>8);
+ if (parts[i].ctype==5) //conserve number of water particles - ctype=5 means this CO2 hasn't released the water particle from BUBW yet
+ create_part(r>>8, x+rx, y+ry, PT_CBNW);
+ else
+ kill_part(r>>8);
}
}
if (parts[i].temp > 9773.15 && pv[y/CELL][x/CELL] > 200.0f)