亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? irc.cpp

?? .net 方面的開(kāi)發(fā)說(shuō)明資料。
?? CPP
字號(hào):
// ========================================================
// Internet Relay Chat Protocol Handler
//
// Based on RFC1459 (http://www.faqs.org/rfcs/rfc1459.html)
//
// Design and Implementation by Floris van den Berg
// ========================================================

#pragma warning (disable : 4275)
#pragma warning (disable : 4786)

#include <vector>
#include <string>

#include "..\OpenNet.h"
#include "..\OpenNetExtensions.h"

#include "Cabinet.h"

// --------------------------------------------------------

class CIRCProtocol : public IProtocol {
public :
	CIRCProtocol();
	virtual unsigned long DLL_CALLCONV AddRef();
	virtual unsigned long DLL_CALLCONV Release();
	virtual HRESULT DLL_CALLCONV QueryInterface(REFIID guid, void **iif);
	virtual void DLL_CALLCONV Initialize(TRANSPORT_HANDLE m_transport);
	virtual void DLL_CALLCONV Receive(unsigned char *data, int size);
	virtual void DLL_CALLCONV Send(EpAction *action);
	virtual void DLL_CALLCONV Reset();
	virtual int DLL_CALLCONV GetName(char *name, int size);
	virtual int DLL_CALLCONV GetMessageName(int msg, char *name, int size);

private :
	void NoticeAuthDecode(_STL::string line);
	void DecodeStatusMessage(_STL::string line, _STL::string server);
	void DecodeCommand(_STL::string line, _STL::string server);
	void Decode(_STL::string line);
	void PingDecode(_STL::string line);
	void IrcDecode(_STL::string line);

private :
	int m_ref_count;
	TRANSPORT_HANDLE m_transport;
	char data[8192];
	int data_size;
	int data_pos;
};

// --------------------------------------------------------

CIRCProtocol::CIRCProtocol() :
m_ref_count(0),
m_transport(NULL),
data(),
data_size(0),
data_pos(0) {
	memset(&data, 0, sizeof(data));
}

unsigned long DLL_CALLCONV
CIRCProtocol::AddRef() {
	return ++m_ref_count;
}

unsigned long DLL_CALLCONV
CIRCProtocol::Release() {
	int ref_count = --m_ref_count;

	if (ref_count == 0) 
		delete this;

	return ref_count;
}

HRESULT DLL_CALLCONV
CIRCProtocol::QueryInterface(REFIID guid, void **iif) {
	if (IsEqualGUID(guid, CLSID_SYSTEM_PROTOCOL)) {
		AddRef();
		*iif = this;
		return S_OK;
	} else if (IsEqualGUID(guid, GUID_OBJECT)) {
		AddRef();
		*iif = this;
		return S_OK;
	}

	return E_NOINTERFACE;
}
	
void DLL_CALLCONV
CIRCProtocol::Initialize(TRANSPORT_HANDLE transport) {
	m_transport = transport;
}

void DLL_CALLCONV
CIRCProtocol::Receive(unsigned char *data, int size) {
	// copy the data into the buffer

	memcpy(data + data_size, data, size);	
	data_size += size;

	// search for 0x0D's. if found we found a valid SMTP reply

	int i = 0;
	int pos = 0;

	// strip any pending 0x0A and 0x0D chars

	while (pos < data_size) {
		if ((data[pos] != 0x0A) && (data[pos] != 0x0D))
			break;

		++pos;
	}

	// search for the next 0x0A or 0x0D

	while (pos + i < data_size) {
		if (data[pos + i] == 0x0D) {
			// copy the found string into a temporary buffer for easier processing

			char tmp_buffer[8192];
			memcpy(tmp_buffer, data + pos, i - pos);
			tmp_buffer[i - pos] = 0;

			// decode the found line

			if (strlen(tmp_buffer) > 0) {
				// send the raw irc string to the user

				EpEvent pm_event;
				pm_event.reference_id = 0;
				pm_event.protocol = CLSID_IRC_PROTOCOL;
				pm_event.msg = IRC_RAW;
				pm_event.data = (unsigned char *)tmp_buffer;
				pm_event.size = strlen(tmp_buffer) + 1;

				EpDispatchEvent(m_transport, &pm_event);

				// decode the string

				IrcDecode(_STL::string(tmp_buffer));
			}

			// skip end of line characters

			while ((pos + i < data_size) && ((data[pos + i] == 0x0D) || (data[pos + i] == 0x0A)))
				++i;

			memcpy(data, data + i, data_size - i);

			data_size -= i;

			i = 0;
		} else {
			++i;
		}
	}
}

