Exemple #1
0
MessagePtr protobuf_codec::parse(const char* buf, const uint32_t len, uint32_t& error)
{
	MessagePtr message;

	do
	{
		//msg_name_len include the end character '\0'
		const uint16_t msg_name_len = *(const uint16_t*)&buf[0];		//TODO: ntoh()

		if (msg_name_len > 128 || msg_name_len < MIN_MSG_NAME_SIZE || msg_name_len + MSG_NAME_LENGTH_SIZE > len)
		{
			LOG(ERROR)<<"message name length error length = "<<msg_name_len<<", total="<<len;
			error = 1;
			break;
		}

		char msgname[128] = {'\0'};
		strncpy(msgname, (const char*)(buf + MSG_NAME_LENGTH_SIZE), msg_name_len);
		const uint16_t n = strlen(msgname) + 1;
		if (n != msg_name_len)
		{
			LOG(ERROR)<<"message name length error (received="<<n<<", expected="<<msg_name_len<<", msgname="<<msgname<<")";
			error = 2;
			break;
		}
		LOG(INFO)<<"[protobuf_codec],parse, msg_name_len="<<msg_name_len<<", msgname="<<msgname;

		message.reset(createMessage(msgname));
		if (!message)
		{
			LOG(ERROR)<<"unrecognized message name = "<<msgname;
			error = 3;
			break;
		}

		if (!message->ParseFromString(std::string(buf + MSG_NAME_LENGTH_SIZE + msg_name_len, len - MSG_NAME_LENGTH_SIZE - msg_name_len)))
		{
			LOG(ERROR)<<"Parse error msgname="<<msgname;
			error = 4;
			break;
		}
	}while(false);

	return message;
}