mirror of
https://github.com/RetroShare/RetroShare.git
synced 2024-12-28 17:09:34 -05:00
removed infinite loop when openning a rscollection file
git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@8135 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
parent
68d25b324a
commit
20deecd6d3
@ -500,40 +500,45 @@ bool RsCollectionDialog::addChild(QTreeWidgetItem* parent, const std::vector<Col
|
||||
*/
|
||||
void RsCollectionDialog::directoryLoaded(QString dirLoaded)
|
||||
{
|
||||
if(!_dirLoaded)
|
||||
{
|
||||
if(!_dirLoaded)
|
||||
{
|
||||
|
||||
QFileInfo lastDir = Settings->getLastDir(RshareSettings::LASTDIR_EXTRAFILE);
|
||||
if (lastDir.absoluteFilePath() == "") return;
|
||||
if (lastDir.absoluteFilePath() == dirLoaded) _dirLoaded = true;
|
||||
QFileInfo lastDir = Settings->getLastDir(RshareSettings::LASTDIR_EXTRAFILE);
|
||||
if (lastDir.absoluteFilePath() == "") return;
|
||||
if (lastDir.absoluteFilePath() == dirLoaded) _dirLoaded = true;
|
||||
|
||||
// Check all parent directory to see if it is loaded
|
||||
//as QFileSystemModel don't load all
|
||||
do {
|
||||
if(lastDir.absolutePath()==dirLoaded) {
|
||||
//Only expand loaded directory
|
||||
QModelIndex lastDirIdx = _dirModel->index(lastDir.absoluteFilePath());
|
||||
//Select LASTDIR_EXTRAFILE or last parent found when loaded
|
||||
if (!lastDirIdx.isValid()){
|
||||
_dirLoaded = true;
|
||||
break;
|
||||
}
|
||||
// Check all parent directory to see if it is loaded
|
||||
//as QFileSystemModel don't load all
|
||||
do {
|
||||
if(lastDir.absolutePath()==dirLoaded) {
|
||||
//Only expand loaded directory
|
||||
QModelIndex lastDirIdx = _dirModel->index(lastDir.absoluteFilePath());
|
||||
//Select LASTDIR_EXTRAFILE or last parent found when loaded
|
||||
if (!lastDirIdx.isValid()){
|
||||
_dirLoaded = true;
|
||||
break;
|
||||
}
|
||||
|
||||
//Ask dirModel to load next parent directory
|
||||
while (_dirModel->canFetchMore(lastDirIdx)) _dirModel->fetchMore(lastDirIdx);
|
||||
//Ask dirModel to load next parent directory
|
||||
while (_dirModel->canFetchMore(lastDirIdx)) _dirModel->fetchMore(lastDirIdx);
|
||||
|
||||
//Ask to Expand last loaded parent
|
||||
lastDirIdx = _tree_proxyModel->mapFromSource(lastDirIdx);
|
||||
if (lastDirIdx.isValid()){
|
||||
ui._systemFileTW->expand(lastDirIdx);
|
||||
ui._systemFileTW->setCurrentIndex(lastDirIdx);
|
||||
}
|
||||
break;
|
||||
}
|
||||
if (lastDir.absoluteFilePath() == lastDir.absolutePath()) break;
|
||||
lastDir = lastDir.absolutePath();
|
||||
} while (true); //(lastDir.absoluteFilePath() != lastDir.absolutePath());
|
||||
}
|
||||
//Ask to Expand last loaded parent
|
||||
lastDirIdx = _tree_proxyModel->mapFromSource(lastDirIdx);
|
||||
if (lastDirIdx.isValid()){
|
||||
ui._systemFileTW->expand(lastDirIdx);
|
||||
ui._systemFileTW->setCurrentIndex(lastDirIdx);
|
||||
}
|
||||
break;
|
||||
}
|
||||
//std::cerr << "lastDir = " << lastDir.absoluteFilePath().toStdString() << std::endl;
|
||||
|
||||
QDir c = lastDir.dir() ;
|
||||
if(!c.cdUp())
|
||||
break ;
|
||||
|
||||
lastDir = QFileInfo(c.path());
|
||||
} while (true); //(lastDir.absoluteFilePath() != lastDir.absolutePath());
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user