File indexing completed on 2024-09-15 04:28:32

0001 // SPDX-FileCopyrightText: 2015 Klaralvdalens Datakonsult AB
0002 // SPDX-FileCopyrightText: 2016 The Qt Company Ltd.
0003 // SPDX-FileCopyrightText: 2021 Noah Davis <noahadvs@gmail.com>
0004 // SPDX-License-Identifier: LicenseRef-KDE-Accepted-LGPL
0005 
0006 #pragma once
0007 
0008 #include <QFileInfo>
0009 #include <QMimeDatabase>
0010 #include <QObject>
0011 #include <QQmlEngine>
0012 #include <qqml.h>
0013 
0014 class FileTypePrivate;
0015 
0016 /**
0017  * @class FileTypeSingleton
0018  *
0019  * Provide a singleton to expose the functionality of QMimeDatabase.
0020  *
0021  * @sa QMimeDatabase
0022  */
0023 class FileType : public QObject
0024 {
0025     Q_OBJECT
0026     QML_ELEMENT
0027     QML_SINGLETON
0028 
0029     /**
0030      * @brief List of supported image formats.
0031      *
0032      * Returns a list of file extensions, not MIME types.
0033      */
0034     Q_PROPERTY(QStringList supportedImageFormats READ supportedImageFormats CONSTANT FINAL)
0035 
0036     /**
0037      * @brief List of supported animated image formats.
0038      *
0039      * Returns a list of file extensions, not MIME types.
0040      */
0041     Q_PROPERTY(QStringList supportedAnimatedImageFormats READ supportedAnimatedImageFormats CONSTANT FINAL)
0042 
0043 public:
0044     explicit FileType(QObject *parent = nullptr);
0045     ~FileType();
0046 
0047     /**
0048      * @brief Returns a MIME type for nameOrAlias or an invalid one if none found.
0049      *
0050      * @sa QMimeDatabase
0051      */
0052     Q_INVOKABLE QMimeType mimeTypeForName(const QString &nameOrAlias) const;
0053 
0054     enum MatchMode { MatchDefault, MatchExtension, MatchContent };
0055     Q_ENUM(MatchMode)
0056 
0057     /**
0058      * @brief Returns a MIME type for the file named fileName using mode.
0059      *
0060      * @sa QMimeDatabase
0061      */
0062     Q_INVOKABLE QMimeType mimeTypeForFile(const QString &fileName, FileType::MatchMode mode = MatchDefault) const;
0063 
0064     /**
0065      * @brief Returns a MIME type for fileInfo.
0066      *
0067      * @sa QMimeDatabase
0068      */
0069     Q_INVOKABLE QMimeType mimeTypeForFile(const QFileInfo &fileInfo, FileType::MatchMode mode = MatchDefault) const;
0070 
0071     /**
0072      * @brief Returns the MIME types for the file name fileName.
0073      *
0074      * @sa QMimeDatabase
0075      */
0076     Q_INVOKABLE QList<QMimeType> mimeTypesForFileName(const QString &fileName) const;
0077 
0078     /**
0079      * @brief Returns a MIME type for data.
0080      *
0081      * @sa QMimeDatabase
0082      */
0083     Q_INVOKABLE QMimeType mimeTypeForData(const QByteArray &data) const;
0084 
0085     /**
0086      * @brief Returns a MIME type for the data in device.
0087      *
0088      * @sa QMimeDatabase
0089      */
0090     Q_INVOKABLE QMimeType mimeTypeForData(QIODevice *device) const;
0091 
0092     /**
0093      * @brief Returns a MIME type for url.
0094      *
0095      * @sa QMimeDatabase
0096      */
0097     Q_INVOKABLE QMimeType mimeTypeForUrl(const QUrl &url) const;
0098 
0099     /**
0100      * @brief Returns a MIME type for the given fileName and device data.
0101      *
0102      * @sa QMimeDatabase
0103      */
0104     Q_INVOKABLE QMimeType mimeTypeForFileNameAndData(const QString &fileName, QIODevice *device) const;
0105 
0106     /**
0107      * @brief Returns a MIME type for the given fileName and device data.
0108      *
0109      * @sa QMimeDatabase
0110      */
0111     Q_INVOKABLE QMimeType mimeTypeForFileNameAndData(const QString &fileName, const QByteArray &data) const;
0112 
0113     /**
0114      * @brief Returns the suffix for the file fileName, as known by the MIME database.
0115      *
0116      * @sa QMimeDatabase
0117      */
0118     Q_INVOKABLE QString suffixForFileName(const QString &fileName) const;
0119 
0120     QStringList supportedImageFormats() const;
0121     QStringList supportedAnimatedImageFormats() const;
0122 
0123 private:
0124     const QScopedPointer<FileTypePrivate> d_ptr;
0125     Q_DECLARE_PRIVATE(FileType)
0126     Q_DISABLE_COPY(FileType)
0127 };