This file is indexed.

/usr/include/phonon/addoninterface.h is in libphonon-dev 4:4.10.0-2.

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
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
/*  This file is part of the KDE project
    Copyright (C) 2007-2008 Matthias Kretz <kretz@kde.org>
    Copyright (C) 2011 Harald Sitter <sitter@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_ADDONINTERFACE_H
#define PHONON_ADDONINTERFACE_H

#include "phononnamespace.h"

#include <QtCore/QList>
#include <QtCore/QVariant>


#ifndef QT_NO_PHONON_MEDIACONTROLLER

namespace Phonon
{
/** \class AddonInterface addoninterface.h phonon/AddonInterface
 * \short Interface for Menu, Chapter, Angle and Title/Track control.
 *
 * \author Matthias Kretz <kretz@kde.org>
 */
class AddonInterface
{
    public:
        virtual ~AddonInterface() {}

        enum Interface {
            NavigationInterface   = 1, /**< Interface for (menu) navigation */
            ChapterInterface      = 2, /**< Interface for chapter control */
            AngleInterface        = 3, /**< Interface for angle control */
            TitleInterface        = 4, /**< Interface for title control */
            SubtitleInterface     = 5, /**< Interface for subtitle control */
            AudioChannelInterface = 6  /**< Interface for audio channel control */
        };

        enum NavigationCommand {
            availableMenus, /**< \returns a QList<MediaController::NavigationMenu>
                                 containing all supported navigation menu types */
            setMenu         /**< Sets the current menu to the first
                                 \c MediaController::NavigationMenu in a QList */
        };

        enum ChapterCommand {
            availableChapters, /**< \returns an \c int representing the amount of
                                    available chapters on the media source */
            chapter,           /**< \returns an \c int representing the current chapter */
            setChapter         /**< Sets the current chapter to the first \c int in the QList */
        };

        enum AngleCommand {
            availableAngles, /**< \returns \c int representing the amount of
                                  available angles on the media source */
            angle,           /**< \returns an \c int representing the current angle */
            setAngle         /**< Sets the current angle to the first \c int in the QList */
        };

        enum TitleCommand {
            availableTitles, /**< \returns \c int representing the amount of
                                  available titles on the media source */
            title,           /**< \returns \c int representing the current title */
            setTitle,        /**< Sets the current tittle to the first \c int in the QList */
            autoplayTitles,  /**< \returns \c bool whether autoplay of titles is on */
            setAutoplayTitles /**< Sets autoplay to \c true or \c false as
                                   indicated in the first \c bool in the QList */
        };

        enum SubtitleCommand {
            availableSubtitles, /**< \returns \c int representing the amount of
                                      available subtitles on the media source */
            currentSubtitle,    /**< \returns \c int representing the current subtitle */
            setCurrentSubtitle, /**< Sets the current subtitle to the first
                                     \c int in the QList */
            setCurrentSubtitleFile, /**< Sets the current subtitle to the first QUrl \since 4.7.0 */
            subtitleAutodetect, /**< \returns \c bool representing if subtitles
                                      autodetection is enabled \since 4.7.0 */
            setSubtitleAutodetect, /**< Sets/Unsets subtitles autodetection \since 4.7.0 */
            subtitleEncoding, /**< \returns a QString representing the current encoding
                                   used to render subtitles \since 4.7.0 */
            setSubtitleEncoding, /** Sets the current encoding used to render subtitles \since 4.7.0 */
            subtitleFont, /**< \returns a QFont representing the current font used
                              to render subtitles \since 4.7.0 */
            setSubtitleFont /**< Sets the current font used to render subtitles \since 4.7.0 */
        };

        enum AudioChannelCommand {
            availableAudioChannels, /**< \returns \c int representing the amount
                                          of all available audio channels on the
                                          media source */
            currentAudioChannel,    /**< \returns \c int representing the current
                                          audio channel */
            setCurrentAudioChannel  /**< Sets the current audio channel to the first
                                         \c int in the QList */
        };

        /**
         * Queries whether the backend supports a specific interface.
         *
         * \param iface The interface to query support information about
         * \returns \c true when the backend supports the interface, \c false otherwise
         * 
         * \ingroup backend
         **/
        virtual bool hasInterface(Interface iface) const = 0;

        /**
         * Calls an interface on the backend.
         *
         * \param iface The interface to call.
         * \param command The command the interface shall execute. This can be
         * any value of the Command enumeration associated with the command. The
         * backend casts this appropriately.
         * \param arguments The arguments for the command. This list can contain
         * a QVariant supported format + additions specific to Phonon. The
         * content entirely depends on the command (e.g. a getter may simply use
         * an empty list).
         * 
         * \return \c QVariant, as with the arguments this can be anything ranging
         * from an empty QVariant to custom types used within Phonon
         * 
         * Setting the chapter of a Media could be done like this: 
         * \code
         * AddonInterface *iface = d->iface();
         * iface->interfaceCall(AddonInterface::ChapterInterface,
         *                      AddonInterface::setChapter,
         *                      QList<QVariant>() << QVariant(titleNumber));
         * \endcode
         * 
         * Handling such a request in the backend is done as follows:
         * \code
         * switch (iface) {
         * case AddonInterface::ChapterInterface:
         *     switch (static_cast<AddonInterface::ChapterCommand>(command)) {
         *     case setChapter:
         *         setCurrentChapter(arguments.first().toInt());
         *         return QVariant();
         *     }
         * }
         * \endcode
         * 
         * \see Interface
         * \see NavigationCommand
         * \see ChapterCommand
         * \see AngleCommand
         * \see TitleCommand
         * \see SubtitleCommand
         * \see AudioChannelCommand
         * 
         * \ingroup backend
         **/
        virtual QVariant interfaceCall(Interface iface, int command,
                const QList<QVariant> &arguments = QList<QVariant>()) = 0;
};

} // namespace Phonon

Q_DECLARE_INTERFACE(Phonon::AddonInterface, "AddonInterface0.2.phonon.kde.org")

#endif //QT_NO_PHONON_MEDIACONTROLLER


#endif // PHONON_ADDONINTERFACE_H