/****************************************************************************** * Copyright 2007-2011 by Aaron Seigo * * * * 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. * * @param packagePath full path to the package directory * @param 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. * * @param fileType the type of file to look for, as defined in the * package structure * @param 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. * * @param 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. * * @param 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; /** * Sets the path to the root of this package * @param 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; private: PackagePrivate * const d; friend class Applet; friend class AppletPrivate; }; } // Namespace Q_DECLARE_METATYPE(Plasma::Package) #endif