summaryrefslogtreecommitdiff
path: root/src/elements
diff options
context:
space:
mode:
authorjacob1 <jfu614@gmail.com>2012-08-07 19:34:47 (GMT)
committer jacksonmj <mj-pt@jacksonmj.co.uk>2012-08-21 23:07:42 (GMT)
commit8d6e0a835e69a020727e3d99bad4411f2771e659 (patch)
tree358714d1dfebffd6d6344fed63f08ecd1bcb52d7 /src/elements
parent2adea2f7e36d1739473ef829a19402fe7ccd7544 (diff)
downloadpowder-8d6e0a835e69a020727e3d99bad4411f2771e659.zip
powder-8d6e0a835e69a020727e3d99bad4411f2771e659.tar.gz
GEL and SPNG absorb water from more elements and leave behind what the water was mixed with
Diffstat (limited to 'src/elements')
-rw-r--r--src/elements/clst.c2
-rw-r--r--src/elements/gel.c24
-rw-r--r--src/elements/spng.c23
3 files changed, 45 insertions, 4 deletions
diff --git a/src/elements/clst.c b/src/elements/clst.c
index 36046cd..8fe1a6c 100644
--- a/src/elements/clst.c
+++ b/src/elements/clst.c
@@ -27,7 +27,7 @@ int update_CLST(UPDATE_FUNC_ARGS) {
continue;
if ((r&0xFF)==PT_WATR && 1>(rand()%1500))
{
- part_change_type(i,x,y,PT_PSTS);
+ part_change_type(i,x,y,PT_PSTS);
kill_part(r>>8);
}
if ((r&0xFF)==PT_NITR)
diff --git a/src/elements/gel.c b/src/elements/gel.c
index c64591a..8287616 100644
--- a/src/elements/gel.c
+++ b/src/elements/gel.c
@@ -30,12 +30,32 @@ int update_GEL(UPDATE_FUNC_ARGS) {
continue;
//Desaturation
- if (((r&0xFF)==PT_WATR || (r&0xFF)==PT_DSTW || (r&0xFF)==PT_SLTW || (r&0xFF)==PT_CBNW)
- && parts[i].tmp<100)
+ if (((r&0xFF)==PT_WATR || (r&0xFF)==PT_DSTW || (r&0xFF)==PT_FRZW) && parts[i].tmp<100)
{
parts[i].tmp++;
kill_part(r>>8);
}
+ if (((r&0xFF)==PT_PSTE) && parts[i].tmp<100)
+ {
+ parts[i].tmp++;
+ create_part(r>>8, x+rx, y+ry, PT_CLST);
+ }
+ if (((r&0xFF)==PT_SLTW) && parts[i].tmp<100)
+ {
+ parts[i].tmp++;
+ if (rand()%4)
+ kill_part(r>>8);
+ else
+ part_change_type(r>>8, x+rx, y+ry, PT_SALT);
+ }
+ if (((r&0xFF)==PT_CBNW) && parts[i].tmp<100)
+ {
+ parts[i].tmp++;
+ if (rand()%4)
+ kill_part(r>>8);
+ else
+ part_change_type(r>>8, x+rx, y+ry, PT_CO2);
+ }
if ((r&0xFF)==PT_SPNG && parts[i].tmp<100 && ((parts[r>>8].life+1)>parts[i].tmp))
{
diff --git a/src/elements/spng.c b/src/elements/spng.c
index 2e4d1ef..b99d12b 100644
--- a/src/elements/spng.c
+++ b/src/elements/spng.c
@@ -26,11 +26,32 @@ int update_SPNG(UPDATE_FUNC_ARGS) {
r = pmap[y+ry][x+rx];
if (!r)
continue;
- if ((r&0xFF)==PT_WATR&&33>=rand()/(RAND_MAX/100)+1)
+ if (((r&0xFF)==PT_WATR || (r&0xFF)==PT_DSTW || (r&0xFF)==PT_FRZW)&&33>=rand()/(RAND_MAX/100)+1)
{
parts[i].life++;
kill_part(r>>8);
}
+ if ((r&0xFF)==PT_SLTW&&33>=rand()/(RAND_MAX/100)+1)
+ {
+ parts[i].life++;
+ if (rand()%4)
+ kill_part(r>>8);
+ else
+ part_change_type(r>>8, x+rx, y+ry, PT_SALT);
+ }
+ if ((r&0xFF)==PT_CBNW&&33>=rand()/(RAND_MAX/100)+1)
+ {
+ parts[i].life++;
+ if (rand()%4)
+ kill_part(r>>8);
+ else
+ part_change_type(r>>8, x+rx, y+ry, PT_CO2);
+ }
+ if ((r&0xFF)==PT_PSTE&&33>=rand()/(RAND_MAX/100)+1)
+ {
+ parts[i].life++;
+ create_part(r>>8, x+rx, y+ry, PT_CLST);
+ }
}
}
else