2005-11-19 20:07:43 +00:00
|
|
|
/*
|
|
|
|
* FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
|
|
|
|
* Copyright (C) 2005/2006, Anthony Minessale II <anthmct@yahoo.com>
|
|
|
|
*
|
|
|
|
* Version: MPL 1.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Anthony Minessale II <anthmct@yahoo.com>
|
|
|
|
* Portions created by the Initial Developer are Copyright (C)
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
*
|
|
|
|
* Anthony Minessale II <anthmct@yahoo.com>
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* switch_buffer.h -- Data Buffering Code
|
|
|
|
*
|
|
|
|
*/
|
2006-01-10 20:10:38 +00:00
|
|
|
/**
|
|
|
|
* @file switch_buffer.h
|
|
|
|
* @brief Data Buffering Code
|
|
|
|
* @see switch_buffer
|
|
|
|
*/
|
2006-01-01 15:23:12 +00:00
|
|
|
|
2005-11-19 20:07:43 +00:00
|
|
|
#ifndef SWITCH_BUFFER_H
|
|
|
|
#define SWITCH_BUFFER_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <switch.h>
|
|
|
|
|
2006-01-02 22:45:50 +00:00
|
|
|
/**
|
|
|
|
* @defgroup switch_buffer Buffer Routines
|
|
|
|
* @ingroup FREESWITCH
|
2006-01-10 20:10:38 +00:00
|
|
|
* The purpose of this module is to make a plain buffering interface that can be used for read/write buffers
|
|
|
|
* throughout the application. The first implementation was done to provide the functionality and the interface
|
|
|
|
* and I think it can be optimized under the hood as we go using bucket brigades and/or ring buffering techniques.
|
2006-01-02 22:45:50 +00:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2006-01-03 00:48:52 +00:00
|
|
|
struct switch_buffer;
|
|
|
|
|
|
|
|
|
2006-01-02 05:00:28 +00:00
|
|
|
/*! \brief Allocate a new switch_buffer
|
|
|
|
* \param pool Pool to allocate the buffer from
|
|
|
|
* \param buffer returned pointer to the new buffer
|
|
|
|
* \param max_len length required by the buffer
|
|
|
|
* \return status
|
|
|
|
*/
|
2006-03-30 23:02:50 +00:00
|
|
|
SWITCH_DECLARE(switch_status) switch_buffer_create(switch_memory_pool *pool, switch_buffer **buffer, switch_size_t max_len);
|
2006-01-01 15:23:12 +00:00
|
|
|
|
2006-01-02 05:00:28 +00:00
|
|
|
/*! \brief Get the length of a switch_buffer
|
|
|
|
* \param buffer any buffer of type switch_buffer
|
|
|
|
* \return int size of the buffer.
|
|
|
|
*/
|
2006-03-30 23:02:50 +00:00
|
|
|
SWITCH_DECLARE(switch_size_t) switch_buffer_len(switch_buffer *buffer);
|
2006-01-01 15:23:12 +00:00
|
|
|
|
2006-01-02 05:00:28 +00:00
|
|
|
/*! \brief Get the freespace of a switch_buffer
|
|
|
|
* \param buffer any buffer of type switch_buffer
|
|
|
|
* \return int freespace in the buffer.
|
|
|
|
*/
|
2006-03-30 23:02:50 +00:00
|
|
|
SWITCH_DECLARE(switch_size_t) switch_buffer_freespace(switch_buffer *buffer);
|
2006-01-01 15:23:12 +00:00
|
|
|
|
2006-01-02 05:00:28 +00:00
|
|
|
/*! \brief Get the in use amount of a switch_buffer
|
|
|
|
* \param buffer any buffer of type switch_buffer
|
2006-01-03 00:48:52 +00:00
|
|
|
* \return int ammount of buffer curently in use
|
2006-01-02 05:00:28 +00:00
|
|
|
*/
|
2006-03-30 23:02:50 +00:00
|
|
|
SWITCH_DECLARE(switch_size_t) switch_buffer_inuse(switch_buffer *buffer);
|
2006-01-01 15:23:12 +00:00
|
|
|
|
2006-01-02 05:00:28 +00:00
|
|
|
/*! \brief Read data from a switch_buffer up to the ammount of datalen if it is available. Remove read data from buffer.
|
|
|
|
* \param buffer any buffer of type switch_buffer
|
|
|
|
* \param data pointer to the read data to be returned
|
|
|
|
* \param datalen amount of data to be returned
|
|
|
|
* \return int ammount of data actually read
|
|
|
|
*/
|
2006-03-30 23:02:50 +00:00
|
|
|
SWITCH_DECLARE(switch_size_t) switch_buffer_read(switch_buffer *buffer, void *data, switch_size_t datalen);
|
2006-01-01 15:23:12 +00:00
|
|
|
|
2006-01-02 05:00:28 +00:00
|
|
|
/*! \brief Write data into a switch_buffer up to the length of datalen
|
|
|
|
* \param buffer any buffer of type switch_buffer
|
|
|
|
* \param data pointer to the data to be written
|
|
|
|
* \param datalen amount of data to be written
|
2006-01-05 21:03:22 +00:00
|
|
|
* \return int amount of buffer used after the write, or 0 if no space available
|
2006-01-02 05:00:28 +00:00
|
|
|
*/
|
2006-03-30 23:02:50 +00:00
|
|
|
SWITCH_DECLARE(switch_size_t) switch_buffer_write(switch_buffer *buffer, void *data, switch_size_t datalen);
|
2006-01-01 15:23:12 +00:00
|
|
|
|
2006-01-02 05:00:28 +00:00
|
|
|
/*! \brief Remove data from the buffer
|
|
|
|
* \param buffer any buffer of type switch_buffer
|
2006-01-05 21:03:22 +00:00
|
|
|
* \param datalen amount of data to be removed
|
2006-01-03 00:48:52 +00:00
|
|
|
* \return int size of buffer, or 0 if unable to toss that much data
|
2006-01-02 05:00:28 +00:00
|
|
|
*/
|
2006-03-30 23:02:50 +00:00
|
|
|
SWITCH_DECLARE(switch_size_t) switch_buffer_toss(switch_buffer *buffer, switch_size_t datalen);
|
2006-02-28 02:08:42 +00:00
|
|
|
|
|
|
|
/*! \brief Remove all data from the buffer
|
|
|
|
* \param buffer any buffer of type switch_buffer
|
|
|
|
*/
|
|
|
|
SWITCH_DECLARE(void) switch_buffer_zero(switch_buffer *buffer);
|
2006-01-02 22:45:50 +00:00
|
|
|
/** @} */
|
2005-11-19 20:07:43 +00:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|