/usr/include/sipxtapi/mp/MpPlayer.h is in libsipxtapi-dev 3.3.0~test17-2.1.
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 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 | //
// Copyright (C) 2006 SIPez LLC.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// Copyright (C) 2004-2006 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2004-2006 Pingtel Corp. All rights reserved.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
///////////////////////////////////////////////////////////////////////////////
#ifndef _MpPlayer_h_
#define _MpPlayer_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include "mp/StreamDefs.h"
#include "os/OsDefs.h"
#include "os/OsStatus.h"
#include "os/OsMutex.h"
// DEFINES
#define MAX_PLAYER_LISTENERS 16 // Max number of player listeners
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
//:Definition of states used by audio players
typedef enum
{
PlayerUnrealized,
PlayerRealized,
PlayerPrefetched,
PlayerPlaying,
PlayerPaused,
PlayerStopped,
PlayerAborted,
PlayerFailed,
PlayerDestroyed
} PlayerState ;
//!enumcode PlayerUnrealized - Data is unrealized (uninitialized) and no
// resources have been allocated.
//!enumcode PlayerRealized - Data has been realized and resource allocated
//!enumcode PlayerPrefetched - Data has been prefetched. Prefetch may fetch
// the entire data source or just enough to ensure smooth playback.
//!enumcode PlayerPlaying - The player has begun playing media.
//!enumcode PlayerPaused - The player has been paused.
//!enumcode PlayerStopped - The player has stopped playing media.
//!enumcode PlayerFailed - The player has failed.
//!enumcode PlayerDestroyed - The player has been destroyed
//!enumcode PlayerAborted - Indicates that the player was stop explicitly by
// a call to stop() (as opposed to normal playing).
// FORWARD DECLARATIONS
class MpPlayerListener ;
//:Defines a stream player control that allows users to realize, start, stop,
//:and pause an audio source.
//
// <pre>
// +-----------------------------------+
// \ / |
// ------------ ------------ --------- ---------
// | Unrealized | ---> | Prefetched | <---> | Playing | ---> | Stopped |
// ------------ ------------ --------- ---------
// / \ .
// |
// \ /
// -------- --------
// | Failed | <--* | Paused |
// -------- --------
//
// -----------
// | Destroyed | <--*
// -----------
//
// ---------
// | Aborted | <--*
// ---------
// </pre>
class MpPlayer
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
typedef enum // Type of players
{
STREAM_PLAYER,
STREAM_PLAYLIST_PLAYER,
STREAM_QUEUE_PLAYER
} playerType;
/* ============================ CREATORS ================================== */
MpPlayer();
//:Default Constructor
virtual ~MpPlayer();
//:Destructor
//@}
/* ============================ MANIPULATORS ============================== */
///@name Manipulators
//@{
virtual OsStatus realize(UtlBoolean bBlock = TRUE) = 0;
//: Realizes the player by initiating a connection to the target,
//: allocates buffers, etc.
//
//!param bBlock - TRUE if the method should block until completion,
// otherwise FALSE.
virtual OsStatus prefetch(UtlBoolean bBlock = TRUE) = 0 ;
//: Prefetch enough of the data source to ensure a smooth playback.
//
//!param bBlock - TRUE if the method should block until completion,
// otherwise FALSE.
virtual OsStatus play(UtlBoolean bBlock = TRUE) = 0 ;
//: Plays the media stream.
//
//!param bBlock - TRUE if the method should block until completion,
// otherwise FALSE.
virtual OsStatus pause() = 0 ;
//: Pauses the media stream temporarily.
virtual OsStatus stop() = 0 ;
//: Stops playing the media stream and resources used for buffering
//: and streaming.
virtual OsStatus destroy() = 0 ;
//: Marks the player as destroy and frees all allocated resources
// in media processing.
OsStatus addListener(MpPlayerListener* pListener, void* pUserData = NULL) ;
//:Adds a player listener to receive notifications when this player
//:changes state
OsStatus removeListener(MpPlayerListener* pListener) ;
//:Removes a previously added player listener. This listener will
// cease to receive state change notifications.
//@}
/* ============================ ACCESSORS ================================= */
///@name Accessors
//@{
virtual OsStatus getState(PlayerState& state) = 0 ;
//: Gets the player state
//@}
/* ============================ INQUIRY =================================== */
///@name Inquiry
//@{
/* ============================ TESTING =================================== */
#ifdef MP_STREAM_DEBUG /* [ */
static const char* getEventString(PlayerState event);
#endif /* MP_STREAM_DEBUG ] */
//@}
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
void fireEvent(PlayerState state);
//:Fires an event to all registered listeners
UtlBoolean isValidStateChange(PlayerState oldState, PlayerState newState) ;
//:Is the transition from oldState to newState valid?
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
struct PlayerListenerDb // Data structure used to maintain listeners
{
UtlBoolean inUse ; // Is the entry in use?
MpPlayerListener* pListener ; // Reference to listener
void* pUserData; // User data specified when added
} ;
PlayerListenerDb mListenerDb[MAX_PLAYER_LISTENERS] ; // DB of listeners
OsMutex mListenerLock ;
};
/* ============================ INLINE METHODS ============================ */
#endif // _MpPlayer_h_
|