2011-11-04 01:01:55 -04:00
# include "cRedstone.h"
2011-11-05 22:36:05 -04:00
# include "cPiston.h"
2011-11-04 03:50:18 -04:00
# include "cRoot.h"
2011-11-04 01:01:55 -04:00
# include "cWorld.h"
2011-11-04 12:05:18 -04:00
# include "BlockID.h"
2011-11-08 20:31:19 -05:00
# include <iostream>
# include <vector>
# include <string>
2011-11-04 01:01:55 -04:00
cRedstone : : cRedstone ( cWorld * a_World )
: m_World ( a_World )
2011-11-06 15:39:44 -05:00
, m_Metadata ( 0 )
2011-11-08 20:31:19 -05:00
, m_Direction ( 0 )
2011-11-04 01:01:55 -04:00
{
}
2011-11-07 17:59:29 -05:00
void cRedstone : : ChangeRedstone ( int fillx , int filly , int fillz , bool added )
2011-11-04 01:01:55 -04:00
{
2011-11-08 20:31:19 -05:00
char before ;
//int tempX;
//int tempY;
//int tempZ;
//int state;
//m_Direction
// 0 = x+
// 1 = x-
// 2 = z+
// 3 = z-
// 4 = y+
// 5 = v-
2011-11-04 01:01:55 -04:00
if ( added ) {
2011-11-06 15:39:44 -05:00
m_Metadata = 15 ;
2011-11-04 01:01:55 -04:00
} else {
2011-11-06 15:39:44 -05:00
m_Metadata = 0 ;
2011-11-04 01:01:55 -04:00
}
2011-11-08 20:31:19 -05:00
before = m_Metadata ;
2011-11-04 03:50:18 -04:00
2011-11-08 20:31:19 -05:00
//printf("etb1\n");
CalculatetRedstone ( fillx , filly , fillz ) ; //calculate all item centers.
//printf("etb2\n");
2011-11-07 17:59:29 -05:00
2011-11-08 20:31:19 -05:00
int Block = ( int ) m_World - > GetBlock ( fillx , filly , fillz ) ;
2011-11-06 16:20:38 -05:00
2011-11-08 20:31:19 -05:00
switch ( Block ) //these blocks won't trigger the normal calculaton because they are affected by the redstone around them. So we check each possible channel around them instead.
{
2011-11-10 12:03:35 -05:00
case E_BLOCK_REDSTONE_TORCH_ON :
case E_BLOCK_REDSTONE_TORCH_OFF :
2011-11-08 20:31:19 -05:00
case E_BLOCK_AIR :
case E_BLOCK_PISTON_EXTENSION :
case E_BLOCK_PISTON :
case E_BLOCK_STICKY_PISTON :
{
m_Metadata = 0 ;
m_Direction = 0 ;
CalculatetRedstone ( fillx + 1 , filly , fillz ) ;
m_Metadata = 0 ;
m_Direction = 1 ;
CalculatetRedstone ( fillx - 1 , filly , fillz ) ;
m_Metadata = 0 ;
m_Direction = 2 ;
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
m_Metadata = 0 ;
m_Direction = 3 ;
CalculatetRedstone ( fillx , filly , fillz - 1 ) ;
2011-11-10 12:03:35 -05:00
m_Metadata = 0 ;
CalculatetRedstone ( fillx , filly - 1 , fillz ) ;
2011-11-08 20:31:19 -05:00
break ;
}
case E_BLOCK_REDSTONE_WIRE : //special case for redstone wire.
{
m_Direction = 0 ;
CalculatetRedstone ( fillx + 1 , filly , fillz ) ;
m_Direction = 1 ;
CalculatetRedstone ( fillx - 1 , filly , fillz ) ;
m_Direction = 2 ;
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
m_Direction = 3 ;
CalculatetRedstone ( fillx , filly , fillz - 1 ) ;
2011-11-10 12:03:35 -05:00
m_Metadata = 0 ;
CalculatetRedstone ( fillx , filly - 1 , fillz ) ;
2011-11-08 22:04:56 -05:00
m_Direction = 4 ;
CalculatetRedstone ( fillx + 1 , filly + 1 , fillz ) ;
CalculatetRedstone ( fillx - 1 , filly + 1 , fillz ) ;
CalculatetRedstone ( fillx , filly + 1 , fillz + 1 ) ;
CalculatetRedstone ( fillx , filly + 1 , fillz - 1 ) ;
2011-11-10 12:03:35 -05:00
m_Direction = 5 ;
2011-11-08 22:04:56 -05:00
CalculatetRedstone ( fillx + 1 , filly - 1 , fillz ) ;
CalculatetRedstone ( fillx - 1 , filly - 1 , fillz ) ;
CalculatetRedstone ( fillx , filly - 1 , fillz + 1 ) ;
CalculatetRedstone ( fillx , filly - 1 , fillz - 1 ) ;
2011-11-08 20:31:19 -05:00
break ;
}
2011-11-07 17:59:29 -05:00
}
2011-11-08 20:31:19 -05:00
//printf("done here\n");
2011-11-04 01:01:55 -04:00
}
2011-11-07 17:59:29 -05:00
void cRedstone : : CalculatetRedstone ( int fillx , int filly , int fillz )
2011-11-04 01:01:55 -04:00
{
2011-11-06 15:39:44 -05:00
2011-11-05 22:36:05 -04:00
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_BLOCK_STICKY_PISTON ) | | ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_BLOCK_PISTON ) ) {
2011-11-07 17:59:29 -05:00
char pistonMeta = m_World - > GetBlockMeta ( fillx , filly , fillz ) ;
2011-11-06 15:39:44 -05:00
if ( m_Metadata > 0 ) {
2011-11-07 17:59:29 -05:00
if ( pistonMeta < 6 ) { // only extend if piston is not already extended
cPiston Piston ( m_World ) ;
Piston . ExtendPiston ( fillx , filly , fillz ) ;
}
2011-11-05 22:36:05 -04:00
} else {
2011-11-07 17:59:29 -05:00
if ( pistonMeta > 6 ) { // only retract if piston is not already retracted
cPiston Piston ( m_World ) ;
Piston . RetractPiston ( fillx , filly , fillz ) ;
}
2011-11-05 22:36:05 -04:00
}
2011-11-04 01:01:55 -04:00
2011-11-08 20:31:19 -05:00
} else if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_ITEM_LEVER ) | | ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_ITEM_STONE_BUTTON ) ) {
if ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz ) > 6 ) { //button powered
m_Metadata = 15 ; //change meta to 15 only if redstone power device in on possition is found.
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) ! = m_Metadata ) ) {
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 ) ) {
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 ) ) {
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 ) ) {
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
}
} else {
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) ! = m_Metadata ) ) {
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 ) ) {
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 ) ) {
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 ) ) {
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
}
}
} else if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_BLOCK_STONE_PRESSURE_PLATE ) | | ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_BLOCK_STONE_BUTTON ) ) {
if ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz ) = = 1 ) { //plate powered
m_Metadata = 15 ; //change meta to 15 only if redstone power device in on possition is found.
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) ! = m_Metadata ) ) {
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 ) ) {
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 ) ) {
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 ) ) {
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
}
} else {
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) ! = m_Metadata ) ) {
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 ) ) {
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 ) ) {
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 ) ) {
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
}
}
} else if ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_BLOCK_REDSTONE_TORCH_ON ) { //If torch is on
//printf("found torch on\n");
m_Metadata = 15 ; //change meta to 15 only if redstone torch in on possition is found.
2011-11-06 15:39:44 -05:00
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) ! = m_Metadata ) ) {
2011-11-07 17:59:29 -05:00
CalculatetRedstone ( fillx - 1 , filly , fillz ) ;
2011-11-06 15:39:44 -05:00
}
if ( ( ( int ) m_World - > GetBlock ( fillx + 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx + 1 , filly , fillz ) ! = m_Metadata ) ) {
2011-11-07 17:59:29 -05:00
CalculatetRedstone ( fillx + 1 , filly , fillz ) ;
2011-11-06 15:39:44 -05:00
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz - 1 ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz - 1 ) ! = m_Metadata ) ) {
2011-11-07 17:59:29 -05:00
CalculatetRedstone ( fillx , filly , fillz - 1 ) ;
2011-11-06 15:39:44 -05:00
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz + 1 ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz + 1 ) ! = m_Metadata ) ) {
2011-11-07 17:59:29 -05:00
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
2011-11-06 15:39:44 -05:00
}
2011-11-10 12:03:35 -05:00
2011-11-07 17:59:29 -05:00
} else if ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_BLOCK_REDSTONE_TORCH_OFF ) { //if the torch is off
2011-11-08 20:31:19 -05:00
//printf("found torch off\n");
// no need to change meta here.
2011-11-06 15:39:44 -05:00
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) ! = m_Metadata ) ) {
2011-11-07 17:59:29 -05:00
CalculatetRedstone ( fillx - 1 , filly , fillz ) ;
2011-11-06 15:39:44 -05:00
}
if ( ( ( int ) m_World - > GetBlock ( fillx + 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx + 1 , filly , fillz ) ! = m_Metadata ) ) {
2011-11-07 17:59:29 -05:00
CalculatetRedstone ( fillx + 1 , filly , fillz ) ;
2011-11-06 15:39:44 -05:00
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz - 1 ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz - 1 ) ! = m_Metadata ) ) {
2011-11-07 17:59:29 -05:00
CalculatetRedstone ( fillx , filly , fillz - 1 ) ;
2011-11-06 15:39:44 -05:00
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz + 1 ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz + 1 ) ! = m_Metadata ) ) {
2011-11-07 17:59:29 -05:00
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
2011-11-06 15:39:44 -05:00
}
2011-11-08 20:31:19 -05:00
} else if ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) { //simple fill algorithm for redstone wire.
2011-11-06 15:39:44 -05:00
2011-11-08 20:31:19 -05:00
if ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz ) ! = m_Metadata ) {
2011-11-06 15:39:44 -05:00
m_World - > FastSetBlock ( fillx , filly , fillz , ( char ) E_BLOCK_REDSTONE_WIRE , m_Metadata ) ;
2011-11-08 20:31:19 -05:00
m_Direction = 0 ;
CalculatetRedstone ( fillx + 1 , filly , fillz ) ;
m_Direction = 1 ;
CalculatetRedstone ( fillx - 1 , filly , fillz ) ;
m_Direction = 2 ;
CalculatetRedstone ( fillx , filly , fillz + 1 ) ;
m_Direction = 3 ;
CalculatetRedstone ( fillx , filly , fillz - 1 ) ;
2011-11-10 12:03:35 -05:00
CalculatetRedstone ( fillx , filly - 1 , fillz ) ; //check one block below //similar to same plane
2011-11-08 22:04:56 -05:00
m_Direction = 4 ;
CalculatetRedstone ( fillx + 1 , filly + 1 , fillz ) ;
CalculatetRedstone ( fillx - 1 , filly + 1 , fillz ) ;
CalculatetRedstone ( fillx , filly + 1 , fillz + 1 ) ;
CalculatetRedstone ( fillx , filly + 1 , fillz - 1 ) ;
m_Direction = 5 ;
CalculatetRedstone ( fillx + 1 , filly - 1 , fillz ) ;
CalculatetRedstone ( fillx - 1 , filly - 1 , fillz ) ;
CalculatetRedstone ( fillx , filly - 1 , fillz + 1 ) ;
CalculatetRedstone ( fillx , filly - 1 , fillz - 1 ) ;
2011-11-08 20:31:19 -05:00
}
} else { //default, check item for torch attached to it. If meta > 0 then turn that torch off, otherwise turn it on. This change needs to be passed to the next world tick.
//check for torch to east with meta 1 //turn off
//check for torch to west with meta 2 //turn off
//check for torch to south with meta 3 //turn off
//check for torch to north with meta 4 //turn off
//check for torch above with meta 5 //turn off
if ( ( int ) m_World - > GetBlock ( fillx , filly , fillz ) ! = E_BLOCK_AIR ) {
2011-11-08 22:04:56 -05:00
if ( m_Direction < 4 ) { //redstone wire can only power blocks on the same plane or directly below
2011-11-08 20:31:19 -05:00
if ( ( int ) m_Metadata > 0 ) { //wire powered
//printf("bird: %i dog: %i \n",(int)m_World->GetBlock( fillx, filly+1, fillz ),(int)m_World->GetBlockMeta( fillx, filly+1, fillz));
if ( ( ( int ) m_World - > GetBlock ( fillx + 1 , filly , fillz ) = = E_BLOCK_REDSTONE_TORCH_ON ) & & ( ( int ) m_World - > GetBlockMeta ( fillx + 1 , filly , fillz ) = = 1 ) ) { //east
m_World - > m_RSList . push_back ( fillx + 1 ) ;
m_World - > m_RSList . push_back ( filly ) ;
m_World - > m_RSList . push_back ( fillz ) ;
m_World - > m_RSList . push_back ( 00000 ) ;
}
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_TORCH_ON ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) = = 2 ) ) { //west
m_World - > m_RSList . push_back ( fillx - 1 ) ;
m_World - > m_RSList . push_back ( filly ) ;
m_World - > m_RSList . push_back ( fillz ) ;
m_World - > m_RSList . push_back ( 00000 ) ;
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz + 1 ) = = E_BLOCK_REDSTONE_TORCH_ON ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz + 1 ) = = 3 ) ) { //south
m_World - > m_RSList . push_back ( fillx ) ;
m_World - > m_RSList . push_back ( filly ) ;
m_World - > m_RSList . push_back ( fillz + 1 ) ;
m_World - > m_RSList . push_back ( 00000 ) ;
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz - 1 ) = = E_BLOCK_REDSTONE_TORCH_ON ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz - 1 ) = = 4 ) ) { //north
m_World - > m_RSList . push_back ( fillx ) ;
m_World - > m_RSList . push_back ( filly ) ;
m_World - > m_RSList . push_back ( fillz - 1 ) ;
m_World - > m_RSList . push_back ( 00000 ) ;
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly + 1 , fillz ) = = E_BLOCK_REDSTONE_TORCH_ON ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly + 1 , fillz ) = = 5 ) ) { //top
m_World - > m_RSList . push_back ( fillx ) ;
m_World - > m_RSList . push_back ( filly + 1 ) ;
m_World - > m_RSList . push_back ( fillz ) ;
m_World - > m_RSList . push_back ( 00000 ) ;
}
} else { //wire not powered
bool BlockPowered = IsBlockPowered ( fillx , filly , fillz ) ; //chck this block for other wire turned on or torch turned on below:
if ( BlockPowered = = false ) { //if block is not bowered by something else then I need to check for off torches and turn them on.
//printf("echo: %i cruiser: %i \n",(int)m_World->GetBlock( fillx, filly+1, fillz ),(int)m_World->GetBlockMeta( fillx, filly+1, fillz));
if ( ( ( int ) m_World - > GetBlock ( fillx + 1 , filly , fillz ) = = E_BLOCK_REDSTONE_TORCH_OFF ) & & ( ( int ) m_World - > GetBlockMeta ( fillx + 1 , filly , fillz ) = = 1 ) ) { //east
m_World - > m_RSList . push_back ( fillx + 1 ) ;
m_World - > m_RSList . push_back ( filly ) ;
m_World - > m_RSList . push_back ( fillz ) ;
m_World - > m_RSList . push_back ( 11111 ) ;
}
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_TORCH_OFF ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) = = 2 ) ) { //west
m_World - > m_RSList . push_back ( fillx - 1 ) ;
m_World - > m_RSList . push_back ( filly ) ;
m_World - > m_RSList . push_back ( fillz ) ;
m_World - > m_RSList . push_back ( 11111 ) ;
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz + 1 ) = = E_BLOCK_REDSTONE_TORCH_OFF ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz + 1 ) = = 3 ) ) { //south
m_World - > m_RSList . push_back ( fillx ) ;
m_World - > m_RSList . push_back ( filly ) ;
m_World - > m_RSList . push_back ( fillz + 1 ) ;
m_World - > m_RSList . push_back ( 11111 ) ; ;
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz - 1 ) = = E_BLOCK_REDSTONE_TORCH_OFF ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz - 1 ) = = 4 ) ) { //north
m_World - > m_RSList . push_back ( fillx ) ;
m_World - > m_RSList . push_back ( filly ) ;
m_World - > m_RSList . push_back ( fillz - 1 ) ;
m_World - > m_RSList . push_back ( 11111 ) ;
}
if ( ( ( int ) m_World - > GetBlock ( fillx , filly + 1 , fillz ) = = E_BLOCK_REDSTONE_TORCH_OFF ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly + 1 , fillz ) = = 5 ) ) { //top
m_World - > m_RSList . push_back ( fillx ) ;
m_World - > m_RSList . push_back ( filly + 1 ) ;
m_World - > m_RSList . push_back ( fillz ) ;
m_World - > m_RSList . push_back ( 11111 ) ;
}
}
}
2011-11-08 22:04:56 -05:00
}
2011-11-08 20:31:19 -05:00
}
2011-11-06 15:39:44 -05:00
}
2011-11-08 20:31:19 -05:00
}
bool cRedstone : : IsBlockPowered ( int fillx , int filly , int fillz )
{
if ( ( int ) m_World - > GetBlock ( fillx , filly - 1 , fillz ) = = E_BLOCK_REDSTONE_TORCH_ON ) { return true ; }
2011-11-10 12:03:35 -05:00
if ( ( int ) m_World - > GetBlock ( fillx + 1 , filly , fillz ) = = E_BLOCK_REDSTONE_TORCH_ON ) { return true ; }
if ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_TORCH_ON ) { return true ; }
if ( ( int ) m_World - > GetBlock ( fillx , filly , fillz + 1 ) = = E_BLOCK_REDSTONE_TORCH_ON ) { return true ; }
if ( ( int ) m_World - > GetBlock ( fillx , filly , fillz - 1 ) = = E_BLOCK_REDSTONE_TORCH_ON ) { return true ; }
2011-11-08 20:31:19 -05:00
if ( ( ( int ) m_World - > GetBlock ( fillx + 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx + 1 , filly , fillz ) > 0 ) ) { return true ; }
if ( ( ( int ) m_World - > GetBlock ( fillx - 1 , filly , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx - 1 , filly , fillz ) > 0 ) ) { return true ; }
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz + 1 ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz + 1 ) > 0 ) ) { return true ; }
if ( ( ( int ) m_World - > GetBlock ( fillx , filly , fillz - 1 ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly , fillz - 1 ) > 0 ) ) { return true ; }
2011-11-10 12:03:35 -05:00
if ( ( ( int ) m_World - > GetBlock ( fillx , filly + 1 , fillz ) = = E_BLOCK_REDSTONE_WIRE ) & & ( ( int ) m_World - > GetBlockMeta ( fillx , filly + 1 , fillz ) > 0 ) ) { return true ; }
2011-11-08 20:31:19 -05:00
return false ;
2011-11-06 15:39:44 -05:00
}