File indexing completed on 2024-10-06 06:42:20
0001 /* 0002 SPDX-FileCopyrightText: 2011 Aaron Seigo <aseigo@kde.org> 0003 SPDX-FileCopyrightText: 2023 Alexander Lohnau <alexander.lohnau@gmx.de> 0004 0005 SPDX-License-Identifier: LGPL-2.0-or-later 0006 */ 0007 0008 #ifndef KPACKAGE_PACKAGESTRUCTURE_H 0009 #define KPACKAGE_PACKAGESTRUCTURE_H 0010 0011 #include <QStringList> 0012 0013 #include <KPluginFactory> 0014 0015 #include <kpackage/package.h> 0016 #include <kpackage/package_export.h> 0017 0018 namespace KPackage 0019 { 0020 /** 0021 * @class PackageStructure kpackage/packagestructure.h <KPackage/PackageStructure> 0022 * 0023 * This class is used to define the filesystem structure of a package type. 0024 * A PackageStructure is implemented as a dynamically loaded plugin, in the reimplementation 0025 * of initPackage the allowed fines and directories in the package are set into the package, 0026 * for instance: 0027 * 0028 * @code 0029 * package->addFileDefinition("mainscript", QStringLiteral("ui/main.qml")); 0030 * package->setDefaultPackageRoot(QStringLiteral("plasma/wallpapers/")); 0031 * package->addDirectoryDefinition("images", QStringLiteral("images")); 0032 * package->addDirectoryDefinition("theme", QStringLiteral("theme")); 0033 * QStringList mimetypes{QStringLiteral("image/svg+xml"), QStringLiteral("image/png"), QStringLiteral("image/jpeg")}; 0034 * package->setMimeTypes("images", mimetypes); 0035 * @endcode 0036 */ 0037 class KPACKAGE_EXPORT PackageStructure : public QObject 0038 { 0039 Q_OBJECT 0040 0041 public: 0042 explicit PackageStructure(QObject *parent = nullptr, const QVariantList &args = QVariantList()); 0043 0044 ~PackageStructure() override; 0045 0046 /** 0047 * Called when a the PackageStructure should initialize a Package with the initial 0048 * structure. This allows setting paths before setPath is called. 0049 * 0050 * Note: one special value is "metadata" which can be set to the location of KPluginMetaData 0051 * compatible .json file within the package. If not defined, it is assumed that this file 0052 * exists under the top level directory of the package. 0053 * 0054 * @param package the Package to set up. The object is empty of all definition when 0055 * first passed in. 0056 */ 0057 virtual void initPackage(Package *package); 0058 0059 /** 0060 * Called whenever the path changes so that subclasses may take 0061 * package specific actions. 0062 */ 0063 virtual void pathChanged(Package *package); 0064 0065 private: 0066 void *d; 0067 }; 0068 0069 } // KPackage namespace 0070 0071 #endif