summaryrefslogtreecommitdiff
path: root/src/simulation/elements/O2.cpp
diff options
context:
space:
mode:
authorSimon Robertshaw <simon@hardwired.org.uk>2012-06-12 18:26:47 (GMT)
committer Simon Robertshaw <simon@hardwired.org.uk>2012-06-12 18:26:47 (GMT)
commit780682c22d6215e655d53c0adb167d9064947928 (patch)
tree50fa4f7a56e81be324eafecfbcd26160b455142f /src/simulation/elements/O2.cpp
parenta93caaa3c7fbb0f3ac7d9edf46eb2b4a89f0aeab (diff)
downloadpowder-780682c22d6215e655d53c0adb167d9064947928.zip
powder-780682c22d6215e655d53c0adb167d9064947928.tar.gz
TPT: oxygen fusion, fix two small bugs
Diffstat (limited to 'src/simulation/elements/O2.cpp')
-rw-r--r--src/simulation/elements/O2.cpp60
1 files changed, 39 insertions, 21 deletions
diff --git a/src/simulation/elements/O2.cpp b/src/simulation/elements/O2.cpp
index 385d1f3..fdc8b98 100644
--- a/src/simulation/elements/O2.cpp
+++ b/src/simulation/elements/O2.cpp
@@ -48,34 +48,52 @@ Element_O2::Element_O2()
//#TPT-Directive ElementHeader Element_O2 static int update(UPDATE_FUNC_ARGS)
int Element_O2::update(UPDATE_FUNC_ARGS)
-
{
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+ry][x+rx];
- if (!r)
- continue;
-
- if ((r&0xFF)==PT_FIRE)
+ if (parts[i].temp < 9773.15)
+ {
+ 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))
{
- parts[r>>8].temp+=(rand()/(RAND_MAX/100));
- if(parts[r>>8].tmp&0x01)
+ r = pmap[y+ry][x+rx];
+ if (!r)
+ continue;
+
+ if ((r&0xFF)==PT_FIRE)
+ {
+ parts[r>>8].temp+=(rand()/(RAND_MAX/100));
+ if(parts[r>>8].tmp&0x01)
parts[r>>8].temp=3473;
- parts[r>>8].tmp |= 2;
- }
- if ((r&0xFF)==PT_FIRE || (r&0xFF)==PT_PLSM)
- {
- sim->create_part(i,x,y,PT_FIRE);
- parts[i].temp+=(rand()/(RAND_MAX/100));
- parts[i].tmp |= 2;
+ parts[r>>8].tmp |= 2;
+ }
+ if ((r&0xFF)==PT_FIRE || (r&0xFF)==PT_PLSM)
+ {
+ sim->create_part(i,x,y,PT_FIRE);
+ parts[i].temp+=(rand()/(RAND_MAX/100));
+ parts[i].tmp |= 2;
+ }
+
}
+ }
+ else if (parts[i].temp > 9973.15 && sim->pv[y/CELL][x/CELL] > 250.0f && abs(sim->gravx[((y/CELL)*(XRES/CELL))+(x/CELL)]) + abs(sim->gravy[((y/CELL)*(XRES/CELL))+(x/CELL)]) > 50)
+ {
+ if (rand()%5 < 1)
+ {
+ int j;
+ sim->part_change_type(i,x,y,PT_PLSM);
+ parts[i].life = rand()%150+50;
+ j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_NEUT); if (j != -1) parts[j].temp = 15000;
+ j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_PHOT); if (j != -1) parts[j].temp = 15000;
+ j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_BRMT); if (j != -1) parts[j].temp = 15000;
+ j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_SING); if (j != -1) { parts[j].temp = 15000; parts[i].life = rand()%25+50; }
- }
+ parts[i].temp += 15000;
+ sim->pv[y/CELL][x/CELL] += 300;
+ }
+ }
return 0;
}
-Element_O2::~Element_O2() {} \ No newline at end of file
+Element_O2::~Element_O2() {}