Home | History | Annotate | Download | only in speex
      1 /* Copyright (C) 2002 Jean-Marc Valin*/
      2 /**
      3   @file speex_callbacks.h
      4   @brief Describes callback handling and in-band signalling
      5 */
      6 /*
      7    Redistribution and use in source and binary forms, with or without
      8    modification, are permitted provided that the following conditions
      9    are met:
     10 
     11    - Redistributions of source code must retain the above copyright
     12    notice, this list of conditions and the following disclaimer.
     13 
     14    - Redistributions in binary form must reproduce the above copyright
     15    notice, this list of conditions and the following disclaimer in the
     16    documentation and/or other materials provided with the distribution.
     17 
     18    - Neither the name of the Xiph.org Foundation nor the names of its
     19    contributors may be used to endorse or promote products derived from
     20    this software without specific prior written permission.
     21 
     22    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     23    ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     24    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
     25    A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
     26    CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
     27    EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
     28    PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
     29    PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
     30    LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
     31    NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
     32    SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     33 
     34 */
     35 
     36 #ifndef SPEEX_CALLBACKS_H
     37 #define SPEEX_CALLBACKS_H
     38 /** @defgroup SpeexCallbacks Various definitions for Speex callbacks supported by the decoder.
     39  *  @{
     40  */
     41 
     42 #include "speex.h"
     43 
     44 #ifdef __cplusplus
     45 extern "C" {
     46 #endif
     47 
     48 /** Total number of callbacks */
     49 #define SPEEX_MAX_CALLBACKS 16
     50 
     51 /* Describes all the in-band requests */
     52 
     53 /*These are 1-bit requests*/
     54 /** Request for perceptual enhancement (1 for on, 0 for off) */
     55 #define SPEEX_INBAND_ENH_REQUEST         0
     56 /** Reserved */
     57 #define SPEEX_INBAND_RESERVED1           1
     58 
     59 /*These are 4-bit requests*/
     60 /** Request for a mode change */
     61 #define SPEEX_INBAND_MODE_REQUEST        2
     62 /** Request for a low mode change */
     63 #define SPEEX_INBAND_LOW_MODE_REQUEST    3
     64 /** Request for a high mode change */
     65 #define SPEEX_INBAND_HIGH_MODE_REQUEST   4
     66 /** Request for VBR (1 on, 0 off) */
     67 #define SPEEX_INBAND_VBR_QUALITY_REQUEST 5
     68 /** Request to be sent acknowledge */
     69 #define SPEEX_INBAND_ACKNOWLEDGE_REQUEST 6
     70 /** Request for VBR (1 for on, 0 for off) */
     71 #define SPEEX_INBAND_VBR_REQUEST         7
     72 
     73 /*These are 8-bit requests*/
     74 /** Send a character in-band */
     75 #define SPEEX_INBAND_CHAR                8
     76 /** Intensity stereo information */
     77 #define SPEEX_INBAND_STEREO              9
     78 
     79 /*These are 16-bit requests*/
     80 /** Transmit max bit-rate allowed */
     81 #define SPEEX_INBAND_MAX_BITRATE         10
     82 
     83 /*These are 32-bit requests*/
     84 /** Acknowledge packet reception */
     85 #define SPEEX_INBAND_ACKNOWLEDGE         12
     86 
     87 /** Callback function type */
     88 typedef int (*speex_callback_func)(SpeexBits *bits, void *state, void *data);
     89 
     90 /** Callback information */
     91 typedef struct SpeexCallback {
     92    int callback_id;             /**< ID associated to the callback */
     93    speex_callback_func func;    /**< Callback handler function */
     94    void *data;                  /**< Data that will be sent to the handler */
     95    void *reserved1;             /**< Reserved for future use */
     96    int   reserved2;             /**< Reserved for future use */
     97 } SpeexCallback;
     98 
     99 /** Handle in-band request */
    100 int speex_inband_handler(SpeexBits *bits, SpeexCallback *callback_list, void *state);
    101 
    102 /** Standard handler for mode request (change mode, no questions asked) */
    103 int speex_std_mode_request_handler(SpeexBits *bits, void *state, void *data);
    104 
    105 /** Standard handler for high mode request (change high mode, no questions asked) */
    106 int speex_std_high_mode_request_handler(SpeexBits *bits, void *state, void *data);
    107 
    108 /** Standard handler for in-band characters (write to stderr) */
    109 int speex_std_char_handler(SpeexBits *bits, void *state, void *data);
    110 
    111 /** Default handler for user-defined requests: in this case, just ignore */
    112 int speex_default_user_handler(SpeexBits *bits, void *state, void *data);
    113 
    114 
    115 
    116 /** Standard handler for low mode request (change low mode, no questions asked) */
    117 int speex_std_low_mode_request_handler(SpeexBits *bits, void *state, void *data);
    118 
    119 /** Standard handler for VBR request (Set VBR, no questions asked) */
    120 int speex_std_vbr_request_handler(SpeexBits *bits, void *state, void *data);
    121 
    122 /** Standard handler for enhancer request (Turn enhancer on/off, no questions asked) */
    123 int speex_std_enh_request_handler(SpeexBits *bits, void *state, void *data);
    124 
    125 /** Standard handler for VBR quality request (Set VBR quality, no questions asked) */
    126 int speex_std_vbr_quality_request_handler(SpeexBits *bits, void *state, void *data);
    127 
    128 
    129 #ifdef __cplusplus
    130 }
    131 #endif
    132 
    133 /** @} */
    134 #endif
    135