27#include <cpl_string.h>
48 const QString &filePath,
const QString &path,
49 const QString &providerKey )
51 , mFilePath( filePath )
56void QgsZipItem::init()
59 mIconName = QStringLiteral(
"/mIconZip.svg" );
64 static std::once_flag initialized;
65 std::call_once( initialized, [ = ]
79 u.
layerType = QStringLiteral(
"collection" );
90 const QString scanZipSetting = settings.
value( QStringLiteral(
"qgis/scanZipInBrowser2" ),
"basic" ).toString();
97 if ( scanZipSetting == QLatin1String(
"no" ) )
109 for (
const QString &fileName : constMZipFileList )
111 const QFileInfo info( fileName );
121 if ( provider->name() == QLatin1String(
"OGR" ) )
123 if ( info.suffix().compare( QLatin1String(
"dbf" ), Qt::CaseInsensitive ) == 0 )
125 if (
mZipFileList.indexOf( fileName.left( fileName.count() - 4 ) +
".shp" ) != -1 )
128 if ( info.completeSuffix().compare( QLatin1String(
"shp.xml" ), Qt::CaseInsensitive ) == 0 )
134 QgsDebugMsgLevel( QStringLiteral(
"trying to load item %1 with %2" ).arg( tmpPath, provider->name() ), 3 );
135 QgsDataItem *item = provider->createDataItem( tmpPath,
this );
160 const QString scanZipSetting = settings.
value( QStringLiteral(
"qgis/scanZipInBrowser2" ),
"basic" ).toString();
161 QStringList zipFileList;
164 bool populated =
false;
169 if ( scanZipSetting == QLatin1String(
"no" ) )
173 if ( (
vsiPrefix != QLatin1String(
"/vsizip/" ) &&
vsiPrefix != QLatin1String(
"/vsitar/" ) ) )
186 if (
path.endsWith( QLatin1String(
".zip" ), Qt::CaseInsensitive ) ||
187 path.endsWith( QLatin1String(
".tar" ), Qt::CaseInsensitive ) )
192 if ( !zipFileList.isEmpty() && zipFileList.count() <= 10 )
196 QgsDebugMsgLevel( QStringLiteral(
"Got zipItem with %1 children, path=%2, name=%3" ).arg( zipItem->
rowCount() ).arg( zipItem->
path(), zipItem->
name() ), 3 );
200 QgsDebugMsgLevel( QStringLiteral(
"Delaying populating zipItem with path=%1, name=%2" ).arg( zipItem->
path(), zipItem->
name() ), 3 );
205 if ( zipItem && ( !populated || zipItem->
rowCount() > 0 ) )
221 const QString scanZipSetting = settings.
value( QStringLiteral(
"qgis/scanZipInBrowser2" ),
"basic" ).toString();
226 if ( scanZipSetting == QLatin1String(
"no" ) )
233 char **papszSiblingFiles = VSIReadDirRecursive( QString(
mVsiPrefix +
mFilePath ).toUtf8().constData() );
234 if ( papszSiblingFiles )
236 for (
int i = 0; papszSiblingFiles[i]; i++ )
238 tmpPath = papszSiblingFiles[i];
241 if ( tmpPath.right( 1 ) != QLatin1String(
"/" ) )
244 CSLDestroy( papszSiblingFiles );
@ ItemRepresentsFile
Item's path() directly represents a file on disk (since QGIS 3.22)
@ Collection
A collection of items.
static QgsDataItemProviderRegistry * dataItemProviderRegistry()
Returns the application's data item provider registry, which keeps a list of data item providers that...
static QIcon getThemeIcon(const QString &name, const QColor &fillColor=QColor(), const QColor &strokeColor=QColor())
Helper to get a theme icon.
A Collection: logical collection of layers or subcollections, e.g.
QList< QgsDataItemProvider * > providers() const
Returns the list of available providers.
This is the interface for those who want to add custom data items to the browser tree.
Base class for all items in the model.
Qgis::BrowserItemType mType
QVector< QgsDataItem * > children() const
QString name() const
Returns the name of the item (the displayed text for the item).
virtual void setCapabilities(Qgis::BrowserItemCapabilities capabilities)
Sets the capabilities for the data item.
void setName(const QString &name)
Sets the name of the item (the displayed text for the item).
QgsDataItem * parent() const
Gets item parent.
virtual Qgis::BrowserItemCapabilities capabilities2() const
Returns the capabilities for the data item.
virtual void populate(const QVector< QgsDataItem * > &children)
QList< QgsMimeDataUtils::Uri > UriList
This class is a composition of two QSettings instances:
QVariant value(const QString &key, const QVariant &defaultValue=QVariant(), Section section=NoSection) const
Returns the value for setting key.
A zip file: contains layers, using GDAL/OGR VSIFILE mechanism.
QgsZipItem(QgsDataItem *parent, const QString &name, const QString &path)
Constructor.
QStringList getZipFileList()
bool hasDragEnabled() const override
Returns true if the item may be dragged.
QgsMimeDataUtils::UriList mimeUris() const override
Returns mime URIs for the data item, most data providers will only return a single URI but some data ...
static QgsDataItem * itemFromPath(QgsDataItem *parent, const QString &path, const QString &name)
Creates a new data item from the specified path.
static QString vsiPrefix(const QString &uri)
QVector< QgsDataItem * > createChildren() override
Create children.
static QStringList sProviderNames
#define QgsDebugMsgLevel(str, level)
QString filePath
Path to file, if uri is associated with a file.
QString uri
Identifier of the data source recognized by its providerKey.
QString layerType
Type of URI.