summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorlieuwe <lieuwe@mint>2011-07-29 13:54:35 (GMT)
committer Simon Robertshaw <simon@hardwired.org.uk>2011-08-08 12:32:53 (GMT)
commit8f92829aab9e3c38f65e4f0f8d83a1293e237e54 (patch)
tree37977e0490171f3580fa599d85deeb0c339295e6 /src
parent50c4bfd86d66c805097f4a12fb12ee8094cc2c5f (diff)
downloadpowder-8f92829aab9e3c38f65e4f0f8d83a1293e237e54.zip
powder-8f92829aab9e3c38f65e4f0f8d83a1293e237e54.tar.gz
IT WOOOOOORKS :D (fixed WIRE logic.)
Diffstat (limited to 'src')
-rw-r--r--src/elements/wire.c20
-rw-r--r--src/graphics.c2
-rw-r--r--src/powder.c14
3 files changed, 26 insertions, 10 deletions
diff --git a/src/elements/wire.c b/src/elements/wire.c
index da41bd1..abdb982 100644
--- a/src/elements/wire.c
+++ b/src/elements/wire.c
@@ -1,8 +1,7 @@
#include <element.h>
int update_WIRE(UPDATE_FUNC_ARGS) {
- int s,r,rx,ry,count;
- printf("FUCK");
+ int s,r,rx,ry,count;
s=pmap[y][x];
/*
0: wire
@@ -11,22 +10,23 @@ int update_WIRE(UPDATE_FUNC_ARGS) {
tmp is previous state, ctype is current state
*/
- parts[s>>8].tmp=parts[s>>8].ctype;
- if(parts[s>>8].tmp==1){parts[s>>8].ctype=2;}
- if(parts[s>>8].tmp==2){parts[s>>8].ctype=0;}
+ //parts[s>>8].tmp=parts[s>>8].ctype;
+ parts[s>>8].ctype=0;
+ if(parts[s>>8].tmp==1){parts[s>>8].ctype=2; return 0;}
+ if(parts[s>>8].tmp==2){parts[s>>8].ctype=0; return 0;}
+ count=0;
for(rx=-1; rx<2; rx++)
for(ry=-1; ry<2; ry++)
{
- count=0;
- if(x+rx>=0 && y+ry>0 && x+rx<XRES && y+ry<YRES && pmap[y+ry][x+rx] && rx==0 && ry==0 && (pmap[y+ry][x+rx]&0xFF)!=0xFF)
+ if(x+rx>=0 && y+ry>0 && x+rx<XRES && y+ry<YRES && pmap[y+ry][x+rx] && (rx!=0 || ry!=0) && (pmap[y+ry][x+rx]&0xFF)!=0xFF)
{
r = pmap[y+ry][x+rx];
- if((r&0xFF)==PT_SPRK){parts[s>>8].ctype=1;}
+ if((r&0xFF)==PT_SPRK){parts[s>>8].ctype=1; return 0;}
if((r&0xFF)==PT_WIRE && parts[r>>8].tmp==1){count++;}
}
- if(count==1 || count==2)
- parts[s>>8].ctype=1;
}
+ if(count==1 || count==2)
+ parts[s>>8].ctype=1;
return 0;
}
diff --git a/src/graphics.c b/src/graphics.c
index ed60df1..5a1061e 100644
--- a/src/graphics.c
+++ b/src/graphics.c
@@ -1732,6 +1732,8 @@ void draw_parts(pixel *vid)
blendpixel(vid, nx, ny, 0, 0, 255, 255);
else
blendpixel(vid, nx, ny, 255, 255, 255, 255);
+
+ continue;
}
if (cmode!=CM_HEAT)
diff --git a/src/powder.c b/src/powder.c
index a1fa55e..8e5139a 100644
--- a/src/powder.c
+++ b/src/powder.c
@@ -709,6 +709,11 @@ inline int create_part(int p, int x, int y, int tv)//the function for creating a
if (t==PT_SPRK)
{
+ if((pmap[y][x]>>8)==PT_WIRE)
+ {
+ parts[pmap[y][x]>>8].ctype=1;
+ return -1;
+ }
if ((pmap[y][x]>>8)>=NPART || !((pmap[y][x]&0xFF)==PT_INST||(ptypes[pmap[y][x]&0xFF].properties&PROP_CONDUCTS)))
return -1;
if (parts[pmap[y][x]>>8].life!=0)
@@ -1466,6 +1471,15 @@ void update_particles_i(pixel *vid, int start, int inc)
}
}
}
+ //wire!
+ for (nx=0; nx<XRES; nx++)
+ for (ny=0; ny<YRES; ny++)
+ {
+ r = pmap[ny][nx];
+ if ((r>>8)>=NPART || !r)
+ continue;
+ parts[r>>8].tmp=parts[r>>8].ctype;
+ }
//game of life!
if (ISGOL==1&&++CGOL>=GSPEED)//GSPEED is frames per generation
{