fixed entities update, version 0.8.55 stable

This commit is contained in:
John Preston 2015-09-02 00:33:44 +03:00
parent fef40bb59f
commit ad089cb8da
5 changed files with 38 additions and 16 deletions

View File

@ -699,13 +699,33 @@ namespace App {
} }
} }
void checkEntitiesUpdate(const MTPDmessage &m) {
if (HistoryItem *existing = App::histItemById(m.vid.v)) {
bool hasLinks = m.has_entities() && !m.ventities.c_vector().v.isEmpty();
if ((hasLinks && !existing->hasTextLinks()) || (!hasLinks && existing->textHasLinks())) {
existing->setText(qs(m.vmessage), m.has_entities() ? linksFromMTP(m.ventities.c_vector().v) : LinksInText());
existing->initDimensions(0);
if (App::main()) App::main()->itemResized(existing);
if (existing->hasTextLinks()) {
existing->history()->addToOverview(existing, OverviewLinks);
}
}
}
}
void feedMsgs(const MTPVector<MTPMessage> &msgs, int msgsState) { void feedMsgs(const MTPVector<MTPMessage> &msgs, int msgsState) {
const QVector<MTPMessage> &v(msgs.c_vector().v); const QVector<MTPMessage> &v(msgs.c_vector().v);
QMap<int32, int32> msgsIds; QMap<int32, int32> msgsIds;
for (int32 i = 0, l = v.size(); i < l; ++i) { for (int32 i = 0, l = v.size(); i < l; ++i) {
const MTPMessage &msg(v.at(i)); const MTPMessage &msg(v.at(i));
switch (msg.type()) { switch (msg.type()) {
case mtpc_message: msgsIds.insert(msg.c_message().vid.v, i); break; case mtpc_message: {
const MTPDmessage &d(msg.c_message());
msgsIds.insert(d.vid.v, i);
if (msgsState == 1) { // new message, index my forwarded messages to links overview
checkEntitiesUpdate(d);
}
} break;
case mtpc_messageEmpty: msgsIds.insert(msg.c_messageEmpty().vid.v, i); break; case mtpc_messageEmpty: msgsIds.insert(msg.c_messageEmpty().vid.v, i); break;
case mtpc_messageService: msgsIds.insert(msg.c_messageService().vid.v, i); break; case mtpc_messageService: msgsIds.insert(msg.c_messageService().vid.v, i); break;
} }

View File

@ -118,6 +118,7 @@ namespace App {
void feedParticipants(const MTPChatParticipants &p, bool requestBotInfos, bool emitPeerUpdated = true); void feedParticipants(const MTPChatParticipants &p, bool requestBotInfos, bool emitPeerUpdated = true);
void feedParticipantAdd(const MTPDupdateChatParticipantAdd &d, bool emitPeerUpdated = true); void feedParticipantAdd(const MTPDupdateChatParticipantAdd &d, bool emitPeerUpdated = true);
void feedParticipantDelete(const MTPDupdateChatParticipantDelete &d, bool emitPeerUpdated = true); void feedParticipantDelete(const MTPDupdateChatParticipantDelete &d, bool emitPeerUpdated = true);
void checkEntitiesUpdate(const MTPDmessage &m);
void feedMsgs(const MTPVector<MTPMessage> &msgs, int msgsState = 0); // 2 - new read message, 1 - new unread message, 0 - not new message, -1 - searched message void feedMsgs(const MTPVector<MTPMessage> &msgs, int msgsState = 0); // 2 - new read message, 1 - new unread message, 0 - not new message, -1 - searched message
void feedWereRead(const QVector<MTPint> &msgsIds); void feedWereRead(const QVector<MTPint> &msgsIds);
void feedInboxRead(const PeerId &peer, int32 upTo); void feedInboxRead(const PeerId &peer, int32 upTo);

View File

@ -644,24 +644,14 @@ HistoryItem *History::createItem(HistoryBlock *block, const MTPmessage &msg, boo
} }
const MTPMessageMedia *media = 0; const MTPMessageMedia *media = 0;
const QVector<MTPMessageEntity> *entities = 0;
switch (msg.type()) { switch (msg.type()) {
case mtpc_message: case mtpc_message:
media = msg.c_message().has_media() ? (&msg.c_message().vmedia) : 0; media = msg.c_message().has_media() ? (&msg.c_message().vmedia) : 0;
entities = msg.c_message().has_entities() ? (&msg.c_message().ventities.c_vector().v) : 0;
break; break;
} }
if (media) { if (media) {
existing->updateMedia(*media); existing->updateMedia(*media);
} }
if (entities && !existing->hasTextLinks()) { // index forwarded messages to links overview
existing->setText(qs(msg.c_message().vmessage), linksFromMTP(*entities));
existing->initDimensions(0);
if (App::main()) App::main()->itemResized(existing);
if (existing->hasTextLinks()) {
existing->history()->addToOverview(existing, OverviewLinks);
}
}
return (returnExisting || regged) ? existing : 0; return (returnExisting || regged) ? existing : 0;
} }
@ -5249,7 +5239,6 @@ HistoryMessage::HistoryMessage(History *history, HistoryBlock *block, const MTPD
, _textHeight(0) , _textHeight(0)
, _media(0) , _media(0)
{ {
//if (msg.has_entities()) msg.ventities.c_vector().v.size()
QString text(textClean(qs(msg.vmessage))); QString text(textClean(qs(msg.vmessage)));
initTime(); initTime();
initMedia(msg.has_media() ? (&msg.vmedia) : 0, text); initMedia(msg.has_media() ? (&msg.vmedia) : 0, text);
@ -5494,6 +5483,10 @@ void HistoryMessage::getTextWithLinks(QString &text, LinksInText &links) {
text = _text.original(); text = _text.original();
} }
bool HistoryMessage::textHasLinks() {
return _text.hasLinks();
}
void HistoryMessage::draw(QPainter &p, uint32 selection) const { void HistoryMessage::draw(QPainter &p, uint32 selection) const {
textstyleSet(&(out() ? st::outTextStyle : st::inTextStyle)); textstyleSet(&(out() ? st::outTextStyle : st::inTextStyle));

View File

@ -786,6 +786,9 @@ public:
} }
virtual void getTextWithLinks(QString &text, LinksInText &links) { virtual void getTextWithLinks(QString &text, LinksInText &links) {
} }
virtual bool textHasLinks() {
return false;
}
virtual QString time() const { virtual QString time() const {
return QString(); return QString();
} }
@ -1339,6 +1342,7 @@ public:
void setMedia(const MTPMessageMedia *media); void setMedia(const MTPMessageMedia *media);
void setText(const QString &text, const LinksInText &links); void setText(const QString &text, const LinksInText &links);
void getTextWithLinks(QString &text, LinksInText &links); void getTextWithLinks(QString &text, LinksInText &links);
bool textHasLinks();
QString time() const { QString time() const {
return _time; return _time;

View File

@ -3414,14 +3414,14 @@ void MainWidget::handleUpdates(const MTPUpdates &updates, uint64 randomId) {
const MTPDupdateShortSentMessage &d(updates.c_updateShortSentMessage()); const MTPDupdateShortSentMessage &d(updates.c_updateShortSentMessage());
HistoryItem *item = 0; HistoryItem *item = 0;
if (randomId) { if (randomId) {
QString text = d.has_entities() ? App::histSentTextByItem(randomId) : QString(); QString text = App::histSentTextByItem(randomId);
feedUpdate(MTP_updateMessageID(d.vid, MTP_long(randomId))); // ignore real date feedUpdate(MTP_updateMessageID(d.vid, MTP_long(randomId))); // ignore real date
if (!text.isEmpty()) { if (!text.isEmpty()) {
LinksInText links(linksFromMTP(d.ventities.c_vector().v)); bool hasLinks = d.has_entities() && !d.ventities.c_vector().v.isEmpty();
item = App::histItemById(d.vid.v); item = App::histItemById(d.vid.v);
if (item && !links.isEmpty()) { if (item && ((hasLinks && !item->hasTextLinks()) || (!hasLinks && item->textHasLinks()))) {
bool was = item->hasTextLinks(); bool was = item->hasTextLinks();
item->setText(text, links); item->setText(text, d.has_entities() ? linksFromMTP(d.ventities.c_vector().v) : LinksInText());
item->initDimensions(0); item->initDimensions(0);
itemResized(item); itemResized(item);
if (!was && item->hasTextLinks()) { if (!was && item->hasTextLinks()) {
@ -3462,6 +3462,10 @@ void MainWidget::feedUpdate(const MTPUpdate &update) {
_byPtsUpdate.insert(ptsKey(SkippedUpdate), update); _byPtsUpdate.insert(ptsKey(SkippedUpdate), update);
return; return;
} }
if (d.vmessage.type() == mtpc_message) { // index forwarded messages to links overview
App::checkEntitiesUpdate(d.vmessage.c_message());
}
HistoryItem *item = App::histories().addToBack(d.vmessage); HistoryItem *item = App::histories().addToBack(d.vmessage);
if (item) { if (item) {
history.peerMessagesUpdated(item->history()->peer->id); history.peerMessagesUpdated(item->history()->peer->id);