void DLL_CALLCONV
CIRCProtocol::Send(EpAction *action) {
	_STL::string complete;

	switch(action->msg) {
		case IRC_CMD_NICK :
		{
			complete = "NICK " + _STL::string((char *)action->data) + _STL::string("\r\n");
			EpCompleteAction(m_transport, (unsigned char *)complete.c_str(), complete.length());
			break;
		}

		case IRC_CMD_PASS :
		{
			complete = "PASS " + _STL::string((char *)action->data) + _STL::string("\r\n");
			EpCompleteAction(m_transport, (unsigned char *)complete.c_str(), complete.length());
			break;
		}

		case IRC_CMD_USER :
		{
			IRCUser *msg = (IRCUser *)action->data;

			complete = "USER " + _STL::string(msg->username) + _STL::string(" ") +
				_STL::string(msg->hostname) + _STL::string(" ") + _STL::string(msg->servername)
				+ _STL::string(" : ") + _STL::string(msg->realname) + _STL::string("\r\n");

			EpCompleteAction(m_transport, (unsigned char *)complete.c_str(), complete.length());
			break;
		}

		case IRC_CMD_PONG :
		{
			complete = "PONG " + _STL::string((char *)action->data) + _STL::string("\r\n");
			EpCompleteAction(m_transport, (unsigned char *)complete.c_str(), complete.length());
			break;
		}

		case IRC_CMD_JOIN :
		{
			complete = "JOIN " + _STL::string((char *)action->data) + _STL::string("\r\n");
			EpCompleteAction(m_transport, (unsigned char *)complete.c_str(), complete.length());
			break;
		}

		case IRC_CMD_PRIVMSG :
		{
			IRCPrivateMsg *msg = (IRCPrivateMsg *)action->data;
			complete = "PRIVMSG " + _STL::string((char *)msg->target) + _STL::string(" :") + _STL::string((char *)msg->message) + _STL::string("\r\n");
			EpCompleteAction(m_transport, (unsigned char *)complete.c_str(), complete.length());
			break;
		}
	};
}

void DLL_CALLCONV
CIRCProtocol::Reset() {
	data_pos = 0;
	data_size = 0;
	memset(&data, 0, sizeof(data));
}

// --------------------------------------------------------

void
CIRCProtocol::NoticeAuthDecode(_STL::string line) {
	EpEvent pm_event;
	pm_event.reference_id = 0;
	pm_event.protocol = CLSID_IRC_PROTOCOL;
	pm_event.msg = IRC_NOTICEAUTH;
	pm_event.data = (unsigned char *)line.c_str();
	pm_event.size = line.length() + 1;

	EpDispatchEvent(m_transport, &pm_event);
}	

