From 51dc47bc70d66667ed1aee597d82dbdcfaf92fa1 Mon Sep 17 00:00:00 2001 From: "madmaxoft@gmail.com" Date: Mon, 30 Jan 2012 16:01:45 +0000 Subject: More cFile cleanup; removed old format writing for block entities git-svn-id: http://mc-server.googlecode.com/svn/trunk@193 0a769ca7-a7f5-676a-18bf-c427514a06d6 --- source/cSignEntity.cpp | 81 ++++++++++++++++++++++++++++++++++++-------------- 1 file changed, 58 insertions(+), 23 deletions(-) (limited to 'source/cSignEntity.cpp') diff --git a/source/cSignEntity.cpp b/source/cSignEntity.cpp index beac869c8..2f57b3867 100644 --- a/source/cSignEntity.cpp +++ b/source/cSignEntity.cpp @@ -22,16 +22,28 @@ cSignEntity::cSignEntity(ENUM_BLOCK_ID a_BlockType, int a_X, int a_Y, int a_Z, c { } + + + + cSignEntity::~cSignEntity() { } + + + + // It don't do anything when 'used' void cSignEntity::UsedBy( cPlayer & a_Player ) { (void)a_Player; } + + + + void cSignEntity::SetLines( const std::string & a_Line1, const std::string & a_Line2, const std::string & a_Line3, const std::string & a_Line4 ) { m_Line[0] = a_Line1; @@ -40,6 +52,10 @@ void cSignEntity::SetLines( const std::string & a_Line1, const std::string & a_L m_Line[3] = a_Line4; } + + + + void cSignEntity::SetLine( int a_Index, std::string a_Line ) { if( a_Index < 4 && a_Index > -1 ) @@ -48,6 +64,10 @@ void cSignEntity::SetLine( int a_Index, std::string a_Line ) } } + + + + std::string cSignEntity::GetLine( int a_Index ) { if( a_Index < 4 && a_Index > -1 ) @@ -57,6 +77,10 @@ std::string cSignEntity::GetLine( int a_Index ) return ""; } + + + + void cSignEntity::SendTo( cClientHandle* a_Client ) { cPacket_UpdateSign Sign; @@ -68,51 +92,58 @@ void cSignEntity::SendTo( cClientHandle* a_Client ) Sign.m_Line3 = m_Line[2]; Sign.m_Line4 = m_Line[3]; - if( a_Client ) a_Client->Send( Sign ); + if( a_Client ) + { + a_Client->Send( Sign ); + } else // broadcast of a_Client == 0 { GetChunk()->Broadcast( Sign ); } } -void cSignEntity::WriteToFile(FILE* a_File) -{ - fwrite( &m_BlockType, sizeof( ENUM_BLOCK_ID ), 1, a_File ); - fwrite( &m_PosX, sizeof( int ), 1, a_File ); - fwrite( &m_PosY, sizeof( int ), 1, a_File ); - fwrite( &m_PosZ, sizeof( int ), 1, a_File ); - for( int i = 0; i < 4; i++ ) - { - short Size = (short)m_Line[i].size(); - fwrite( &Size, sizeof(short), 1, a_File ); - fwrite( m_Line[i].c_str(), Size * sizeof(char), 1, a_File ); + + + +#define READ(File, Var) \ + if (File.Read(&Var, sizeof(Var)) != sizeof(Var)) \ + { \ + LOGERROR("ERROR READING cSignEntity %s FROM FILE (line %d)", #Var, __LINE__); \ + return false; \ } -} -bool cSignEntity::LoadFromFile(FILE* a_File) +bool cSignEntity::LoadFromFile(cFile & f) { - if( fread( &m_PosX, sizeof(int), 1, a_File) != 1 ) { LOGERROR("ERROR READING SIGN FROM FILE"); return false; } - if( fread( &m_PosY, sizeof(int), 1, a_File) != 1 ) { LOGERROR("ERROR READING SIGN FROM FILE"); return false; } - if( fread( &m_PosZ, sizeof(int), 1, a_File) != 1 ) { LOGERROR("ERROR READING SIGN FROM FILE"); return false; } + READ(f, m_PosX); + READ(f, m_PosY); + READ(f, m_PosZ); for( int i = 0; i < 4; i++ ) { short Size = 0; - if( fread( &Size, sizeof(short), 1, a_File) != 1 ) { LOGERROR("ERROR READING SIGN FROM FILE"); return false; } - if( Size > 0 ) + READ(f, Size); + if (Size > 0) { - char* c_Str = new char[Size]; - if( fread( c_Str, Size * sizeof(char), 1, a_File) != 1 ) { LOGERROR("ERROR READING SIGN FROM FILE"); delete [] c_Str; return false; } + char * c_Str = new char[Size]; + if (f.Read(c_Str, Size) != Size ) + { + LOGERROR("ERROR READING SIGN FROM FILE"); + delete [] c_Str; + return false; + } m_Line[i].assign( c_Str, Size ); delete [] c_Str; } - LOG("Line %i: %s", i+1, m_Line[i].c_str() ); } return true; } + + + + bool cSignEntity::LoadFromJson( const Json::Value & a_Value ) { m_PosX = a_Value.get("x", 0).asInt(); @@ -137,4 +168,8 @@ void cSignEntity::SaveToJson( Json::Value & a_Value ) a_Value["Line2"] = m_Line[1]; a_Value["Line3"] = m_Line[2]; a_Value["Line4"] = m_Line[3]; -} \ No newline at end of file +} + + + + -- cgit v1.2.3