mirror of
				https://github.com/ciphervance/supercell-wx.git
				synced 2025-10-31 02:40:05 +00:00 
			
		
		
		
	Default ValidateMessage implementation
This commit is contained in:
		
							parent
							
								
									0303412519
								
							
						
					
					
						commit
						cb86ab4b9b
					
				
					 6 changed files with 59 additions and 48 deletions
				
			
		|  | @ -29,44 +29,9 @@ Level2Message::~Level2Message() = default; | |||
| Level2Message::Level2Message(Level2Message&&) noexcept = default; | ||||
| Level2Message& Level2Message::operator=(Level2Message&&) noexcept = default; | ||||
| 
 | ||||
| bool Level2Message::ValidateMessage(std::istream& is, size_t bytesRead) const | ||||
| size_t Level2Message::data_size() const | ||||
| { | ||||
|    bool   messageValid = true; | ||||
|    size_t dataSize     = header().message_size() * 2 - header().SIZE; | ||||
| 
 | ||||
|    if (is.eof()) | ||||
|    { | ||||
|       BOOST_LOG_TRIVIAL(warning) << logPrefix_ << "Reached end of data stream"; | ||||
|       messageValid = false; | ||||
|    } | ||||
|    else if (is.fail()) | ||||
|    { | ||||
|       BOOST_LOG_TRIVIAL(warning) | ||||
|          << logPrefix_ << "Could not read from input stream"; | ||||
|       messageValid = false; | ||||
|    } | ||||
|    else if (bytesRead != dataSize) | ||||
|    { | ||||
|       is.seekg(static_cast<std::streamoff>(dataSize) - | ||||
|                   static_cast<std::streamoff>(bytesRead), | ||||
|                std::ios_base::cur); | ||||
| 
 | ||||
|       if (bytesRead < dataSize) | ||||
|       { | ||||
|          BOOST_LOG_TRIVIAL(trace) | ||||
|             << logPrefix_ << "Message contents smaller than size: " << bytesRead | ||||
|             << " < " << dataSize << " bytes"; | ||||
|       } | ||||
|       if (bytesRead > dataSize) | ||||
|       { | ||||
|          BOOST_LOG_TRIVIAL(warning) | ||||
|             << logPrefix_ << "Message contents larger than size: " << bytesRead | ||||
|             << " > " << dataSize << " bytes"; | ||||
|          messageValid = false; | ||||
|       } | ||||
|    } | ||||
| 
 | ||||
|    return messageValid; | ||||
|    return (header().message_size() * 2 - header().SIZE); | ||||
| } | ||||
| 
 | ||||
| const Level2MessageHeader& Level2Message::header() const | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Dan Paulat
						Dan Paulat