void
CIRCProtocol::DecodeStatusMessage(_STL::string line, _STL::string server) {
	_STL::string command;
	_STL::vector<_STL::string> middle;
	_STL::string params;

	unsigned i = 0;

	// retrieve all the command data stuff

	while ((i < line.length()) && (isdigit(line[i])))
		command += line[i++];

	while ((i < line.length()) && (line[i] == ' '))
		++i;

	while ((i < line.length()) && (line[i] == '*'))
		++i;

	while ((i < line.length()) && (line[i] == ' '))
		++i;

	while ((i < line.length())  && (line[i] != ':')) {
		_STL::string tmp;

		while ((i < line.length()) && (line[i] != ' ') && (line[i] != ':'))
			tmp += line[i++];

		middle.push_back(tmp);

		while ((i < line.length()) && (line[i] == ' '))
			++i;
	}

	++i; // skip ':'

	while ((i < line.length()) && (line[i] == ' '))
		++i;

	while (i < line.length())
		params += line[i++];

	// use the command string to create an event

	EpEvent pm_event;
	pm_event.reference_id = 0;
	pm_event.protocol = CLSID_IRC_PROTOCOL;

	switch(atoi(command.c_str())) {
		case 365 : // [RPL_ENDOFLINKS]
		case 366 : // [RPL_ENDOFNAMES]
		case 368 : // [RPL_ENDOFBANLIST]
			break;

		case 332 : // [RPL_TOPIC]
		{
			IRCChannelTopic msg;
			strcpy(msg.server, server.c_str());
			strcpy(msg.channel, middle[0].c_str());
			strcpy(msg.topic, params.c_str());

			pm_event.msg = IRC_CHANNEL_TOPIC;
			pm_event.data = (unsigned char *)&msg;
			pm_event.size = sizeof(IRCChannelTopic);

			EpDispatchEvent(m_transport, &pm_event);
			break;
		}

		case 353 : // [RPL_NAMREPLY]
		{
			IRCNick ircnick;
			strcpy(ircnick.channel, middle[2].c_str());
			pm_event.msg = IRC_NICK_ENTRY;

			unsigned i = 0;

			while (i < params.length()) {
				_STL::string nick;

				while ((i < params.length()) && (params[i] != ' '))
					nick += params[i++];
	
				while ((i < params.length()) && (params[i] == ' '))
					++i;

				strcpy(ircnick.nick, nick.c_str());

				pm_event.data = (unsigned char *)&ircnick;
				pm_event.size = sizeof(IRCNick);
				EpDispatchEvent(m_transport, &pm_event);
			}
			
			break;
		}

		case 252 : // [RPL_LUSEROP]
		case 253 : // [RPL_LUSERUNKNOWN]
		case 254 : // [RPL_LUSERCHANNELS]
		{
			_STL::string tmp = middle[1] + _STL::string(" ") + params;

			IRCStatusMessage msg;
			strcpy(msg.message, tmp.c_str());
			strcpy(msg.server, server.c_str());

			pm_event.msg = IRC_STATUS_MESSAGE;
			pm_event.data = (unsigned char *)&msg;
			pm_event.size = sizeof(IRCStatusMessage);

			EpDispatchEvent(m_transport, &pm_event);
			break;
		}

		default :
		{
			IRCStatusMessage msg;
			strcpy(msg.message, params.c_str());
			strcpy(msg.server, server.c_str());

			pm_event.msg = IRC_STATUS_MESSAGE;
			pm_event.data = (unsigned char *)&msg;
			pm_event.size = sizeof(IRCStatusMessage);

			EpDispatchEvent(m_transport, &pm_event);
			break;
		}
	}
}

