fixed a few bugs in posts model

This commit is contained in:
csoler 2020-06-06 21:32:06 +02:00
parent 129ffdd6c5
commit fecd4369ec
No known key found for this signature in database
GPG Key ID: 7BCA522266C0804C
2 changed files with 32 additions and 38 deletions

View File

@ -115,13 +115,10 @@ int RsGxsChannelPostsModel::rowCount(const QModelIndex& parent) const
return 0; return 0;
if(!parent.isValid()) if(!parent.isValid())
return (getChildrenCount(0) + mColumns-1)/mColumns; return (mPosts.size()-1 + mColumns-1)/mColumns; // mPosts always has an item at 0, so size()>=1, and mColumn>=1
RsErr() << __PRETTY_FUNCTION__ << " rowCount cannot figure out the porper number of rows." << std::endl; RsErr() << __PRETTY_FUNCTION__ << " rowCount cannot figure out the porper number of rows." << std::endl;
return 0; return 0;
//else
// return getChildrenCount(parent.internalId());
} }
int RsGxsChannelPostsModel::columnCount(const QModelIndex &/*parent*/) const int RsGxsChannelPostsModel::columnCount(const QModelIndex &/*parent*/) const
@ -173,7 +170,7 @@ bool RsGxsChannelPostsModel::convertTabEntryToRefPointer(uint32_t entry,quintptr
// This means that the whole software has the following build-in limitation: // This means that the whole software has the following build-in limitation:
// * 4 B simultaenous posts. Should be enough ! // * 4 B simultaenous posts. Should be enough !
ref = (intptr_t)entry; ref = (intptr_t)(entry+1);
return true; return true;
} }
@ -187,7 +184,13 @@ bool RsGxsChannelPostsModel::convertRefPointerToTabEntry(quintptr ref, uint32_t&
RsErr() << "(EE) trying to make a ChannelPostsModelIndex out of a number that is larger than 2^32-1 !" << std::endl; RsErr() << "(EE) trying to make a ChannelPostsModelIndex out of a number that is larger than 2^32-1 !" << std::endl;
return false ; return false ;
} }
entry = quintptr(val); if(val==0)
{
RsErr() << "(EE) trying to make a ChannelPostsModelIndex out of index 0." << std::endl;
return false;
}
entry = val - 1;
return true; return true;
} }
@ -197,7 +200,7 @@ QModelIndex RsGxsChannelPostsModel::index(int row, int column, const QModelIndex
if(row < 0 || column < 0 || column >= mColumns) if(row < 0 || column < 0 || column >= mColumns)
return QModelIndex(); return QModelIndex();
quintptr ref = getChildRef(parent.internalId(),row + column*mColumns); quintptr ref = getChildRef(parent.internalId(),column + row*mColumns);
#ifdef DEBUG_CHANNEL_MODEL #ifdef DEBUG_CHANNEL_MODEL
std::cerr << "index-3(" << row << "," << column << " parent=" << parent << ") : " << createIndex(row,column,ref) << std::endl; std::cerr << "index-3(" << row << "," << column << " parent=" << parent << ") : " << createIndex(row,column,ref) << std::endl;
@ -223,6 +226,11 @@ Qt::ItemFlags RsGxsChannelPostsModel::flags(const QModelIndex& index) const
void RsGxsChannelPostsModel::setNumColumns(int n) void RsGxsChannelPostsModel::setNumColumns(int n)
{ {
if(n < 1)
{
RsErr() << __PRETTY_FUNCTION__ << " Attempt to set a number of column of 0. This is wrong." << std::endl;
return;
}
preMods(); preMods();
beginRemoveRows(QModelIndex(),0,rowCount()-1); beginRemoveRows(QModelIndex(),0,rowCount()-1);
@ -241,15 +249,10 @@ quintptr RsGxsChannelPostsModel::getChildRef(quintptr ref,int index) const
if (index < 0) if (index < 0)
return 0; return 0;
ChannelPostsModelIndex entry ; if(ref == quintptr(0))
if(!convertRefPointerToTabEntry(ref,entry) || entry >= mPosts.size())
return 0 ;
if(entry == 0)
{ {
quintptr new_ref; quintptr new_ref;
convertTabEntryToRefPointer(index+1,new_ref); convertTabEntryToRefPointer(index,new_ref);
return new_ref; return new_ref;
} }
else else
@ -278,17 +281,9 @@ int RsGxsChannelPostsModel::getChildrenCount(quintptr ref) const
{ {
uint32_t entry = 0 ; uint32_t entry = 0 ;
if(!convertRefPointerToTabEntry(ref,entry) || entry >= mPosts.size()) if(ref == quintptr(0))
return 0 ; return rowCount()-1;
if(entry == 0)
{
#ifdef DEBUG_CHANNEL_MODEL
std::cerr << "Children count (flat mode): " << mPosts.size()-1 << std::endl;
#endif
return ((int)mPosts.size())-1;
}
else
return 0; return 0;
} }
@ -803,7 +798,7 @@ void RsGxsChannelPostsModel::createPostsArray(std::vector<RsGxsChannelPost>& pos
{ {
// collect new versions of posts if any // collect new versions of posts if any
#ifdef DEBUG_CHANNEL_MODEL #ifndef DEBUG_CHANNEL_MODEL
std::cerr << "Inserting channel posts" << std::endl; std::cerr << "Inserting channel posts" << std::endl;
#endif #endif
@ -813,8 +808,8 @@ void RsGxsChannelPostsModel::createPostsArray(std::vector<RsGxsChannelPost>& pos
if(posts[i].mMeta.mOrigMsgId == posts[i].mMeta.mMsgId) if(posts[i].mMeta.mOrigMsgId == posts[i].mMeta.mMsgId)
posts[i].mMeta.mOrigMsgId.clear(); posts[i].mMeta.mOrigMsgId.clear();
#ifdef DEBUG_CHANNEL_MODEL #ifndef DEBUG_CHANNEL_MODEL
std::cerr << " " << i << ": msg_id=" << posts[i].mMeta.mMsgId << ": orig msg id = " << posts[i].mMeta.mOrigMsgId << std::endl; std::cerr << " " << i << ": name=\"" << posts[i].mMeta.mMsgName << "\" msg_id=" << posts[i].mMeta.mMsgId << ": orig msg id = " << posts[i].mMeta.mOrigMsgId << std::endl;
#endif #endif
if(!posts[i].mMeta.mOrigMsgId.isNull()) if(!posts[i].mMeta.mOrigMsgId.isNull())
@ -903,20 +898,16 @@ void RsGxsChannelPostsModel::createPostsArray(std::vector<RsGxsChannelPost>& pos
for (std::vector<RsGxsChannelPost>::const_reverse_iterator it = posts.rbegin(); it != posts.rend(); ++it) for (std::vector<RsGxsChannelPost>::const_reverse_iterator it = posts.rbegin(); it != posts.rend(); ++it)
{ {
#ifdef DEBUG_CHANNEL_MODEL
std::cerr << " adding post: " << (*it).mMeta.mMsgId ;
#endif
if(!(*it).mMeta.mMsgId.isNull()) if(!(*it).mMeta.mMsgId.isNull())
{ {
#ifdef DEBUG_CHANNEL_MODEL #ifndef DEBUG_CHANNEL_MODEL
std::cerr << " added" << std::endl; std::cerr << " adding post \"" << (*it).mMeta.mMsgName << "\"" << std::endl;
#endif #endif
mPosts.push_back(*it); mPosts.push_back(*it);
} }
#ifdef DEBUG_CHANNEL_MODEL #ifdef DEBUG_CHANNEL_MODEL
else else
std::cerr << " skipped" << std::endl; std::cerr << " skipped older version post \"" << (*it).mMeta.mMsgName << "\"" << std::endl;
#endif #endif
} }
} }
@ -1025,7 +1016,7 @@ QModelIndex RsGxsChannelPostsModel::getIndexOfMessage(const RsGxsMessageId& mid)
quintptr ref ; quintptr ref ;
convertTabEntryToRefPointer(i,ref); // we dont use i+1 here because i is not a row, but an index in the mPosts tab convertTabEntryToRefPointer(i,ref); // we dont use i+1 here because i is not a row, but an index in the mPosts tab
return createIndex(i-1,0,ref); return createIndex((i-1)%mColumns, (i-1)/mColumns,ref);
} }
if(mPosts[i].mMeta.mMsgId == postId) if(mPosts[i].mMeta.mMsgId == postId)
@ -1033,7 +1024,7 @@ QModelIndex RsGxsChannelPostsModel::getIndexOfMessage(const RsGxsMessageId& mid)
quintptr ref ; quintptr ref ;
convertTabEntryToRefPointer(i,ref); // we dont use i+1 here because i is not a row, but an index in the mPosts tab convertTabEntryToRefPointer(i,ref); // we dont use i+1 here because i is not a row, but an index in the mPosts tab
return createIndex(i-1,0,ref); return createIndex((i-1)%mColumns, (i-1)/mColumns,ref);
} }
} }

View File

@ -488,6 +488,9 @@ void GxsChannelPostsWidgetWithModel::showPostDetails()
mChannelPostFilesModel->clear(); mChannelPostFilesModel->clear();
return; return;
} }
if(index.row()==0 && index.column()==0)
std::cerr << "here" << std::endl;
RsGxsChannelPost post = index.data(Qt::UserRole).value<RsGxsChannelPost>() ; RsGxsChannelPost post = index.data(Qt::UserRole).value<RsGxsChannelPost>() ;
mChannelPostFilesModel->setFiles(post.mFiles); mChannelPostFilesModel->setFiles(post.mFiles);