}
IrcChannel::~IrcChannel() {
-
}
// ====================
void IrcChannel::join(IrcUser *ircuser) {
if(!_userModes.contains(ircuser) && ircuser) {
_userModes[ircuser] = QString();
- ircuser->joinChannel(name());
+ ircuser->joinChannel(this);
//qDebug() << "JOIN" << name() << ircuser->nick() << ircUsers().count();
connect(ircuser, SIGNAL(nickSet(QString)), this, SLOT(ircUserNickSet(QString)));
connect(ircuser, SIGNAL(destroyed()), this, SLOT(ircUserDestroyed()));
void IrcChannel::part(IrcUser *ircuser) {
if(isKnownUser(ircuser)) {
_userModes.remove(ircuser);
- ircuser->partChannel(name());
+ ircuser->partChannel(this);
//qDebug() << "PART" << name() << ircuser->nick() << ircUsers().count();
// if you wonder why there is no counterpart to ircUserParted:
// the joines are propagted by the ircuser. the signal ircUserParted is only for convenience
}
void IrcChannel::ircUserDestroyed() {
- qDebug() << "IrcChannel::ircUserDestroyed()";
IrcUser *ircUser = static_cast<IrcUser *>(sender());
Q_ASSERT(ircUser);
_userModes.remove(ircUser);
}
IrcUser::~IrcUser() {
- QList<IrcChannel *> channels = _channels.toList();
- foreach(IrcChannel *channel, channels) {
- partChannel(channel);
- }
}
// ====================
connect(ircuser, SIGNAL(nickSet(QString)), this, SLOT(ircUserNickChanged(QString)));
connect(ircuser, SIGNAL(initDone()), this, SLOT(ircUserInitDone()));
- connect(ircuser, SIGNAL(destroyed()), this, SLOT(ircUserDestroyed()));
_ircUsers[nick] = ircuser;
emit ircUserAdded(hostmask);
emit ircUserAdded(ircuser);
emit ircChannelInitDone(ircchannel);
}
-void Network::ircUserDestroyed() {
- IrcUser *ircuser = static_cast<IrcUser *>(sender());
- Q_ASSERT(ircuser);
- removeIrcUser(ircuser);
-}
-
void Network::channelDestroyed() {
IrcChannel *channel = static_cast<IrcChannel *>(sender());
Q_ASSERT(channel);
- emit ircChannelRemoved(sender());
_ircChannels.remove(_ircChannels.key(channel));
+ emit ircChannelRemoved(channel);
}
void Network::requestConnect() const {
void emitConnectionError(const QString &);
private slots:
- void ircUserDestroyed();
void channelDestroyed();
void removeIrcUser(IrcUser *ircuser);
void ircUserInitDone();
{ using namespace Global;
quasselVersion = "0.2.0-pre";
- quasselDate = "2008-02-04";
- quasselBuild = 458;
+ quasselDate = "2008-02-05";
+ quasselBuild = 459;
//! Minimum client build number the core needs
- clientBuildNeeded = 456;
+ clientBuildNeeded = 459;
clientVersionNeeded = quasselVersion;
//! Minimum core build number the client needs
- coreBuildNeeded = 456;
+ coreBuildNeeded = 459;
coreVersionNeeded = quasselVersion;
}