mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-14 00:49:41 -05:00
Merge pull request #2228 from PhenomRetroShare/Fix_RsPostedPostsModelHandleEvent
Fix RsPostedPostsModel::handleEvent_main_thread
This commit is contained in:
commit
d6f02e28a7
@ -72,55 +72,57 @@ void RsPostedPostsModel::handleEvent_main_thread(std::shared_ptr<const RsEvent>
|
|||||||
|
|
||||||
switch(e->mPostedEventCode)
|
switch(e->mPostedEventCode)
|
||||||
{
|
{
|
||||||
case RsPostedEventCode::UPDATED_MESSAGE:
|
case RsPostedEventCode::UPDATED_MESSAGE:
|
||||||
case RsPostedEventCode::READ_STATUS_CHANGED:
|
case RsPostedEventCode::READ_STATUS_CHANGED:
|
||||||
case RsPostedEventCode::MESSAGE_VOTES_UPDATED:
|
case RsPostedEventCode::MESSAGE_VOTES_UPDATED:
|
||||||
case RsPostedEventCode::NEW_MESSAGE:
|
case RsPostedEventCode::NEW_MESSAGE:
|
||||||
{
|
{
|
||||||
// Normally we should just emit dataChanged() on the index of the data that has changed:
|
// Normally we should just emit dataChanged() on the index of the data that has changed:
|
||||||
//
|
//
|
||||||
// We need to update the data!
|
// We need to update the data!
|
||||||
|
|
||||||
if(e->mPostedGroupId == mPostedGroup.mMeta.mGroupId)
|
RsGxsPostedEvent E(*e);
|
||||||
RsThread::async([this, e]()
|
|
||||||
{
|
|
||||||
// 1 - get message data from p3GxsChannels
|
|
||||||
|
|
||||||
std::vector<RsPostedPost> posts;
|
if(E.mPostedGroupId == mPostedGroup.mMeta.mGroupId)
|
||||||
std::vector<RsGxsComment> comments;
|
RsThread::async([this, E]()
|
||||||
std::vector<RsGxsVote> votes;
|
|
||||||
|
|
||||||
if(!rsPosted->getBoardContent(mPostedGroup.mMeta.mGroupId,std::set<RsGxsMessageId>{ e->mPostedMsgId }, posts,comments,votes))
|
|
||||||
{
|
{
|
||||||
std::cerr << __PRETTY_FUNCTION__ << " failed to retrieve channel message data for channel/msg " << e->mPostedGroupId << "/" << e->mPostedMsgId << std::endl;
|
// 1 - get message data from p3GxsChannels
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 2 - update the model in the UI thread.
|
std::vector<RsPostedPost> posts;
|
||||||
|
std::vector<RsGxsComment> comments;
|
||||||
|
std::vector<RsGxsVote> votes;
|
||||||
|
|
||||||
RsQThreadUtils::postToObject( [posts,comments,votes,this]()
|
if(!rsPosted->getBoardContent(mPostedGroup.mMeta.mGroupId,std::set<RsGxsMessageId>{ E.mPostedMsgId }, posts,comments,votes))
|
||||||
{
|
|
||||||
for(uint32_t i=0;i<posts.size();++i)
|
|
||||||
{
|
{
|
||||||
// linear search. Not good at all, but normally this is for a single post.
|
RS_ERR(" failed to retrieve channel message data for channel/msg ", E.mPostedGroupId, "/", E.mPostedMsgId);
|
||||||
|
return;
|
||||||
for(uint32_t j=0;j<mPosts.size();++j)
|
|
||||||
if(mPosts[j].mMeta.mMsgId == posts[i].mMeta.mMsgId)
|
|
||||||
{
|
|
||||||
mPosts[j] = posts[i];
|
|
||||||
|
|
||||||
//emit dataChanged(createIndex(0,0,(void*)NULL), createIndex(mFilteredPosts.size(),0,(void*)NULL));
|
|
||||||
|
|
||||||
preMods();
|
|
||||||
postMods();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},this);
|
|
||||||
});
|
|
||||||
|
|
||||||
default:
|
// 2 - update the model in the UI thread.
|
||||||
break;
|
|
||||||
|
RsQThreadUtils::postToObject( [posts,comments,votes,this]()
|
||||||
|
{
|
||||||
|
for(uint32_t i=0;i<posts.size();++i)
|
||||||
|
{
|
||||||
|
// linear search. Not good at all, but normally this is for a single post.
|
||||||
|
|
||||||
|
for(uint32_t j=0;j<mPosts.size();++j)
|
||||||
|
if(mPosts[j].mMeta.mMsgId == posts[i].mMeta.mMsgId)
|
||||||
|
{
|
||||||
|
mPosts[j] = posts[i];
|
||||||
|
|
||||||
|
//emit dataChanged(createIndex(0,0,(void*)NULL), createIndex(mFilteredPosts.size(),0,(void*)NULL));
|
||||||
|
|
||||||
|
preMods();
|
||||||
|
postMods();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},this);
|
||||||
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user