/usr/include/phonon/platformplugin.h is in libphonon-dev 4:4.7.0really4.6.0-0ubuntu1.
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 | /* This file is part of the KDE project
Copyright (C) 2007-2008 Matthias Kretz <kretz@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) version 3, or any
later version accepted by the membership of KDE e.V. (or its
successor approved by the membership of KDE e.V.), Nokia Corporation
(or its successors, if any) and the KDE Free Qt Foundation, which shall
act as a proxy defined in Section 6 of version 3 of the license.
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
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef PHONON_PLATFORMPLUGIN_H
#define PHONON_PLATFORMPLUGIN_H
#include <QtCore/QObject>
#include <QtCore/QStringList>
#include <QtCore/QPair>
#include "phonon_export.h"
#include "objectdescription.h"
QT_BEGIN_HEADER
QT_BEGIN_NAMESPACE
#ifndef QT_NO_PHONON_PLATFORMPLUGIN
class QUrl;
class QObject;
class QIcon;
namespace Phonon
{
class AbstractMediaStream;
class PlatformPlugin
{
public:
virtual ~PlatformPlugin() {}
/**
* Creates a AbstractMediaStream object that provides the data for the given \p url. On KDE
* this uses KIO.
*/
virtual AbstractMediaStream *createMediaStream(const QUrl &url, QObject *parent) = 0;
/**
* Returns the icon for the given icon name.
*/
virtual QIcon icon(const QString &name) const = 0;
/**
* Shows a notification popup
*/
virtual void notification(const char *notificationName, const QString &text,
const QStringList &actions = QStringList(), QObject *receiver = 0,
const char *actionSlot = 0) const = 0;
/**
* Returns the name of the application. For most Qt application this is
* QCoreApplication::applicationName(), but for KDE this is overridden by KAboutData.
*/
virtual QString applicationName() const = 0;
/**
* Creates a backend object. This way the platform can decide the backend preference.
*/
virtual QObject *createBackend() = 0;
/**
* Using the library loader of the platform, loads a given backend.
*/
virtual QObject *createBackend(const QString &library, const QString &version) = 0;
/**
* Tries to check whether the default backend supports a given MIME type without loading the
* actual backend library. On KDE this reads the MIME type list from the .desktop file of
* the backend.
*/
virtual bool isMimeTypeAvailable(const QString &mimeType) const = 0;
/**
* Saves the volume for the given output.
*/
virtual void saveVolume(const QString &outputName, qreal volume) = 0;
/**
* Loads the volume for the given output.
*/
virtual qreal loadVolume(const QString &outputName) const = 0;
virtual QList<int> objectDescriptionIndexes(ObjectDescriptionType type) const = 0;
virtual QHash<QByteArray, QVariant> objectDescriptionProperties(ObjectDescriptionType type, int index) const = 0;
/**
* Returns a list of (driver, handle) pairs for the given AudioOutputDevice description.
* Implementation is optional.
*/
virtual DeviceAccessList deviceAccessListFor(const AudioOutputDevice &) const { return DeviceAccessList(); }
#ifndef PHONON_NO_AUDIOCAPTURE
/**
* Returns a list of (driver, handle) pairs for the given AudioCaptureDevice description.
* Implementation is optional.
*/
virtual DeviceAccessList deviceAccessListFor(const AudioCaptureDevice &) const { return DeviceAccessList(); }
#endif // PHONON_NO_AUDIOCAPTURE
#ifndef PHONON_NO_VIDEOCAPTURE
/**
* Returns a list of (driver, handle) pairs for the given VideoCaptureDevice description.
* Implementation is optional.
*/
virtual DeviceAccessList deviceAccessListFor(const VideoCaptureDevice &) const { return DeviceAccessList(); }
#endif // PHONON_NO_VIDEOCAPTURE
};
} // namespace Phonon
Q_DECLARE_INTERFACE(Phonon::PlatformPlugin, "3PlatformPlugin.phonon.kde.org")
#endif //QT_NO_PHONON_PLATFORMPLUGIN
QT_END_NAMESPACE
QT_END_HEADER
#endif // PHONON_PLATFORMPLUGIN_H
|