mirror of
https://github.com/glest/glest-source.git
synced 2025-08-15 04:43:58 +02:00
- added IRC client to the Internet game menu (still need to update VC++ projects)
This commit is contained in:
@@ -1,52 +1,43 @@
|
||||
/*
|
||||
* Copyright (C) 2004-2009 Georgy Yunaev gyunaev@ulduzsoft.com
|
||||
*
|
||||
* This example is free, and not covered by LGPL license. There is no
|
||||
* restriction applied to their modification, redistribution, using and so on.
|
||||
* You can study them, modify them, use them in your own program - either
|
||||
* completely or partially. By using it you may give me some credits in your
|
||||
* program, but you don't have to.
|
||||
*
|
||||
*
|
||||
* This example tests most features of libirc. It can join the specific
|
||||
* channel, welcoming all the people there, and react on some messages -
|
||||
* 'help', 'quit', 'dcc chat', 'dcc send', 'ctcp'. Also it can reply to
|
||||
* CTCP requests, receive DCC files and accept DCC chats.
|
||||
*
|
||||
* Features used:
|
||||
* - nickname parsing;
|
||||
* - handling 'channel' event to track the messages;
|
||||
* - handling dcc and ctcp events;
|
||||
* - using internal ctcp rely procedure;
|
||||
* - generating channel messages;
|
||||
* - handling dcc send and dcc chat events;
|
||||
* - initiating dcc send and dcc chat.
|
||||
*
|
||||
* $Id: irctest.c 73 2009-01-03 11:14:59Z gyunaev $
|
||||
*/
|
||||
// ==============================================================
|
||||
// This file is part of MegaGlest Shared Library (www.glest.org)
|
||||
//
|
||||
// Copyright (C) 2009-2010 Titus Tscharntke (info@titusgames.de) and
|
||||
// Mark Vejvoda (mark_vejvoda@hotmail.com)
|
||||
//
|
||||
// You can redistribute this code and/or modify it under
|
||||
// the terms of the GNU General Public License as published
|
||||
// by the Free Software Foundation; either version 2 of the
|
||||
// License, or (at your option) any later version
|
||||
// ==============================================================
|
||||
|
||||
#include "ircclient.h"
|
||||
#include "util.h"
|
||||
#include "platform_common.h"
|
||||
|
||||
using namespace Shared::Util;
|
||||
using namespace Shared::PlatformCommon;
|
||||
|
||||
namespace Shared { namespace PlatformCommon {
|
||||
|
||||
|
||||
/*
|
||||
#include <stdio.h>
|
||||
#include <stdarg.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include <libircclient/libircclient.h>
|
||||
|
||||
|
||||
IRCCallbackInterface *IRCThread::callbackObj=NULL;
|
||||
std::vector<string> IRCThread::eventData;
|
||||
bool IRCThread::eventDataDone = false;
|
||||
bool IRCThread::isConnected = false;
|
||||
//
|
||||
// We store data in IRC session context.
|
||||
//
|
||||
typedef struct
|
||||
{
|
||||
char * channel;
|
||||
char * nick;
|
||||
|
||||
typedef struct {
|
||||
string channel;
|
||||
string nick;
|
||||
} irc_ctx_t;
|
||||
|
||||
|
||||
void addlog (const char * fmt, ...)
|
||||
{
|
||||
void addlog (const char * fmt, ...) {
|
||||
FILE * fp;
|
||||
char buf[1024];
|
||||
va_list va_alist;
|
||||
@@ -58,68 +49,65 @@ void addlog (const char * fmt, ...)
|
||||
vsnprintf (buf, sizeof(buf), fmt, va_alist);
|
||||
#endif
|
||||
va_end (va_alist);
|
||||
printf ("===> IRC: %s\n", buf);
|
||||
|
||||
printf ("%s\n", buf);
|
||||
|
||||
if ( (fp = fopen ("irctest.log", "ab")) != 0 )
|
||||
{
|
||||
if ( (fp = fopen ("irctest.log", "ab")) != 0 ) {
|
||||
fprintf (fp, "%s\n", buf);
|
||||
fclose (fp);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void dump_event (irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count)
|
||||
{
|
||||
char buf[512];
|
||||
int cnt;
|
||||
|
||||
void dump_event (irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count) {
|
||||
char buf[512]="";
|
||||
int cnt=0;
|
||||
buf[0] = '\0';
|
||||
|
||||
for ( cnt = 0; cnt < count; cnt++ )
|
||||
{
|
||||
for ( cnt = 0; cnt < count; cnt++ ) {
|
||||
if ( cnt )
|
||||
strcat (buf, "|");
|
||||
|
||||
strcat (buf, params[cnt]);
|
||||
}
|
||||
|
||||
|
||||
addlog ("Event \"%s\", origin: \"%s\", params: %d [%s]", event, origin ? origin : "NULL", cnt, buf);
|
||||
}
|
||||
|
||||
|
||||
void event_join (irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count)
|
||||
{
|
||||
void event_join(irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count) {
|
||||
dump_event (session, event, origin, params, count);
|
||||
irc_cmd_user_mode (session, "+i");
|
||||
irc_cmd_msg (session, params[0], "Hi all");
|
||||
|
||||
if(IRCThread::isConnected == false) {
|
||||
irc_cmd_user_mode (session, "+i");
|
||||
irc_cmd_msg (session, params[0], "MG Bot says hello!");
|
||||
//GetIRCConnectedNickList(argv[2]);
|
||||
}
|
||||
else {
|
||||
char realNick[128]="";
|
||||
irc_target_get_nick(origin,&realNick[0],127);
|
||||
printf ("===> IRC: user joined channel realNick [%s] origin [%s]\n", realNick,origin);
|
||||
IRCThread::eventData.push_back(realNick);
|
||||
}
|
||||
|
||||
IRCThread::isConnected = true;
|
||||
}
|
||||
|
||||
|
||||
void event_connect (irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count)
|
||||
{
|
||||
void event_connect (irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count) {
|
||||
irc_ctx_t * ctx = (irc_ctx_t *) irc_get_ctx (session);
|
||||
dump_event (session, event, origin, params, count);
|
||||
|
||||
irc_cmd_join (session, ctx->channel, 0);
|
||||
irc_cmd_join (session, ctx->channel.c_str(), 0);
|
||||
}
|
||||
|
||||
|
||||
void event_privmsg (irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count)
|
||||
{
|
||||
void event_privmsg (irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count) {
|
||||
dump_event (session, event, origin, params, count);
|
||||
|
||||
printf ("'%s' said me (%s): %s\n",
|
||||
printf ("'%s' said me (%s): %s\n",
|
||||
origin ? origin : "someone",
|
||||
params[0], params[1] );
|
||||
}
|
||||
|
||||
|
||||
void dcc_recv_callback (irc_session_t * session, irc_dcc_t id, int status, void * ctx, const char * data, unsigned int length)
|
||||
{
|
||||
void dcc_recv_callback (irc_session_t * session, irc_dcc_t id, int status, void * ctx, const char * data, unsigned int length) {
|
||||
static int count = 1;
|
||||
char buf[12];
|
||||
char buf[12]="";
|
||||
|
||||
switch (status)
|
||||
{
|
||||
@@ -133,7 +121,7 @@ void dcc_recv_callback (irc_session_t * session, irc_dcc_t id, int status, void
|
||||
printf ("DCC %d: chat connected\n", id);
|
||||
irc_dcc_msg (session, id, "Hehe");
|
||||
}
|
||||
else
|
||||
else
|
||||
{
|
||||
printf ("DCC %d: %s\n", id, data);
|
||||
sprintf (buf, "DCC [%d]: %d", id, count++);
|
||||
@@ -147,42 +135,36 @@ void dcc_recv_callback (irc_session_t * session, irc_dcc_t id, int status, void
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void dcc_file_recv_callback (irc_session_t * session, irc_dcc_t id, int status, void * ctx, const char * data, unsigned int length)
|
||||
{
|
||||
if ( status == 0 && length == 0 )
|
||||
{
|
||||
void dcc_file_recv_callback (irc_session_t * session, irc_dcc_t id, int status, void * ctx, const char * data, unsigned int length) {
|
||||
if ( status == 0 && length == 0 ) {
|
||||
printf ("File sent successfully\n");
|
||||
|
||||
if ( ctx )
|
||||
fclose ((FILE*) ctx);
|
||||
}
|
||||
else if ( status )
|
||||
{
|
||||
else if ( status ) {
|
||||
printf ("File sent error: %d\n", status);
|
||||
|
||||
if ( ctx )
|
||||
fclose ((FILE*) ctx);
|
||||
}
|
||||
else
|
||||
{
|
||||
else {
|
||||
if ( ctx )
|
||||
fwrite (data, 1, length, (FILE*) ctx);
|
||||
printf ("File sent progress: %d\n", length);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void event_channel (irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count)
|
||||
{
|
||||
char nickbuf[128];
|
||||
void event_channel(irc_session_t * session, const char * event, const char * origin, const char ** params, unsigned int count) {
|
||||
char nickbuf[128]="";
|
||||
|
||||
if ( count != 2 )
|
||||
return;
|
||||
|
||||
printf ("'%s' said in channel %s: %s\n",
|
||||
origin ? origin : "someone",
|
||||
params[0], params[1] );
|
||||
printf ("===> IRC: '%s' said in channel %s: %s\n",origin ? origin : "someone",params[0], params[1] );
|
||||
if(IRCThread::callbackObj) {
|
||||
IRCThread::callbackObj->IRC_CallbackEvent(origin, params, count);
|
||||
}
|
||||
|
||||
if ( !origin )
|
||||
return;
|
||||
@@ -205,24 +187,24 @@ void event_channel (irc_session_t * session, const char * event, const char * or
|
||||
irc_cmd_ctcp_request (session, nickbuf, "TIME");
|
||||
}
|
||||
|
||||
if ( !strcmp (params[1], "dcc chat") )
|
||||
{
|
||||
if ( !strcmp (params[1], "dcc chat") ) {
|
||||
irc_dcc_t dccid;
|
||||
irc_dcc_chat (session, 0, nickbuf, dcc_recv_callback, &dccid);
|
||||
printf ("DCC chat ID: %d\n", dccid);
|
||||
}
|
||||
|
||||
if ( !strcmp (params[1], "dcc send") )
|
||||
{
|
||||
if ( !strcmp (params[1], "dcc send") ) {
|
||||
irc_dcc_t dccid;
|
||||
irc_dcc_sendfile (session, 0, nickbuf, "irctest.c", dcc_file_recv_callback, &dccid);
|
||||
printf ("DCC send ID: %d\n", dccid);
|
||||
}
|
||||
|
||||
if ( !strcmp (params[1], "topic") )
|
||||
if ( !strcmp (params[1], "topic") ) {
|
||||
irc_cmd_topic (session, params[0], 0);
|
||||
else if ( strstr (params[1], "topic ") == params[1] )
|
||||
}
|
||||
else if ( strstr (params[1], "topic ") == params[1] ) {
|
||||
irc_cmd_topic (session, params[0], params[1] + 6);
|
||||
}
|
||||
|
||||
if ( strstr (params[1], "mode ") == params[1] )
|
||||
irc_cmd_channel_mode (session, params[0], params[1] + 5);
|
||||
@@ -234,17 +216,13 @@ void event_channel (irc_session_t * session, const char * event, const char * or
|
||||
irc_cmd_whois (session, params[1] + 5);
|
||||
}
|
||||
|
||||
|
||||
void irc_event_dcc_chat (irc_session_t * session, const char * nick, const char * addr, irc_dcc_t dccid)
|
||||
{
|
||||
void irc_event_dcc_chat(irc_session_t * session, const char * nick, const char * addr, irc_dcc_t dccid) {
|
||||
printf ("DCC chat [%d] requested from '%s' (%s)\n", dccid, nick, addr);
|
||||
|
||||
irc_dcc_accept (session, dccid, 0, dcc_recv_callback);
|
||||
}
|
||||
|
||||
|
||||
void irc_event_dcc_send (irc_session_t * session, const char * nick, const char * addr, const char * filename, unsigned long size, irc_dcc_t dccid)
|
||||
{
|
||||
void irc_event_dcc_send(irc_session_t * session, const char * nick, const char * addr, const char * filename, unsigned long size, irc_dcc_t dccid) {
|
||||
FILE * fp;
|
||||
printf ("DCC send [%d] requested from '%s' (%s): %s (%lu bytes)\n", dccid, nick, addr, filename, size);
|
||||
|
||||
@@ -254,70 +232,226 @@ void irc_event_dcc_send (irc_session_t * session, const char * nick, const char
|
||||
irc_dcc_accept (session, dccid, fp, dcc_file_recv_callback);
|
||||
}
|
||||
|
||||
void event_numeric (irc_session_t * session, unsigned int event, const char * origin, const char ** params, unsigned int count)
|
||||
{
|
||||
char buf[24];
|
||||
void event_leave(irc_session_t *session, const char *event, const char *origin, const char ** params, unsigned count) {
|
||||
char buf[24]="";
|
||||
sprintf (buf, "%s", event);
|
||||
|
||||
// someone left the channel.
|
||||
|
||||
if(origin) {
|
||||
printf ("===> IRC: user left channel [%s]\n", origin);
|
||||
|
||||
char realNick[128]="";
|
||||
irc_target_get_nick(origin,&realNick[0],127);
|
||||
|
||||
printf ("===> IRC: user left channel realNick [%s]\n", realNick);
|
||||
|
||||
for(int i = 0; i < IRCThread::eventData.size(); ++i) {
|
||||
printf ("===> IRC: lookingfor match [%s] realNick [%s]\n", IRCThread::eventData[i].c_str(),realNick);
|
||||
|
||||
if(IRCThread::eventData[i] == realNick) {
|
||||
IRCThread::eventData.erase(IRCThread::eventData.begin() + i);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
dump_event (session, buf, origin, params, count);
|
||||
}
|
||||
void event_numeric(irc_session_t * session, unsigned int event, const char * origin, const char ** params, unsigned int count) {
|
||||
char buf[24]="";
|
||||
sprintf (buf, "%d", event);
|
||||
|
||||
switch (event) {
|
||||
case LIBIRC_RFC_ERR_NICKNAMEINUSE :
|
||||
case LIBIRC_RFC_ERR_NICKCOLLISION :
|
||||
//irc_auto_rename_nick(session);
|
||||
break;
|
||||
case LIBIRC_RFC_RPL_TOPIC :
|
||||
break;
|
||||
case LIBIRC_RFC_RPL_NAMREPLY :
|
||||
{
|
||||
if(event == LIBIRC_RFC_RPL_NAMREPLY) {
|
||||
IRCThread::eventData.clear();
|
||||
if(count >= 4) {
|
||||
for(int i = 3; i < count && params[i]; ++i) {
|
||||
|
||||
vector<string> tokens;
|
||||
Tokenize(params[i],tokens," ");
|
||||
|
||||
for(int j = 0; j < tokens.size(); ++j) {
|
||||
IRCThread::eventData.push_back(tokens[j]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
case LIBIRC_RFC_RPL_ENDOFNAMES:
|
||||
IRCThread::eventDataDone = true;
|
||||
break;
|
||||
}
|
||||
|
||||
dump_event (session, buf, origin, params, count);
|
||||
}
|
||||
|
||||
int main (int argc, char **argv)
|
||||
{
|
||||
irc_callbacks_t callbacks;
|
||||
irc_ctx_t ctx;
|
||||
irc_session_t * s;
|
||||
|
||||
if ( argc != 4 )
|
||||
{
|
||||
printf ("Usage: %s <server> <nick> <channel>\n", argv[0]);
|
||||
return 1;
|
||||
}
|
||||
|
||||
memset (&callbacks, 0, sizeof(callbacks));
|
||||
|
||||
callbacks.event_connect = event_connect;
|
||||
callbacks.event_join = event_join;
|
||||
callbacks.event_nick = dump_event;
|
||||
callbacks.event_quit = dump_event;
|
||||
callbacks.event_part = dump_event;
|
||||
callbacks.event_mode = dump_event;
|
||||
callbacks.event_topic = dump_event;
|
||||
callbacks.event_kick = dump_event;
|
||||
callbacks.event_channel = event_channel;
|
||||
callbacks.event_privmsg = event_privmsg;
|
||||
callbacks.event_notice = dump_event;
|
||||
callbacks.event_invite = dump_event;
|
||||
callbacks.event_umode = dump_event;
|
||||
callbacks.event_ctcp_rep = dump_event;
|
||||
callbacks.event_ctcp_action = dump_event;
|
||||
callbacks.event_unknown = dump_event;
|
||||
callbacks.event_numeric = event_numeric;
|
||||
|
||||
callbacks.event_dcc_chat_req = irc_event_dcc_chat;
|
||||
callbacks.event_dcc_send_req = irc_event_dcc_send;
|
||||
|
||||
s = irc_create_session (&callbacks);
|
||||
|
||||
if ( !s )
|
||||
{
|
||||
printf ("Could not create session\n");
|
||||
return 1;
|
||||
}
|
||||
|
||||
ctx.channel = argv[3];
|
||||
ctx.nick = argv[2];
|
||||
|
||||
irc_set_ctx (s, &ctx);
|
||||
|
||||
if ( irc_connect (s, argv[1], 6667, 0, argv[2], 0, 0) )
|
||||
{
|
||||
printf ("Could not connect: %s\n", irc_strerror (irc_errno(s)));
|
||||
return 1;
|
||||
}
|
||||
|
||||
irc_run (s);
|
||||
|
||||
return 1;
|
||||
IRCThread::IRCThread(const std::vector<string> &argv, IRCCallbackInterface *callbackObj) : BaseThread() {
|
||||
this->argv = argv;
|
||||
this->callbackObj = callbackObj;
|
||||
ircSession = NULL;
|
||||
IRCThread::eventData.clear();
|
||||
IRCThread::eventDataDone = false;
|
||||
isConnected = false;
|
||||
}
|
||||
*/
|
||||
|
||||
void IRCThread::signalQuit() {
|
||||
printf ("===> IRC: signalQuit [%p]\n",ircSession);
|
||||
|
||||
if(ircSession != NULL) {
|
||||
callbackObj=NULL;
|
||||
printf ("===> IRC: Quitting Channel\n");
|
||||
irc_cmd_quit(ircSession, "MG Bot is closing!");
|
||||
BaseThread::signalQuit();
|
||||
isConnected = false;
|
||||
}
|
||||
}
|
||||
|
||||
bool IRCThread::shutdownAndWait() {
|
||||
printf ("===> IRC: shutdownAndWait [%p]\n",ircSession);
|
||||
|
||||
signalQuit();
|
||||
BaseThread::shutdownAndWait();
|
||||
}
|
||||
|
||||
void IRCThread::SendIRCCmdMessage(string target, string msg) {
|
||||
if(ircSession != NULL && isConnected == true) {
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"In [%s::%s Line: %d] sending IRC command to [%s] cmd [%s]\n",__FILE__,__FUNCTION__,__LINE__,target.c_str(),msg.c_str());
|
||||
int ret = irc_cmd_msg (ircSession, target.c_str(), msg.c_str());
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"In [%s::%s Line: %d] sending IRC command to [%s] cmd [%s] ret = %d\n",__FILE__,__FUNCTION__,__LINE__,target.c_str(),msg.c_str(),ret);
|
||||
}
|
||||
}
|
||||
|
||||
std::vector<string> IRCThread::GetIRCConnectedNickList(string target) {
|
||||
IRCThread::eventDataDone = false;
|
||||
//IRCThread::eventData.clear();
|
||||
if(ircSession != NULL && isConnected == true) {
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"In [%s::%s Line: %d] sending IRC nick list command to [%s]\n",__FILE__,__FUNCTION__,__LINE__,target.c_str());
|
||||
int ret = irc_cmd_names (ircSession, target.c_str());
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"In [%s::%s Line: %d] sending IRC nick list command to [%s] ret = %d\n",__FILE__,__FUNCTION__,__LINE__,target.c_str(),ret);
|
||||
|
||||
for(time_t tElapsed = time(NULL);
|
||||
IRCThread::eventDataDone == false &&
|
||||
this->getQuitStatus() == false &&
|
||||
difftime(time(NULL),tElapsed) <= 5;) {
|
||||
sleep(50);
|
||||
}
|
||||
}
|
||||
|
||||
return IRCThread::eventData;
|
||||
}
|
||||
|
||||
void IRCThread::execute() {
|
||||
{
|
||||
RunningStatusSafeWrapper runningStatus(this);
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"In [%s::%s Line: %d] argv.size() = %d\n",__FILE__,__FUNCTION__,__LINE__,argv.size());
|
||||
|
||||
if(getQuitStatus() == true) {
|
||||
return;
|
||||
}
|
||||
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"IRC thread is running\n");
|
||||
|
||||
try {
|
||||
irc_callbacks_t callbacks;
|
||||
irc_ctx_t ctx;
|
||||
ircSession=NULL;
|
||||
|
||||
if(argv.size() != 3) {
|
||||
printf ("===> IRC Usage: <server> <nick> <channel> : got params [%ld]\n",argv.size());
|
||||
return;
|
||||
}
|
||||
|
||||
memset (&callbacks, 0, sizeof(callbacks));
|
||||
|
||||
callbacks.event_connect = event_connect;
|
||||
callbacks.event_join = event_join;
|
||||
callbacks.event_nick = dump_event;
|
||||
callbacks.event_quit = dump_event;
|
||||
callbacks.event_part = event_leave;
|
||||
callbacks.event_mode = dump_event;
|
||||
callbacks.event_topic = dump_event;
|
||||
callbacks.event_kick = dump_event;
|
||||
callbacks.event_channel = event_channel;
|
||||
callbacks.event_privmsg = event_privmsg;
|
||||
callbacks.event_notice = dump_event;
|
||||
callbacks.event_invite = dump_event;
|
||||
callbacks.event_umode = dump_event;
|
||||
callbacks.event_ctcp_rep = dump_event;
|
||||
callbacks.event_ctcp_action = dump_event;
|
||||
callbacks.event_unknown = dump_event;
|
||||
callbacks.event_numeric = event_numeric;
|
||||
|
||||
callbacks.event_dcc_chat_req = irc_event_dcc_chat;
|
||||
callbacks.event_dcc_send_req = irc_event_dcc_send;
|
||||
|
||||
if(this->getQuitStatus() == true) {
|
||||
return;
|
||||
}
|
||||
ircSession = irc_create_session (&callbacks);
|
||||
|
||||
if(!ircSession) {
|
||||
printf ("===> IRC Could not create session\n");
|
||||
return;
|
||||
}
|
||||
|
||||
ctx.channel = argv[2];
|
||||
ctx.nick = argv[1];
|
||||
|
||||
if(this->getQuitStatus() == true) {
|
||||
return;
|
||||
}
|
||||
|
||||
irc_set_ctx(ircSession, &ctx);
|
||||
|
||||
if(irc_connect(ircSession, argv[0].c_str(), 6667, 0, argv[1].c_str(), 0, 0)) {
|
||||
printf ("===> IRC Could not connect: %s\n", irc_strerror (irc_errno(ircSession)));
|
||||
return;
|
||||
}
|
||||
|
||||
if(this->getQuitStatus() == true) {
|
||||
return;
|
||||
}
|
||||
|
||||
GetIRCConnectedNickList(argv[2]);
|
||||
|
||||
if(this->getQuitStatus() == true) {
|
||||
return;
|
||||
}
|
||||
|
||||
for(int iAttempts=1;
|
||||
this->getQuitStatus() == false && iAttempts <= 5;
|
||||
++iAttempts) {
|
||||
if(irc_run(ircSession)) {
|
||||
printf ("===> IRC Could not run the session: %s\n", irc_strerror (irc_errno(ircSession)));
|
||||
}
|
||||
}
|
||||
|
||||
printf ("===> IRC exiting IRC CLient!\n");
|
||||
}
|
||||
catch(const exception &ex) {
|
||||
SystemFlags::OutputDebug(SystemFlags::debugError,"In [%s::%s Line: %d] Error [%s]\n",__FILE__,__FUNCTION__,__LINE__,ex.what());
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"In [%s::%s Line: %d] error [%s]\n",__FILE__,__FUNCTION__,__LINE__,ex.what());
|
||||
}
|
||||
catch(...) {
|
||||
SystemFlags::OutputDebug(SystemFlags::debugError,"In [%s::%s Line: %d] UNKNOWN Error\n",__FILE__,__FUNCTION__,__LINE__);
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"In [%s::%s Line: %d] unknown error\n",__FILE__,__FUNCTION__,__LINE__);
|
||||
}
|
||||
|
||||
SystemFlags::OutputDebug(SystemFlags::debugNetwork,"In [%s::%s Line: %d] IRC thread is exiting\n",__FILE__,__FUNCTION__,__LINE__);
|
||||
}
|
||||
|
||||
delete this;
|
||||
}
|
||||
|
||||
|
||||
}}//end namespace
|
||||
|
Reference in New Issue
Block a user