void
CIRCProtocol::DecodeCommand(_STL::string line, _STL::string server) {
	_STL::string command;
	_STL::vector<_STL::string> middle;
	_STL::string params;

	unsigned i = 0;

	// retrieve all the command data stuff

	while ((i < line.length()) && (line[i] != ' '))
		command += line[i++];

	while ((i < line.length()) && (line[i] == ' '))
		++i;

	while ((i < line.length())  && (line[i] != ':')) {
		_STL::string tmp;

		while ((i < line.length()) && (line[i] != ' ') && (line[i] != ':'))
			tmp += line[i++];

		middle.push_back(tmp);

		while ((i < line.length()) && (line[i] == ' '))
			++i;
	}

	++i; // skip ':'

	while ((i < line.length()) && (line[i] == ' '))
		++i;

	while (i < line.length())
		params += line[i++];

	// use the command string to create an event

	EpEvent pm_event;
	pm_event.reference_id = 0;
	pm_event.protocol = CLSID_IRC_PROTOCOL;

	if (strncmp(command.c_str(), "PRIVMSG", 7) == 0) {
		IRCReplyPrivateMsg msg;

		int find = server.find("!");
		strcpy(msg.nick, server.substr(0, find).c_str());
		strcpy(msg.mask, server.substr(find + 1, server.length() - find - 1).c_str());
		strcpy(msg.channel, middle[0].c_str());
		strcpy(msg.message, params.c_str());

		pm_event.msg = IRC_PRIVMSG;
		pm_event.data = (unsigned char *)&msg;
		pm_event.size = sizeof(IRCReplyPrivateMsg);

		EpDispatchEvent(m_transport, &pm_event);
		return;
	}

	if (strncmp(command.c_str(), "JOIN", 4) == 0) {
		IRCNick nick;

		int find = server.find("!");
		strcpy(nick.nick, server.substr(0, find).c_str());
		strcpy(nick.mask, server.substr(find + 1, server.length() - find - 1).c_str());
		strcpy(nick.channel, params.c_str());

		pm_event.msg = IRC_JOIN;
		pm_event.data = (unsigned char *)&nick;
		pm_event.size = sizeof(IRCNick);

		EpDispatchEvent(m_transport, &pm_event);
		return;
	};

	if (strncmp(command.c_str(), "PART", 4) == 0) {
		IRCNick nick;

		int find = server.find("!");
		strcpy(nick.nick, server.substr(0, find).c_str());
		strcpy(nick.mask, server.substr(find + 1, server.length() - find - 1).c_str());
		strcpy(nick.channel, params.c_str());

		pm_event.msg = IRC_PART;
		pm_event.data = (unsigned char *)&nick;
		pm_event.size = sizeof(IRCNick);

		EpDispatchEvent(m_transport, &pm_event);
		return;
	};

	if (strncmp(command.c_str(), "QUIT", 4) == 0) {
		IRCNick nick;

		int find = server.find("!");
		strcpy(nick.nick, server.substr(0, find).c_str());
		strcpy(nick.mask, server.substr(find + 1, server.length() - find - 1).c_str());
		strcpy(nick.channel, params.c_str());

		pm_event.msg = IRC_QUIT;
		pm_event.data = (unsigned char *)&nick;
		pm_event.size = sizeof(IRCNick);

		EpDispatchEvent(m_transport, &pm_event);
		return;
	};
}

void
CIRCProtocol::Decode(_STL::string line) {
	_STL::string nickserver;

	// prefix part

	unsigned i = 0;

	if (line[i] == ':') {
		++i;

		while ((i < line.length()) && (line[i] != ' '))
			nickserver += line[i++];

		while ((i < line.length()) && (line[i] == ' '))
			++i;
	}

	// command part (3 digits or a string)

	if (isdigit(line[i]))
		DecodeStatusMessage(line.substr(i, line.length() - i), nickserver);
	else
		DecodeCommand(line.substr(i, line.length() - i), nickserver);
}

void
CIRCProtocol::PingDecode(_STL::string line) {
	EpEvent pm_event;
	pm_event.reference_id = 0;
	pm_event.protocol = CLSID_IRC_PROTOCOL;
	pm_event.msg = IRC_PING;
	pm_event.data = (unsigned char *)line.c_str();
	pm_event.size = line.length() + 1;

	EpDispatchEvent(m_transport, &pm_event);
}

void
CIRCProtocol::IrcDecode(_STL::string line) {
	if (strncmp(line.c_str(), "NOTICE AUTH", 11) == 0) {
		unsigned i = 11;

		while ((i < line.length()) && (line[i] != ':'))
			++i;

		while ((i < line.length()) && (line[i] == ':'))
			++i;

		NoticeAuthDecode(line.substr(i, line.length() - i));
	} else if (strncmp(line.c_str(), "PING", 4) == 0) {
		unsigned i = 4;

		while ((i < line.length()) && (line[i] != ':'))
			++i;

		while ((i < line.length()) && (line[i] == ':'))
			++i;

		PingDecode(line.substr(i, line.length() - i));
	} else {
		Decode(line);
	}

	int i[] = { 0, 1, 2 };

}

