/usr/include/kfileitemactions.h is in kdelibs5-dev 4:4.14.38-0ubuntu3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 | /* This file is part of the KDE project
Copyright (C) 1998-2009 David Faure <faure@kde.org>
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 ) version 3 or, at the discretion of KDE e.V.
( which shall act as a proxy as in section 14 of the GPLv3 ), 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 KFILEITEMACTIONS_H
#define KFILEITEMACTIONS_H
#include <kservice.h>
#include <kfileitem.h>
#include <kio/kio_export.h>
class KFileItemListProperties;
class KAction;
class QMenu;
class KFileItemActionsPrivate;
/**
* This class creates and handles the actions for a url (or urls) in a popupmenu.
*
* This includes:
* @li "open with <application>" actions, but also
* @li builtin services like mount/unmount for old-style device desktop files
* @li user-defined actions for a .desktop file, defined in the file itself (see the desktop entry standard)
* @li servicemenus actions, defined in .desktop files and selected based on the mimetype of the url
*
* @since 4.3
*/
class KIO_EXPORT KFileItemActions : public QObject
{
Q_OBJECT
public:
/**
* Creates a KFileItemActions instance.
* Note that this instance must stay alive for at least as long as the popupmenu;
* it has the slots for the actions created by addOpenWithActionsTo/addServiceActionsTo.
*/
KFileItemActions(QObject* parent = 0);
/**
* Destructor
*/
~KFileItemActions();
/**
* Sets all the data for the next instance of the popupmenu.
* @see KFileItemListProperties
*/
void setItemListProperties(const KFileItemListProperties& itemList);
/**
* Set the parent widget for any dialogs being shown.
*
* This should normally be your mainwindow, not a popup menu,
* so that it still exists even after the popup is closed
* (e.g. error message from KRun) and so that QAction::setStatusTip
* can find a statusbar, too.
*/
void setParentWidget(QWidget* widget);
/**
* Generate the "Open With <Application>" actions, and adds them to the @p menu.
* All actions are created as children of the menu.
* @param menu the QMenu where to add actions
* @param traderConstraint this constraint allows to exclude the current application
* from the "open with" list. Example: "DesktopEntryName != 'kfmclient'".
* (Default value added in kdelibs-4.5, pass QString() explicitely for earlier versions).
*/
void addOpenWithActionsTo(QMenu* menu, const QString& traderConstraint = QString());
/**
* Returns an action for the preferred application only.
* @param traderConstraint this constraint allows to exclude the current application
* from the "open with" list. Example: "DesktopEntryName != 'kfmclient'".
* @return the action - or 0 if no application was found.
*/
KAction* preferredOpenWithAction(const QString& traderConstraint);
/**
* Helper method used internally, can also be used for similar GUIs that
* show the list of associated applications.
* Used in KParts::BrowserOpenOrSaveQuestion for example.
*
* This is basically a KMimeTypeTrader::query, but it supports multiple mimetypes, and
* also cleans up "apparent" duplicates, such as the kde3 and kde4 applications with the same name.
*
* The list is sorted according to the user preferences for the given mimetype(s).
* In case multiple mimetypes appear in the url list, the logic is:
* applications that on average appear earlier on the associated applications
* list for the given mimetypes also appear earlier on the final applications list.
*
* Note that for a single mimetype there is no need to use this, you should use
* KMimeTypeTrader instead, e.g. query() or preferredService().
*
* Returns the applications associated with all the given mimetypes.
* @param mimeTypeList the mimetypes
* @param traderConstraint this optional constraint allows to exclude the current application
* from the "open with" list. Example: "DesktopEntryName != 'kfmclient'".
* @return the sorted list of services.
* @since 4.4
*/
static KService::List associatedApplications(const QStringList& mimeTypeList, const QString& traderConstraint);
/**
* Generate the user-defined actions and submenus, and adds them to the @p menu.
* User-defined actions include:
* - builtin services like mount/unmount for old-style device desktop files
* - user-defined actions for a .desktop file, defined in the file itself (see the desktop entry standard)
* - servicemenus actions, defined in .desktop files and selected based on the mimetype of the url
*
* When KFileItemListProperties::supportsWriting() is false, actions that modify the files are not shown.
* This is controlled by Require=Write in the servicemenu desktop files.
*
* All actions are created as children of the menu.
* @return the number of actions added
*/
int addServiceActionsTo(QMenu* menu);
Q_SIGNALS:
/**
* Emitted before the "Open With" dialog is shown
* This is used e.g in folderview to close the folder peek popups on invoking the "Open With" menu action
* @since 4.8.2
*/
void openWithDialogAboutToBeShown();
public Q_SLOTS:
/**
* Slot used to execute a list of files in their respective preferred application.
* @param fileOpenList the list of KFileItems to open.
* @param traderConstraint this optional constraint allows to exclude the current application
* @since 4.5
*/
void runPreferredApplications(const KFileItemList& fileOpenList, const QString& traderConstraint);
private:
KFileItemActionsPrivate* const d;
friend class KFileItemActionsPrivate;
};
#endif /* KFILEITEMACTIONS_H */
|