/usr/include/phonon/streaminterface.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 | /*
Copyright (C) 2007 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_STREAMINTERFACE_H
#define PHONON_STREAMINTERFACE_H
#include "phonon_export.h"
#include <QtCore/QObject>
#ifndef QT_NO_PHONON_ABSTRACTMEDIASTREAM
namespace Phonon
{
class StreamInterfacePrivate;
class MediaSource;
/** \class StreamInterface streaminterface.h phonon/StreamInterface
* \brief Backend interface to handle media streams (AbstractMediaStream).
*
* All functions relay their calls to the AbstractMediaStream using invokeMethod on the
* AbstractMediaStream's QMetaObject. This means that every function call will
* actually be executed in the thread context of the AbstractMediaStream (which
* usually is a thread Phonon also lives in, could however also be another one).
* This protectes the AbstractMediaStream against calls from different threads,
* such as a callback thread.
* This is very important as most IO implementations are by default not
* thread-safe.
*
* This protection is only established in one direction though, meaning that a
* backend implementation of this interface must be made thread-safe at all costs
* as it can get called from any thread.
*
* \author Matthias Kretz <kretz@kde.org>
*/
class PHONON_EXPORT StreamInterface
{
friend class StreamInterfacePrivate;
friend class AbstractMediaStreamPrivate;
public:
virtual ~StreamInterface();
/**
* Called by the application to send a chunk of (encoded) media data.
*
* It is recommended to keep the QByteArray object until the data is consumed so that no
* memcopy is needed.
*/
virtual void writeData(const QByteArray &data) = 0;
/**
* Called when no more media data is available and writeData will not be called anymore.
*/
virtual void endOfData() = 0;
/**
* Called at the start of the stream to tell how many bytes will be sent through writeData
* (if no seeks happen, of course). If this value is negative the stream size cannot be
* determined (might be a "theoretically infinite" stream - like webradio).
*/
virtual void setStreamSize(qint64 newSize) = 0;
/**
* Tells whether the stream is seekable.
*/
virtual void setStreamSeekable(bool s) = 0;
/**
* Call this function from the constructor of your StreamInterface implementation (or as
* soon as you get the MediaSource object). This will connect your object to the
* AbstractMediaStream object. Only after the connection is done will the following
* functions have an effect.
*/
void connectToSource(const MediaSource &mediaSource);
/**
* Call this function to tell the AbstractMediaStream that you need more data. The data will
* arrive through writeData.
* writeData() will not be called from needData() due to the thread protection of
* the AbstractMediaStream.
*
* Depending on the buffering you need you either treat needData as a replacement for a
* read call like QIODevice::read, or you start calling needData whenever your buffer
* reaches a certain lower threshold.
*/
void needData();
/**
* Call this function to tell the AbstractMediaStream that you have enough data in your
* buffer and that it should pause calling writeData if possible.
*/
void enoughData();
/**
* If the stream is seekable, calling this function will make the next call to writeData
* pass data that starts at the byte offset \p seekTo.
*/
void seekStream(qint64 seekTo);
/**
* Resets the AbstractMediaStream. E.g. this can be useful for non-seekable streams to start
* over again.
*/
void reset();
protected:
StreamInterface();
StreamInterfacePrivate *const d;
};
} // namespace Phonon
Q_DECLARE_INTERFACE(Phonon::StreamInterface, "StreamInterface1.phonon.kde.org")
#endif //QT_NO_PHONON_ABSTRACTMEDIASTREAM
#endif // PHONON_STREAMINTERFACE_H
|