int DLL_CALLCONV
CIRCProtocol::GetName(char *name, int size) {
	if (size >= 4)
		strcpy(name, "IRC");

	return 4;
}

int DLL_CALLCONV
CIRCProtocol::GetMessageName(int msg, char *name, int size) {
	return 0;
}

// --------------------------------------------------------
// Instantation function
// --------------------------------------------------------

static HRESULT DLL_CALLCONV
IRCProtocolCreate(void **iif) {
	CIRCProtocol *object = new CIRCProtocol;

	if (object) {
		object->AddRef();
		*iif = object;
		return S_OK;
	}

	return E_FAIL;
}

// --------------------------------------------------------
// Discover function
// --------------------------------------------------------

void DLL_CALLCONV
IRCProtocolInitialize() {
	EpRegisterProtocol(CLSID_IRC_PROTOCOL, IRCProtocolCreate);
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久国产尿小便嘘嘘| 午夜精品影院在线观看| 精品视频一区三区九区| 久久99久久久久久久久久久| 亚洲色图色小说| 日韩精品一区二区三区视频在线观看 | 一区二区三区电影在线播| 日韩欧美一区二区三区在线| 色悠悠亚洲一区二区| 精品一区二区在线播放| 亚洲成av人片| 亚洲人成小说网站色在线| 国产亚洲精品精华液| 欧美二区三区91| av日韩在线网站| 国内精品伊人久久久久影院对白| 亚洲一区二区精品视频| 国产精品久久久久永久免费观看| 精品久久久久久久久久久久久久久久久 | 成人av网站免费观看| 日韩成人av影视| 亚洲丰满少妇videoshd| 亚洲综合在线观看视频| 亚洲欧美在线观看| 日本一区二区成人在线| 久久免费偷拍视频| 精品国产精品网麻豆系列 | 国产精品免费久久| 国产色产综合色产在线视频| 精品久久久久99| 91精品国产色综合久久| 欧美裸体一区二区三区| 欧美日韩一区高清| 欧美日韩三级在线| 欧美美女一区二区在线观看| 欧美在线free| 精品视频在线免费看| 欧美久久免费观看| 欧美福利视频一区| 欧美一二三区在线| 日韩精品一区二区三区三区免费| 日韩欧美亚洲国产另类| 日韩一区二区电影网| 日韩美女视频一区二区在线观看| 日韩一级高清毛片| 精品国产乱码久久久久久老虎| 日韩欧美国产电影| 久久影院电视剧免费观看| 久久综合九色综合欧美98| 26uuu成人网一区二区三区| 久久久91精品国产一区二区三区| 久久精品亚洲精品国产欧美kt∨| 国产情人综合久久777777| 国产人久久人人人人爽| 亚洲欧美日韩精品久久久久| 亚洲你懂的在线视频| 亚洲午夜精品一区二区三区他趣| 亚洲成av人片在线| 日韩av中文在线观看| 韩日精品视频一区| 丁香一区二区三区| 91精品91久久久中77777| 欧美日韩一区不卡| 日韩一二在线观看| 中文字幕欧美日本乱码一线二线 | 日韩**一区毛片| 久久99国产精品久久| 粉嫩绯色av一区二区在线观看| jiyouzz国产精品久久| 91香蕉视频在线| 911精品国产一区二区在线| 精品久久久网站| 中文字幕中文字幕在线一区 | 国精品**一区二区三区在线蜜桃| 成人免费看黄yyy456| 91久久精品一区二区三区| 9191国产精品| 国产精品你懂的| 亚洲第四色夜色| 国产成人免费在线| 欧洲国内综合视频| 久久婷婷综合激情| 亚洲综合色网站| 久国产精品韩国三级视频| av资源站一区| 日韩一区二区影院| 国产精品三级在线观看| 日韩黄色免费电影| 9人人澡人人爽人人精品| 5566中文字幕一区二区电影| 亚洲国产精品ⅴa在线观看| 亚洲国产一区二区a毛片| 粉嫩13p一区二区三区| 欧美高清视频不卡网| 中文字幕在线一区| 老司机午夜精品99久久| 91麻豆免费观看| 精品国产精品网麻豆系列| 午夜电影一区二区三区| 成人av资源站| 久久综合久久综合九色| 亚洲成av人片一区二区三区| 99国产精品久| 久久精品综合网| 免费观看一级特黄欧美大片| 日本韩国欧美国产| 亚洲国产精品激情在线观看| 日本成人中文字幕| 欧美图区在线视频| 亚洲色欲色欲www在线观看| 国产成人精品亚洲777人妖| 欧美一级欧美三级| 亚洲v中文字幕| 色综合久久综合网97色综合| 中日韩免费视频中文字幕| 国内精品久久久久影院薰衣草| 91麻豆精品国产综合久久久久久| 亚洲精品中文在线影院| av影院午夜一区| 国产色产综合色产在线视频| 国产在线播精品第三| 欧美va亚洲va在线观看蝴蝶网| 日韩精品一级中文字幕精品视频免费观看| 色婷婷精品大视频在线蜜桃视频| 国产精品国产三级国产普通话99| 国产激情视频一区二区三区欧美| 欧美一区二区三区视频免费 | 美女视频黄a大片欧美| 欧美日本乱大交xxxxx| 一区二区三区四区亚洲| 色先锋aa成人| 亚洲精品高清在线| 日本高清不卡视频| 夜夜揉揉日日人人青青一国产精品| av亚洲产国偷v产偷v自拍| 国产亚洲污的网站| 99在线热播精品免费| 日本在线观看不卡视频| 精品国一区二区三区| 精品无人区卡一卡二卡三乱码免费卡 | kk眼镜猥琐国模调教系列一区二区| 欧美日本韩国一区二区三区视频 | 欧美精品粉嫩高潮一区二区| 色一情一伦一子一伦一区| 成人欧美一区二区三区| 中文字幕一区在线观看| 麻豆精品视频在线观看视频| 国产精品一区二区你懂的| 成人免费av在线| 欧美激情自拍偷拍| 欧美一区二区三区小说| caoporm超碰国产精品| 亚洲欧美一区二区三区国产精品| 国产精品人妖ts系列视频| 91麻豆精品国产综合久久久久久| 欧美在线短视频| 色94色欧美sute亚洲13| 国产传媒一区在线| 精品一区二区三区免费毛片爱| 精品电影一区二区三区| 国产香蕉久久精品综合网| 久久精品日韩一区二区三区| 日本一区二区三区在线不卡| 欧美国产一区视频在线观看| 国产欧美一区二区三区鸳鸯浴 | 欧美成人精品福利| 欧美性生交片4| 日本高清免费不卡视频| 欧美色图激情小说| 色欧美片视频在线观看| 成人综合婷婷国产精品久久蜜臀 | 色综合亚洲欧洲| 97成人超碰视| 欧洲另类一二三四区| 96av麻豆蜜桃一区二区| 免费观看一级特黄欧美大片| 久久精品国内一区二区三区| 久久精品国产77777蜜臀| 亚洲一区二区美女| 蜜桃一区二区三区在线| 亚洲va欧美va人人爽午夜| 午夜视频一区二区| 日韩二区三区四区| 国产高清在线观看免费不卡| 国产裸体歌舞团一区二区| 国产成都精品91一区二区三| av激情亚洲男人天堂| 欧美日韩日日夜夜| 久久综合色播五月| 日韩毛片高清在线播放| 奇米影视在线99精品| 91丨九色丨蝌蚪富婆spa| 久久在线观看免费| 国产精品久久久久久久裸模| 日本亚洲电影天堂| 日韩美女天天操| 国产在线看一区| 欧美日韩高清一区二区三区| 午夜免费久久看| 91精品国产综合久久久久久久久久|