+bool SqliteMigrationReader::readMo(IdentityMO& identity)
+{
+ if (!next())
+ return false;
+
+ identity.id = value(0).toInt();
+ identity.userid = value(1).toInt();
+ identity.identityname = value(2).toString();
+ identity.realname = value(3).toString();
+ identity.awayNick = value(4).toString();
+ identity.awayNickEnabled = value(5).toInt() == 1 ? true : false;
+ identity.awayReason = value(6).toString();
+ identity.awayReasonEnabled = value(7).toInt() == 1 ? true : false;
+ identity.autoAwayEnabled = value(8).toInt() == 1 ? true : false;
+ identity.autoAwayTime = value(9).toInt();
+ identity.autoAwayReason = value(10).toString();
+ identity.autoAwayReasonEnabled = value(11).toInt() == 1 ? true : false;
+ identity.detachAwayEnabled = value(12).toInt() == 1 ? true : false;
+ identity.detachAwayReason = value(13).toString();
+ identity.detachAwayReasonEnabled = value(14).toInt() == 1 ? true : false;
+ identity.ident = value(15).toString();
+ identity.kickReason = value(16).toString();
+ identity.partReason = value(17).toString();
+ identity.quitReason = value(18).toString();
+ identity.sslCert = value(19).toByteArray();
+ identity.sslKey = value(20).toByteArray();
+ return true;
+}
+
+bool SqliteMigrationReader::readMo(IdentityNickMO& identityNick)
+{
+ if (!next())
+ return false;
+
+ identityNick.nickid = value(0).toInt();
+ identityNick.identityId = value(1).toInt();
+ identityNick.nick = value(2).toString();
+ return true;
+}
+
+bool SqliteMigrationReader::readMo(NetworkMO& network)
+{
+ if (!next())
+ return false;
+
+ network.networkid = value(0).toInt();
+ network.userid = value(1).toInt();
+ network.networkname = value(2).toString();
+ network.identityid = value(3).toInt();
+ network.encodingcodec = value(4).toString();
+ network.decodingcodec = value(5).toString();
+ network.servercodec = value(6).toString();
+ network.userandomserver = value(7).toInt() == 1 ? true : false;
+ network.perform = value(8).toString();
+ network.useautoidentify = value(9).toInt() == 1 ? true : false;
+ network.autoidentifyservice = value(10).toString();
+ network.autoidentifypassword = value(11).toString();
+ network.useautoreconnect = value(12).toInt() == 1 ? true : false;
+ network.autoreconnectinterval = value(13).toInt();
+ network.autoreconnectretries = value(14).toInt();
+ network.unlimitedconnectretries = value(15).toInt() == 1 ? true : false;
+ network.rejoinchannels = value(16).toInt() == 1 ? true : false;
+ network.connected = value(17).toInt() == 1 ? true : false;
+ network.usermode = value(18).toString();
+ network.awaymessage = value(19).toString();
+ network.attachperform = value(20).toString();
+ network.detachperform = value(21).toString();
+ network.usesasl = value(22).toInt() == 1 ? true : false;
+ network.saslaccount = value(23).toString();
+ network.saslpassword = value(24).toString();
+ // Custom rate limiting
+ network.usecustommessagerate = value(25).toInt() == 1 ? true : false;
+ network.messagerateburstsize = value(26).toInt();
+ network.messageratedelay = value(27).toUInt();
+ network.unlimitedmessagerate = value(28).toInt() == 1 ? true : false;
+ return true;
+}
+
+bool SqliteMigrationReader::readMo(BufferMO& buffer)
+{
+ if (!next())
+ return false;
+
+ buffer.bufferid = value(0).toInt();
+ buffer.userid = value(1).toInt();
+ buffer.groupid = value(2).toInt();
+ buffer.networkid = value(3).toInt();
+ buffer.buffername = value(4).toString();
+ buffer.buffercname = value(5).toString();
+ buffer.buffertype = value(6).toInt();
+ buffer.lastmsgid = value(7).toLongLong();
+ buffer.lastseenmsgid = value(8).toLongLong();
+ buffer.markerlinemsgid = value(9).toLongLong();
+ buffer.bufferactivity = value(10).toInt();
+ buffer.highlightcount = value(11).toInt();
+ buffer.key = value(12).toString();
+ buffer.joined = value(13).toInt() == 1 ? true : false;
+ buffer.cipher = value(14).toString();
+ return true;
+}
+
+bool SqliteMigrationReader::readMo(SenderMO& sender)
+{
+ int skipSteps = 0;
+ while (!next()) {
+ if (sender.senderId < _maxId) {
+ bindValue(0, sender.senderId + (skipSteps * stepSize()));
+ bindValue(1, sender.senderId + ((skipSteps + 1) * stepSize()));
+ skipSteps++;
+ if (!exec())
+ return false;
+ }
+ else {
+ return false;
+ }
+ }
+
+ sender.senderId = value(0).toLongLong();
+ sender.sender = value(1).toString();
+ sender.realname = value(2).toString();
+ sender.avatarurl = value(3).toString();
+ return true;
+}
+
+bool SqliteMigrationReader::readMo(BacklogMO& backlog)
+{
+ qint64 skipSteps = 0;
+ while (!next()) {
+ if (backlog.messageid < _maxId) {
+ bindValue(0, backlog.messageid.toQint64() + (skipSteps * stepSize()));
+ bindValue(1, backlog.messageid.toQint64() + ((skipSteps + 1) * stepSize()));
+ skipSteps++;
+ if (!exec())
+ return false;
+ }
+ else {
+ return false;
+ }
+ }
+
+ backlog.messageid = value(0).toLongLong();
+ // As of SQLite schema version 31, timestamps are stored in milliseconds instead of
+ // seconds. This nets us more precision as well as simplifying 64-bit time.
+ backlog.time = QDateTime::fromMSecsSinceEpoch(value(1).toLongLong()).toUTC();
+ backlog.bufferid = value(2).toInt();
+ backlog.type = value(3).toInt();
+ backlog.flags = value(4).toInt();
+ backlog.senderid = value(5).toLongLong();
+ backlog.senderprefixes = value(6).toString();
+ backlog.message = value(7).toString();
+ return true;
+}
+
+bool SqliteMigrationReader::readMo(IrcServerMO& ircserver)
+{
+ if (!next())
+ return false;
+
+ ircserver.serverid = value(0).toInt();
+ ircserver.userid = value(1).toInt();
+ ircserver.networkid = value(2).toInt();
+ ircserver.hostname = value(3).toString();
+ ircserver.port = value(4).toInt();
+ ircserver.password = value(5).toString();
+ ircserver.ssl = value(6).toInt() == 1 ? true : false;
+ ircserver.sslversion = value(7).toInt();
+ ircserver.useproxy = value(8).toInt() == 1 ? true : false;
+ ircserver.proxytype = value(9).toInt();
+ ircserver.proxyhost = value(10).toString();
+ ircserver.proxyport = value(11).toInt();
+ ircserver.proxyuser = value(12).toString();
+ ircserver.proxypass = value(13).toString();
+ ircserver.sslverify = value(14).toInt() == 1 ? true : false;
+ return true;
+}
+
+bool SqliteMigrationReader::readMo(UserSettingMO& userSetting)
+{
+ if (!next())
+ return false;
+
+ userSetting.userid = value(0).toInt();
+ userSetting.settingname = value(1).toString();
+ userSetting.settingvalue = value(2).toByteArray();
+
+ return true;
+}
+
+bool SqliteMigrationReader::readMo(CoreStateMO& coreState)
+{
+ if (!next())
+ return false;
+
+ coreState.key = value(0).toString();
+ coreState.value = value(1).toByteArray();
+
+ return true;