diff options
author | admin@omencraft.com <admin@omencraft.com@0a769ca7-a7f5-676a-18bf-c427514a06d6> | 2011-11-04 06:01:55 +0100 |
---|---|---|
committer | admin@omencraft.com <admin@omencraft.com@0a769ca7-a7f5-676a-18bf-c427514a06d6> | 2011-11-04 06:01:55 +0100 |
commit | d2b1aea018650c570e405b5ebb58de3f5b85054e (patch) | |
tree | 9dfbcb6bc841ac1e4639b0d4160019524666a499 /source/cRedstone.cpp | |
parent | Fixed some redstone items and a bug that prevented floats from client to server packets reading correctly on 64 bit linux. (diff) | |
download | cuberite-d2b1aea018650c570e405b5ebb58de3f5b85054e.tar cuberite-d2b1aea018650c570e405b5ebb58de3f5b85054e.tar.gz cuberite-d2b1aea018650c570e405b5ebb58de3f5b85054e.tar.bz2 cuberite-d2b1aea018650c570e405b5ebb58de3f5b85054e.tar.lz cuberite-d2b1aea018650c570e405b5ebb58de3f5b85054e.tar.xz cuberite-d2b1aea018650c570e405b5ebb58de3f5b85054e.tar.zst cuberite-d2b1aea018650c570e405b5ebb58de3f5b85054e.zip |
Diffstat (limited to 'source/cRedstone.cpp')
-rw-r--r-- | source/cRedstone.cpp | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/source/cRedstone.cpp b/source/cRedstone.cpp new file mode 100644 index 000000000..619ead615 --- /dev/null +++ b/source/cRedstone.cpp @@ -0,0 +1,79 @@ +#include "cRedstone.h"
+#include "cWorld.h"
+
+
+cRedstone::cRedstone( cWorld* a_World )
+ :m_World ( a_World )
+{
+
+}
+
+void cRedstone::ChangeRedstoneTorch( int fillx, int filly, int fillz, bool added )
+{
+ char metadata = 0;
+ if (added) {
+ metadata = 15;
+ } else {
+ metadata = 0;
+ }
+ if ( ( m_World->GetWorld()->GetBlock( fillx+1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx+1, filly, fillz, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx-1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx-1, filly, fillz, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx, filly, fillz+1 ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx, filly, fillz+1, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx, filly, fillz-1 ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx, filly, fillz-1, metadata );
+ }
+
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx+1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx+1, filly-1, fillz, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx-1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx-1, filly-1, fillz, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx, filly, fillz+1 ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx, filly-1, fillz+1, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx, filly, fillz-1 ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx, filly-1, fillz-1, metadata );
+ }
+
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx+1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx+1, filly+1, fillz, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx-1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx-1, filly+1, fillz, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx, filly, fillz+1 ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx, filly+1, fillz+1, metadata );
+ }
+ if ( ((int)m_World->GetWorld()->GetBlock( fillx, filly, fillz-1 ) == E_BLOCK_REDSTONE_WIRE) ) {
+ LightRedstone( fillx, filly+1, fillz-1, metadata );
+ }
+}
+
+void cRedstone::LightRedstone( int fillx, int filly, int fillz, char metadata)
+{
+ if ( ( (int)m_World->GetWorld()->GetBlock( fillx, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetWorld()->GetBlockMeta( fillx, filly, fillz) != metadata ) ) {
+ m_World->GetWorld()->SetBlock( fillx, filly, fillz, (char)E_BLOCK_REDSTONE_WIRE, metadata );
+ LightRedstone(fillx-1,filly,fillz,metadata);
+ LightRedstone(fillx+1,filly,fillz,metadata);
+ LightRedstone(fillx,filly,fillz-1,metadata);
+ LightRedstone(fillx,filly,fillz+1,metadata);
+
+ LightRedstone(fillx-1,filly-1,fillz,metadata);
+ LightRedstone(fillx+1,filly-1,fillz,metadata);
+ LightRedstone(fillx,filly-1,fillz-1,metadata);
+ LightRedstone(fillx,filly-1,fillz+1,metadata);
+
+ LightRedstone(fillx-1,filly+1,fillz,metadata);
+ LightRedstone(fillx+1,filly+1,fillz,metadata);
+ LightRedstone(fillx,filly+1,fillz-1,metadata);
+ LightRedstone(fillx,filly+1,fillz+1,metadata);
+ }
+
+}
|