Skip to content

Commit

Permalink
Cleanup some browser favorite code
Browse files Browse the repository at this point in the history
  • Loading branch information
nyalldawson committed May 17, 2021
1 parent 1fea062 commit ff2b8dc
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 25 deletions.
43 changes: 19 additions & 24 deletions src/core/qgsdataitem.cpp
Expand Up @@ -1547,13 +1547,14 @@ QVector<QgsDataItem *> QgsFavoritesItem::createChildren()

const QStringList favDirs = settings.value( QStringLiteral( "browser/favourites" ), QVariant() ).toStringList();

children.reserve( favDirs.size() );
for ( const QString &favDir : favDirs )
{
QStringList parts = favDir.split( QStringLiteral( "|||" ) );
const QStringList parts = favDir.split( QStringLiteral( "|||" ) );
if ( parts.empty() )
continue;

QString dir = parts.at( 0 );
const QString dir = parts.at( 0 );
QString name = dir;
if ( parts.count() > 1 )
name = parts.at( 1 );
Expand All @@ -1566,7 +1567,7 @@ QVector<QgsDataItem *> QgsFavoritesItem::createChildren()

void QgsFavoritesItem::addDirectory( const QString &favDir, const QString &n )
{
QString name = n.isEmpty() ? favDir : n;
const QString name = n.isEmpty() ? favDir : n;

QgsSettings settings;
QStringList favDirs = settings.value( QStringLiteral( "browser/favourites" ) ).toStringList();
Expand All @@ -1575,9 +1576,8 @@ void QgsFavoritesItem::addDirectory( const QString &favDir, const QString &n )

if ( state() == Populated )
{
QVector<QgsDataItem *> items = createChildren( favDir, name );
const auto constItems = items;
for ( QgsDataItem *item : constItems )
const QVector<QgsDataItem *> items = createChildren( favDir, name );
for ( QgsDataItem *item : items )
{
addChildItem( item, true );
}
Expand All @@ -1593,11 +1593,11 @@ void QgsFavoritesItem::removeDirectory( QgsDirectoryItem *item )
QStringList favDirs = settings.value( QStringLiteral( "browser/favourites" ) ).toStringList();
for ( int i = favDirs.count() - 1; i >= 0; --i )
{
QStringList parts = favDirs.at( i ).split( QStringLiteral( "|||" ) );
const QStringList parts = favDirs.at( i ).split( QStringLiteral( "|||" ) );
if ( parts.empty() )
continue;

QString dir = parts.at( 0 );
const QString dir = parts.at( 0 );
if ( dir == item->dirPath() )
favDirs.removeAt( i );
}
Expand All @@ -1621,11 +1621,11 @@ void QgsFavoritesItem::renameFavorite( const QString &path, const QString &name
QStringList favDirs = settings.value( QStringLiteral( "browser/favourites" ) ).toStringList();
for ( int i = 0; i < favDirs.count(); ++i )
{
QStringList parts = favDirs.at( i ).split( QStringLiteral( "|||" ) );
const QStringList parts = favDirs.at( i ).split( QStringLiteral( "|||" ) );
if ( parts.empty() )
continue;

QString dir = parts.at( 0 );
const QString dir = parts.at( 0 );
if ( dir == path )
{
favDirs[i] = QStringLiteral( "%1|||%2" ).arg( path, name );
Expand All @@ -1649,19 +1649,18 @@ void QgsFavoritesItem::renameFavorite( const QString &path, const QString &name
}
}

QVector<QgsDataItem *> QgsFavoritesItem::createChildren( const QString &favDir, const QString &name )
QVector<QgsDataItem *> QgsFavoritesItem::createChildren( const QString &directory, const QString &name )
{
const QString pathName = pathComponent( directory );
const QList<QgsDataItemProvider *> providers = QgsApplication::dataItemProviderRegistry()->providers();

QVector<QgsDataItem *> children;
QString pathName = pathComponent( favDir );
const auto constProviders = QgsApplication::dataItemProviderRegistry()->providers();
for ( QgsDataItemProvider *provider : constProviders )
children.reserve( providers.size() );
for ( QgsDataItemProvider *provider : providers )
{
int capabilities = provider->capabilities();

if ( capabilities & QgsDataProvider::Dir )
if ( provider->capabilities() & QgsDataProvider::Dir )
{
QgsDataItem *item = provider->createDataItem( favDir, this );
if ( item )
if ( QgsDataItem *item = provider->createDataItem( directory, this ) )
{
item->setName( name );
children.append( item );
Expand All @@ -1670,11 +1669,7 @@ QVector<QgsDataItem *> QgsFavoritesItem::createChildren( const QString &favDir,
}
if ( children.isEmpty() )
{
QgsFavoriteItem *item = new QgsFavoriteItem( this, name, favDir, mPath + '/' + pathName );
if ( item )
{
children.append( item );
}
children.append( new QgsFavoriteItem( this, name, directory, mPath + '/' + pathName ) );
}
return children;
}
Expand Down
16 changes: 15 additions & 1 deletion src/core/qgsdataitem.h
Expand Up @@ -977,7 +977,7 @@ class CORE_EXPORT QgsFavoritesItem : public QgsDataCollectionItem
QVariant sortKey() const override;

private:
QVector<QgsDataItem *> createChildren( const QString &favDir, const QString &name );
QVector<QgsDataItem *> createChildren( const QString &directory, const QString &name );
};

/**
Expand Down Expand Up @@ -1166,8 +1166,22 @@ class CORE_EXPORT QgsFavoriteItem : public QgsDirectoryItem

public:

/**
* Constructor for QgsFavoriteItem.
*
* \param parent parent favorites item
* \param name visible name for item
* \param dirPath corresponding directory (folder) path
* \param path unique data item path
*/
QgsFavoriteItem( QgsFavoritesItem *parent, const QString &name, const QString &dirPath, const QString &path );

// TODO QGIS 4.0 - don't remove this method when the deprecated base class virtual method is removed, but instead
// remove the override!

/**
* Sets a new \a name for the favorite.
*/
bool rename( const QString &name ) override;

private:
Expand Down

0 comments on commit ff2b8dc

Please sign in to comment.