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
This commit is contained in:
@@ -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);
|
||||
CalculatetRedstone(fillx-1,filly,fillz);
|
||||
CalculatetRedstone(fillx+1,filly,fillz);
|
||||
CalculatetRedstone(fillx,filly,fillz-1);
|
||||
CalculatetRedstone(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);
|
||||
CalculatetRedstone(fillx-1,filly-1,fillz);
|
||||
CalculatetRedstone(fillx+1,filly-1,fillz);
|
||||
CalculatetRedstone(fillx,filly-1,fillz-1);
|
||||
CalculatetRedstone(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+1,fillz);
|
||||
CalculatetRedstone(fillx+1,filly+1,fillz);
|
||||
CalculatetRedstone(fillx,filly+1,fillz-1);
|
||||
CalculatetRedstone(fillx,filly+1,fillz+1);
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user