ratox

FIFO based tox client
git clone git://git.2f30.org/ratox
Log | Files | Refs | README | LICENSE

commit d973b73e8457c464a433d625d2b938467a00bbf5
parent a89dbc70c04202951d100c2ed10ea3d45bd82ffd
Author: z3bra <contactatz3bradotorg>
Date:   Tue,  1 Nov 2016 09:16:45 +0100

Replace toxav_send_audio with toxav_audio_send_frame

Diffstat:
Mconfig.def.h | 6++++++
Mratox.c | 21++++++++-------------
2 files changed, 14 insertions(+), 13 deletions(-)

diff --git a/config.def.h b/config.def.h @@ -9,6 +9,12 @@ /* Maximum number of simultaneous calls */ #define MAXCALLS 8 +/* Audio settings definition */ +#define AUDIOCHANNELS 1 +#define AUDIOBITRATE 32 +#define AUDIOFRAME 20 +#define AUDIOSAMPLERATE 48000 + static char *savefile = ".ratox.tox"; static int encryptsavefile = 0; diff --git a/ratox.c b/ratox.c @@ -136,7 +136,6 @@ struct call { int num; int state; uint8_t *frame; - uint8_t payload[RTP_PAYLOAD_SIZE]; ssize_t n; struct timespec lastsent; }; @@ -514,9 +513,9 @@ cancelcall(struct friend *f, char *action) static void sendfriendcalldata(struct friend *f) { - struct timespec now, diff; - ssize_t n, payloadsize; - int r; + struct timespec now, diff; + ssize_t n, pcm; + uint16_t *buf; n = fiforead(f->dirfd, &f->fd[FCALL_IN], ffiles[FCALL_IN], f->av.frame + (f->av.state & INCOMPLETE) * f->av.n, @@ -535,13 +534,10 @@ sendfriendcalldata(struct friend *f) return; } - payloadsize = toxav_prepare_audio_frame(toxav, f->av.num, - f->av.payload, sizeof(f->av.payload), - (int16_t *)f->av.frame, framesize); - if (payloadsize < 0) { - weprintf("Failed to encode payload\n"); - return; - } + pcm = AUDIOFRAME * AUDIOSAMPLERATE / 1000; + buf = malloc(pcm * AUDIOCHANNEL * 2); + if (!buf) + eprintf("malloc:"); clock_gettime(CLOCK_MONOTONIC, &now); diff = timediff(f->av.lastsent, now); @@ -550,8 +546,7 @@ sendfriendcalldata(struct friend *f) nanosleep(&diff, NULL); } clock_gettime(CLOCK_MONOTONIC, &f->av.lastsent); - r = toxav_send_audio(toxav, f->av.num, f->av.payload, payloadsize); - if (r < 0) + if (!toxav_audio_send_frame(av, f->av.num, buf, pcm, AUDIOCHANNEL, AUDIOCHANNEL, NULL)) weprintf("Failed to send audio frame\n"); }