_host(hostFromMask(hostmask)),
networkInfo(networkinfo)
{
- setObjectName(QString::number(networkInfo->networkId()) + "/" + IrcUser::hostmask());
+ updateObjectName();
}
IrcUser::~IrcUser() {
return _channels.toList();
}
-void IrcUser::updateObjectName() {
- setObjectName(QString::number(networkInfo->networkId()) + "/" + hostmask());
- emit objectNameSet();
-}
-
// ====================
// PUBLIC SLOTS:
// ====================
if(!user.isEmpty() && _user != user) {
_user = user;
emit userSet(user);
-
- setObjectName(hostmask());
- emit objectNameSet();
}
}
if(!host.isEmpty() && _host != host) {
_host = host;
emit hostSet(host);
- updateObjectName();
}
}
if(!nick.isEmpty() && nick != _nick) {
QString oldnick(_nick);
_nick = nick;
- emit nickSet(nick);
updateObjectName();
+ emit nickSet(nick);
+ }
+}
+
+void IrcUser::updateObjectName() {
+ QString oldName(objectName());
+ setObjectName(QString::number(networkInfo->networkId()) + "/" + _nick);
+ if(!oldName.isEmpty()) {
+ emit renameObject(oldName, objectName());
}
}
+
void IrcUser::updateHostmask(const QString &mask) {
if(mask == hostmask())
return;
QString user = userFromMask(mask);
QString host = hostFromMask(mask);
-
- // we only need to check user and hostmask.
- // nick can't have changed since we're identifying IrcUsers by nick
-
- // we don't use setUser and setHost here.
- // though this is unpretty code duplication this saves us one emit objectNameSet()
- // the second one would be erroneous
-
- if(!user.isEmpty() && _user != user) {
- _user = user;
- }
-
- if(!host.isEmpty() && _host != host) {
- _host = host;
- }
-
- emit hostmaskUpdated(mask);
- updateObjectName();
+ setUser(user);
+ setHost(host);
}
void IrcUser::joinChannel(const QString &channel) {