summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoshua Colp <jcolp@digium.com>2008-03-12 21:06:50 +0000
committerJoshua Colp <jcolp@digium.com>2008-03-12 21:06:50 +0000
commita3c7b08d19e0224fc5c1a71db90a666a73ee1f5f (patch)
tree555db47571c38baddfb3c3302c4f40516f0f4d32
parent5ebfa5638a1ef4be8880181ca2b39a9d553c8276 (diff)
Doxygenify slinfactory a bit.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@108226 65c4cc65-6c06-0410-ace0-fbb531ad65f3
-rw-r--r--include/asterisk/slinfactory.h59
-rw-r--r--main/slinfactory.c49
2 files changed, 99 insertions, 9 deletions
diff --git a/include/asterisk/slinfactory.h b/include/asterisk/slinfactory.h
index 603c648c7..386cf51ba 100644
--- a/include/asterisk/slinfactory.h
+++ b/include/asterisk/slinfactory.h
@@ -29,33 +29,74 @@ extern "C" {
#endif
struct ast_slinfactory {
- AST_LIST_HEAD_NOLOCK(, ast_frame) queue;
- struct ast_trans_pvt *trans;
- short hold[1280];
- short *offset;
- size_t holdlen; /*!< in samples */
- unsigned int size; /*!< in samples */
- unsigned int format;
+ AST_LIST_HEAD_NOLOCK(, ast_frame) queue; /*!< A list of unaltered frames */
+ struct ast_trans_pvt *trans; /*!< Translation path that converts fed frames into signed linear */
+ 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; /*!< Offset into the hold where audio begins */
+ size_t holdlen; /*!< Number of samples currently in the hold */
+ unsigned int size; /*!< Number of samples currently in the factory */
+ 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);
/*!
* \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
* 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
+ * \return Nothing
*/
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);
+
+/*!
+ * \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);
+
+/*!
+ * \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);
+
+/*!
+ * \brief Flush the contents of an slinfactory
+ *
+ * \arg sf The slinfactory to flush
+ *
+ * \return Nothing
+ */
void ast_slinfactory_flush(struct ast_slinfactory *sf);
#if defined(__cplusplus) || defined(c_plusplus)
diff --git a/main/slinfactory.c b/main/slinfactory.c
index adec9f3e8..6c1bdd6f9 100644
--- a/main/slinfactory.c
+++ b/main/slinfactory.c
@@ -32,12 +32,30 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
#include "asterisk/slinfactory.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)
{
memset(sf, 0, sizeof(*sf));
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)
{
struct ast_frame *f;
@@ -51,6 +69,14 @@ void ast_slinfactory_destroy(struct ast_slinfactory *sf)
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)
{
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;
}
+/*!
+ * \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)
{
struct ast_frame *frame_ptr;
@@ -150,11 +185,25 @@ int ast_slinfactory_read(struct ast_slinfactory *sf, short *buf, size_t samples)
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)
{
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)
{
struct ast_frame *fr = NULL;