mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-25 07:01:09 +00:00
Doxygenify slinfactory a bit.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@108226 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -29,33 +29,74 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct ast_slinfactory {
|
struct ast_slinfactory {
|
||||||
AST_LIST_HEAD_NOLOCK(, ast_frame) queue;
|
AST_LIST_HEAD_NOLOCK(, ast_frame) queue; /*!< A list of unaltered frames */
|
||||||
struct ast_trans_pvt *trans;
|
struct ast_trans_pvt *trans; /*!< Translation path that converts fed frames into signed linear */
|
||||||
short hold[1280];
|
short hold[1280]; /*!< Hold for audio that no longer belongs to a frame (ie: if only some samples were taken from a frame) */
|
||||||
short *offset;
|
short *offset; /*!< Offset into the hold where audio begins */
|
||||||
size_t holdlen; /*!< in samples */
|
size_t holdlen; /*!< Number of samples currently in the hold */
|
||||||
unsigned int size; /*!< in samples */
|
unsigned int size; /*!< Number of samples currently in the factory */
|
||||||
unsigned int format;
|
unsigned int format; /*!< Current format the translation path is converting from */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Initialize an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to initialize
|
||||||
|
*
|
||||||
|
* \return Nothing
|
||||||
|
*/
|
||||||
void ast_slinfactory_init(struct ast_slinfactory *sf);
|
void ast_slinfactory_init(struct ast_slinfactory *sf);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Destroy the contents of a slinfactory
|
* \brief Destroy the contents of a slinfactory
|
||||||
*
|
*
|
||||||
* \arg sf the slinfactory that is no longer needed
|
* \arg sf The slinfactory that is no longer needed
|
||||||
*
|
*
|
||||||
* This function will free any memory allocated for the contents of the
|
* This function will free any memory allocated for the contents of the
|
||||||
* slinfactory. It does not free the slinfactory itself. If the sf is
|
* slinfactory. It does not free the slinfactory itself. If the sf is
|
||||||
* malloc'd, then it must be explicitly free'd after calling this function.
|
* malloc'd, then it must be explicitly free'd after calling this function.
|
||||||
*
|
*
|
||||||
* \return nothing
|
* \return Nothing
|
||||||
*/
|
*/
|
||||||
void ast_slinfactory_destroy(struct ast_slinfactory *sf);
|
void ast_slinfactory_destroy(struct ast_slinfactory *sf);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Feed audio into an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to feed into
|
||||||
|
* \arg f Frame containing audio to feed in
|
||||||
|
*
|
||||||
|
* \return Number of frames currently in factory
|
||||||
|
*/
|
||||||
int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f);
|
int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Read samples from an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to read from
|
||||||
|
* \arg buf Buffer to put samples into
|
||||||
|
* \arg samples Number of samples wanted
|
||||||
|
*
|
||||||
|
* \return Number of samples read
|
||||||
|
*/
|
||||||
int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples);
|
int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Retrieve number of samples currently in an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to peek into
|
||||||
|
*
|
||||||
|
* \return Number of samples in slinfactory
|
||||||
|
*/
|
||||||
unsigned int ast_slinfactory_available(const struct ast_slinfactory *sf);
|
unsigned int ast_slinfactory_available(const struct ast_slinfactory *sf);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Flush the contents of an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to flush
|
||||||
|
*
|
||||||
|
* \return Nothing
|
||||||
|
*/
|
||||||
void ast_slinfactory_flush(struct ast_slinfactory *sf);
|
void ast_slinfactory_flush(struct ast_slinfactory *sf);
|
||||||
|
|
||||||
#if defined(__cplusplus) || defined(c_plusplus)
|
#if defined(__cplusplus) || defined(c_plusplus)
|
||||||
|
@@ -32,12 +32,30 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
|
|||||||
#include "asterisk/slinfactory.h"
|
#include "asterisk/slinfactory.h"
|
||||||
#include "asterisk/translate.h"
|
#include "asterisk/translate.h"
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Initialize an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to initialize
|
||||||
|
*
|
||||||
|
* \return Nothing
|
||||||
|
*/
|
||||||
void ast_slinfactory_init(struct ast_slinfactory *sf)
|
void ast_slinfactory_init(struct ast_slinfactory *sf)
|
||||||
{
|
{
|
||||||
memset(sf, 0, sizeof(*sf));
|
memset(sf, 0, sizeof(*sf));
|
||||||
sf->offset = sf->hold;
|
sf->offset = sf->hold;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Destroy the contents of a slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory that is no longer needed
|
||||||
|
*
|
||||||
|
* This function will free any memory allocated for the contents of the
|
||||||
|
* slinfactory. It does not free the slinfactory itself. If the sf is
|
||||||
|
* malloc'd, then it must be explicitly free'd after calling this function.
|
||||||
|
*
|
||||||
|
* \return Nothing
|
||||||
|
*/
|
||||||
void ast_slinfactory_destroy(struct ast_slinfactory *sf)
|
void ast_slinfactory_destroy(struct ast_slinfactory *sf)
|
||||||
{
|
{
|
||||||
struct ast_frame *f;
|
struct ast_frame *f;
|
||||||
@@ -51,6 +69,14 @@ void ast_slinfactory_destroy(struct ast_slinfactory *sf)
|
|||||||
ast_frfree(f);
|
ast_frfree(f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Feed audio into an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to feed into
|
||||||
|
* \arg f Frame containing audio to feed in
|
||||||
|
*
|
||||||
|
* \return Number of frames currently in factory
|
||||||
|
*/
|
||||||
int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f)
|
int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f)
|
||||||
{
|
{
|
||||||
struct ast_frame *begin_frame = f, *duped_frame = NULL, *frame_ptr;
|
struct ast_frame *begin_frame = f, *duped_frame = NULL, *frame_ptr;
|
||||||
@@ -99,6 +125,15 @@ int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f)
|
|||||||
return x;
|
return x;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Read samples from an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to read from
|
||||||
|
* \arg buf Buffer to put samples into
|
||||||
|
* \arg samples Number of samples wanted
|
||||||
|
*
|
||||||
|
* \return Number of samples read
|
||||||
|
*/
|
||||||
int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples)
|
int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples)
|
||||||
{
|
{
|
||||||
struct ast_frame *frame_ptr;
|
struct ast_frame *frame_ptr;
|
||||||
@@ -150,11 +185,25 @@ int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples)
|
|||||||
return sofar;
|
return sofar;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Retrieve number of samples currently in an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to peek into
|
||||||
|
*
|
||||||
|
* \return Number of samples in slinfactory
|
||||||
|
*/
|
||||||
unsigned int ast_slinfactory_available(const struct ast_slinfactory *sf)
|
unsigned int ast_slinfactory_available(const struct ast_slinfactory *sf)
|
||||||
{
|
{
|
||||||
return sf->size;
|
return sf->size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Flush the contents of an slinfactory
|
||||||
|
*
|
||||||
|
* \arg sf The slinfactory to flush
|
||||||
|
*
|
||||||
|
* \return Nothing
|
||||||
|
*/
|
||||||
void ast_slinfactory_flush(struct ast_slinfactory *sf)
|
void ast_slinfactory_flush(struct ast_slinfactory *sf)
|
||||||
{
|
{
|
||||||
struct ast_frame *fr = NULL;
|
struct ast_frame *fr = NULL;
|
||||||
|
Reference in New Issue
Block a user