summaryrefslogtreecommitdiffstats
path: root/source/cRedstone.cpp
diff options
context:
space:
mode:
authoradmin@omencraft.com <admin@omencraft.com@0a769ca7-a7f5-676a-18bf-c427514a06d6>2011-11-07 23:59:29 +0100
committeradmin@omencraft.com <admin@omencraft.com@0a769ca7-a7f5-676a-18bf-c427514a06d6>2011-11-07 23:59:29 +0100
commita9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1 (patch)
tree62167f9ff48fb895c7542e44ef5b5520172a79f4 /source/cRedstone.cpp
parentMore updates to cPiston.cpp. Piston action will now only be broadcasted to players who have the chunk with the moving piston loaded. (diff)
downloadcuberite-a9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1.tar
cuberite-a9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1.tar.gz
cuberite-a9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1.tar.bz2
cuberite-a9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1.tar.lz
cuberite-a9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1.tar.xz
cuberite-a9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1.tar.zst
cuberite-a9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1.zip
Diffstat (limited to 'source/cRedstone.cpp')
-rw-r--r--source/cRedstone.cpp147
1 files changed, 107 insertions, 40 deletions
diff --git a/source/cRedstone.cpp b/source/cRedstone.cpp
index 6a0b1473a..178fdc7be 100644
--- a/source/cRedstone.cpp
+++ b/source/cRedstone.cpp
@@ -11,7 +11,7 @@ cRedstone::cRedstone( cWorld* a_World )
}
-void cRedstone::ChangeRedstoneTorch( int fillx, int filly, int fillz, bool added )
+void cRedstone::ChangeRedstone( int fillx, int filly, int fillz, bool added )
{
if (added) {
m_Metadata = 15;
@@ -19,90 +19,157 @@ void cRedstone::ChangeRedstoneTorch( int fillx, int filly, int fillz, bool added
m_Metadata = 0;
}
- LightRedstone( fillx, filly, fillz );
+ CalculatetRedstone( fillx, filly, fillz );
- if ( (int)m_World->GetBlock( fillx, filly, fillz ) == 0 ) { //we removed an item
+ if ( ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_AIR ) || ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_PISTON_EXTENSION ) ) {
- LightRedstone( fillx+1, filly, fillz );
m_Metadata = 0;
- LightRedstone( fillx-1, filly, fillz );
+ CalculatetRedstone( fillx+1, filly, fillz );
m_Metadata = 0;
- LightRedstone( fillx, filly, fillz+1 );
+ CalculatetRedstone( fillx-1, filly, fillz );
m_Metadata = 0;
- LightRedstone( fillx, filly, fillz-1 );
+ CalculatetRedstone( fillx, filly, fillz+1 );
m_Metadata = 0;
-
+ CalculatetRedstone( fillx, filly, fillz-1 );
+ m_Metadata = 0;
+
+ CalculatetRedstone( fillx+1, filly+1, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx-1, filly+1, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly+1, fillz+1 );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly+1, fillz-1 );
+ m_Metadata = 0;
+
+ CalculatetRedstone( fillx+1, filly-1, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx-1, filly-1, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly-1, fillz+1 );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly-1, fillz-1 );
+ m_Metadata = 0;
+
}
if ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_REDSTONE_WIRE ) { //we added dust
- LightRedstone( fillx+1, filly, fillz );
- LightRedstone( fillx-1, filly, fillz );
- LightRedstone( fillx, filly, fillz+1 );
- LightRedstone( fillx, filly, fillz-1 );
+ CalculatetRedstone( fillx+1, filly, fillz );
+ CalculatetRedstone( fillx-1, filly, fillz );
+ CalculatetRedstone( fillx, filly, fillz+1 );
+ CalculatetRedstone( fillx, filly, fillz-1 );
+
+ CalculatetRedstone( fillx+1, filly+1, fillz );
+ CalculatetRedstone( fillx-1, filly+1, fillz );
+ CalculatetRedstone( fillx, filly+1, fillz+1 );
+ CalculatetRedstone( fillx, filly+1, fillz-1 );
+
+ CalculatetRedstone( fillx+1, filly-1, fillz );
+ CalculatetRedstone( fillx-1, filly-1, fillz );
+ CalculatetRedstone( fillx, filly-1, fillz+1 );
+ CalculatetRedstone( fillx, filly-1, fillz-1 );
+
+ }
+
+ if ( ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_PISTON ) || ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_STICKY_PISTON ) ) { //we added a piston
+
+ m_Metadata = 0;
+ CalculatetRedstone( fillx+1, filly, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx-1, filly, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly, fillz+1 );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly, fillz-1 );
+ m_Metadata = 0;
+
+ CalculatetRedstone( fillx+1, filly+1, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx-1, filly+1, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly+1, fillz+1 );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly+1, fillz-1 );
+ m_Metadata = 0;
+
+ CalculatetRedstone( fillx+1, filly-1, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx-1, filly-1, fillz );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly-1, fillz+1 );
+ m_Metadata = 0;
+ CalculatetRedstone( fillx, filly-1, fillz-1 );
+ m_Metadata = 0;
}
}
-void cRedstone::LightRedstone( int fillx, int filly, int fillz)
+void cRedstone::CalculatetRedstone( int fillx, int filly, int fillz)
{
if ( ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_STICKY_PISTON ) || ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_PISTON ) ) {
- cPiston Piston(m_World);
+ char pistonMeta = m_World->GetBlockMeta( fillx, filly, fillz );
if (m_Metadata > 0) {
- Piston.ExtendPiston(fillx, filly, fillz);
+ if (pistonMeta < 6) { // only extend if piston is not already extended
+ cPiston Piston(m_World);
+ Piston.ExtendPiston(fillx, filly, fillz);
+ }
} else {
- Piston.RetractPiston(fillx, filly, fillz);
+ if (pistonMeta > 6) { // only retract if piston is not already retracted
+ cPiston Piston(m_World);
+ Piston.RetractPiston(fillx, filly, fillz);
+ }
}
}
- if ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_REDSTONE_TORCH_OFF ) { //I don't think notch knows on from off. >.>
+ if ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_REDSTONE_TORCH_ON ) { //If torch is on
m_Metadata = 15;
if ( ( (int)m_World->GetBlock( fillx-1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx-1, filly, fillz) != m_Metadata ) ) {
- LightRedstone(fillx-1,filly,fillz);
+ CalculatetRedstone(fillx-1,filly,fillz);
}
if ( ( (int)m_World->GetBlock( fillx+1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx+1, filly, fillz) != m_Metadata ) ) {
- LightRedstone(fillx+1,filly,fillz);
+ CalculatetRedstone(fillx+1,filly,fillz);
}
if ( ( (int)m_World->GetBlock( fillx, filly, fillz-1 ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx, filly, fillz-1) != m_Metadata ) ) {
- LightRedstone(fillx,filly,fillz-1);
+ CalculatetRedstone(fillx,filly,fillz-1);
}
if ( ( (int)m_World->GetBlock( fillx, filly, fillz+1 ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx, filly, fillz+1) != m_Metadata ) ) {
- LightRedstone(fillx,filly,fillz+1);
+ CalculatetRedstone(fillx,filly,fillz+1);
}
- } else if ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_REDSTONE_TORCH_ON ) { //if the torch is off
+ } else if ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_REDSTONE_TORCH_OFF ) { //if the torch is off
if ( ( (int)m_World->GetBlock( fillx-1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx-1, filly, fillz) != m_Metadata ) ) {
- LightRedstone(fillx-1,filly,fillz);
+ CalculatetRedstone(fillx-1,filly,fillz);
}
if ( ( (int)m_World->GetBlock( fillx+1, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx+1, filly, fillz) != m_Metadata ) ) {
- LightRedstone(fillx+1,filly,fillz);
+ CalculatetRedstone(fillx+1,filly,fillz);
}
if ( ( (int)m_World->GetBlock( fillx, filly, fillz-1 ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx, filly, fillz-1) != m_Metadata ) ) {
- LightRedstone(fillx,filly,fillz-1);
+ CalculatetRedstone(fillx,filly,fillz-1);
}
if ( ( (int)m_World->GetBlock( fillx, filly, fillz+1 ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx, filly, fillz+1) != m_Metadata ) ) {
- LightRedstone(fillx,filly,fillz+1);
+ CalculatetRedstone(fillx,filly,fillz+1);
}
}
if ( ( (int)m_World->GetBlock( fillx, filly, fillz ) == E_BLOCK_REDSTONE_WIRE) && ( (int)m_World->GetBlockMeta( fillx, filly, fillz) != m_Metadata ) ) {
m_World->FastSetBlock( fillx, filly, fillz, (char)E_BLOCK_REDSTONE_WIRE, m_Metadata );
- LightRedstone(fillx-1,filly,fillz);
- LightRedstone(fillx+1,filly,fillz);
- LightRedstone(fillx,filly,fillz-1);
- LightRedstone(fillx,filly,fillz+1);
-
- LightRedstone(fillx-1,filly-1,fillz);
- LightRedstone(fillx+1,filly-1,fillz);
- LightRedstone(fillx,filly-1,fillz-1);
- LightRedstone(fillx,filly-1,fillz+1);
-
- LightRedstone(fillx-1,filly+1,fillz);
- LightRedstone(fillx+1,filly+1,fillz);
- LightRedstone(fillx,filly+1,fillz-1);
- LightRedstone(fillx,filly+1,fillz+1);
+ CalculatetRedstone(fillx-1,filly,fillz);
+ CalculatetRedstone(fillx+1,filly,fillz);
+ CalculatetRedstone(fillx,filly,fillz-1);
+ CalculatetRedstone(fillx,filly,fillz+1);
+
+ CalculatetRedstone(fillx-1,filly-1,fillz);
+ CalculatetRedstone(fillx+1,filly-1,fillz);
+ CalculatetRedstone(fillx,filly-1,fillz-1);
+ CalculatetRedstone(fillx,filly-1,fillz+1);
+
+ CalculatetRedstone(fillx-1,filly+1,fillz);
+ CalculatetRedstone(fillx+1,filly+1,fillz);
+ CalculatetRedstone(fillx,filly+1,fillz-1);
+ CalculatetRedstone(fillx,filly+1,fillz+1);
}
} \ No newline at end of file