diff options
| author | Jacob1 <jfu614@gmail.com> | 2012-03-14 23:33:10 (GMT) |
|---|---|---|
| committer | Jacob1 <jfu614@gmail.com> | 2012-03-14 23:33:10 (GMT) |
| commit | 83d4658589d366a8a708d64c912c128bcebb9d1c (patch) | |
| tree | 487f6e796b397a185fe8abc927a218d247e6d33e /src/elements/h2.c | |
| parent | 446f773542c2a025a86b0d022c086efbdb86474d (diff) | |
| download | powder-83d4658589d366a8a708d64c912c128bcebb9d1c.zip powder-83d4658589d366a8a708d64c912c128bcebb9d1c.tar.gz | |
prevent ionizing NBLE and burning H2 during fusion
Diffstat (limited to 'src/elements/h2.c')
| -rw-r--r-- | src/elements/h2.c | 25 |
1 files changed, 17 insertions, 8 deletions
diff --git a/src/elements/h2.c b/src/elements/h2.c index 529f22b..fa504ca 100644 --- a/src/elements/h2.c +++ b/src/elements/h2.c @@ -3,6 +3,8 @@ int update_H2(UPDATE_FUNC_ARGS) { int r,rx,ry,rt; + if (parts[i].temp > 2273.15 && pv[y/CELL][x/CELL] > 50.0f) + parts[i].tmp = 1; 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)) @@ -16,24 +18,24 @@ int update_H2(UPDATE_FUNC_ARGS) part_change_type(r>>8,x+rx,y+ry,PT_WATR); part_change_type(i,x,y,PT_OIL); } + if (parts[r>>8].temp > 2273.15)// && pv[y/CELL][x/CELL] > 50.0f) + continue; if (parts[i].tmp != 1) { - if ((r&0xFF)==PT_FIRE) + if (rt==PT_FIRE) { parts[r>>8].temp=2473.15; if(parts[r>>8].tmp&0x02) parts[r>>8].temp=3473; parts[r>>8].tmp |= 1; } - if ((r&0xFF)==PT_FIRE || (r&0xFF)==PT_PLSM || (r&0xFF)==PT_LAVA) + if (rt==PT_FIRE || rt==PT_PLSM || rt==PT_LAVA) { create_part(i,x,y,PT_FIRE); parts[i].temp+=(rand()/(RAND_MAX/100)); parts[i].tmp |= 1; } } - if (parts[i].temp > 2273.15 && pv[y/CELL][x/CELL] > 50.0f && (r&0xFF) == PT_H2) - parts[r>>8].tmp = 1; } if (parts[i].temp > 2273.15 && pv[y/CELL][x/CELL] > 50.0f) { @@ -42,14 +44,21 @@ int update_H2(UPDATE_FUNC_ARGS) { int j; part_change_type(i,x,y,PT_PLSM); + parts[i].life = rand()%150+50; create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_NEUT); create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_ELEC); j = create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_PHOT); - if (j) - parts[j].ctype = 0xFFFF00; - create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_NBLE); + if (j) parts[j].ctype = 0xFFFF00; + + j = create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_NBLE); + if (j) parts[j].tmp = 1; + if (rand()%2) - create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_NBLE); + { + j = create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_NBLE); + if (j) parts[j].tmp = 1; + } + if (parts[i].temp < 4273.15) parts[i].temp = 4273.15; pv[y/CELL][x/CELL] += 50; |
