123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- #ifdef HAVE_CONFIG_H
- #include "config.h"
- #endif
- #include "os_support.h"
- #include "arch.h"
- #include "speex/speex_buffer.h"
- struct SpeexBuffer_ {
- char *data;
- int size;
- int read_ptr;
- int write_ptr;
- int available;
- };
- EXPORT SpeexBuffer *speex_buffer_init(int size)
- {
- SpeexBuffer *st = speex_alloc(sizeof(SpeexBuffer));
- st->data = speex_alloc(size);
- st->size = size;
- st->read_ptr = 0;
- st->write_ptr = 0;
- st->available = 0;
- return st;
- }
- EXPORT void speex_buffer_destroy(SpeexBuffer *st)
- {
- speex_free(st->data);
- speex_free(st);
- }
- EXPORT int speex_buffer_write(SpeexBuffer *st, void *_data, int len)
- {
- int end;
- int end1;
- char *data = _data;
- if (len > st->size)
- {
- data += len-st->size;
- len = st->size;
- }
- end = st->write_ptr + len;
- end1 = end;
- if (end1 > st->size)
- end1 = st->size;
- SPEEX_COPY(st->data + st->write_ptr, data, end1 - st->write_ptr);
- if (end > st->size)
- {
- end -= st->size;
- SPEEX_COPY(st->data, data+end1 - st->write_ptr, end);
- }
- st->available += len;
- if (st->available > st->size)
- {
- st->available = st->size;
- st->read_ptr = st->write_ptr;
- }
- st->write_ptr += len;
- if (st->write_ptr > st->size)
- st->write_ptr -= st->size;
- return len;
- }
- EXPORT int speex_buffer_writezeros(SpeexBuffer *st, int len)
- {
-
- int end;
- int end1;
- if (len > st->size)
- {
- len = st->size;
- }
- end = st->write_ptr + len;
- end1 = end;
- if (end1 > st->size)
- end1 = st->size;
- SPEEX_MEMSET(st->data + st->write_ptr, 0, end1 - st->write_ptr);
- if (end > st->size)
- {
- end -= st->size;
- SPEEX_MEMSET(st->data, 0, end);
- }
- st->available += len;
- if (st->available > st->size)
- {
- st->available = st->size;
- st->read_ptr = st->write_ptr;
- }
- st->write_ptr += len;
- if (st->write_ptr > st->size)
- st->write_ptr -= st->size;
- return len;
- }
- EXPORT int speex_buffer_read(SpeexBuffer *st, void *_data, int len)
- {
- int end, end1;
- char *data = _data;
- if (len > st->available)
- {
- SPEEX_MEMSET(data+st->available, 0, len - st->available);
- len = st->available;
- }
- end = st->read_ptr + len;
- end1 = end;
- if (end1 > st->size)
- end1 = st->size;
- SPEEX_COPY(data, st->data + st->read_ptr, end1 - st->read_ptr);
- if (end > st->size)
- {
- end -= st->size;
- SPEEX_COPY(data+end1 - st->read_ptr, st->data, end);
- }
- st->available -= len;
- st->read_ptr += len;
- if (st->read_ptr > st->size)
- st->read_ptr -= st->size;
- return len;
- }
- EXPORT int speex_buffer_get_available(SpeexBuffer *st)
- {
- return st->available;
- }
- EXPORT int speex_buffer_resize(SpeexBuffer *st, int len)
- {
- int old_len = st->size;
- if (len > old_len)
- {
- st->data = speex_realloc(st->data, len);
-
- } else {
-
- st->data = speex_realloc(st->data, len);
- }
- return len;
- }
|