File indexing completed on 2024-09-08 12:14:58

0001 /*
0002  * This file is part of the KDE Libraries
0003  * Copyright (C) 2000 Espen Sand (espen@kde.org)
0004  * Copyright (C) 2008 Friedrich W. H. Kossebau <kossebau@kde.org>
0005  * Copyright (C) 2010 Teo Mrnjavac <teo@kde.org>
0006  *
0007  * This library is free software; you can redistribute it and/or
0008  * modify it under the terms of the GNU Library General Public
0009  * License as published by the Free Software Foundation; either
0010  * version 2 of the License, or (at your option) any later version.
0011  *
0012  * This library is distributed in the hope that it will be useful,
0013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
0014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
0015  * Library General Public License for more details.
0016  *
0017  * You should have received a copy of the GNU Library General Public License
0018  * along with this library; see the file COPYING.LIB.  If not, write to
0019  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
0020  * Boston, MA 02110-1301, USA.
0021  *
0022  */
0023 
0024 #ifndef K4ABOUTDATA_H
0025 #define K4ABOUTDATA_H
0026 
0027 #include <kdelibs4support_export.h>
0028 
0029 #ifdef KDELIBS4SUPPORT_NO_DEPRECATED_NOISE
0030 #warning "This file is deprecated."
0031 #endif
0032 
0033 #include <klocalizedstring.h>
0034 // Qt
0035 #include <QString>
0036 #include <QSharedDataPointer>
0037 
0038 template <class T> class QList;
0039 class QVariant;
0040 class KAboutData;
0041 class K4AboutData;
0042 
0043 /**
0044  * This class is used to store information about a person or developer.
0045  * It can store the person's name, a task, an email address and a
0046  * link to a home page. This class is intended for use in the
0047  * K4AboutData class, but it can be used elsewhere as well.
0048  * Normally you should at least define the person's name.
0049  * Creating a K4AboutPerson object by yourself is relatively useless,
0050  * but the K4AboutData methods K4AboutData::authors() and K4AboutData::credits()
0051  * return lists of K4AboutPerson data objects which you can examine.
0052  *
0053  * Example usage within a main(), retrieving the list of people involved
0054  * with a program and re-using data from one of them:
0055  *
0056  * @code
0057  * K4AboutData about("khello", "khello", ki18n("KHello"), "0.1",
0058  *                   ki18n("A KDE version of Hello, world!"),
0059  *                   K4AboutData::License_LGPL,
0060  *                   ki18n("Copyright (C) 2003 Developer"));
0061  *
0062  * about.addAuthor(ki18n("Joe Developer"), ki18n("developer"), "joe@host.com", 0);
0063  * QList<K4AboutPerson> people = about.authors();
0064  * about.addCredit(people[0].name(), people[0].task());
0065  * @endcode
0066  *
0067  * @note Instead of the more usual i18n calls, for translatable text the ki18n
0068  * calls are used to produce KLocalizedStrings, which can delay the translation
0069  * lookup. This is necessary because the translation catalogs are usually not
0070  * yet initialized at the point where K4AboutData is constructed.
0071  *
0072  * @bc KDE4
0073  *
0074  * @deprecated Instead, use KAboutData in KCoreAddons
0075  */
0076 class KDELIBS4SUPPORT_DEPRECATED_EXPORT_NOISE K4AboutPerson
0077 {
0078     friend class K4AboutData;
0079 public:
0080     /**
0081      * Convenience constructor
0082      *
0083      * @param name The name of the person.
0084      *
0085      * @param task The task of this person.
0086      *
0087      * @param emailAddress The email address of the person.
0088      *
0089      * @param webAddress Home page of the person.
0090      */
0091     KDELIBS4SUPPORT_DEPRECATED explicit K4AboutPerson(const KLocalizedString &name,
0092                            const KLocalizedString &task = KLocalizedString(),
0093                            const QByteArray &emailAddress = QByteArray(),
0094                            const QByteArray &webAddress = QByteArray());
0095 
0096     /**
0097      * Convenience constructor with Open Collaboration Services data
0098      *
0099      * @param name The name of the person.
0100      *
0101      * @param task The task of this person.
0102      *
0103      * @param emailAddress The email address of the person.
0104      *
0105      * @param webAddress Home page of the person.
0106      *
0107      * @param ocsUsername Open Collaboration Services username of the person.
0108      */
0109     KDELIBS4SUPPORT_DEPRECATED explicit K4AboutPerson(const KLocalizedString &name,
0110                            const KLocalizedString &task,
0111                            const QByteArray &emailAddress,
0112                            const QByteArray &webAddress,
0113                            const QByteArray &ocsUsername);  //KDE5: merge into main ctor
0114 
0115     /**
0116      * Copy constructor.  Performs a deep copy.
0117      * @param other object to copy
0118      */
0119     K4AboutPerson(const K4AboutPerson &other);
0120 
0121     ~K4AboutPerson();
0122 
0123     /**
0124      * Assignment operator.  Performs a deep copy.
0125      * @param other object to copy
0126      */
0127     K4AboutPerson &operator=(const K4AboutPerson &other);
0128 
0129     /**
0130      * The person's name
0131      * @return the person's name (can be QString(), if it has been
0132      *           constructed with an empty name)
0133      */
0134     QString name() const;
0135 
0136     /**
0137      * The person's task
0138      * @return the person's task (can be QString(), if it has been
0139      *           constructed with an empty task)
0140      */
0141     QString task() const;
0142 
0143     /**
0144      * The person's email address
0145      * @return the person's email address (can be QString(), if it has been
0146      *           constructed with an empty email)
0147      */
0148     QString emailAddress() const;
0149 
0150     /**
0151      * The home page or a relevant link
0152      * @return the persons home page (can be QString(), if it has been
0153      *           constructed with an empty home page)
0154      */
0155     QString webAddress() const;
0156 
0157     /**
0158      * The person's Open Collaboration Services username
0159      * @return the persons OCS username (can be QString(), if it has been
0160      *           constructed with an empty username)
0161      */
0162     QString ocsUsername() const;
0163 
0164 private:
0165     /**
0166      * @internal Used by K4AboutData to construct translator data.
0167      */
0168     KDELIBS4SUPPORT_DEPRECATED explicit K4AboutPerson(const QString &name, const QString &email);
0169 
0170     class Private;
0171     Private *const d;
0172 };
0173 
0174 class K4AboutLicense;
0175 
0176 // KDE5: refactor together with KComponentData.
0177 // Like changing all property names which contain Program or App.
0178 
0179 /**
0180  * This class is used to store information about a program. It can store
0181  * such values as version number, program name, home page, email address
0182  * for bug reporting, multiple authors and contributors
0183  * (using K4AboutPerson), license and copyright information.
0184  *
0185  * Currently, the values set here are shown by the "About" box
0186  * (see K4AboutDialog), used by the bug report dialog (see KBugReport),
0187  * and by the help shown on command line (see KCmdLineArgs).
0188  * They are also used for the icon and the name of the program's windows.
0189  *
0190  * @note Instead of the more usual i18n calls, for translatable text the ki18n
0191  * calls are used to produce KLocalizedStrings, which can delay the translation
0192  * lookup. This is necessary because the translation catalogs are usually not
0193  * yet initialized at the point where K4AboutData is constructed.
0194  *
0195  * @short Holds information needed by the "About" box and other
0196  * classes.
0197  * @author Espen Sand (espen@kde.org), David Faure (faure@kde.org)
0198  */
0199 class KDELIBS4SUPPORT_DEPRECATED_EXPORT_NOISE K4AboutData
0200 {
0201 public:
0202     /**
0203      * Describes the license of the software.
0204      */
0205     enum LicenseKey { // KDE5: move to K4AboutLicense, cut License_ prefix
0206         License_Custom = -2,
0207         License_File = -1,
0208         License_Unknown = 0,
0209         License_GPL  = 1,
0210         License_GPL_V2 = 1,
0211         License_LGPL = 2,
0212         License_LGPL_V2 = 2,
0213         License_BSD  = 3,
0214         License_Artistic = 4,
0215         License_QPL = 5,
0216         License_QPL_V1_0 = 5,
0217         License_GPL_V3 = 6,
0218         License_LGPL_V3 = 7
0219     };
0220 
0221     /**
0222      * Format of the license name.
0223      */
0224     enum NameFormat { // KDE5: move to K4AboutLicense
0225         ShortName,
0226         FullName
0227     };
0228 
0229 public:
0230     /**
0231      * Constructor.
0232      *
0233      * @param appName The program name used internally. Example: "kedit"
0234      *
0235      * @param catalogName The translation catalog name; if null or empty, the
0236      *        @p appName will be used. You may want the catalog name to
0237      *        differ from program name, for example, when you want to group
0238      *        translations of several smaller utilities under the same catalog.
0239      *
0240      * @param programName A displayable program name string. This string
0241      *        should be marked for translation. Example: ki18n("KEdit")
0242      *
0243      * @param version The program version string.
0244      *
0245      * @param shortDescription A short description of what the program does.
0246      *        This string should be marked for translation.
0247      *        Example: ki18n("A simple text editor.")
0248      *
0249      * @param licenseType The license identifier. Use setLicenseText or
0250               setLicenseTextFile if you use a license not predefined here.
0251      *
0252      * @param copyrightStatement A copyright statement, that can look like this:
0253      *        ki18n("Copyright (C) 1999-2000 Name"). The string specified here is
0254      *        taken verbatim; the author information from addAuthor is not used.
0255      *
0256      * @param otherText Some free form text, that can contain any kind of
0257      *        information. The text can contain newlines. This string
0258      *        should be marked for translation.
0259      *
0260      * @param homePageAddress The program homepage string.
0261      *        Start the address with "http://". "http://some.domain" is
0262      *        is correct, "some.domain" is not.
0263      * IMPORTANT: if you set a home page address, this will change the "organization domain"
0264      * of the application, which is used for automatic D-Bus registration.
0265      * @see setOrganizationDomain
0266      *
0267      * @param bugsEmailAddress The bug report email address string.
0268      *        This defaults to the kde.org bug system.
0269      *
0270      */
0271     K4AboutData(const QByteArray &appName,
0272                 const QByteArray &catalogName,
0273                 const KLocalizedString &programName,
0274                 const QByteArray &version,
0275                 const KLocalizedString &shortDescription = KLocalizedString(),
0276                 enum LicenseKey licenseType = License_Unknown,
0277                 const KLocalizedString &copyrightStatement = KLocalizedString(),
0278                 const KLocalizedString &otherText = KLocalizedString(),
0279                 const QByteArray &homePageAddress = QByteArray(),
0280                 const QByteArray &bugsEmailAddress = "submit@bugs.kde.org"
0281                );
0282 
0283     /**
0284      * Copy constructor.  Performs a deep copy.
0285      * @param other object to copy
0286      */
0287     K4AboutData(const K4AboutData &other);
0288 
0289     /**
0290      * Assignment operator.  Performs a deep copy.
0291      * @param other object to copy
0292      */
0293     K4AboutData &operator=(const K4AboutData &other);
0294 
0295     ~K4AboutData();
0296 
0297     operator KAboutData() const;
0298 
0299     /**
0300      * Defines an author.
0301      *
0302      * You can call this function as many times as you need. Each entry is
0303      * appended to a list. The person in the first entry is assumed to be
0304      * the leader of the project.
0305      *
0306      * @param name The developer's name. It should be marked for translation
0307      *             like this: ki18n("Developer Name")
0308      *
0309      * @param task What the person is responsible for. This text can contain
0310      *             newlines. It should be marked for translation like this:
0311      *             ki18n("Task description..."). Can be left empty.
0312      *
0313      * @param emailAddress An Email address where the person can be reached.
0314      *                     Can be left empty.
0315      *
0316      * @param webAddress The person's homepage or a relevant link.
0317      *        Start the address with "http://". "http://some.domain" is
0318      *        correct, "some.domain" is not. Can be left empty.
0319      *
0320      */
0321     K4AboutData &addAuthor(const KLocalizedString &name,
0322                            const KLocalizedString &task = KLocalizedString(),
0323                            const QByteArray &emailAddress = QByteArray(),
0324                            const QByteArray &webAddress = QByteArray());
0325 
0326     /**
0327      * Defines an author.
0328      *
0329      * You can call this function as many times as you need. Each entry is
0330      * appended to a list. The person in the first entry is assumed to be
0331      * the leader of the project.
0332      *
0333      * @param name The developer's name. It should be marked for translation
0334      *             like this: ki18n("Developer Name")
0335      *
0336      * @param task What the person is responsible for. This text can contain
0337      *             newlines. It should be marked for translation like this:
0338      *             ki18n("Task description..."). Can be left empty.
0339      *
0340      * @param emailAddress An Email address where the person can be reached.
0341      *                     Can be left empty.
0342      *
0343      * @param webAddress The person's homepage or a relevant link.
0344      *        Start the address with "http://". "http://some.domain" is
0345      *        correct, "some.domain" is not. Can be left empty.
0346      *
0347      * @param ocsUsername The person's Open Collaboration Services username.
0348      *        The provider can be optionally specified with @see setOcsProvider.
0349      *
0350      */
0351     K4AboutData &addAuthor(const KLocalizedString &name,
0352                            const KLocalizedString &task,
0353                            const QByteArray &emailAddress,
0354                            const QByteArray &webAddress,
0355                            const QByteArray &ocsUsername);  //KDE5: merge with addAuthor
0356 
0357     /**
0358      * Defines a person that deserves credit.
0359      *
0360      * You can call this function as many times as you need. Each entry
0361      * is appended to a list.
0362      *
0363      * @param name The person's name. It should be marked for translation
0364      *             like this: ki18n("Contributor Name")
0365      *
0366      * @param task What the person has done to deserve the honor. The
0367      *        text can contain newlines. It should be marked for
0368      *        translation like this: ki18n("Task description...")
0369      *        Can be left empty.
0370      *
0371      * @param emailAddress An email address when the person can be reached.
0372      *        Can be left empty.
0373      *
0374      * @param webAddress The person's homepage or a relevant link.
0375      *        Start the address with "http://". "http://some.domain" is
0376      *        is correct, "some.domain" is not. Can be left empty.
0377      *
0378      */
0379     K4AboutData &addCredit(const KLocalizedString &name,
0380                            const KLocalizedString &task = KLocalizedString(),
0381                            const QByteArray &emailAddress = QByteArray(),
0382                            const QByteArray &webAddress = QByteArray());
0383 
0384     /**
0385      * Defines a person that deserves credit.
0386      *
0387      * You can call this function as many times as you need. Each entry
0388      * is appended to a list.
0389      *
0390      * @param name The person's name. It should be marked for translation
0391      *             like this: ki18n("Contributor Name")
0392      *
0393      * @param task What the person has done to deserve the honor. The
0394      *        text can contain newlines. It should be marked for
0395      *        translation like this: ki18n("Task description...")
0396      *        Can be left empty.
0397      *
0398      * @param emailAddress An email address when the person can be reached.
0399      *        Can be left empty.
0400      *
0401      * @param webAddress The person's homepage or a relevant link.
0402      *        Start the address with "http://". "http://some.domain" is
0403      *        is correct, "some.domain" is not. Can be left empty.
0404      *
0405      * @param ocsUsername The person's Open Collaboration Services username.
0406      *        The provider can be optionally specified with @see setOcsProvider.
0407      *
0408      */
0409     K4AboutData &addCredit(const KLocalizedString &name,
0410                            const KLocalizedString &task,
0411                            const QByteArray &emailAddress,
0412                            const QByteArray &webAddress,
0413                            const QByteArray &ocsUsername);  //KDE5: merge with addCredit
0414 
0415     /**
0416      * @brief Sets the name(s) of the translator(s) of the GUI.
0417      *
0418      * Since this depends on the language, just use a dummy text marked for
0419      * translation.
0420      *
0421      * The canonical use is:
0422      *
0423      * \code
0424      * setTranslator(ki18nc("NAME OF TRANSLATORS", "Your names"),
0425      *               ki18nc("EMAIL OF TRANSLATORS", "Your emails"));
0426      * \endcode
0427      *
0428      * The translator can then translate this dummy text with his name
0429      * or with a list of names separated with ",".
0430      * If there is no translation or the application is used with the
0431      * default language, this function call is ignored.
0432      *
0433      * @param name the name(s) of the translator(s)
0434      * @param emailAddress the email address(es) of the translator(s)
0435      * @see K4AboutTranslator
0436      */
0437     K4AboutData &setTranslator(const KLocalizedString &name,
0438                                const KLocalizedString &emailAddress);
0439 
0440     /**
0441      * Defines a license text, which is marked for translation.
0442      *
0443      * Example:
0444      * \code
0445      * setLicenseText( ki18n("This is my license") );
0446      * \endcode
0447      *
0448      * @param license The license text.
0449      */
0450     K4AboutData &setLicenseText(const KLocalizedString &license);
0451 
0452     /**
0453      * Adds a license text, which is marked for translation.
0454      *
0455      * If there is only one unknown license set, e.g. by using the default
0456      * parameter in the constructor, that one is replaced.
0457      *
0458      * Example:
0459      * \code
0460      * addLicenseText( ki18n("This is my license") );
0461      * \endcode
0462      *
0463      * @param license The license text.
0464      * @see setLicenseText, addLicense, addLicenseTextFile
0465      * @since 4.1
0466      */
0467     K4AboutData &addLicenseText(const KLocalizedString &license);
0468 
0469     /**
0470      * Defines a license text by pointing to a file where it resides.
0471      * The file format has to be plain text in an encoding compatible to the locale.
0472      *
0473      * @param file Path to the file in the local filesystem containing the license text.
0474      */
0475     K4AboutData &setLicenseTextFile(const QString &file);
0476 
0477     /**
0478      * Adds a license text by pointing to a file where it resides.
0479      * The file format has to be plain text in an encoding compatible to the locale.
0480      *
0481      * If there is only one unknown license set, e.g. by using the default
0482      * parameter in the constructor, that one is replaced.
0483      *
0484      * @param file Path to the file in the local filesystem containing the license text.
0485      * @see addLicenseText, addLicense, setLicenseTextFile
0486      * @since 4.1
0487      */
0488     K4AboutData &addLicenseTextFile(const QString &file);
0489 
0490     /**
0491      * Defines the program name used internally.
0492      *
0493      * @param appName The application name. Example: "kate".
0494      */
0495     K4AboutData &setAppName(const QByteArray &appName);
0496 
0497     /**
0498      * Defines the displayable program name string.
0499      *
0500      * @param programName The program name. This string should be
0501      *        marked for translation.
0502      *        Example: ki18n("Advanced Text Editor").
0503      */
0504     K4AboutData &setProgramName(const KLocalizedString &programName);
0505 
0506     /**
0507      * Defines the program icon.
0508      *
0509      * Use this if you need to have an application icon
0510      * whose name is different than the application name.
0511      *
0512      * @param iconName name of the icon. Example: "accessories-text-editor"
0513      * @see programIconName()
0514      * @since 4.1
0515      */
0516     K4AboutData &setProgramIconName(const QString &iconName);
0517 
0518     /**
0519      * Defines the program logo.
0520      *
0521      * Use this if you need to have an application logo
0522      * in AboutData other than the application icon.
0523      *
0524      * Because K4AboutData is in kdecore it cannot use QImage directly,
0525      * so this is a QVariant that should contain a QImage.
0526      *
0527      * @param image logo image.
0528      * @see programLogo()
0529     */
0530     K4AboutData &setProgramLogo(const QVariant &image);
0531 
0532     /**
0533      * Specifies an Open Collaboration Services provider by URL.
0534      * A provider file must be available for the chosen provider.
0535      *
0536      * Use this if you need to override the default provider.
0537      *
0538      * If this method is not used, all the K4AboutPerson OCS usernames
0539      * will be used with the openDesktop.org entry from the default
0540      * provider file.
0541      *
0542      * @param providerUrl The provider URL as defined in the provider file.
0543      */
0544     K4AboutData &setOcsProvider(const QByteArray &providerUrl);
0545 
0546     /**
0547      * Defines the program version string.
0548      *
0549      * @param version The program version.
0550      */
0551     K4AboutData &setVersion(const QByteArray &version);
0552 
0553     /**
0554      * Defines a short description of what the program does.
0555      *
0556      * @param shortDescription The program description. This string should
0557      *        be marked for translation. Example: ki18n("An advanced text
0558      *        editor with syntax highlighting support.").
0559      */
0560     K4AboutData &setShortDescription(const KLocalizedString &shortDescription);
0561 
0562     /**
0563      * Defines the translation catalog that the program uses.
0564      *
0565      * @param catalogName The translation catalog name.
0566      */
0567     K4AboutData &setCatalogName(const QByteArray &catalogName);
0568 
0569     /**
0570      * Defines the license identifier.
0571      *
0572      * @param licenseKey The license identifier.
0573      * @see addLicenseText, setLicenseText, setLicenseTextFile
0574      */
0575     K4AboutData &setLicense(LicenseKey licenseKey);
0576 
0577     /**
0578      * Adds a license identifier.
0579      *
0580      * If there is only one unknown license set, e.g. by using the default
0581      * parameter in the constructor, that one is replaced.
0582      *
0583      * @param licenseKey The license identifier.
0584      * @see setLicenseText, addLicenseText, addLicenseTextFile
0585      * @since 4.1
0586      */
0587     K4AboutData &addLicense(LicenseKey licenseKey);
0588 
0589     /**
0590      * Defines the copyright statement to show when displaying the license.
0591      *
0592      * @param copyrightStatement A copyright statement, that can look like
0593      *        this: ki18n("Copyright (C) 1999-2000 Name"). The string specified here is
0594      *        taken verbatim; the author information from addAuthor is not used.
0595      */
0596     K4AboutData &setCopyrightStatement(const KLocalizedString &copyrightStatement);
0597 
0598     /**
0599      * Defines the additional text to show in the about dialog.
0600      *
0601      * @param otherText Some free form text, that can contain any kind of
0602      *        information. The text can contain newlines. This string
0603      *        should be marked for translation.
0604      */
0605     K4AboutData &setOtherText(const KLocalizedString &otherText);
0606 
0607     /**
0608      * Defines the program homepage.
0609      *
0610      * @param homepage The program homepage string.
0611      *        Start the address with "http://". "http://kate.kde.org"
0612      *        is correct but "kate.kde.org" is not.
0613      */
0614     K4AboutData &setHomepage(const QByteArray &homepage);
0615 
0616     /**
0617      * Defines the address where bug reports should be sent.
0618      *
0619      * @param bugAddress The bug report email address string.
0620      *        This defaults to the kde.org bug system.
0621      */
0622     K4AboutData &setBugAddress(const QByteArray &bugAddress);
0623 
0624     /**
0625      * Defines the Internet domain of the organization that wrote this application.
0626      * The domain is set to kde.org by default, or the domain of the homePageAddress constructor argument,
0627      * if set.
0628      *
0629      * Make sure to call setOrganizationDomain if your product is developed out of the
0630      * kde.org version-control system.
0631      *
0632      * Used by the automatic registration to D-Bus done by KApplication and KUniqueApplication.
0633      *
0634      * IMPORTANT: if the organization domain is set, the .desktop file that describes your
0635      * application should have an entry like X-DBUS-ServiceName=reversed_domain.kmyapp
0636      * For instance kwrite passes "http://www.kate-editor.org" as the homePageAddress so it needs
0637      * X-DBUS-ServiceName=org.kate-editor.kwrite in its kwrite.desktop file.
0638      *
0639      * @param domain the domain name, for instance kde.org, koffice.org, kdevelop.org, etc.
0640      */
0641     K4AboutData &setOrganizationDomain(const QByteArray &domain);
0642 
0643     /**
0644      * Defines the product name which will be used in the KBugReport dialog.
0645      * By default it's the appName, but you can overwrite it here to provide
0646      * support for special components e.g. in the form 'product/component',
0647      * such as 'kontact/summary'.
0648      *
0649      * @param name The name of product
0650      */
0651     K4AboutData &setProductName(const QByteArray &name);
0652 
0653     /**
0654      * Returns the application's internal name.
0655      * @return the internal program name.
0656      */
0657     QString appName() const;
0658 
0659     /**
0660      * Returns the application's product name, which will be used in KBugReport
0661      * dialog. By default it returns appName(), otherwise the one which is set
0662      * with setProductName()
0663      *
0664      * @return the product name.
0665      */
0666     QString productName() const;
0667 
0668     /**
0669      * Returns the translated program name.
0670      * @return the program name (translated).
0671      */
0672     QString programName() const;
0673 
0674     /**
0675      * Returns the domain name of the organization that wrote this application.
0676      *
0677      * Used by the automatic registration to D-Bus done by KApplication and KUniqueApplication.
0678      */
0679     QString organizationDomain() const;
0680 
0681     /**
0682      * @internal
0683      * Provided for use by KCrash
0684      */
0685     const char *internalProgramName() const;
0686 
0687     /**
0688      * @internal
0689      * Provided for use by KCrash
0690      */
0691     void translateInternalProgramName() const;
0692 
0693     /**
0694      * Returns the program's icon name.
0695      *
0696      * The default value is appName().
0697      * Use setProgramIconName() if you need to have an icon
0698      * whose name is different from the internal application name.
0699      *
0700      * @return the program's icon name.
0701      * @see setProgramIconName()
0702      * @since 4.1
0703      */
0704     QString programIconName() const;
0705 
0706     /**
0707      * Returns the program logo image.
0708      *
0709      * Because K4AboutData is in kdecore it cannot use QImage directly,
0710      * so this is a QVariant containing a QImage.
0711      *
0712      * @return the program logo data, or a null image if there is
0713      *         no custom application logo defined.
0714      */
0715     QVariant programLogo() const;
0716 
0717     /**
0718      * Returns the chosen Open Collaboration Services provider URL.
0719      * @return the provider URL.
0720      */
0721     QString ocsProviderUrl() const;
0722 
0723     /**
0724      * Returns the program's version.
0725      * @return the version string.
0726      */
0727     QString version() const;
0728 
0729     /**
0730      * @internal
0731      * Provided for use by KCrash
0732      */
0733     const char *internalVersion() const;
0734 
0735     /**
0736      * Returns a short, translated description.
0737      * @return the short description (translated). Can be
0738      *         QString() if not set.
0739      */
0740     QString shortDescription() const;
0741 
0742     /**
0743      * Returns the program's translation catalog name.
0744      * @return the catalog name.
0745      */
0746     QString catalogName() const;
0747 
0748     /**
0749      * Returns the application homepage.
0750      * @return the application homepage URL. Can be QString() if
0751      *         not set.
0752      */
0753     QString homepage() const;
0754 
0755     /**
0756      * Returns the email address for bugs.
0757      * @return the email address where to report bugs.
0758      */
0759     QString bugAddress() const;
0760 
0761     /**
0762      * @internal
0763      * Provided for use by KCrash
0764      */
0765     const char *internalBugAddress() const;
0766 
0767     /**
0768      * Returns a list of authors.
0769      * @return author information (list of persons).
0770      */
0771     QList<K4AboutPerson> authors() const;
0772 
0773     /**
0774      * Returns a list of persons who contributed.
0775      * @return credit information (list of persons).
0776      */
0777     QList<K4AboutPerson> credits() const;
0778 
0779     /**
0780      * Returns a list of translators.
0781      * @return translators information (list of persons)
0782      */
0783     QList<K4AboutPerson> translators() const;
0784 
0785     /**
0786      * Returns a message about the translation team.
0787      * @return a message about the translation team
0788      */
0789     static QString aboutTranslationTeam();
0790 
0791     /**
0792      * Returns a translated, free form text.
0793      * @return the free form text (translated). Can be QString() if not set.
0794      */
0795     QString otherText() const;
0796 
0797     /**
0798      * Returns the license. If the licenseType argument of the constructor has been
0799      * used, any text defined by setLicenseText is ignored,
0800      * and the standard text for the chosen license will be returned.
0801      *
0802      * @return The license text.
0803      *
0804      * @deprecated There could be multiple licenses, use licenses() instead.
0805      */
0806     QString license() const;
0807 
0808     /**
0809      * Returns the license name.
0810      *
0811      * @return The license name as a string.
0812      *
0813      * @deprecated There could be multiple licenses, use licenses() instead.
0814      */
0815     QString licenseName(NameFormat formatName) const;
0816 
0817     /**
0818      * Returns a list of licenses.
0819      *
0820      * @return licenses information (list of licenses)
0821      * @since 4.1
0822      */
0823     QList<K4AboutLicense> licenses() const;
0824 
0825     /**
0826      * Returns the copyright statement.
0827      * @return the copyright statement. Can be QString() if not set.
0828      */
0829     QString copyrightStatement() const;
0830 
0831     /**
0832      * Returns the plain text displayed around the list of authors instead
0833      * of the default message telling users to send bug reports to bugAddress().
0834      *
0835      * @return the plain text displayed around the list of authors instead
0836      *         of the default message.  Can be QString().
0837      */
0838     QString customAuthorPlainText() const;
0839 
0840     /**
0841      * Returns the rich text displayed around the list of authors instead
0842      * of the default message telling users to send bug reports to bugAddress().
0843      *
0844      * @return the rich text displayed around the list of authors instead
0845      *         of the default message.  Can be QString().
0846      */
0847     QString customAuthorRichText() const;
0848 
0849     /**
0850      * Returns whether custom text should be displayed around the list of
0851      * authors.
0852      *
0853      * @return whether custom text should be displayed around the list of
0854      *         authors.
0855      */
0856     bool customAuthorTextEnabled() const;
0857 
0858     /**
0859      * Sets the custom text displayed around the list of authors instead
0860      * of the default message telling users to send bug reports to bugAddress().
0861      *
0862      * @param plainText The plain text.
0863      * @param richText The rich text.
0864      *
0865      * Setting both to parameters to KLocalizedString() will cause no message to be
0866      * displayed at all.  Call unsetCustomAuthorText() to revert to the default
0867      * message.
0868      */
0869     K4AboutData &setCustomAuthorText(const KLocalizedString &plainText,
0870                                      const KLocalizedString &richText);
0871 
0872     /**
0873      * Clears any custom text displayed around the list of authors and falls
0874      * back to the default message telling users to send bug reports to
0875      * bugAddress().
0876      */
0877     K4AboutData &unsetCustomAuthorText();
0878 
0879 private:
0880 
0881     class Private;
0882     Private *const d;
0883 };
0884 
0885 /**
0886  * This class is used to store information about a license.
0887  * The license can be one of some predefined, one given as text or one
0888  * that can be loaded from a file. This class is used in the K4AboutData class.
0889  * Explicitly creating a K4AboutLicense object is not possible.
0890  * If the license is wanted for a KDE component having K4AboutData object,
0891  * use K4AboutData::licenses() to get the licenses for that component.
0892  * If the license is for a non-code resource and given by a keyword
0893  * (e.g. in .desktop files), try using K4AboutLicense::byKeyword().
0894  *
0895  * @note Instead of the more usual i18n calls, for translatable text the ki18n
0896  * calls are used to produce KLocalizedStrings, which can delay the translation
0897  * lookup. This is necessary because the translation catalogs are usually not
0898  * yet initialized at the point where K4AboutData is constructed.
0899  */
0900 class KDELIBS4SUPPORT_DEPRECATED_EXPORT_NOISE K4AboutLicense
0901 {
0902     friend class K4AboutData;
0903 public:
0904     /**
0905      * Copy constructor.  Performs a deep copy.
0906      * @param other object to copy
0907      */
0908     K4AboutLicense(const K4AboutLicense &other);
0909 
0910     ~K4AboutLicense();
0911 
0912     /**
0913      * Assignment operator.  Performs a deep copy.
0914      * @param other object to copy
0915      */
0916     K4AboutLicense &operator=(const K4AboutLicense &other);
0917 
0918     /**
0919      * Returns the full license text. If the licenseType argument of the
0920      * constructor has been used, any text defined by setLicenseText is ignored,
0921      * and the standard text for the chosen license will be returned.
0922      *
0923      * @return The license text.
0924      */
0925     QString text() const;
0926 
0927     /**
0928      * Returns the license name.
0929      *
0930      * @return The license name as a string.
0931      */
0932     QString name(K4AboutData::NameFormat formatName) const;
0933 
0934     /**
0935      * Returns the license key.
0936      *
0937      * @return The license key as element of K4AboutData::LicenseKey enum.
0938      * @since 4.1
0939      */
0940     K4AboutData::LicenseKey key() const;
0941 
0942     /**
0943      * Fetch a known license by a keyword.
0944      *
0945      * Frequently the license data is provided by a terse keyword-like string,
0946      * e.g. by a field in a .desktop file. Using this method, an application
0947      * can get hold of a proper K4AboutLicense object, providing that the
0948      * license is one of the several known to KDE, and use it to present
0949      * more human-readable information to the user.
0950      *
0951      * Keywords are matched by stripping all whitespace and lowercasing.
0952      * The known keywords correspond to the K4AboutData::LicenseKey enumeration,
0953      * e.g. any of "LGPLV3", "LGPLv3", "LGPL v3" would match License_LGPL_V3.
0954      * If there is no match for the keyword, a valid license object is still
0955      * returned, with its name and text informing about a custom license,
0956      * and its key equal to K4AboutData::License_Custom.
0957      *
0958      * @param keyword The license keyword.
0959      * @return The license object.
0960      *
0961      * @see K4AboutData::LicenseKey
0962      * @since 4.1
0963      */
0964     static K4AboutLicense byKeyword(const QString &keyword);
0965 
0966 private:
0967     /**
0968      * @internal Used by K4AboutData to construct a predefined license.
0969      */
0970     KDELIBS4SUPPORT_DEPRECATED explicit K4AboutLicense(enum K4AboutData::LicenseKey licenseType, const K4AboutData *aboutData);
0971     /**
0972      * @internal Used by K4AboutData to construct license by given text
0973      */
0974     KDELIBS4SUPPORT_DEPRECATED explicit K4AboutLicense(const QString &pathToFile, const K4AboutData *aboutData);
0975     /**
0976      * @internal Used by K4AboutData to construct license by given text
0977      */
0978     KDELIBS4SUPPORT_DEPRECATED explicit K4AboutLicense(const KLocalizedString &licenseText, const K4AboutData *aboutData);
0979 
0980     class Private;
0981     QSharedDataPointer<Private> d;
0982 };
0983 
0984 #endif
0985