From a9e02cf8fa3afbdbe853e52f030e9a8c7efe46c1 Mon Sep 17 00:00:00 2001 From: "admin@omencraft.com" Date: Mon, 7 Nov 2011 22:59:29 +0000 Subject: Updated redstone and pistons some mode. If you break an extended piston the piston extension will now also break. When a redstone device is broken by something other than a person the redstone circuit should now update. git-svn-id: http://mc-server.googlecode.com/svn/trunk@74 0a769ca7-a7f5-676a-18bf-c427514a06d6 --- source/cRedstone.cpp | 147 +++++++++++++++++++++++++++++++++++++-------------- 1 file changed, 107 insertions(+), 40 deletions(-) (limited to 'source/cRedstone.cpp') 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 -- cgit v1.2.3