/usr/include/sipxtapi/mp/MprVad.h is in libsipxtapi-dev 3.3.0~test17-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 | //
// Copyright (C) 2008 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2008 SIPez LLC.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
//////////////////////////////////////////////////////////////////////////////
// Author: Alexander Chemeris <Alexander DOT Chemeris AT SIPez DOT com>
#ifndef _MprVad_h_
#define _MprVad_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include "mp/MpAudioResource.h"
#include "mp/MpResourceMsg.h"
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
class MpVadBase;
/**
* @brief Voice Activity Detection resource.
*
* @nosubgrouping
*/
class MprVad : public MpAudioResource
{
/* //////////////////////////////// PUBLIC //////////////////////////////// */
public:
/* =============================== CREATORS =============================== */
///@name Creators
//@{
/// Constructor
MprVad(const UtlString& rName, const UtlString &vadAlgorithm = "");
/**<
* @param[in] vadAlgorithm - see chageVadAlgorithm() for description.
*/
/// Destructor
~MprVad();
//@}
/* ============================= MANIPULATORS ============================= */
///@name Manipulators
//@{
/// Change VAD algorithm to the given one.
OsStatus chageVadAlgorithm(const UtlString& namedResource,
OsMsgQ& fgQ,
const UtlString &vadAlgorithm);
/**<
* @param[in] vadAlgorithm - name of the VAD algorithm to use. If empty
* string of incorrect name is given, default VAD algorithm
* will be used and no error is generated.
*/
//@}
/* ============================== ACCESSORS =============================== */
///@name Accessors
//@{
//@}
/* =============================== INQUIRY ================================ */
///@name Inquiry
//@{
//@}
/* ////////////////////////////// PROTECTED /////////////////////////////// */
protected:
enum
{
MPRM_CHANGE_VAD = MpResourceMsg::MPRM_EXTERNAL_MESSAGE_START
};
MpVadBase *mpVad; ///< Instance of the VAD algorithm to use.
/// @copydoc MpAudioResource::doProcessFrame
UtlBoolean doProcessFrame(MpBufPtr inBufs[],
MpBufPtr outBufs[],
int inBufsSize,
int outBufsSize,
UtlBoolean isEnabled,
int samplesPerFrame,
int samplesPerSecond);
/// @copydoc MpResource::handleMessage
UtlBoolean handleMessage(MpResourceMsg& rMsg);
/// Handle MPRM_CHANGE_VAD message.
UtlBoolean handleChageVadAlgorithm(const UtlString &vadAlgorithm);
/// @copydoc MpResource::setFlowGraph()
OsStatus setFlowGraph(MpFlowGraphBase* pFlowGraph);
/* /////////////////////////////// PRIVATE //////////////////////////////// */
private:
};
/* ============================ INLINE METHODS ============================ */
#endif // _MprVad_h_
|