/****************************************************************************** * Copyright 2007 by Aaron Seigo * * Copyright 2007 by Riccardo Iaconelli * * * * This library is free software; you can redistribute it and/or * * modify it under the terms of the GNU Library General Public * * License as published by the Free Software Foundation; either * * version 2 of the License, or (at your option) any later version. * * * * This library is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * * Library General Public License for more details. * * * * You should have received a copy of the GNU Library General Public License * * along with this library; see the file COPYING.LIB. If not, write to * * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * * Boston, MA 02110-1301, USA. * *******************************************************************************/ #ifndef PLASMA_PACKAGE_H #define PLASMA_PACKAGE_H #include #include #include #include namespace Plasma { /** * @class Package plasma/package.h * * @short object representing an installed Plasmagik package **/ class PackageMetadata; class PackagePrivate; class PLASMA_EXPORT Package { public: /** * Default constructor that creates an invalid Package * @since 4.6 */ explicit Package(); /** * Construct a Package object * * @arg packageRoot path to the package installation root * @arg package the name of the package * @arg structure the package structure describing this package **/ Package(const QString &packageRoot, const QString &package, PackageStructure::Ptr structure); /** * Construct a Package object. * * @arg packagePath full path to the package directory * @arg structure the package structure describing this package */ Package(const QString &packagePath, PackageStructure::Ptr structure); /** * Copy constructore * @since 4.6 */ Package(const Package &other); ~Package(); /** * Assignment operator * @since 4.6 */ Package &operator=(const Package &rhs); /** * @return true if all the required components as defined in * the PackageStructure exist **/ bool isValid() const; /** * Get the path to a given file. * * @arg fileType the type of file to look for, as defined in the * package structure * @arg filename the name of the file * @return path to the file on disk. QString() if not found. **/ QString filePath(const char *fileType, const QString &filename) const; /** * Get the path to a given file. * * @arg fileType the type of file to look for, as defined in the * package structure. The type must refer to a file * in the package structure and not a directory. * @return path to the file on disk. QString() if not found **/ QString filePath(const char *fileType) const; /** * Get the list of files of a given type. * * @arg fileType the type of file to look for, as defined in the * package structure. * @return list of files by name, suitable for passing to filePath **/ QStringList entryList(const char *fileType) const; /** * @return the package metadata object. */ PackageMetadata metadata() const; /** * Sets the path to the root of this package * @arg path and absolute path * @since 4.3 */ void setPath(const QString &path); /** * Publish this package on the network. * @param methods the ways to announce this package on the network. */ void publish(AnnouncementMethods methods, const QString &name); /** * Remove this package from the network. */ void unpublish(const QString &name = QString()); /** * @returns whether or not this service is currently published on the network. */ bool isPublished() const; /** * @return the path to the root of this particular package */ const QString path() const; /** * @return the PackageStructure use in this Package */ const PackageStructure::Ptr structure() const; /** * @return a SHA1 hash digest of the contents of the package in hexadecimal form * @since 4.4 */ QString contentsHash() const; /** * Returns a list of all installed packages by name * * @param packageRoot path to the directory where Plasmagik packages * have been installed to * @return a list of installed Plasmagik packages **/ static QStringList listInstalled(const QString &packageRoot); /** * Returns a list of all paths of installed packages in the given root * * @param packageRoot path to the directory where Plasmagik packages * have been installed to * @return a list of installed Plasmagik packages by path **/ static QStringList listInstalledPaths(const QString &packageRoot); private: PackagePrivate * const d; friend class Applet; friend class AppletPrivate; }; } // Namespace Q_DECLARE_METATYPE(Plasma::Package) #endif