mirror of
https://github.com/Tha14/toxic.git
synced 2024-11-22 20:33:02 +01:00
Astyle everything and add an astyle options script to repo
This commit is contained in:
parent
3515623159
commit
f056f13329
11
astylerc
Normal file
11
astylerc
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
--style=kr
|
||||||
|
--pad-header
|
||||||
|
--max-code-length=120
|
||||||
|
--convert-tabs
|
||||||
|
--indent-switches
|
||||||
|
--pad-oper
|
||||||
|
--align-pointer=name
|
||||||
|
--align-reference=name
|
||||||
|
--preserve-date
|
||||||
|
--lineend=linux
|
||||||
|
--break-blocks
|
@ -75,9 +75,9 @@ static int set_call(Call* call, bool start)
|
|||||||
|
|
||||||
if ( pthread_mutex_init(&call->mutex, NULL) != 0 )
|
if ( pthread_mutex_init(&call->mutex, NULL) != 0 )
|
||||||
return -1;
|
return -1;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
call->ttid = 0;
|
call->ttid = 0;
|
||||||
|
|
||||||
if ( pthread_mutex_destroy(&call->mutex) != 0 )
|
if ( pthread_mutex_destroy(&call->mutex) != 0 )
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -85,7 +85,8 @@ static int set_call(Call* call, bool start)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void call_cb ( ToxAV *av, uint32_t friend_number, bool audio_enabled, bool video_enabled, void *user_data );
|
void call_cb ( ToxAV *av, uint32_t friend_number, bool audio_enabled, bool video_enabled,
|
||||||
|
void *user_data );
|
||||||
void callstate_cb ( ToxAV *av, uint32_t friend_number, uint32_t state, void *user_data );
|
void callstate_cb ( ToxAV *av, uint32_t friend_number, uint32_t state, void *user_data );
|
||||||
void receive_audio_frame_cb ( ToxAV *av, uint32_t friend_number, int16_t const *pcm, size_t sample_count,
|
void receive_audio_frame_cb ( ToxAV *av, uint32_t friend_number, int16_t const *pcm, size_t sample_count,
|
||||||
uint8_t channels, uint32_t sampling_rate, void *user_data );
|
uint8_t channels, uint32_t sampling_rate, void *user_data );
|
||||||
@ -158,6 +159,7 @@ ToxAV *init_audio(ToxWindow *self, Tox *tox)
|
|||||||
void terminate_audio()
|
void terminate_audio()
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_CALLS; ++i)
|
for (i = 0; i < MAX_CALLS; ++i)
|
||||||
stop_transmission(&CallControl.calls[i], i);
|
stop_transmission(&CallControl.calls[i], i);
|
||||||
|
|
||||||
@ -177,8 +179,8 @@ void read_device_callback(const int16_t* captured, uint32_t size, void* data)
|
|||||||
if ( sample_count <= 0 || toxav_audio_send_frame(CallControl.av, friend_number,
|
if ( sample_count <= 0 || toxav_audio_send_frame(CallControl.av, friend_number,
|
||||||
captured, sample_count,
|
captured, sample_count,
|
||||||
CallControl.audio_channels,
|
CallControl.audio_channels,
|
||||||
CallControl.audio_sample_rate, &error) == false )
|
CallControl.audio_sample_rate, &error) == false ) {
|
||||||
{}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void write_device_callback(uint32_t friend_number, const int16_t *PCM, uint16_t sample_count, uint8_t channels,
|
void write_device_callback(uint32_t friend_number, const int16_t *PCM, uint16_t sample_count, uint8_t channels,
|
||||||
@ -287,6 +289,7 @@ void callstate_cb(ToxAV *av, uint32_t friend_number, uint32_t state, void *user_
|
|||||||
CallControl.pending_call = false;
|
CallControl.pending_call = false;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ( TOXAV_FRIEND_CALL_STATE_FINISHED ):
|
case ( TOXAV_FRIEND_CALL_STATE_FINISHED ):
|
||||||
if ( CallControl.pending_call )
|
if ( CallControl.pending_call )
|
||||||
callback_call_rejected(friend_number);
|
callback_call_rejected(friend_number);
|
||||||
@ -305,6 +308,7 @@ void callstate_cb(ToxAV *av, uint32_t friend_number, uint32_t state, void *user_
|
|||||||
CallControl.pending_call = false;
|
CallControl.pending_call = false;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if ( CallControl.pending_call ) {
|
if ( CallControl.pending_call ) {
|
||||||
/* Start answered call */
|
/* Start answered call */
|
||||||
@ -313,6 +317,7 @@ void callstate_cb(ToxAV *av, uint32_t friend_number, uint32_t state, void *user_
|
|||||||
|
|
||||||
} else {
|
} else {
|
||||||
#ifdef VIDEO
|
#ifdef VIDEO
|
||||||
|
|
||||||
/* Handle receiving client video call states */
|
/* Handle receiving client video call states */
|
||||||
if ( state & TOXAV_FRIEND_CALL_STATE_SENDING_V )
|
if ( state & TOXAV_FRIEND_CALL_STATE_SENDING_V )
|
||||||
callback_recv_video_starting(friend_number);
|
callback_recv_video_starting(friend_number);
|
||||||
@ -376,9 +381,11 @@ void callback_recv_starting(uint32_t friend_number)
|
|||||||
ToxWindow *windows = CallControl.prompt;
|
ToxWindow *windows = CallControl.prompt;
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
||||||
if ( windows[i].onStarting != NULL && windows[i].num == friend_number ) {
|
if ( windows[i].onStarting != NULL && windows[i].num == friend_number ) {
|
||||||
windows[i].onStarting(&windows[i], CallControl.av, friend_number, CallControl.call_state);
|
windows[i].onStarting(&windows[i], CallControl.av, friend_number, CallControl.call_state);
|
||||||
|
|
||||||
if ( 0 != start_transmission(&windows[i], &CallControl.calls[friend_number]) ) /* YEAH! */
|
if ( 0 != start_transmission(&windows[i], &CallControl.calls[friend_number]) ) /* YEAH! */
|
||||||
line_info_add(&windows[i], NULL, NULL, NULL, SYS_MSG, 0, 0 , "Error starting transmission!");
|
line_info_add(&windows[i], NULL, NULL, NULL, SYS_MSG, 0, 0 , "Error starting transmission!");
|
||||||
|
|
||||||
@ -402,9 +409,11 @@ void callback_call_started(uint32_t friend_number)
|
|||||||
ToxWindow *windows = CallControl.prompt;
|
ToxWindow *windows = CallControl.prompt;
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_WINDOWS_NUM; ++i)
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i)
|
||||||
if ( windows[i].onStart != NULL && windows[i].num == friend_number ) {
|
if ( windows[i].onStart != NULL && windows[i].num == friend_number ) {
|
||||||
windows[i].onStart(&windows[i], CallControl.av, friend_number, CallControl.call_state);
|
windows[i].onStart(&windows[i], CallControl.av, friend_number, CallControl.call_state);
|
||||||
|
|
||||||
if ( 0 != start_transmission(&windows[i], &CallControl.calls[friend_number]) ) {/* YEAH! */
|
if ( 0 != start_transmission(&windows[i], &CallControl.calls[friend_number]) ) {/* YEAH! */
|
||||||
line_info_add(&windows[i], NULL, NULL, NULL, SYS_MSG, 0, 0, "Error starting transmission!");
|
line_info_add(&windows[i], NULL, NULL, NULL, SYS_MSG, 0, 0, "Error starting transmission!");
|
||||||
return;
|
return;
|
||||||
@ -479,6 +488,7 @@ void cmd_call(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MA
|
|||||||
}
|
}
|
||||||
|
|
||||||
toxav_call(CallControl.av, self->num, CallControl.audio_bit_rate, CallControl.video_bit_rate, &error);
|
toxav_call(CallControl.av, self->num, CallControl.audio_bit_rate, CallControl.video_bit_rate, &error);
|
||||||
|
|
||||||
if ( error != TOXAV_ERR_CALL_OK ) {
|
if ( error != TOXAV_ERR_CALL_OK ) {
|
||||||
if ( error == TOXAV_ERR_CALL_FRIEND_ALREADY_IN_CALL ) error_str = "Already in a call!";
|
if ( error == TOXAV_ERR_CALL_FRIEND_ALREADY_IN_CALL ) error_str = "Already in a call!";
|
||||||
else if ( error == TOXAV_ERR_CALL_MALLOC ) error_str = "Memory allocation issue";
|
else if ( error == TOXAV_ERR_CALL_MALLOC ) error_str = "Memory allocation issue";
|
||||||
@ -518,6 +528,7 @@ void cmd_answer(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[
|
|||||||
}
|
}
|
||||||
|
|
||||||
toxav_answer(CallControl.av, self->num, CallControl.audio_bit_rate, CallControl.video_bit_rate, &error);
|
toxav_answer(CallControl.av, self->num, CallControl.audio_bit_rate, CallControl.video_bit_rate, &error);
|
||||||
|
|
||||||
if ( error != TOXAV_ERR_ANSWER_OK ) {
|
if ( error != TOXAV_ERR_ANSWER_OK ) {
|
||||||
if ( error == TOXAV_ERR_ANSWER_FRIEND_NOT_CALLING ) error_str = "No incoming call!";
|
if ( error == TOXAV_ERR_ANSWER_FRIEND_NOT_CALLING ) error_str = "No incoming call!";
|
||||||
else if ( error == TOXAV_ERR_ANSWER_CODEC_INITIALIZATION ) error_str = "Failed to initialize codecs!";
|
else if ( error == TOXAV_ERR_ANSWER_CODEC_INITIALIZATION ) error_str = "Failed to initialize codecs!";
|
||||||
@ -715,6 +726,7 @@ void cmd_ccur_device(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*a
|
|||||||
/* If call is active, change device */
|
/* If call is active, change device */
|
||||||
if ( self->is_call ) {
|
if ( self->is_call ) {
|
||||||
Call *this_call = &CallControl.calls[self->num];
|
Call *this_call = &CallControl.calls[self->num];
|
||||||
|
|
||||||
if ( this_call->ttas ) {
|
if ( this_call->ttas ) {
|
||||||
|
|
||||||
|
|
||||||
@ -725,8 +737,7 @@ void cmd_ccur_device(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*a
|
|||||||
CallControl.audio_sample_rate, CallControl.audio_frame_duration, CallControl.audio_channels)
|
CallControl.audio_sample_rate, CallControl.audio_frame_duration, CallControl.audio_channels)
|
||||||
== de_None ? 1 : 0;
|
== de_None ? 1 : 0;
|
||||||
pthread_mutex_unlock(&this_call->mutex);
|
pthread_mutex_unlock(&this_call->mutex);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
/* TODO: check for failure */
|
/* TODO: check for failure */
|
||||||
close_device(input, this_call->in_idx);
|
close_device(input, this_call->in_idx);
|
||||||
open_device(input, selection, &this_call->in_idx, CallControl.audio_sample_rate,
|
open_device(input, selection, &this_call->in_idx, CallControl.audio_sample_rate,
|
||||||
@ -774,6 +785,7 @@ void cmd_mute(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MA
|
|||||||
Call *this_call = &CallControl.calls[self->num];
|
Call *this_call = &CallControl.calls[self->num];
|
||||||
|
|
||||||
pthread_mutex_lock(&this_call->mutex);
|
pthread_mutex_lock(&this_call->mutex);
|
||||||
|
|
||||||
if ( type == input ) {
|
if ( type == input ) {
|
||||||
device_mute(type, this_call->in_idx);
|
device_mute(type, this_call->in_idx);
|
||||||
self->chatwin->infobox.in_is_muted ^= 1;
|
self->chatwin->infobox.in_is_muted ^= 1;
|
||||||
@ -781,6 +793,7 @@ void cmd_mute(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MA
|
|||||||
device_mute(type, this_call->out_idx);
|
device_mute(type, this_call->out_idx);
|
||||||
self->chatwin->infobox.out_is_muted ^= 1;
|
self->chatwin->infobox.out_is_muted ^= 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
pthread_mutex_unlock(&this_call->mutex);
|
pthread_mutex_unlock(&this_call->mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -103,6 +103,7 @@ DeviceError init_devices()
|
|||||||
const char *stringed_device_list;
|
const char *stringed_device_list;
|
||||||
|
|
||||||
size[input] = 0;
|
size[input] = 0;
|
||||||
|
|
||||||
if ( (stringed_device_list = alcGetString(NULL, ALC_CAPTURE_DEVICE_SPECIFIER)) ) {
|
if ( (stringed_device_list = alcGetString(NULL, ALC_CAPTURE_DEVICE_SPECIFIER)) ) {
|
||||||
ddevice_names[input] = alcGetString(NULL, ALC_CAPTURE_DEFAULT_DEVICE_SPECIFIER);
|
ddevice_names[input] = alcGetString(NULL, ALC_CAPTURE_DEFAULT_DEVICE_SPECIFIER);
|
||||||
|
|
||||||
@ -113,10 +114,12 @@ DeviceError init_devices()
|
|||||||
}
|
}
|
||||||
|
|
||||||
size[output] = 0;
|
size[output] = 0;
|
||||||
|
|
||||||
if (alcIsExtensionPresent(NULL, "ALC_ENUMERATE_ALL_EXT") != AL_FALSE)
|
if (alcIsExtensionPresent(NULL, "ALC_ENUMERATE_ALL_EXT") != AL_FALSE)
|
||||||
stringed_device_list = alcGetString(NULL, ALC_ALL_DEVICES_SPECIFIER);
|
stringed_device_list = alcGetString(NULL, ALC_ALL_DEVICES_SPECIFIER);
|
||||||
else
|
else
|
||||||
stringed_device_list = alcGetString(NULL, ALC_DEVICE_SPECIFIER);
|
stringed_device_list = alcGetString(NULL, ALC_DEVICE_SPECIFIER);
|
||||||
|
|
||||||
if (stringed_device_list) {
|
if (stringed_device_list) {
|
||||||
ddevice_names[output] = alcGetString(NULL, ALC_DEFAULT_DEVICE_SPECIFIER);
|
ddevice_names[output] = alcGetString(NULL, ALC_DEFAULT_DEVICE_SPECIFIER);
|
||||||
|
|
||||||
@ -131,6 +134,7 @@ DeviceError init_devices()
|
|||||||
return de_InternalError;
|
return de_InternalError;
|
||||||
|
|
||||||
pthread_t thread_id;
|
pthread_t thread_id;
|
||||||
|
|
||||||
if ( pthread_create(&thread_id, NULL, thread_poll, NULL) != 0 || pthread_detach(thread_id) != 0)
|
if ( pthread_create(&thread_id, NULL, thread_poll, NULL) != 0 || pthread_detach(thread_id) != 0)
|
||||||
return de_InternalError;
|
return de_InternalError;
|
||||||
|
|
||||||
@ -159,6 +163,7 @@ DeviceError terminate_devices()
|
|||||||
DeviceError device_mute(DeviceType type, uint32_t device_idx)
|
DeviceError device_mute(DeviceType type, uint32_t device_idx)
|
||||||
{
|
{
|
||||||
if (device_idx >= MAX_DEVICES) return de_InvalidSelection;
|
if (device_idx >= MAX_DEVICES) return de_InvalidSelection;
|
||||||
|
|
||||||
lock;
|
lock;
|
||||||
|
|
||||||
Device *device = running[type][device_idx];
|
Device *device = running[type][device_idx];
|
||||||
@ -178,6 +183,7 @@ DeviceError device_mute(DeviceType type, uint32_t device_idx)
|
|||||||
DeviceError device_set_VAD_treshold(uint32_t device_idx, float value)
|
DeviceError device_set_VAD_treshold(uint32_t device_idx, float value)
|
||||||
{
|
{
|
||||||
if (device_idx >= MAX_DEVICES) return de_InvalidSelection;
|
if (device_idx >= MAX_DEVICES) return de_InvalidSelection;
|
||||||
|
|
||||||
lock;
|
lock;
|
||||||
|
|
||||||
Device *device = running[input][device_idx];
|
Device *device = running[input][device_idx];
|
||||||
@ -198,12 +204,14 @@ DeviceError device_set_VAD_treshold(uint32_t device_idx, float value)
|
|||||||
DeviceError set_primary_device(DeviceType type, int32_t selection)
|
DeviceError set_primary_device(DeviceType type, int32_t selection)
|
||||||
{
|
{
|
||||||
if (size[type] <= selection || selection < 0) return de_InvalidSelection;
|
if (size[type] <= selection || selection < 0) return de_InvalidSelection;
|
||||||
|
|
||||||
primary_device[type] = selection;
|
primary_device[type] = selection;
|
||||||
|
|
||||||
return de_None;
|
return de_None;
|
||||||
}
|
}
|
||||||
|
|
||||||
DeviceError open_primary_device(DeviceType type, uint32_t* device_idx, uint32_t sample_rate, uint32_t frame_duration, uint8_t channels)
|
DeviceError open_primary_device(DeviceType type, uint32_t *device_idx, uint32_t sample_rate, uint32_t frame_duration,
|
||||||
|
uint8_t channels)
|
||||||
{
|
{
|
||||||
return open_device(type, primary_device[type], device_idx, sample_rate, frame_duration, channels);
|
return open_device(type, primary_device[type], device_idx, sample_rate, frame_duration, channels);
|
||||||
}
|
}
|
||||||
@ -214,7 +222,8 @@ void get_primary_device_name(DeviceType type, char *buf, int size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO: generate buffers separately
|
// TODO: generate buffers separately
|
||||||
DeviceError open_device(DeviceType type, int32_t selection, uint32_t* device_idx, uint32_t sample_rate, uint32_t frame_duration, uint8_t channels)
|
DeviceError open_device(DeviceType type, int32_t selection, uint32_t *device_idx, uint32_t sample_rate,
|
||||||
|
uint32_t frame_duration, uint8_t channels)
|
||||||
{
|
{
|
||||||
if (size[type] <= selection || selection < 0) return de_InvalidSelection;
|
if (size[type] <= selection || selection < 0) return de_InvalidSelection;
|
||||||
|
|
||||||
@ -225,10 +234,13 @@ DeviceError open_device(DeviceType type, int32_t selection, uint32_t* device_idx
|
|||||||
const uint32_t frame_size = (sample_rate * frame_duration / 1000);
|
const uint32_t frame_size = (sample_rate * frame_duration / 1000);
|
||||||
|
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_DEVICES && running[type][i] != NULL; ++i);
|
for (i = 0; i < MAX_DEVICES && running[type][i] != NULL; ++i);
|
||||||
|
|
||||||
if (i == MAX_DEVICES) { unlock; return de_AllDevicesBusy; }
|
if (i == MAX_DEVICES) {
|
||||||
else *device_idx = i;
|
unlock;
|
||||||
|
return de_AllDevicesBusy;
|
||||||
|
} else *device_idx = i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_DEVICES; i ++) { /* Check if any device has the same selection */
|
for (i = 0; i < MAX_DEVICES; i ++) { /* Check if any device has the same selection */
|
||||||
if ( running[type][i] && running[type][i]->selection == selection ) {
|
if ( running[type][i] && running[type][i]->selection == selection ) {
|
||||||
@ -261,9 +273,9 @@ DeviceError open_device(DeviceType type, int32_t selection, uint32_t* device_idx
|
|||||||
#ifdef AUDIO
|
#ifdef AUDIO
|
||||||
device->VAD_treshold = user_settings->VAD_treshold;
|
device->VAD_treshold = user_settings->VAD_treshold;
|
||||||
#endif
|
#endif
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
device->dhndl = alcOpenDevice(devices_names[type][selection]);
|
device->dhndl = alcOpenDevice(devices_names[type][selection]);
|
||||||
|
|
||||||
if ( !device->dhndl ) {
|
if ( !device->dhndl ) {
|
||||||
free(device);
|
free(device);
|
||||||
running[type][*device_idx] = NULL;
|
running[type][*device_idx] = NULL;
|
||||||
@ -323,27 +335,28 @@ DeviceError close_device(DeviceType type, uint32_t device_idx)
|
|||||||
if ( !device->ref_count ) {
|
if ( !device->ref_count ) {
|
||||||
if (type == input) {
|
if (type == input) {
|
||||||
if ( !alcCaptureCloseDevice(device->dhndl) ) rc = de_AlError;
|
if ( !alcCaptureCloseDevice(device->dhndl) ) rc = de_AlError;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
if (alcGetCurrentContext() != device->ctx) alcMakeContextCurrent(device->ctx);
|
if (alcGetCurrentContext() != device->ctx) alcMakeContextCurrent(device->ctx);
|
||||||
|
|
||||||
alDeleteSources(1, &device->source);
|
alDeleteSources(1, &device->source);
|
||||||
alDeleteBuffers(OPENAL_BUFS, device->buffers);
|
alDeleteBuffers(OPENAL_BUFS, device->buffers);
|
||||||
|
|
||||||
alcMakeContextCurrent(NULL);
|
alcMakeContextCurrent(NULL);
|
||||||
|
|
||||||
if ( device->ctx ) alcDestroyContext(device->ctx);
|
if ( device->ctx ) alcDestroyContext(device->ctx);
|
||||||
|
|
||||||
if ( !alcCloseDevice(device->dhndl) ) rc = de_AlError;
|
if ( !alcCloseDevice(device->dhndl) ) rc = de_AlError;
|
||||||
}
|
}
|
||||||
|
|
||||||
free(device);
|
free(device);
|
||||||
}
|
} else device->ref_count--;
|
||||||
else device->ref_count--;
|
|
||||||
|
|
||||||
unlock;
|
unlock;
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
DeviceError register_device_callback( int32_t friend_number, uint32_t device_idx, DataHandleCallback callback, void* data, bool enable_VAD)
|
DeviceError register_device_callback( int32_t friend_number, uint32_t device_idx, DataHandleCallback callback,
|
||||||
|
void *data, bool enable_VAD)
|
||||||
{
|
{
|
||||||
if (size[input] <= device_idx || !running[input][device_idx] || running[input][device_idx]->dhndl == NULL)
|
if (size[input] <= device_idx || !running[input][device_idx] || running[input][device_idx]->dhndl == NULL)
|
||||||
return de_InvalidSelection;
|
return de_InvalidSelection;
|
||||||
@ -380,15 +393,15 @@ inline__ DeviceError write_out(uint32_t device_idx, const int16_t* data, uint32_
|
|||||||
alSourceUnqueueBuffers(device->source, processed, bufids);
|
alSourceUnqueueBuffers(device->source, processed, bufids);
|
||||||
alDeleteBuffers(processed - 1, bufids + 1);
|
alDeleteBuffers(processed - 1, bufids + 1);
|
||||||
bufid = bufids[0];
|
bufid = bufids[0];
|
||||||
}
|
} else if (queued < 16) alGenBuffers(1, &bufid);
|
||||||
else if(queued < 16) alGenBuffers(1, &bufid);
|
|
||||||
else {
|
else {
|
||||||
pthread_mutex_unlock(device->mutex);
|
pthread_mutex_unlock(device->mutex);
|
||||||
return de_Busy;
|
return de_Busy;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
alBufferData(bufid, channels == 1 ? AL_FORMAT_MONO16 : AL_FORMAT_STEREO16, data, sample_count * 2 * channels, sample_rate);
|
alBufferData(bufid, channels == 1 ? AL_FORMAT_MONO16 : AL_FORMAT_STEREO16, data, sample_count * 2 * channels,
|
||||||
|
sample_rate);
|
||||||
alSourceQueueBuffers(device->source, 1, &bufid);
|
alSourceQueueBuffers(device->source, 1, &bufid);
|
||||||
|
|
||||||
ALint state;
|
ALint state;
|
||||||
@ -411,9 +424,9 @@ void* thread_poll (void* arg) // TODO: maybe use thread for every input source
|
|||||||
int32_t sample = 0;
|
int32_t sample = 0;
|
||||||
|
|
||||||
|
|
||||||
while (1)
|
while (1) {
|
||||||
{
|
|
||||||
lock;
|
lock;
|
||||||
|
|
||||||
if (!thread_running) {
|
if (!thread_running) {
|
||||||
unlock;
|
unlock;
|
||||||
break;
|
break;
|
||||||
@ -430,6 +443,7 @@ void* thread_poll (void* arg) // TODO: maybe use thread for every input source
|
|||||||
else {
|
else {
|
||||||
for (i = 0; i < size[input]; ++i) {
|
for (i = 0; i < size[input]; ++i) {
|
||||||
lock;
|
lock;
|
||||||
|
|
||||||
if (running[input][i] != NULL) {
|
if (running[input][i] != NULL) {
|
||||||
alcGetIntegerv(running[input][i]->dhndl, ALC_CAPTURE_SAMPLES, sizeof(int32_t), &sample);
|
alcGetIntegerv(running[input][i]->dhndl, ALC_CAPTURE_SAMPLES, sizeof(int32_t), &sample);
|
||||||
|
|
||||||
@ -439,6 +453,7 @@ void* thread_poll (void* arg) // TODO: maybe use thread for every input source
|
|||||||
unlock;
|
unlock;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
Device *device = running[input][i];
|
Device *device = running[input][i];
|
||||||
|
|
||||||
int16_t frame[16000];
|
int16_t frame[16000];
|
||||||
@ -451,8 +466,10 @@ void* thread_poll (void* arg) // TODO: maybe use thread for every input source
|
|||||||
|
|
||||||
if ( device->cb ) device->cb(frame, f_size, device->cb_data);
|
if ( device->cb ) device->cb(frame, f_size, device->cb_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock;
|
unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
usleep(5000);
|
usleep(5000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -64,7 +64,8 @@ DeviceError init_devices();
|
|||||||
DeviceError terminate_devices();
|
DeviceError terminate_devices();
|
||||||
|
|
||||||
/* Callback handles ready data from INPUT device */
|
/* Callback handles ready data from INPUT device */
|
||||||
DeviceError register_device_callback(int32_t friend_number, uint32_t device_idx, DataHandleCallback callback, void* data, bool enable_VAD);
|
DeviceError register_device_callback(int32_t friend_number, uint32_t device_idx, DataHandleCallback callback,
|
||||||
|
void *data, bool enable_VAD);
|
||||||
void *get_device_callback_data(uint32_t device_idx);
|
void *get_device_callback_data(uint32_t device_idx);
|
||||||
|
|
||||||
/* toggle device mute */
|
/* toggle device mute */
|
||||||
@ -75,14 +76,17 @@ DeviceError device_set_VAD_treshold(uint32_t device_idx, float value);
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
DeviceError set_primary_device(DeviceType type, int32_t selection);
|
DeviceError set_primary_device(DeviceType type, int32_t selection);
|
||||||
DeviceError open_primary_device(DeviceType type, uint32_t* device_idx, uint32_t sample_rate, uint32_t frame_duration, uint8_t channels);
|
DeviceError open_primary_device(DeviceType type, uint32_t *device_idx, uint32_t sample_rate, uint32_t frame_duration,
|
||||||
|
uint8_t channels);
|
||||||
/* Start device */
|
/* Start device */
|
||||||
DeviceError open_device(DeviceType type, int32_t selection, uint32_t* device_idx, uint32_t sample_rate, uint32_t frame_duration, uint8_t channels);
|
DeviceError open_device(DeviceType type, int32_t selection, uint32_t *device_idx, uint32_t sample_rate,
|
||||||
|
uint32_t frame_duration, uint8_t channels);
|
||||||
/* Stop device */
|
/* Stop device */
|
||||||
DeviceError close_device(DeviceType type, uint32_t device_idx);
|
DeviceError close_device(DeviceType type, uint32_t device_idx);
|
||||||
|
|
||||||
/* Write data to device */
|
/* Write data to device */
|
||||||
DeviceError write_out(uint32_t device_idx, const int16_t* data, uint32_t length, uint8_t channels, uint32_t sample_rate);
|
DeviceError write_out(uint32_t device_idx, const int16_t *data, uint32_t length, uint8_t channels,
|
||||||
|
uint32_t sample_rate);
|
||||||
|
|
||||||
void print_devices(ToxWindow *self, DeviceType type);
|
void print_devices(ToxWindow *self, DeviceType type);
|
||||||
void get_primary_device_name(DeviceType type, char *buf, int size);
|
void get_primary_device_name(DeviceType type, char *buf, int size);
|
||||||
|
@ -185,6 +185,7 @@ int complete_line(ToxWindow *self, const void *list, int n_items, int size)
|
|||||||
int n_endchrs = strlen(endchrs);
|
int n_endchrs = strlen(endchrs);
|
||||||
int strt = ctx->pos - s_len;
|
int strt = ctx->pos - s_len;
|
||||||
int diff = match_len - s_len + n_endchrs;
|
int diff = match_len - s_len + n_endchrs;
|
||||||
|
|
||||||
if (ctx->len + diff >= MAX_STR_SIZE)
|
if (ctx->len + diff >= MAX_STR_SIZE)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
@ -55,6 +55,7 @@ int avatar_send(Tox *m, uint32_t friendnum)
|
|||||||
TOX_ERR_FILE_SEND err;
|
TOX_ERR_FILE_SEND err;
|
||||||
uint32_t filenum = tox_file_send(m, friendnum, TOX_FILE_KIND_AVATAR, (size_t) Avatar.size,
|
uint32_t filenum = tox_file_send(m, friendnum, TOX_FILE_KIND_AVATAR, (size_t) Avatar.size,
|
||||||
NULL, (uint8_t *) Avatar.name, Avatar.name_len, &err);
|
NULL, (uint8_t *) Avatar.name, Avatar.name_len, &err);
|
||||||
|
|
||||||
if (Avatar.size == 0)
|
if (Avatar.size == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -150,6 +151,7 @@ void on_avatar_file_control(Tox *m, struct FileTransfer *ft, TOX_FILE_CONTROL co
|
|||||||
} else if (ft->state == FILE_TRANSFER_PAUSED) {
|
} else if (ft->state == FILE_TRANSFER_PAUSED) {
|
||||||
ft->state = FILE_TRANSFER_STARTED;
|
ft->state = FILE_TRANSFER_STARTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TOX_FILE_CONTROL_PAUSE:
|
case TOX_FILE_CONTROL_PAUSE:
|
||||||
|
@ -251,6 +251,7 @@ static int update_DHT_nodeslist(const char *nodes_path)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct Recv_Curl_Data recv_data;
|
struct Recv_Curl_Data recv_data;
|
||||||
|
|
||||||
memset(&recv_data, 0, sizeof(struct Recv_Curl_Data));
|
memset(&recv_data, 0, sizeof(struct Recv_Curl_Data));
|
||||||
|
|
||||||
if (curl_fetch_nodes_JSON(&recv_data) == -1) {
|
if (curl_fetch_nodes_JSON(&recv_data) == -1) {
|
||||||
@ -523,6 +524,7 @@ int load_DHT_nodeslist(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
thread_data.active = true;
|
thread_data.active = true;
|
||||||
|
|
||||||
if (pthread_create(&thread_data.tid, &thread_data.attr, load_nodeslist_thread, NULL) != 0) {
|
if (pthread_create(&thread_data.tid, &thread_data.attr, load_nodeslist_thread, NULL) != 0) {
|
||||||
thread_data.active = false;
|
thread_data.active = false;
|
||||||
return -5;
|
return -5;
|
||||||
|
11
src/chat.c
11
src/chat.c
@ -466,10 +466,12 @@ static void chat_onFileControl(ToxWindow *self, Tox *m, uint32_t friendnum, uint
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case TOX_FILE_CONTROL_PAUSE: {
|
case TOX_FILE_CONTROL_PAUSE: {
|
||||||
ft->state = FILE_TRANSFER_PAUSED;
|
ft->state = FILE_TRANSFER_PAUSED;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case TOX_FILE_CONTROL_CANCEL: {
|
case TOX_FILE_CONTROL_CANCEL: {
|
||||||
snprintf(msg, sizeof(msg), "File transfer for '%s' was aborted.", ft->file_name);
|
snprintf(msg, sizeof(msg), "File transfer for '%s' was aborted.", ft->file_name);
|
||||||
close_file_transfer(self, m, ft, -1, msg, notif_error);
|
close_file_transfer(self, m, ft, -1, msg, notif_error);
|
||||||
@ -671,8 +673,10 @@ void chat_onRinging (ToxWindow *self, ToxAV *av, uint32_t friend_number, int sta
|
|||||||
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Ringing...type \"/hangup\" to cancel it.");
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Ringing...type \"/hangup\" to cancel it.");
|
||||||
|
|
||||||
#ifdef SOUND_NOTIFY
|
#ifdef SOUND_NOTIFY
|
||||||
|
|
||||||
if (self->ringing_sound == -1)
|
if (self->ringing_sound == -1)
|
||||||
sound_notify(self, call_outgoing, NT_LOOP, &self->ringing_sound);
|
sound_notify(self, call_outgoing, NT_LOOP, &self->ringing_sound);
|
||||||
|
|
||||||
#endif /* SOUND_NOTIFY */
|
#endif /* SOUND_NOTIFY */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -950,8 +954,7 @@ static void chat_onKey(ToxWindow *self, Tox *m, wint_t key, bool ltr)
|
|||||||
} else if (key == '\r') {
|
} else if (key == '\r') {
|
||||||
rm_trailing_spaces_buf(ctx);
|
rm_trailing_spaces_buf(ctx);
|
||||||
|
|
||||||
if (!wstring_is_empty(ctx->line))
|
if (!wstring_is_empty(ctx->line)) {
|
||||||
{
|
|
||||||
add_line_to_hist(ctx);
|
add_line_to_hist(ctx);
|
||||||
|
|
||||||
wstrsubst(ctx->line, L'¶', L'\n');
|
wstrsubst(ctx->line, L'¶', L'\n');
|
||||||
@ -1029,9 +1032,11 @@ static void chat_onDraw(ToxWindow *self, Tox *m)
|
|||||||
case TOX_USER_STATUS_NONE:
|
case TOX_USER_STATUS_NONE:
|
||||||
colour = GREEN;
|
colour = GREEN;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TOX_USER_STATUS_AWAY:
|
case TOX_USER_STATUS_AWAY:
|
||||||
colour = YELLOW;
|
colour = YELLOW;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TOX_USER_STATUS_BUSY:
|
case TOX_USER_STATUS_BUSY:
|
||||||
colour = RED;
|
colour = RED;
|
||||||
break;
|
break;
|
||||||
@ -1107,9 +1112,11 @@ static void chat_onDraw(ToxWindow *self, Tox *m)
|
|||||||
wnoutrefresh(self->window);
|
wnoutrefresh(self->window);
|
||||||
|
|
||||||
#ifdef AUDIO
|
#ifdef AUDIO
|
||||||
|
|
||||||
if (ctx->infobox.active) {
|
if (ctx->infobox.active) {
|
||||||
draw_infobox(self);
|
draw_infobox(self);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (self->help->active)
|
if (self->help->active)
|
||||||
|
@ -120,6 +120,7 @@ void cmd_join_group(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*ar
|
|||||||
|
|
||||||
if (type == TOX_GROUPCHAT_TYPE_TEXT)
|
if (type == TOX_GROUPCHAT_TYPE_TEXT)
|
||||||
groupnum = tox_join_groupchat(m, self->num, (uint8_t *) groupkey, length);
|
groupnum = tox_join_groupchat(m, self->num, (uint8_t *) groupkey, length);
|
||||||
|
|
||||||
/*#ifdef AUDIO
|
/*#ifdef AUDIO
|
||||||
else
|
else
|
||||||
groupnum = toxav_join_av_groupchat(m, self->num, (uint8_t *) groupkey, length,
|
groupnum = toxav_join_av_groupchat(m, self->num, (uint8_t *) groupkey, length,
|
||||||
@ -190,6 +191,7 @@ void cmd_savefile(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
on_recv_error:
|
on_recv_error:
|
||||||
|
|
||||||
switch (err) {
|
switch (err) {
|
||||||
case TOX_ERR_FILE_CONTROL_FRIEND_NOT_FOUND:
|
case TOX_ERR_FILE_CONTROL_FRIEND_NOT_FOUND:
|
||||||
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "File transfer failed: Friend not found.");
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "File transfer failed: Friend not found.");
|
||||||
@ -282,6 +284,7 @@ void cmd_sendfile(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
on_send_error:
|
on_send_error:
|
||||||
|
|
||||||
switch (err) {
|
switch (err) {
|
||||||
case TOX_ERR_FILE_SEND_FRIEND_NOT_FOUND:
|
case TOX_ERR_FILE_SEND_FRIEND_NOT_FOUND:
|
||||||
errmsg = "File transfer failed: Invalid friend.";
|
errmsg = "File transfer failed: Invalid friend.";
|
||||||
|
@ -186,6 +186,7 @@ void execute(WINDOW *w, ToxWindow *self, Tox *m, const char *input, int mode)
|
|||||||
case GROUPCHAT_COMMAND_MODE:
|
case GROUPCHAT_COMMAND_MODE:
|
||||||
if (do_command(w, self, m, num_args, group_commands, args) == 0)
|
if (do_command(w, self, m, num_args, group_commands, args) == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -560,6 +560,7 @@ static void select_friend(ToxWindow *self, wint_t key, int *selected, int num)
|
|||||||
static void delete_friend(Tox *m, uint32_t f_num)
|
static void delete_friend(Tox *m, uint32_t f_num)
|
||||||
{
|
{
|
||||||
TOX_ERR_FRIEND_DELETE err;
|
TOX_ERR_FRIEND_DELETE err;
|
||||||
|
|
||||||
if (tox_friend_delete(m, f_num, &err) != true) {
|
if (tox_friend_delete(m, f_num, &err) != true) {
|
||||||
fprintf(stderr, "tox_friend_delete failed with error %d\n", err);
|
fprintf(stderr, "tox_friend_delete failed with error %d\n", err);
|
||||||
return;
|
return;
|
||||||
@ -645,10 +646,12 @@ static void draw_del_popup(void)
|
|||||||
wattron(PendingDelete.popup, A_BOLD);
|
wattron(PendingDelete.popup, A_BOLD);
|
||||||
|
|
||||||
pthread_mutex_lock(&Winthread.lock);
|
pthread_mutex_lock(&Winthread.lock);
|
||||||
|
|
||||||
if (blocklist_view == 0)
|
if (blocklist_view == 0)
|
||||||
wprintw(PendingDelete.popup, "%s", Friends.list[PendingDelete.num].name);
|
wprintw(PendingDelete.popup, "%s", Friends.list[PendingDelete.num].name);
|
||||||
else
|
else
|
||||||
wprintw(PendingDelete.popup, "%s", Blocked.list[PendingDelete.num].name);
|
wprintw(PendingDelete.popup, "%s", Blocked.list[PendingDelete.num].name);
|
||||||
|
|
||||||
pthread_mutex_unlock(&Winthread.lock);
|
pthread_mutex_unlock(&Winthread.lock);
|
||||||
|
|
||||||
wattroff(PendingDelete.popup, A_BOLD);
|
wattroff(PendingDelete.popup, A_BOLD);
|
||||||
@ -799,6 +802,7 @@ static void friendlist_onKey(ToxWindow *self, Tox *m, wint_t key, bool ltr)
|
|||||||
block_friend(m, f);
|
block_friend(m, f);
|
||||||
else
|
else
|
||||||
unblock_friend(m, f);
|
unblock_friend(m, f);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KEY_RIGHT:
|
case KEY_RIGHT:
|
||||||
@ -811,6 +815,7 @@ static void friendlist_onKey(ToxWindow *self, Tox *m, wint_t key, bool ltr)
|
|||||||
select_friend(self, key, &Friends.num_selected, Friends.num_friends);
|
select_friend(self, key, &Friends.num_selected, Friends.num_friends);
|
||||||
else
|
else
|
||||||
select_friend(self, key, &Blocked.num_selected, Blocked.num_blocked);
|
select_friend(self, key, &Blocked.num_selected, Blocked.num_blocked);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -970,9 +975,11 @@ static void friendlist_onDraw(ToxWindow *self, Tox *m)
|
|||||||
case TOX_USER_STATUS_NONE:
|
case TOX_USER_STATUS_NONE:
|
||||||
colour = GREEN;
|
colour = GREEN;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TOX_USER_STATUS_AWAY:
|
case TOX_USER_STATUS_AWAY:
|
||||||
colour = YELLOW;
|
colour = YELLOW;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TOX_USER_STATUS_BUSY:
|
case TOX_USER_STATUS_BUSY:
|
||||||
colour = RED;
|
colour = RED;
|
||||||
break;
|
break;
|
||||||
@ -1112,6 +1119,7 @@ void disable_chatwin(uint32_t f_num)
|
|||||||
static void friendlist_onAV(ToxWindow *self, ToxAV *av, uint32_t friend_number, int state)
|
static void friendlist_onAV(ToxWindow *self, ToxAV *av, uint32_t friend_number, int state)
|
||||||
{
|
{
|
||||||
assert(0);
|
assert(0);
|
||||||
|
|
||||||
if ( friend_number >= Friends.max_idx)
|
if ( friend_number >= Friends.max_idx)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -130,6 +130,7 @@ void cmd_add_helper(ToxWindow *self, Tox *m, const char *id_bin, const char *msg
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case TOX_ERR_FRIEND_ADD_NULL:
|
case TOX_ERR_FRIEND_ADD_NULL:
|
||||||
|
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
default:
|
default:
|
||||||
errmsg = "Faile to add friend: Unknown error.";
|
errmsg = "Faile to add friend: Unknown error.";
|
||||||
@ -260,6 +261,7 @@ void cmd_connect(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
char key_binary[TOX_PUBLIC_KEY_SIZE * 2 + 1];
|
char key_binary[TOX_PUBLIC_KEY_SIZE * 2 + 1];
|
||||||
|
|
||||||
if (hex_string_to_bin(ascii_key, strlen(ascii_key), key_binary, TOX_PUBLIC_KEY_SIZE) == -1) {
|
if (hex_string_to_bin(ascii_key, strlen(ascii_key), key_binary, TOX_PUBLIC_KEY_SIZE) == -1) {
|
||||||
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Invalid key.");
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Invalid key.");
|
||||||
return;
|
return;
|
||||||
@ -281,6 +283,7 @@ void cmd_connect(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)
|
|||||||
case TOX_ERR_BOOTSTRAP_NULL:
|
case TOX_ERR_BOOTSTRAP_NULL:
|
||||||
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Bootstrap failed.");
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Bootstrap failed.");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -345,6 +348,7 @@ void cmd_groupchat(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*arg
|
|||||||
|
|
||||||
if (type == TOX_GROUPCHAT_TYPE_TEXT)
|
if (type == TOX_GROUPCHAT_TYPE_TEXT)
|
||||||
groupnum = tox_add_groupchat(m);
|
groupnum = tox_add_groupchat(m);
|
||||||
|
|
||||||
/*#ifdef AUDIO
|
/*#ifdef AUDIO
|
||||||
else
|
else
|
||||||
groupnum = toxav_add_av_groupchat(m, NULL, NULL);
|
groupnum = toxav_add_av_groupchat(m, NULL, NULL);
|
||||||
@ -543,8 +547,10 @@ void cmd_nospam(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[
|
|||||||
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Your new Tox ID is:");
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Your new Tox ID is:");
|
||||||
cmd_myid(window, self, m, 0, NULL);
|
cmd_myid(window, self, m, 0, NULL);
|
||||||
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "");
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "");
|
||||||
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "Any services that relied on your old ID will need to be updated manually.");
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0,
|
||||||
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "If you ever want your old Tox ID back, type '/nospam %X'", old_nospam);
|
"Any services that relied on your old ID will need to be updated manually.");
|
||||||
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "If you ever want your old Tox ID back, type '/nospam %X'",
|
||||||
|
old_nospam);
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmd_prompt_help(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
void cmd_prompt_help(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
||||||
|
@ -142,9 +142,11 @@ int init_groupchat_win(ToxWindow *prompt, Tox *m, int groupnum, uint8_t type)
|
|||||||
groupchats[i].oldpeer_name_lengths[0] = (uint16_t) strlen(UNKNOWN_NAME);
|
groupchats[i].oldpeer_name_lengths[0] = (uint16_t) strlen(UNKNOWN_NAME);
|
||||||
|
|
||||||
#ifdef AUDIO
|
#ifdef AUDIO
|
||||||
|
|
||||||
if (type == TOX_GROUPCHAT_TYPE_AV)
|
if (type == TOX_GROUPCHAT_TYPE_AV)
|
||||||
if (group_audio_open_out_device(i) == -1)
|
if (group_audio_open_out_device(i) == -1)
|
||||||
fprintf(stderr, "Group Audio failed to init\n");
|
fprintf(stderr, "Group Audio failed to init\n");
|
||||||
|
|
||||||
#endif /* AUDIO */
|
#endif /* AUDIO */
|
||||||
|
|
||||||
set_active_window(groupchats[i].chatwin);
|
set_active_window(groupchats[i].chatwin);
|
||||||
@ -266,8 +268,7 @@ static void groupchat_onGroupMessage(ToxWindow *self, Tox *m, int groupnum, int
|
|||||||
box_silent_notify(self, NT_NOFOCUS, &self->active_box, self->name, "%s %s", nick, msg);
|
box_silent_notify(self, NT_NOFOCUS, &self->active_box, self->name, "%s %s", nick, msg);
|
||||||
|
|
||||||
nick_clr = RED;
|
nick_clr = RED;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
sound_notify(self, silent, NT_WNDALERT_1, NULL);
|
sound_notify(self, silent, NT_WNDALERT_1, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -302,8 +303,7 @@ static void groupchat_onGroupAction(ToxWindow *self, Tox *m, int groupnum, int p
|
|||||||
box_silent_notify2(self, NT_NOFOCUS, self->active_box, "* %s %s", nick, action );
|
box_silent_notify2(self, NT_NOFOCUS, self->active_box, "* %s %s", nick, action );
|
||||||
else
|
else
|
||||||
box_silent_notify(self, NT_NOFOCUS, &self->active_box, self->name, "* %s %s", nick, action);
|
box_silent_notify(self, NT_NOFOCUS, &self->active_box, self->name, "* %s %s", nick, action);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
sound_notify(self, silent, NT_WNDALERT_1, NULL);
|
sound_notify(self, silent, NT_WNDALERT_1, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -621,8 +621,7 @@ static void groupchat_onKey(ToxWindow *self, Tox *m, wint_t key, bool ltr)
|
|||||||
} else if (key == '\r') {
|
} else if (key == '\r') {
|
||||||
rm_trailing_spaces_buf(ctx);
|
rm_trailing_spaces_buf(ctx);
|
||||||
|
|
||||||
if (!wstring_is_empty(ctx->line))
|
if (!wstring_is_empty(ctx->line)) {
|
||||||
{
|
|
||||||
add_line_to_hist(ctx);
|
add_line_to_hist(ctx);
|
||||||
|
|
||||||
wstrsubst(ctx->line, L'¶', L'\n');
|
wstrsubst(ctx->line, L'¶', L'\n');
|
||||||
|
@ -275,9 +275,9 @@ bool input_handle(ToxWindow *self, wint_t key, int x, int y, int mx_x, int mx_y)
|
|||||||
self->show_peerlist ^= 1;
|
self->show_peerlist ^= 1;
|
||||||
redraw_groupchat_win(self);
|
redraw_groupchat_win(self);
|
||||||
}
|
}
|
||||||
|
|
||||||
match = true;
|
match = true;
|
||||||
}
|
} else if (key == user_settings->key_toggle_pastemode) {
|
||||||
else if (key == user_settings->key_toggle_pastemode) {
|
|
||||||
self->chatwin->pastemode ^= 1;
|
self->chatwin->pastemode ^= 1;
|
||||||
match = true;
|
match = true;
|
||||||
}
|
}
|
||||||
|
@ -158,12 +158,14 @@ void line_info_add(ToxWindow *self, const char *timestr, const char *name1, cons
|
|||||||
/* for type-specific formatting in print function */
|
/* for type-specific formatting in print function */
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case IN_ACTION:
|
case IN_ACTION:
|
||||||
|
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
case OUT_ACTION:
|
case OUT_ACTION:
|
||||||
len += strlen(user_settings->line_normal) + 2;
|
len += strlen(user_settings->line_normal) + 2;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case IN_MSG:
|
case IN_MSG:
|
||||||
|
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
case OUT_MSG:
|
case OUT_MSG:
|
||||||
len += strlen(user_settings->line_normal) + 3;
|
len += strlen(user_settings->line_normal) + 3;
|
||||||
@ -304,8 +306,10 @@ void line_info_print(ToxWindow *self)
|
|||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case OUT_MSG:
|
case OUT_MSG:
|
||||||
|
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
case OUT_MSG_READ:
|
case OUT_MSG_READ:
|
||||||
|
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
case IN_MSG:
|
case IN_MSG:
|
||||||
wattron(win, COLOR_PAIR(BLUE));
|
wattron(win, COLOR_PAIR(BLUE));
|
||||||
@ -324,8 +328,8 @@ void line_info_print(ToxWindow *self)
|
|||||||
wattroff(win, COLOR_PAIR(nameclr));
|
wattroff(win, COLOR_PAIR(nameclr));
|
||||||
|
|
||||||
char *msg = line->msg;
|
char *msg = line->msg;
|
||||||
while (msg)
|
|
||||||
{
|
while (msg) {
|
||||||
char *line = strsep(&msg, "\n");
|
char *line = strsep(&msg, "\n");
|
||||||
|
|
||||||
if (line[0] == '>')
|
if (line[0] == '>')
|
||||||
@ -360,8 +364,10 @@ void line_info_print(ToxWindow *self)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case OUT_ACTION_READ:
|
case OUT_ACTION_READ:
|
||||||
|
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
case OUT_ACTION:
|
case OUT_ACTION:
|
||||||
|
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
case IN_ACTION:
|
case IN_ACTION:
|
||||||
wattron(win, COLOR_PAIR(BLUE));
|
wattron(win, COLOR_PAIR(BLUE));
|
||||||
@ -548,20 +554,15 @@ bool line_info_onKey(ToxWindow *self, wint_t key)
|
|||||||
|
|
||||||
if (key == user_settings->key_half_page_up) {
|
if (key == user_settings->key_half_page_up) {
|
||||||
line_info_page_up(self, hst);
|
line_info_page_up(self, hst);
|
||||||
}
|
} else if (key == user_settings->key_half_page_down) {
|
||||||
else if (key == user_settings->key_half_page_down) {
|
|
||||||
line_info_page_down(self, hst);
|
line_info_page_down(self, hst);
|
||||||
}
|
} else if (key == user_settings->key_scroll_line_up) {
|
||||||
else if (key == user_settings->key_scroll_line_up) {
|
|
||||||
line_info_scroll_up(hst);
|
line_info_scroll_up(hst);
|
||||||
}
|
} else if (key == user_settings->key_scroll_line_down) {
|
||||||
else if (key == user_settings->key_scroll_line_down) {
|
|
||||||
line_info_scroll_down(hst);
|
line_info_scroll_down(hst);
|
||||||
}
|
} else if (key == user_settings->key_page_bottom) {
|
||||||
else if (key == user_settings->key_page_bottom) {
|
|
||||||
line_info_reset_start(self, hst);
|
line_info_reset_start(self, hst);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
match = false;
|
match = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -262,6 +262,7 @@ int rename_logfile(char *src, char *dest, const char *selfkey, const char *other
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
on_error:
|
on_error:
|
||||||
|
|
||||||
if (log_on)
|
if (log_on)
|
||||||
log_enable(src, selfkey, otherkey, log, LOG_CHAT);
|
log_enable(src, selfkey, otherkey, log, LOG_CHAT);
|
||||||
|
|
||||||
|
@ -249,21 +249,29 @@ void *lookup_thread_func(void *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct Recv_Curl_Data recv_data;
|
struct Recv_Curl_Data recv_data;
|
||||||
|
|
||||||
memset(&recv_data, 0, sizeof(struct Recv_Curl_Data));
|
memset(&recv_data, 0, sizeof(struct Recv_Curl_Data));
|
||||||
|
|
||||||
char post_data[MAX_STR_SIZE];
|
char post_data[MAX_STR_SIZE];
|
||||||
|
|
||||||
snprintf(post_data, sizeof(post_data), "{\"action\": 3, \"name\": \"%s\"}", name);
|
snprintf(post_data, sizeof(post_data), "{\"action\": 3, \"name\": \"%s\"}", name);
|
||||||
|
|
||||||
struct curl_slist *headers = NULL;
|
struct curl_slist *headers = NULL;
|
||||||
|
|
||||||
headers = curl_slist_append(headers, "Content-Type: application/json");
|
headers = curl_slist_append(headers, "Content-Type: application/json");
|
||||||
|
|
||||||
headers = curl_slist_append(headers, "charsets: utf-8");
|
headers = curl_slist_append(headers, "charsets: utf-8");
|
||||||
|
|
||||||
curl_easy_setopt(c_handle, CURLOPT_HTTPHEADER, headers);
|
curl_easy_setopt(c_handle, CURLOPT_HTTPHEADER, headers);
|
||||||
|
|
||||||
curl_easy_setopt(c_handle, CURLOPT_URL, real_domain);
|
curl_easy_setopt(c_handle, CURLOPT_URL, real_domain);
|
||||||
|
|
||||||
curl_easy_setopt(c_handle, CURLOPT_WRITEFUNCTION, curl_cb_write_data);
|
curl_easy_setopt(c_handle, CURLOPT_WRITEFUNCTION, curl_cb_write_data);
|
||||||
|
|
||||||
curl_easy_setopt(c_handle, CURLOPT_WRITEDATA, &recv_data);
|
curl_easy_setopt(c_handle, CURLOPT_WRITEDATA, &recv_data);
|
||||||
|
|
||||||
curl_easy_setopt(c_handle, CURLOPT_USERAGENT, "libcurl-agent/1.0");
|
curl_easy_setopt(c_handle, CURLOPT_USERAGENT, "libcurl-agent/1.0");
|
||||||
|
|
||||||
curl_easy_setopt(c_handle, CURLOPT_POSTFIELDS, post_data);
|
curl_easy_setopt(c_handle, CURLOPT_POSTFIELDS, post_data);
|
||||||
|
|
||||||
int proxy_ret = set_curl_proxy(c_handle, arg_opts.proxy_address, arg_opts.proxy_port, arg_opts.proxy_type);
|
int proxy_ret = set_curl_proxy(c_handle, arg_opts.proxy_address, arg_opts.proxy_port, arg_opts.proxy_type);
|
||||||
|
60
src/notify.c
60
src/notify.c
@ -189,11 +189,13 @@ void graceful_clear()
|
|||||||
for (i = 0; i < ACTIVE_NOTIFS_MAX; i ++) {
|
for (i = 0; i < ACTIVE_NOTIFS_MAX; i ++) {
|
||||||
if (actives[i].active) {
|
if (actives[i].active) {
|
||||||
#ifdef BOX_NOTIFY
|
#ifdef BOX_NOTIFY
|
||||||
|
|
||||||
if (actives[i].box) {
|
if (actives[i].box) {
|
||||||
GError *ignore;
|
GError *ignore;
|
||||||
notify_notification_close(actives[i].box, &ignore);
|
notify_notification_close(actives[i].box, &ignore);
|
||||||
actives[i].box = NULL;
|
actives[i].box = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (actives[i].id_indicator)
|
if (actives[i].id_indicator)
|
||||||
@ -240,10 +242,12 @@ void* do_playing(void* _p)
|
|||||||
for (i = 0; i < ACTIVE_NOTIFS_MAX; i ++) {
|
for (i = 0; i < ACTIVE_NOTIFS_MAX; i ++) {
|
||||||
|
|
||||||
if (actives[i].looping) has_looping = true;
|
if (actives[i].looping) has_looping = true;
|
||||||
|
|
||||||
test_active_notify = actives[i].active && !actives[i].looping;
|
test_active_notify = actives[i].active && !actives[i].looping;
|
||||||
#ifdef BOX_NOTIFY
|
#ifdef BOX_NOTIFY
|
||||||
test_active_notify = test_active_notify && !actives[i].box;
|
test_active_notify = test_active_notify && !actives[i].box;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (test_active_notify) {
|
if (test_active_notify) {
|
||||||
if (actives[i].id_indicator)
|
if (actives[i].id_indicator)
|
||||||
*actives[i].id_indicator = -1; /* reset indicator value */
|
*actives[i].id_indicator = -1; /* reset indicator value */
|
||||||
@ -256,12 +260,13 @@ void* do_playing(void* _p)
|
|||||||
memset(&actives[i], 0, sizeof(struct _ActiveNotifications));
|
memset(&actives[i], 0, sizeof(struct _ActiveNotifications));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef BOX_NOTIFY
|
#ifdef BOX_NOTIFY
|
||||||
else if (actives[i].box && time(NULL) >= actives[i].n_timeout)
|
else if (actives[i].box && time(NULL) >= actives[i].n_timeout) {
|
||||||
{
|
|
||||||
GError *ignore;
|
GError *ignore;
|
||||||
notify_notification_close(actives[i].box, &ignore);
|
notify_notification_close(actives[i].box, &ignore);
|
||||||
actives[i].box = NULL;
|
actives[i].box = NULL;
|
||||||
|
|
||||||
if (actives[i].id_indicator)
|
if (actives[i].id_indicator)
|
||||||
*actives[i].id_indicator = -1; /* reset indicator value */
|
*actives[i].id_indicator = -1; /* reset indicator value */
|
||||||
|
|
||||||
@ -273,6 +278,7 @@ void* do_playing(void* _p)
|
|||||||
memset(&actives[i], 0, sizeof(struct _ActiveNotifications));
|
memset(&actives[i], 0, sizeof(struct _ActiveNotifications));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -281,18 +287,22 @@ void* do_playing(void* _p)
|
|||||||
(time(NULL) - last_opened_update) > DEVICE_COOLDOWN) {
|
(time(NULL) - last_opened_update) > DEVICE_COOLDOWN) {
|
||||||
m_close_device();
|
m_close_device();
|
||||||
}
|
}
|
||||||
|
|
||||||
has_looping = false;
|
has_looping = false;
|
||||||
|
|
||||||
control_unlock();
|
control_unlock();
|
||||||
usleep(10000);
|
usleep(10000);
|
||||||
}
|
}
|
||||||
|
|
||||||
pthread_exit(NULL);
|
pthread_exit(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
int play_source(uint32_t source, uint32_t buffer, bool looping)
|
int play_source(uint32_t source, uint32_t buffer, bool looping)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
for (; i < ACTIVE_NOTIFS_MAX && actives[i].active; i ++);
|
for (; i < ACTIVE_NOTIFS_MAX && actives[i].active; i ++);
|
||||||
|
|
||||||
if ( i == ACTIVE_NOTIFS_MAX ) {
|
if ( i == ACTIVE_NOTIFS_MAX ) {
|
||||||
return -1; /* Full */
|
return -1; /* Full */
|
||||||
}
|
}
|
||||||
@ -323,20 +333,22 @@ void* do_playing(void* _p)
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < ACTIVE_NOTIFS_MAX; i ++) {
|
for (i = 0; i < ACTIVE_NOTIFS_MAX; i ++) {
|
||||||
if (actives[i].box && time(NULL) >= actives[i].n_timeout)
|
if (actives[i].box && time(NULL) >= actives[i].n_timeout) {
|
||||||
{
|
|
||||||
GError *ignore;
|
GError *ignore;
|
||||||
notify_notification_close(actives[i].box, &ignore);
|
notify_notification_close(actives[i].box, &ignore);
|
||||||
actives[i].box = NULL;
|
actives[i].box = NULL;
|
||||||
|
|
||||||
if (actives[i].id_indicator)
|
if (actives[i].id_indicator)
|
||||||
*actives[i].id_indicator = -1; /* reset indicator value */
|
*actives[i].id_indicator = -1; /* reset indicator value */
|
||||||
|
|
||||||
memset(&actives[i], 0, sizeof(struct _ActiveNotifications));
|
memset(&actives[i], 0, sizeof(struct _ActiveNotifications));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
control_unlock();
|
control_unlock();
|
||||||
usleep(10000);
|
usleep(10000);
|
||||||
}
|
}
|
||||||
|
|
||||||
pthread_exit(NULL);
|
pthread_exit(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -378,6 +390,7 @@ int init_notify(int login_cooldown, int notification_timeout)
|
|||||||
#endif /* SOUND_NOTIFY */
|
#endif /* SOUND_NOTIFY */
|
||||||
|
|
||||||
#if defined(SOUND_NOTIFY) || defined(BOX_NOTIFY)
|
#if defined(SOUND_NOTIFY) || defined(BOX_NOTIFY)
|
||||||
|
|
||||||
if (pthread_mutex_init(Control.poll_mutex, NULL) != 0)
|
if (pthread_mutex_init(Control.poll_mutex, NULL) != 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -419,7 +432,9 @@ void terminate_notify()
|
|||||||
|
|
||||||
#ifdef SOUND_NOTIFY
|
#ifdef SOUND_NOTIFY
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
for (; i < SOUNDS_SIZE; i ++) free(Control.sounds[i]);
|
for (; i < SOUNDS_SIZE; i ++) free(Control.sounds[i]);
|
||||||
|
|
||||||
alutExit();
|
alutExit();
|
||||||
#endif /* SOUND_NOTIFY */
|
#endif /* SOUND_NOTIFY */
|
||||||
|
|
||||||
@ -457,6 +472,7 @@ int play_sound_internal(Notification what, bool loop)
|
|||||||
alSourcei(source, AL_LOOPING, loop);
|
alSourcei(source, AL_LOOPING, loop);
|
||||||
|
|
||||||
int rc = play_source(source, buffer, loop);
|
int rc = play_source(source, buffer, loop);
|
||||||
|
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
alSourceStop(source);
|
alSourceStop(source);
|
||||||
alDeleteSources(1, &source);
|
alDeleteSources(1, &source);
|
||||||
@ -472,6 +488,7 @@ int play_notify_sound(Notification notif, uint64_t flags)
|
|||||||
int rc = -1;
|
int rc = -1;
|
||||||
|
|
||||||
if (flags & NT_BEEP) beep();
|
if (flags & NT_BEEP) beep();
|
||||||
|
|
||||||
if (notif != silent) {
|
if (notif != silent) {
|
||||||
if ( !Control.poll_active || !Control.sounds[notif] )
|
if ( !Control.poll_active || !Control.sounds[notif] )
|
||||||
return -1;
|
return -1;
|
||||||
@ -487,13 +504,17 @@ void stop_sound(int id)
|
|||||||
{
|
{
|
||||||
if (id >= 0 && id < ACTIVE_NOTIFS_MAX && actives[id].looping && actives[id].active ) {
|
if (id >= 0 && id < ACTIVE_NOTIFS_MAX && actives[id].looping && actives[id].active ) {
|
||||||
#ifdef BOX_NOTIFY
|
#ifdef BOX_NOTIFY
|
||||||
|
|
||||||
if (actives[id].box) {
|
if (actives[id].box) {
|
||||||
GError *ignore;
|
GError *ignore;
|
||||||
notify_notification_close(actives[id].box, &ignore);
|
notify_notification_close(actives[id].box, &ignore);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (actives[id].id_indicator)
|
if (actives[id].id_indicator)
|
||||||
*actives[id].id_indicator = -1;
|
*actives[id].id_indicator = -1;
|
||||||
|
|
||||||
// alSourcei(actives[id].source, AL_LOOPING, false);
|
// alSourcei(actives[id].source, AL_LOOPING, false);
|
||||||
alSourceStop(actives[id].source);
|
alSourceStop(actives[id].source);
|
||||||
alDeleteSources(1, &actives[id].source);
|
alDeleteSources(1, &actives[id].source);
|
||||||
@ -508,6 +529,7 @@ static int m_play_sound(Notification notif, uint64_t flags)
|
|||||||
#ifdef SOUND_NOTIFY
|
#ifdef SOUND_NOTIFY
|
||||||
return play_notify_sound(notif, flags);
|
return play_notify_sound(notif, flags);
|
||||||
#else
|
#else
|
||||||
|
|
||||||
if (notif != silent)
|
if (notif != silent)
|
||||||
beep();
|
beep();
|
||||||
|
|
||||||
@ -540,6 +562,7 @@ int sound_notify(ToxWindow* self, Notification notif, uint64_t flags, int* id_in
|
|||||||
|
|
||||||
if (id == -1) {
|
if (id == -1) {
|
||||||
for (id = 0; id < ACTIVE_NOTIFS_MAX && actives[id].box; id++);
|
for (id = 0; id < ACTIVE_NOTIFS_MAX && actives[id].box; id++);
|
||||||
|
|
||||||
if ( id == ACTIVE_NOTIFS_MAX ) {
|
if ( id == ACTIVE_NOTIFS_MAX ) {
|
||||||
control_unlock();
|
control_unlock();
|
||||||
return -1; /* Full */
|
return -1; /* Full */
|
||||||
@ -566,6 +589,7 @@ int sound_notify2(ToxWindow* self, Notification notif, uint64_t flags, int id)
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (id < 0 || id >= ACTIVE_NOTIFS_MAX) return -1;
|
if (id < 0 || id >= ACTIVE_NOTIFS_MAX) return -1;
|
||||||
|
|
||||||
#ifdef SOUND_NOTIFY
|
#ifdef SOUND_NOTIFY
|
||||||
control_lock();
|
control_lock();
|
||||||
|
|
||||||
@ -592,6 +616,7 @@ int sound_notify2(ToxWindow* self, Notification notif, uint64_t flags, int id)
|
|||||||
|
|
||||||
return id;
|
return id;
|
||||||
#else
|
#else
|
||||||
|
|
||||||
if (notif != silent)
|
if (notif != silent)
|
||||||
beep();
|
beep();
|
||||||
|
|
||||||
@ -599,7 +624,8 @@ int sound_notify2(ToxWindow* self, Notification notif, uint64_t flags, int id)
|
|||||||
#endif /* SOUND_NOTIFY */
|
#endif /* SOUND_NOTIFY */
|
||||||
}
|
}
|
||||||
|
|
||||||
int box_notify(ToxWindow* self, Notification notif, uint64_t flags, int* id_indicator, const char* title, const char* format, ...)
|
int box_notify(ToxWindow *self, Notification notif, uint64_t flags, int *id_indicator, const char *title,
|
||||||
|
const char *format, ...)
|
||||||
{
|
{
|
||||||
if (notifications_are_disabled(flags)) {
|
if (notifications_are_disabled(flags)) {
|
||||||
tab_notify(self, flags);
|
tab_notify(self, flags);
|
||||||
@ -613,9 +639,11 @@ int box_notify(ToxWindow* self, Notification notif, uint64_t flags, int* id_indi
|
|||||||
control_lock();
|
control_lock();
|
||||||
|
|
||||||
#ifdef SOUND_NOTIFY
|
#ifdef SOUND_NOTIFY
|
||||||
|
|
||||||
if (id == -1) { /* Could not play */
|
if (id == -1) { /* Could not play */
|
||||||
|
|
||||||
for (id = 0; id < ACTIVE_NOTIFS_MAX && actives[id].active; id ++);
|
for (id = 0; id < ACTIVE_NOTIFS_MAX && actives[id].active; id ++);
|
||||||
|
|
||||||
if ( id == ACTIVE_NOTIFS_MAX ) {
|
if ( id == ACTIVE_NOTIFS_MAX ) {
|
||||||
control_unlock();
|
control_unlock();
|
||||||
return -1; /* Full */
|
return -1; /* Full */
|
||||||
@ -623,17 +651,23 @@ int box_notify(ToxWindow* self, Notification notif, uint64_t flags, int* id_indi
|
|||||||
|
|
||||||
actives[id].active = 1;
|
actives[id].active = 1;
|
||||||
actives[id].id_indicator = id_indicator;
|
actives[id].id_indicator = id_indicator;
|
||||||
|
|
||||||
if (id_indicator) *id_indicator = id;
|
if (id_indicator) *id_indicator = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
if (id == -1)
|
if (id == -1)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
#endif /* SOUND_NOTIFY */
|
#endif /* SOUND_NOTIFY */
|
||||||
|
|
||||||
snprintf(actives[id].title, sizeof(actives[id].title), "%s", title);
|
snprintf(actives[id].title, sizeof(actives[id].title), "%s", title);
|
||||||
|
|
||||||
if (strlen(title) > 23) strcpy(actives[id].title + 20, "...");
|
if (strlen(title) > 23) strcpy(actives[id].title + 20, "...");
|
||||||
|
|
||||||
va_list __ARGS__; va_start (__ARGS__, format);
|
va_list __ARGS__;
|
||||||
|
va_start (__ARGS__, format);
|
||||||
vsnprintf (actives[id].messages[0], MAX_BOX_MSG_LEN, format, __ARGS__);
|
vsnprintf (actives[id].messages[0], MAX_BOX_MSG_LEN, format, __ARGS__);
|
||||||
va_end (__ARGS__);
|
va_end (__ARGS__);
|
||||||
|
|
||||||
@ -675,7 +709,8 @@ int box_notify2(ToxWindow* self, Notification notif, uint64_t flags, int id, con
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
va_list __ARGS__; va_start (__ARGS__, format);
|
va_list __ARGS__;
|
||||||
|
va_start (__ARGS__, format);
|
||||||
vsnprintf (actives[id].messages[actives[id].size], MAX_BOX_MSG_LEN, format, __ARGS__);
|
vsnprintf (actives[id].messages[actives[id].size], MAX_BOX_MSG_LEN, format, __ARGS__);
|
||||||
va_end (__ARGS__);
|
va_end (__ARGS__);
|
||||||
|
|
||||||
@ -688,6 +723,7 @@ int box_notify2(ToxWindow* self, Notification notif, uint64_t flags, int id, con
|
|||||||
char formated[128 * 129] = {'\0'};
|
char formated[128 * 129] = {'\0'};
|
||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
for (; i < actives[id].size; i ++) {
|
for (; i < actives[id].size; i ++) {
|
||||||
strcat(formated, actives[id].messages[i]);
|
strcat(formated, actives[id].messages[i]);
|
||||||
strcat(formated, "\n");
|
strcat(formated, "\n");
|
||||||
@ -718,7 +754,9 @@ int box_silent_notify(ToxWindow* self, uint64_t flags, int* id_indicator, const
|
|||||||
control_lock();
|
control_lock();
|
||||||
|
|
||||||
int id;
|
int id;
|
||||||
|
|
||||||
for (id = 0; id < ACTIVE_NOTIFS_MAX && actives[id].active; id ++);
|
for (id = 0; id < ACTIVE_NOTIFS_MAX && actives[id].active; id ++);
|
||||||
|
|
||||||
if ( id == ACTIVE_NOTIFS_MAX ) {
|
if ( id == ACTIVE_NOTIFS_MAX ) {
|
||||||
control_unlock();
|
control_unlock();
|
||||||
return -1; /* Full */
|
return -1; /* Full */
|
||||||
@ -730,9 +768,11 @@ int box_silent_notify(ToxWindow* self, uint64_t flags, int* id_indicator, const
|
|||||||
}
|
}
|
||||||
|
|
||||||
snprintf(actives[id].title, sizeof(actives[id].title), "%s", title);
|
snprintf(actives[id].title, sizeof(actives[id].title), "%s", title);
|
||||||
|
|
||||||
if (strlen(title) > 23) strcpy(actives[id].title + 20, "...");
|
if (strlen(title) > 23) strcpy(actives[id].title + 20, "...");
|
||||||
|
|
||||||
va_list __ARGS__; va_start (__ARGS__, format);
|
va_list __ARGS__;
|
||||||
|
va_start (__ARGS__, format);
|
||||||
vsnprintf (actives[id].messages[0], MAX_BOX_MSG_LEN, format, __ARGS__);
|
vsnprintf (actives[id].messages[0], MAX_BOX_MSG_LEN, format, __ARGS__);
|
||||||
va_end (__ARGS__);
|
va_end (__ARGS__);
|
||||||
|
|
||||||
@ -772,7 +812,8 @@ int box_silent_notify2(ToxWindow* self, uint64_t flags, int id, const char* form
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
va_list __ARGS__; va_start (__ARGS__, format);
|
va_list __ARGS__;
|
||||||
|
va_start (__ARGS__, format);
|
||||||
vsnprintf (actives[id].messages[actives[id].size], MAX_BOX_MSG_LEN, format, __ARGS__);
|
vsnprintf (actives[id].messages[actives[id].size], MAX_BOX_MSG_LEN, format, __ARGS__);
|
||||||
va_end (__ARGS__);
|
va_end (__ARGS__);
|
||||||
|
|
||||||
@ -785,6 +826,7 @@ int box_silent_notify2(ToxWindow* self, uint64_t flags, int id, const char* form
|
|||||||
char formated[128 * 129] = {'\0'};
|
char formated[128 * 129] = {'\0'};
|
||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
for (; i < actives[id].size; i ++) {
|
for (; i < actives[id].size; i ++) {
|
||||||
strcat(formated, actives[id].messages[i]);
|
strcat(formated, actives[id].messages[i]);
|
||||||
strcat(formated, "\n");
|
strcat(formated, "\n");
|
||||||
|
@ -26,8 +26,7 @@
|
|||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include "windows.h"
|
#include "windows.h"
|
||||||
|
|
||||||
typedef enum _Notification
|
typedef enum _Notification {
|
||||||
{
|
|
||||||
silent = -1,
|
silent = -1,
|
||||||
notif_error,
|
notif_error,
|
||||||
self_log_in,
|
self_log_in,
|
||||||
@ -68,7 +67,8 @@ int sound_notify2(ToxWindow* self, Notification notif, uint64_t flags, int id);
|
|||||||
|
|
||||||
void stop_sound(int id);
|
void stop_sound(int id);
|
||||||
|
|
||||||
int box_notify(ToxWindow* self, Notification notif, uint64_t flags, int* id_indicator, const char* title, const char* format, ...);
|
int box_notify(ToxWindow *self, Notification notif, uint64_t flags, int *id_indicator, const char *title,
|
||||||
|
const char *format, ...);
|
||||||
int box_notify2(ToxWindow *self, Notification notif, uint64_t flags, int id, const char *format, ...);
|
int box_notify2(ToxWindow *self, Notification notif, uint64_t flags, int id, const char *format, ...);
|
||||||
int box_silent_notify(ToxWindow *self, uint64_t flags, int *id_indicator, const char *title, const char *format, ...);
|
int box_silent_notify(ToxWindow *self, uint64_t flags, int *id_indicator, const char *title, const char *format, ...);
|
||||||
int box_silent_notify2(ToxWindow *self, uint64_t flags, int id, const char *format, ...);
|
int box_silent_notify2(ToxWindow *self, uint64_t flags, int id, const char *format, ...);
|
||||||
|
@ -36,8 +36,11 @@
|
|||||||
void bgrtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t *rgb, uint16_t width, uint16_t height);
|
void bgrtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t *rgb, uint16_t width, uint16_t height);
|
||||||
|
|
||||||
#ifdef __OBJC__
|
#ifdef __OBJC__
|
||||||
@interface OSXVideo : NSObject <AVCaptureVideoDataOutputSampleBufferDelegate>
|
@interface OSXVideo :
|
||||||
- (instancetype)initWithDeviceNames:(char **)device_names AmtDevices:(int *)size;
|
NSObject <AVCaptureVideoDataOutputSampleBufferDelegate>
|
||||||
|
- (instancetype)initWithDeviceNames:
|
||||||
|
(char **)device_names AmtDevices:
|
||||||
|
(int *)size;
|
||||||
@end
|
@end
|
||||||
#endif /* __OBJC__ */
|
#endif /* __OBJC__ */
|
||||||
|
|
||||||
|
@ -67,6 +67,7 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
|
|
||||||
for (y = 0; y != height; y += 2) {
|
for (y = 0; y != height; y += 2) {
|
||||||
p = rgb;
|
p = rgb;
|
||||||
|
|
||||||
for (x = 0; x != width; x++) {
|
for (x = 0; x != width; x++) {
|
||||||
b = *rgb++;
|
b = *rgb++;
|
||||||
g = *rgb++;
|
g = *rgb++;
|
||||||
@ -91,9 +92,12 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
|
|
||||||
*plane_y++ = rgb_to_y(r, g, b);
|
*plane_y++ = rgb_to_y(r, g, b);
|
||||||
|
|
||||||
b = ((int)b + (int)*(rgb - 8) + (int)*p + (int)*(p + 4) + 2) / 4; p++;
|
b = ((int)b + (int) * (rgb - 8) + (int) * p + (int) * (p + 4) + 2) / 4;
|
||||||
g = ((int)g + (int)*(rgb - 7) + (int)*p + (int)*(p + 4) + 2) / 4; p++;
|
p++;
|
||||||
r = ((int)r + (int)*(rgb - 6) + (int)*p + (int)*(p + 4) + 2) / 4; p++;
|
g = ((int)g + (int) * (rgb - 7) + (int) * p + (int) * (p + 4) + 2) / 4;
|
||||||
|
p++;
|
||||||
|
r = ((int)r + (int) * (rgb - 6) + (int) * p + (int) * (p + 4) + 2) / 4;
|
||||||
|
p++;
|
||||||
p++;
|
p++;
|
||||||
|
|
||||||
*plane_u++ = rgb_to_u(r, g, b);
|
*plane_u++ = rgb_to_u(r, g, b);
|
||||||
@ -122,11 +126,14 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
BOOL _shouldMangleDimensions;
|
BOOL _shouldMangleDimensions;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (instancetype)initWithDeviceNames: (char **)device_names AmtDevices: (int *)size {
|
- (instancetype)initWithDeviceNames:
|
||||||
|
(char **)device_names AmtDevices:
|
||||||
|
(int *)size {
|
||||||
_session = [[AVCaptureSession alloc] init];
|
_session = [[AVCaptureSession alloc] init];
|
||||||
|
|
||||||
NSArray *devices = [AVCaptureDevice devicesWithMediaType: AVMediaTypeVideo];
|
NSArray *devices = [AVCaptureDevice devicesWithMediaType: AVMediaTypeVideo];
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < [devices count]; ++i) {
|
for (i = 0; i < [devices count]; ++i) {
|
||||||
AVCaptureDevice *device = [devices objectAtIndex: i];
|
AVCaptureDevice *device = [devices objectAtIndex: i];
|
||||||
char *video_input_name;
|
char *video_input_name;
|
||||||
@ -138,6 +145,7 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
|
|
||||||
if ( i <= 0 )
|
if ( i <= 0 )
|
||||||
return nil;
|
return nil;
|
||||||
|
|
||||||
*size = i;
|
*size = i;
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
@ -151,7 +159,10 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (int)openVideoDeviceIndex: (uint32_t)device_idx Width: (uint16_t *)width Height: (uint16_t *)height {
|
- (int)openVideoDeviceIndex:
|
||||||
|
(uint32_t)device_idx Width:
|
||||||
|
(uint16_t *)width Height:
|
||||||
|
(uint16_t *)height {
|
||||||
pthread_mutex_init(&_frameLock, NULL);
|
pthread_mutex_init(&_frameLock, NULL);
|
||||||
pthread_mutex_lock(&_frameLock);
|
pthread_mutex_lock(&_frameLock);
|
||||||
_processingQueue = dispatch_queue_create("Toxic processing queue", DISPATCH_QUEUE_SERIAL);
|
_processingQueue = dispatch_queue_create("Toxic processing queue", DISPATCH_QUEUE_SERIAL);
|
||||||
@ -178,6 +189,7 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
/* Obtain device resolution */
|
/* Obtain device resolution */
|
||||||
AVCaptureInputPort *port = [input.ports objectAtIndex: 0];
|
AVCaptureInputPort *port = [input.ports objectAtIndex: 0];
|
||||||
CMFormatDescriptionRef format_description = port.formatDescription;
|
CMFormatDescriptionRef format_description = port.formatDescription;
|
||||||
|
|
||||||
if ( format_description ) {
|
if ( format_description ) {
|
||||||
CMVideoDimensions dimensions = CMVideoFormatDescriptionGetDimensions(format_description);
|
CMVideoDimensions dimensions = CMVideoFormatDescriptionGetDimensions(format_description);
|
||||||
*width = dimensions.width;
|
*width = dimensions.width;
|
||||||
@ -189,11 +201,14 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
|
|
||||||
_linkerVideo = [[AVCaptureVideoDataOutput alloc] init];
|
_linkerVideo = [[AVCaptureVideoDataOutput alloc] init];
|
||||||
[_linkerVideo setSampleBufferDelegate: self queue: _processingQueue];
|
[_linkerVideo setSampleBufferDelegate: self queue: _processingQueue];
|
||||||
|
|
||||||
// TODO possibly get a better pixel format
|
// TODO possibly get a better pixel format
|
||||||
if (_shouldMangleDimensions) {
|
if (_shouldMangleDimensions) {
|
||||||
[_linkerVideo setVideoSettings:@{(id)kCVPixelBufferPixelFormatTypeKey: @(kCVPixelFormatType_32BGRA),
|
[_linkerVideo setVideoSettings: @ {
|
||||||
|
(id)kCVPixelBufferPixelFormatTypeKey: @(kCVPixelFormatType_32BGRA),
|
||||||
(id)kCVPixelBufferWidthKey: @640,
|
(id)kCVPixelBufferWidthKey: @640,
|
||||||
(id)kCVPixelBufferHeightKey: @480}];
|
(id)kCVPixelBufferHeightKey: @480
|
||||||
|
}];
|
||||||
} else {
|
} else {
|
||||||
[_linkerVideo setVideoSettings: @{(id)kCVPixelBufferPixelFormatTypeKey: @(kCVPixelFormatType_32BGRA)}];
|
[_linkerVideo setVideoSettings: @{(id)kCVPixelBufferPixelFormatTypeKey: @(kCVPixelFormatType_32BGRA)}];
|
||||||
}
|
}
|
||||||
@ -204,7 +219,8 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)closeVideoDeviceIndex: (uint32_t)device_idx {
|
- (void)closeVideoDeviceIndex:
|
||||||
|
(uint32_t)device_idx {
|
||||||
NSArray *devices = [AVCaptureDevice devicesWithMediaType: AVMediaTypeVideo];
|
NSArray *devices = [AVCaptureDevice devicesWithMediaType: AVMediaTypeVideo];
|
||||||
AVCaptureDevice *device = [devices objectAtIndex: device_idx];
|
AVCaptureDevice *device = [devices objectAtIndex: device_idx];
|
||||||
NSError *error = NULL;
|
NSError *error = NULL;
|
||||||
@ -215,9 +231,13 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
[_linkerVideo release];
|
[_linkerVideo release];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)captureOutput:(AVCaptureOutput *)captureOutput didOutputSampleBuffer:(CMSampleBufferRef)sampleBuffer fromConnection:(AVCaptureConnection *)connection {
|
- (void)captureOutput:
|
||||||
|
(AVCaptureOutput *)captureOutput didOutputSampleBuffer:
|
||||||
|
(CMSampleBufferRef)sampleBuffer fromConnection:
|
||||||
|
(AVCaptureConnection *)connection {
|
||||||
pthread_mutex_lock(&_frameLock);
|
pthread_mutex_lock(&_frameLock);
|
||||||
CVImageBufferRef img = CMSampleBufferGetImageBuffer(sampleBuffer);
|
CVImageBufferRef img = CMSampleBufferGetImageBuffer(sampleBuffer);
|
||||||
|
|
||||||
if (!img) {
|
if (!img) {
|
||||||
NSLog(@"Toxic WARNING: Bad sampleBuffer from AVfoundation!");
|
NSLog(@"Toxic WARNING: Bad sampleBuffer from AVfoundation!");
|
||||||
} else {
|
} else {
|
||||||
@ -231,7 +251,12 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
pthread_mutex_unlock(&_frameLock);
|
pthread_mutex_unlock(&_frameLock);
|
||||||
}
|
}
|
||||||
|
|
||||||
- (int)getVideoFrameY: (uint8_t *)y U: (uint8_t *)u V: (uint8_t *)v Width: (uint16_t *)width Height: (uint16_t *)height {
|
- (int)getVideoFrameY:
|
||||||
|
(uint8_t *)y U:
|
||||||
|
(uint8_t *)u V:
|
||||||
|
(uint8_t *)v Width:
|
||||||
|
(uint16_t *)width Height:
|
||||||
|
(uint16_t *)height {
|
||||||
if (!_currentFrame) {
|
if (!_currentFrame) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -240,6 +265,7 @@ void bgrxtoyuv420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v, uint8_t
|
|||||||
CFRetain(_currentFrame);
|
CFRetain(_currentFrame);
|
||||||
|
|
||||||
CFTypeID imageType = CFGetTypeID(_currentFrame);
|
CFTypeID imageType = CFGetTypeID(_currentFrame);
|
||||||
|
|
||||||
if (imageType == CVPixelBufferGetTypeID()) {
|
if (imageType == CVPixelBufferGetTypeID()) {
|
||||||
// TODO maybe handle other formats
|
// TODO maybe handle other formats
|
||||||
bgrxtoyuv420(y, u, v, CVPixelBufferGetBaseAddress(_currentFrame), *width, *height);
|
bgrxtoyuv420(y, u, v, CVPixelBufferGetBaseAddress(_currentFrame), *width, *height);
|
||||||
|
@ -238,8 +238,7 @@ static void prompt_onKey(ToxWindow *self, Tox *m, wint_t key, bool ltr)
|
|||||||
} else if (key == '\r') {
|
} else if (key == '\r') {
|
||||||
rm_trailing_spaces_buf(ctx);
|
rm_trailing_spaces_buf(ctx);
|
||||||
|
|
||||||
if (!wstring_is_empty(ctx->line))
|
if (!wstring_is_empty(ctx->line)) {
|
||||||
{
|
|
||||||
add_line_to_hist(ctx);
|
add_line_to_hist(ctx);
|
||||||
wstrsubst(ctx->line, L'¶', L'\n');
|
wstrsubst(ctx->line, L'¶', L'\n');
|
||||||
|
|
||||||
@ -301,10 +300,12 @@ static void prompt_onDraw(ToxWindow *self, Tox *m)
|
|||||||
status_text = "Online";
|
status_text = "Online";
|
||||||
colour = GREEN;
|
colour = GREEN;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TOX_USER_STATUS_AWAY:
|
case TOX_USER_STATUS_AWAY:
|
||||||
status_text = "Away";
|
status_text = "Away";
|
||||||
colour = YELLOW;
|
colour = YELLOW;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TOX_USER_STATUS_BUSY:
|
case TOX_USER_STATUS_BUSY:
|
||||||
status_text = "Busy";
|
status_text = "Busy";
|
||||||
colour = RED;
|
colour = RED;
|
||||||
@ -404,8 +405,7 @@ static void prompt_onConnectionChange(ToxWindow *self, Tox *m, uint32_t friendnu
|
|||||||
else
|
else
|
||||||
box_notify(self, user_log_in, NT_WNDALERT_2 | NT_NOTIFWND | NT_RESTOL, &self->active_box,
|
box_notify(self, user_log_in, NT_WNDALERT_2 | NT_NOTIFWND | NT_RESTOL, &self->active_box,
|
||||||
"Toxic", "%s has come online", nick );
|
"Toxic", "%s has come online", nick );
|
||||||
}
|
} else if (connection_status == TOX_CONNECTION_NONE) {
|
||||||
else if (connection_status == TOX_CONNECTION_NONE) {
|
|
||||||
msg = "has gone offline";
|
msg = "has gone offline";
|
||||||
line_info_add(self, timefrmt, nick, NULL, DISCONNECTION, 0, RED, msg);
|
line_info_add(self, timefrmt, nick, NULL, DISCONNECTION, 0, RED, msg);
|
||||||
write_to_log(msg, nick, ctx->log, true);
|
write_to_log(msg, nick, ctx->log, true);
|
||||||
|
@ -245,7 +245,8 @@ static const struct sound_strings {
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int key_parse(const char **bind) {
|
static int key_parse(const char **bind)
|
||||||
|
{
|
||||||
int len = strlen(*bind);
|
int len = strlen(*bind);
|
||||||
|
|
||||||
if (len > 5) {
|
if (len > 5) {
|
||||||
@ -262,7 +263,8 @@ static int key_parse(const char **bind) {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void set_key_binding(int *key, const char **bind) {
|
static void set_key_binding(int *key, const char **bind)
|
||||||
|
{
|
||||||
int code = key_parse(bind);
|
int code = key_parse(bind);
|
||||||
|
|
||||||
if (code != -1) {
|
if (code != -1) {
|
||||||
@ -318,6 +320,7 @@ int settings_load(struct user_settings *s, const char *patharg)
|
|||||||
config_setting_lookup_bool(setting, ui_strings.timestamps, &s->timestamps);
|
config_setting_lookup_bool(setting, ui_strings.timestamps, &s->timestamps);
|
||||||
|
|
||||||
int time = 24;
|
int time = 24;
|
||||||
|
|
||||||
if ( config_setting_lookup_int(setting, ui_strings.time_format, &time) ) {
|
if ( config_setting_lookup_int(setting, ui_strings.time_format, &time) ) {
|
||||||
if (time == 12) {
|
if (time == 12) {
|
||||||
snprintf(s->timestamp_format, sizeof(s->timestamp_format), "%s", "%I:%M:%S %p");
|
snprintf(s->timestamp_format, sizeof(s->timestamp_format), "%s", "%I:%M:%S %p");
|
||||||
@ -338,12 +341,15 @@ int settings_load(struct user_settings *s, const char *patharg)
|
|||||||
if (config_setting_lookup_bool(setting, ui_strings.bell_on_message, &s->bell_on_message)) {
|
if (config_setting_lookup_bool(setting, ui_strings.bell_on_message, &s->bell_on_message)) {
|
||||||
s->bell_on_message = s->bell_on_message ? NT_BEEP : 0;
|
s->bell_on_message = s->bell_on_message ? NT_BEEP : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config_setting_lookup_bool(setting, ui_strings.bell_on_filetrans, &s->bell_on_filetrans)) {
|
if (config_setting_lookup_bool(setting, ui_strings.bell_on_filetrans, &s->bell_on_filetrans)) {
|
||||||
s->bell_on_filetrans = s->bell_on_filetrans ? NT_BEEP : 0;
|
s->bell_on_filetrans = s->bell_on_filetrans ? NT_BEEP : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config_setting_lookup_bool(setting, ui_strings.bell_on_filetrans_accept, &s->bell_on_filetrans_accept)) {
|
if (config_setting_lookup_bool(setting, ui_strings.bell_on_filetrans_accept, &s->bell_on_filetrans_accept)) {
|
||||||
s->bell_on_filetrans_accept = s->bell_on_filetrans_accept ? NT_BEEP : 0;
|
s->bell_on_filetrans_accept = s->bell_on_filetrans_accept ? NT_BEEP : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config_setting_lookup_bool(setting, ui_strings.bell_on_invite, &s->bell_on_invite)) {
|
if (config_setting_lookup_bool(setting, ui_strings.bell_on_invite, &s->bell_on_invite)) {
|
||||||
s->bell_on_invite = s->bell_on_invite ? NT_BEEP : 0;
|
s->bell_on_invite = s->bell_on_invite ? NT_BEEP : 0;
|
||||||
}
|
}
|
||||||
@ -361,12 +367,15 @@ int settings_load(struct user_settings *s, const char *patharg)
|
|||||||
if ( config_setting_lookup_string(setting, ui_strings.line_join, &str) ) {
|
if ( config_setting_lookup_string(setting, ui_strings.line_join, &str) ) {
|
||||||
snprintf(s->line_join, sizeof(s->line_join), "%s", str);
|
snprintf(s->line_join, sizeof(s->line_join), "%s", str);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( config_setting_lookup_string(setting, ui_strings.line_quit, &str) ) {
|
if ( config_setting_lookup_string(setting, ui_strings.line_quit, &str) ) {
|
||||||
snprintf(s->line_quit, sizeof(s->line_quit), "%s", str);
|
snprintf(s->line_quit, sizeof(s->line_quit), "%s", str);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( config_setting_lookup_string(setting, ui_strings.line_alert, &str) ) {
|
if ( config_setting_lookup_string(setting, ui_strings.line_alert, &str) ) {
|
||||||
snprintf(s->line_alert, sizeof(s->line_alert), "%s", str);
|
snprintf(s->line_alert, sizeof(s->line_alert), "%s", str);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( config_setting_lookup_string(setting, ui_strings.line_normal, &str) ) {
|
if ( config_setting_lookup_string(setting, ui_strings.line_normal, &str) ) {
|
||||||
snprintf(s->line_normal, sizeof(s->line_normal), "%s", str);
|
snprintf(s->line_normal, sizeof(s->line_normal), "%s", str);
|
||||||
}
|
}
|
||||||
@ -421,31 +430,43 @@ int settings_load(struct user_settings *s, const char *patharg)
|
|||||||
/* keys */
|
/* keys */
|
||||||
if ((setting = config_lookup(cfg, key_strings.self)) != NULL) {
|
if ((setting = config_lookup(cfg, key_strings.self)) != NULL) {
|
||||||
const char *tmp = NULL;
|
const char *tmp = NULL;
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.next_tab, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.next_tab, &tmp))
|
||||||
set_key_binding(&s->key_next_tab, &tmp);
|
set_key_binding(&s->key_next_tab, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.prev_tab, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.prev_tab, &tmp))
|
||||||
set_key_binding(&s->key_prev_tab, &tmp);
|
set_key_binding(&s->key_prev_tab, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.scroll_line_up, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.scroll_line_up, &tmp))
|
||||||
set_key_binding(&s->key_scroll_line_up, &tmp);
|
set_key_binding(&s->key_scroll_line_up, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.scroll_line_down, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.scroll_line_down, &tmp))
|
||||||
set_key_binding(&s->key_scroll_line_down, &tmp);
|
set_key_binding(&s->key_scroll_line_down, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.half_page_up, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.half_page_up, &tmp))
|
||||||
set_key_binding(&s->key_half_page_up, &tmp);
|
set_key_binding(&s->key_half_page_up, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.half_page_down, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.half_page_down, &tmp))
|
||||||
set_key_binding(&s->key_half_page_down, &tmp);
|
set_key_binding(&s->key_half_page_down, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.page_bottom, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.page_bottom, &tmp))
|
||||||
set_key_binding(&s->key_page_bottom, &tmp);
|
set_key_binding(&s->key_page_bottom, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.peer_list_up, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.peer_list_up, &tmp))
|
||||||
set_key_binding(&s->key_peer_list_up, &tmp);
|
set_key_binding(&s->key_peer_list_up, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.peer_list_down, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.peer_list_down, &tmp))
|
||||||
set_key_binding(&s->key_peer_list_down, &tmp);
|
set_key_binding(&s->key_peer_list_down, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.toggle_peerlist, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.toggle_peerlist, &tmp))
|
||||||
set_key_binding(&s->key_toggle_peerlist, &tmp);
|
set_key_binding(&s->key_toggle_peerlist, &tmp);
|
||||||
|
|
||||||
if (config_setting_lookup_string(setting, key_strings.toggle_pastemode, &tmp))
|
if (config_setting_lookup_string(setting, key_strings.toggle_pastemode, &tmp))
|
||||||
set_key_binding(&s->key_toggle_pastemode, &tmp);
|
set_key_binding(&s->key_toggle_pastemode, &tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef AUDIO
|
#ifdef AUDIO
|
||||||
|
|
||||||
if ((setting = config_lookup(cfg, audio_strings.self)) != NULL) {
|
if ((setting = config_lookup(cfg, audio_strings.self)) != NULL) {
|
||||||
config_setting_lookup_int(setting, audio_strings.input_device, &s->audio_in_dev);
|
config_setting_lookup_int(setting, audio_strings.input_device, &s->audio_in_dev);
|
||||||
s->audio_in_dev = s->audio_in_dev < 0 || s->audio_in_dev > MAX_DEVICES ? 0 : s->audio_in_dev;
|
s->audio_in_dev = s->audio_in_dev < 0 || s->audio_in_dev > MAX_DEVICES ? 0 : s->audio_in_dev;
|
||||||
@ -455,9 +476,11 @@ int settings_load(struct user_settings *s, const char *patharg)
|
|||||||
|
|
||||||
config_setting_lookup_float(setting, audio_strings.VAD_treshold, &s->VAD_treshold);
|
config_setting_lookup_float(setting, audio_strings.VAD_treshold, &s->VAD_treshold);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SOUND_NOTIFY
|
#ifdef SOUND_NOTIFY
|
||||||
|
|
||||||
if ((setting = config_lookup(cfg, sound_strings.self)) != NULL) {
|
if ((setting = config_lookup(cfg, sound_strings.self)) != NULL) {
|
||||||
if ( (config_setting_lookup_string(setting, sound_strings.notif_error, &str) != CONFIG_TRUE) ||
|
if ( (config_setting_lookup_string(setting, sound_strings.notif_error, &str) != CONFIG_TRUE) ||
|
||||||
!set_sound(notif_error, str) ) {
|
!set_sound(notif_error, str) ) {
|
||||||
@ -506,8 +529,7 @@ int settings_load(struct user_settings *s, const char *patharg)
|
|||||||
if (str && strcasecmp(str, NO_SOUND) != 0)
|
if (str && strcasecmp(str, NO_SOUND) != 0)
|
||||||
set_sound(transfer_completed, PACKAGE_DATADIR "/sounds/ToxicTransferComplete.wav");
|
set_sound(transfer_completed, PACKAGE_DATADIR "/sounds/ToxicTransferComplete.wav");
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
set_sound(notif_error, PACKAGE_DATADIR "/sounds/ToxicError.wav");
|
set_sound(notif_error, PACKAGE_DATADIR "/sounds/ToxicError.wav");
|
||||||
set_sound(user_log_in, PACKAGE_DATADIR "/sounds/ToxicContactOnline.wav");
|
set_sound(user_log_in, PACKAGE_DATADIR "/sounds/ToxicContactOnline.wav");
|
||||||
set_sound(user_log_out, PACKAGE_DATADIR "/sounds/ToxicContactOffline.wav");
|
set_sound(user_log_out, PACKAGE_DATADIR "/sounds/ToxicContactOffline.wav");
|
||||||
@ -517,6 +539,7 @@ int settings_load(struct user_settings *s, const char *patharg)
|
|||||||
set_sound(transfer_pending, PACKAGE_DATADIR "/sounds/ToxicTransferStart.wav");
|
set_sound(transfer_pending, PACKAGE_DATADIR "/sounds/ToxicTransferStart.wav");
|
||||||
set_sound(transfer_completed, PACKAGE_DATADIR "/sounds/ToxicTransferComplete.wav");
|
set_sound(transfer_completed, PACKAGE_DATADIR "/sounds/ToxicTransferComplete.wav");
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
config_destroy(cfg);
|
config_destroy(cfg);
|
||||||
|
@ -52,8 +52,7 @@ extern struct Winthread Winthread;
|
|||||||
#define PATH_SEP_S "/"
|
#define PATH_SEP_S "/"
|
||||||
#define PATH_SEP_C '/'
|
#define PATH_SEP_C '/'
|
||||||
|
|
||||||
typedef enum
|
typedef enum {
|
||||||
{
|
|
||||||
MPLEX_NONE,
|
MPLEX_NONE,
|
||||||
MPLEX_SCREEN,
|
MPLEX_SCREEN,
|
||||||
MPLEX_TMUX,
|
MPLEX_TMUX,
|
||||||
@ -97,13 +96,14 @@ static char *read_into_dyn_buffer (FILE *stream)
|
|||||||
char *dyn_buffer = NULL;
|
char *dyn_buffer = NULL;
|
||||||
int dyn_buffer_size = 1; /* account for the \0 */
|
int dyn_buffer_size = 1; /* account for the \0 */
|
||||||
|
|
||||||
while ((input_ptr = fgets (buffer, BUFFER_SIZE, stream)) != NULL)
|
while ((input_ptr = fgets (buffer, BUFFER_SIZE, stream)) != NULL) {
|
||||||
{
|
|
||||||
int length = dyn_buffer_size + strlen (input_ptr);
|
int length = dyn_buffer_size + strlen (input_ptr);
|
||||||
|
|
||||||
if (dyn_buffer)
|
if (dyn_buffer)
|
||||||
dyn_buffer = (char *) realloc (dyn_buffer, length);
|
dyn_buffer = (char *) realloc (dyn_buffer, length);
|
||||||
else
|
else
|
||||||
dyn_buffer = (char *) malloc (length);
|
dyn_buffer = (char *) malloc (length);
|
||||||
|
|
||||||
strcpy (dyn_buffer + dyn_buffer_size - 1, input_ptr);
|
strcpy (dyn_buffer + dyn_buffer_size - 1, input_ptr);
|
||||||
dyn_buffer_size = length;
|
dyn_buffer_size = length;
|
||||||
}
|
}
|
||||||
@ -123,15 +123,18 @@ static char *extract_socket_path (const char *info)
|
|||||||
|
|
||||||
pos += strlen (search_str);
|
pos += strlen (search_str);
|
||||||
pos = strchr (pos, PATH_SEP_C);
|
pos = strchr (pos, PATH_SEP_C);
|
||||||
|
|
||||||
if (!pos)
|
if (!pos)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
end = strchr (pos, '\n');
|
end = strchr (pos, '\n');
|
||||||
|
|
||||||
if (!end)
|
if (!end)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
*end = '\0';
|
*end = '\0';
|
||||||
end = strrchr (pos, '.');
|
end = strrchr (pos, '.');
|
||||||
|
|
||||||
if (!end)
|
if (!end)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -147,14 +150,17 @@ static int detect_gnu_screen ()
|
|||||||
char *dyn_buffer = NULL;
|
char *dyn_buffer = NULL;
|
||||||
|
|
||||||
socket_name = getenv ("STY");
|
socket_name = getenv ("STY");
|
||||||
|
|
||||||
if (!socket_name)
|
if (!socket_name)
|
||||||
goto nomplex;
|
goto nomplex;
|
||||||
|
|
||||||
session_info_stream = popen ("env LC_ALL=C screen -ls", "r");
|
session_info_stream = popen ("env LC_ALL=C screen -ls", "r");
|
||||||
|
|
||||||
if (!session_info_stream)
|
if (!session_info_stream)
|
||||||
goto nomplex;
|
goto nomplex;
|
||||||
|
|
||||||
dyn_buffer = read_into_dyn_buffer (session_info_stream);
|
dyn_buffer = read_into_dyn_buffer (session_info_stream);
|
||||||
|
|
||||||
if (!dyn_buffer)
|
if (!dyn_buffer)
|
||||||
goto nomplex;
|
goto nomplex;
|
||||||
|
|
||||||
@ -162,6 +168,7 @@ static int detect_gnu_screen ()
|
|||||||
session_info_stream = NULL;
|
session_info_stream = NULL;
|
||||||
|
|
||||||
socket_path = extract_socket_path (dyn_buffer);
|
socket_path = extract_socket_path (dyn_buffer);
|
||||||
|
|
||||||
if (!socket_path)
|
if (!socket_path)
|
||||||
goto nomplex;
|
goto nomplex;
|
||||||
|
|
||||||
@ -181,23 +188,29 @@ static int detect_gnu_screen ()
|
|||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
nomplex:
|
nomplex:
|
||||||
|
|
||||||
if (session_info_stream)
|
if (session_info_stream)
|
||||||
pclose (session_info_stream);
|
pclose (session_info_stream);
|
||||||
|
|
||||||
if (dyn_buffer)
|
if (dyn_buffer)
|
||||||
free (dyn_buffer);
|
free (dyn_buffer);
|
||||||
|
|
||||||
if (socket_path)
|
if (socket_path)
|
||||||
free(socket_path);
|
free(socket_path);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int detect_tmux ()
|
static int detect_tmux ()
|
||||||
{
|
{
|
||||||
char *tmux_env = getenv ("TMUX"), *pos;
|
char *tmux_env = getenv ("TMUX"), *pos;
|
||||||
|
|
||||||
if (!tmux_env)
|
if (!tmux_env)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* find second separator */
|
/* find second separator */
|
||||||
pos = strrchr (tmux_env, ',');
|
pos = strrchr (tmux_env, ',');
|
||||||
|
|
||||||
if (!pos)
|
if (!pos)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -230,6 +243,7 @@ static int gnu_screen_is_detached ()
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
struct stat sb;
|
struct stat sb;
|
||||||
|
|
||||||
if (stat (mplex_data, &sb) != 0)
|
if (stat (mplex_data, &sb) != 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -257,10 +271,12 @@ static int tmux_is_detached ()
|
|||||||
const int numstr_len = strlen (mplex_data);
|
const int numstr_len = strlen (mplex_data);
|
||||||
|
|
||||||
session_info_stream = popen ("env LC_ALL=C tmux list-sessions", "r");
|
session_info_stream = popen ("env LC_ALL=C tmux list-sessions", "r");
|
||||||
|
|
||||||
if (!session_info_stream)
|
if (!session_info_stream)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
dyn_buffer = read_into_dyn_buffer (session_info_stream);
|
dyn_buffer = read_into_dyn_buffer (session_info_stream);
|
||||||
|
|
||||||
if (!dyn_buffer)
|
if (!dyn_buffer)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
@ -295,12 +311,16 @@ static int tmux_is_detached ()
|
|||||||
return attached_pos == NULL || attached_pos > nl_pos;
|
return attached_pos == NULL || attached_pos > nl_pos;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
|
||||||
if (session_info_stream)
|
if (session_info_stream)
|
||||||
pclose (session_info_stream);
|
pclose (session_info_stream);
|
||||||
|
|
||||||
if (dyn_buffer)
|
if (dyn_buffer)
|
||||||
free (dyn_buffer);
|
free (dyn_buffer);
|
||||||
|
|
||||||
if (search_str)
|
if (search_str)
|
||||||
free (search_str);
|
free (search_str);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -332,15 +352,11 @@ static void mplex_timer_handler (Tox *m)
|
|||||||
current_status = tox_self_get_status (m);
|
current_status = tox_self_get_status (m);
|
||||||
pthread_mutex_unlock (&Winthread.lock);
|
pthread_mutex_unlock (&Winthread.lock);
|
||||||
|
|
||||||
if (auto_away_active && current_status == TOX_USER_STATUS_AWAY && !detached)
|
if (auto_away_active && current_status == TOX_USER_STATUS_AWAY && !detached) {
|
||||||
{
|
|
||||||
auto_away_active = false;
|
auto_away_active = false;
|
||||||
new_status = prev_status;
|
new_status = prev_status;
|
||||||
new_note = prev_note;
|
new_note = prev_note;
|
||||||
}
|
} else if (current_status == TOX_USER_STATUS_NONE && detached) {
|
||||||
else
|
|
||||||
if (current_status == TOX_USER_STATUS_NONE && detached)
|
|
||||||
{
|
|
||||||
auto_away_active = true;
|
auto_away_active = true;
|
||||||
prev_status = current_status;
|
prev_status = current_status;
|
||||||
new_status = TOX_USER_STATUS_AWAY;
|
new_status = TOX_USER_STATUS_AWAY;
|
||||||
@ -350,8 +366,7 @@ static void mplex_timer_handler (Tox *m)
|
|||||||
prev_note[slen] = '\0';
|
prev_note[slen] = '\0';
|
||||||
pthread_mutex_unlock (&Winthread.lock);
|
pthread_mutex_unlock (&Winthread.lock);
|
||||||
new_note = user_settings->mplex_away_note;
|
new_note = user_settings->mplex_away_note;
|
||||||
}
|
} else
|
||||||
else
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
char argv[3][MAX_STR_SIZE];
|
char argv[3][MAX_STR_SIZE];
|
||||||
|
13
src/toxic.c
13
src/toxic.c
@ -320,8 +320,10 @@ static int password_prompt(char *buf, int size)
|
|||||||
/* eat overflowed stdin and return error */
|
/* eat overflowed stdin and return error */
|
||||||
if (buf[--len] != '\n') {
|
if (buf[--len] != '\n') {
|
||||||
int ch;
|
int ch;
|
||||||
|
|
||||||
while ((ch = getchar()) != '\n' && ch > 0)
|
while ((ch = getchar()) != '\n' && ch > 0)
|
||||||
;
|
;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -338,6 +340,7 @@ static int password_eval(char *buf, int size)
|
|||||||
|
|
||||||
/* Run password_eval command */
|
/* Run password_eval command */
|
||||||
FILE *f = popen(user_settings->password_eval, "r");
|
FILE *f = popen(user_settings->password_eval, "r");
|
||||||
|
|
||||||
if (f == NULL) {
|
if (f == NULL) {
|
||||||
fprintf(stderr, "Executing password_eval failed\n");
|
fprintf(stderr, "Executing password_eval failed\n");
|
||||||
return 0;
|
return 0;
|
||||||
@ -345,6 +348,7 @@ static int password_eval(char *buf, int size)
|
|||||||
|
|
||||||
/* Get output from command */
|
/* Get output from command */
|
||||||
char *ret = fgets(buf, size, f);
|
char *ret = fgets(buf, size, f);
|
||||||
|
|
||||||
if (ret == NULL) {
|
if (ret == NULL) {
|
||||||
fprintf(stderr, "Reading password from password_eval command failed\n");
|
fprintf(stderr, "Reading password from password_eval command failed\n");
|
||||||
pclose(f);
|
pclose(f);
|
||||||
@ -353,6 +357,7 @@ static int password_eval(char *buf, int size)
|
|||||||
|
|
||||||
/* Get exit status */
|
/* Get exit status */
|
||||||
int status = pclose(f);
|
int status = pclose(f);
|
||||||
|
|
||||||
if (status != 0) {
|
if (status != 0) {
|
||||||
fprintf(stderr, "password_eval command returned error %d\n", status);
|
fprintf(stderr, "password_eval command returned error %d\n", status);
|
||||||
return 0;
|
return 0;
|
||||||
@ -360,6 +365,7 @@ static int password_eval(char *buf, int size)
|
|||||||
|
|
||||||
/* Removez whitespace or \n at end */
|
/* Removez whitespace or \n at end */
|
||||||
int i, len = strlen(buf);
|
int i, len = strlen(buf);
|
||||||
|
|
||||||
for (i = len - 1; i > 0 && isspace(buf[i]); i--) {
|
for (i = len - 1; i > 0 && isspace(buf[i]); i--) {
|
||||||
buf[i] = 0;
|
buf[i] = 0;
|
||||||
len--;
|
len--;
|
||||||
@ -612,6 +618,7 @@ static Tox *load_tox(char *data_path, struct Tox_Options *tox_opts, TOX_ERR_NEW
|
|||||||
|
|
||||||
size_t pwlen = 0;
|
size_t pwlen = 0;
|
||||||
int pweval = user_settings->password_eval[0];
|
int pweval = user_settings->password_eval[0];
|
||||||
|
|
||||||
if (!pweval) {
|
if (!pweval) {
|
||||||
system("clear"); // TODO: is this portable?
|
system("clear"); // TODO: is this portable?
|
||||||
printf("Enter password (q to quit) ");
|
printf("Enter password (q to quit) ");
|
||||||
@ -626,6 +633,7 @@ static Tox *load_tox(char *data_path, struct Tox_Options *tox_opts, TOX_ERR_NEW
|
|||||||
} else {
|
} else {
|
||||||
pwlen = password_prompt(user_password.pass, sizeof(user_password.pass));
|
pwlen = password_prompt(user_password.pass, sizeof(user_password.pass));
|
||||||
}
|
}
|
||||||
|
|
||||||
user_password.len = pwlen;
|
user_password.len = pwlen;
|
||||||
|
|
||||||
if (strcasecmp(user_password.pass, "q") == 0) {
|
if (strcasecmp(user_password.pass, "q") == 0) {
|
||||||
@ -1139,8 +1147,10 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef X11
|
#ifdef X11
|
||||||
|
|
||||||
if (init_xtra(DnD_callback) == -1)
|
if (init_xtra(DnD_callback) == -1)
|
||||||
queue_init_message("X failed to initialize");
|
queue_init_message("X failed to initialize");
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Tox *m = load_toxic(DATA_FILE);
|
Tox *m = load_toxic(DATA_FILE);
|
||||||
@ -1182,6 +1192,7 @@ int main(int argc, char **argv)
|
|||||||
set_primary_device(output, user_settings->audio_out_dev);
|
set_primary_device(output, user_settings->audio_out_dev);
|
||||||
|
|
||||||
#elif SOUND_NOTIFY
|
#elif SOUND_NOTIFY
|
||||||
|
|
||||||
if ( init_devices() == de_InternalError )
|
if ( init_devices() == de_InternalError )
|
||||||
queue_init_message("Failed to init audio devices");
|
queue_init_message("Failed to init audio devices");
|
||||||
|
|
||||||
@ -1219,8 +1230,10 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
if (timed_out(last_save, AUTOSAVE_FREQ)) {
|
if (timed_out(last_save, AUTOSAVE_FREQ)) {
|
||||||
pthread_mutex_lock(&Winthread.lock);
|
pthread_mutex_lock(&Winthread.lock);
|
||||||
|
|
||||||
if (store_data(m, DATA_FILE) != 0)
|
if (store_data(m, DATA_FILE) != 0)
|
||||||
line_info_add(prompt, NULL, NULL, NULL, SYS_MSG, 0, RED, "WARNING: Failed to save to data file");
|
line_info_add(prompt, NULL, NULL, NULL, SYS_MSG, 0, RED, "WARNING: Failed to save to data file");
|
||||||
|
|
||||||
pthread_mutex_unlock(&Winthread.lock);
|
pthread_mutex_unlock(&Winthread.lock);
|
||||||
|
|
||||||
last_save = cur_time;
|
last_save = cur_time;
|
||||||
|
12
src/toxic.h
12
src/toxic.h
@ -107,7 +107,8 @@ int store_data(Tox *m, const char *path);
|
|||||||
/* callbacks */
|
/* callbacks */
|
||||||
void on_request(Tox *m, const uint8_t *public_key, const uint8_t *data, size_t length, void *userdata);
|
void on_request(Tox *m, const uint8_t *public_key, const uint8_t *data, size_t length, void *userdata);
|
||||||
void on_connectionchange(Tox *m, uint32_t friendnumber, TOX_CONNECTION status, void *userdata);
|
void on_connectionchange(Tox *m, uint32_t friendnumber, TOX_CONNECTION status, void *userdata);
|
||||||
void on_message(Tox *m, uint32_t friendnumber, TOX_MESSAGE_TYPE type, const uint8_t *string, size_t length, void *userdata);
|
void on_message(Tox *m, uint32_t friendnumber, TOX_MESSAGE_TYPE type, const uint8_t *string, size_t length,
|
||||||
|
void *userdata);
|
||||||
void on_action(Tox *m, uint32_t friendnumber, const uint8_t *string, size_t length, void *userdata);
|
void on_action(Tox *m, uint32_t friendnumber, const uint8_t *string, size_t length, void *userdata);
|
||||||
void on_nickchange(Tox *m, uint32_t friendnumber, const uint8_t *string, size_t length, void *userdata);
|
void on_nickchange(Tox *m, uint32_t friendnumber, const uint8_t *string, size_t length, void *userdata);
|
||||||
void on_statuschange(Tox *m, uint32_t friendnumber, TOX_USER_STATUS status, void *userdata);
|
void on_statuschange(Tox *m, uint32_t friendnumber, TOX_USER_STATUS status, void *userdata);
|
||||||
@ -115,10 +116,13 @@ void on_statusmessagechange(Tox *m, uint32_t friendnumber, const uint8_t *string
|
|||||||
void on_friendadded(Tox *m, uint32_t friendnumber, bool sort);
|
void on_friendadded(Tox *m, uint32_t friendnumber, bool sort);
|
||||||
void on_groupmessage(Tox *m, int groupnumber, int peernumber, const uint8_t *message, uint16_t length, void *userdata);
|
void on_groupmessage(Tox *m, int groupnumber, int peernumber, const uint8_t *message, uint16_t length, void *userdata);
|
||||||
void on_groupaction(Tox *m, int groupnumber, int peernumber, const uint8_t *action, uint16_t length, void *userdata);
|
void on_groupaction(Tox *m, int groupnumber, int peernumber, const uint8_t *action, uint16_t length, void *userdata);
|
||||||
void on_groupinvite(Tox *m, int32_t friendnumber, uint8_t type, const uint8_t *group_pub_key, uint16_t length, void *userdata);
|
void on_groupinvite(Tox *m, int32_t friendnumber, uint8_t type, const uint8_t *group_pub_key, uint16_t length,
|
||||||
|
void *userdata);
|
||||||
void on_group_namelistchange(Tox *m, int groupnumber, int peernumber, uint8_t change, void *userdata);
|
void on_group_namelistchange(Tox *m, int groupnumber, int peernumber, uint8_t change, void *userdata);
|
||||||
void on_group_titlechange(Tox *m, int groupnumber, int peernumber, const uint8_t *title, uint8_t length, void *userdata);
|
void on_group_titlechange(Tox *m, int groupnumber, int peernumber, const uint8_t *title, uint8_t length,
|
||||||
void on_file_chunk_request(Tox *m, uint32_t friendnumber, uint32_t filenumber, uint64_t position, size_t length, void *userdata);
|
void *userdata);
|
||||||
|
void on_file_chunk_request(Tox *m, uint32_t friendnumber, uint32_t filenumber, uint64_t position, size_t length,
|
||||||
|
void *userdata);
|
||||||
void on_file_recv_chunk(Tox *m, uint32_t friendnumber, uint32_t filenumber, uint64_t position, const uint8_t *data,
|
void on_file_recv_chunk(Tox *m, uint32_t friendnumber, uint32_t filenumber, uint64_t position, const uint8_t *data,
|
||||||
size_t length, void *userdata);
|
size_t length, void *userdata);
|
||||||
void on_file_control (Tox *m, uint32_t friendnumber, uint32_t filenumber, TOX_FILE_CONTROL control, void *userdata);
|
void on_file_control (Tox *m, uint32_t friendnumber, uint32_t filenumber, TOX_FILE_CONTROL control, void *userdata);
|
||||||
|
@ -246,6 +246,7 @@ void fetch_hist_item(ChatContext *ctx, int key_dir)
|
|||||||
void strsubst(char *str, char old, char new)
|
void strsubst(char *str, char old, char new)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; str[i] != '\0'; ++i)
|
for (i = 0; str[i] != '\0'; ++i)
|
||||||
if (str[i] == old)
|
if (str[i] == old)
|
||||||
str[i] = new;
|
str[i] = new;
|
||||||
@ -254,6 +255,7 @@ void strsubst(char* str, char old, char new)
|
|||||||
void wstrsubst(wchar_t *str, wchar_t old, wchar_t new)
|
void wstrsubst(wchar_t *str, wchar_t old, wchar_t new)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; str[i] != L'\0'; ++i)
|
for (i = 0; str[i] != L'\0'; ++i)
|
||||||
if (str[i] == old)
|
if (str[i] == old)
|
||||||
str[i] = new;
|
str[i] = new;
|
||||||
|
@ -82,6 +82,7 @@ ToxAV *init_video(ToxWindow *self, Tox *tox)
|
|||||||
void terminate_video()
|
void terminate_video()
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_CALLS; ++i) {
|
for (i = 0; i < MAX_CALLS; ++i) {
|
||||||
Call *this_call = &CallControl.calls[i];
|
Call *this_call = &CallControl.calls[i];
|
||||||
|
|
||||||
@ -94,7 +95,8 @@ void terminate_video()
|
|||||||
terminate_video_devices();
|
terminate_video_devices();
|
||||||
}
|
}
|
||||||
|
|
||||||
void read_video_device_callback(int16_t width, int16_t height, const uint8_t* y, const uint8_t* u, const uint8_t* v, void* data)
|
void read_video_device_callback(int16_t width, int16_t height, const uint8_t *y, const uint8_t *u, const uint8_t *v,
|
||||||
|
void *data)
|
||||||
{
|
{
|
||||||
uint32_t friend_number = *((uint32_t *)data); /* TODO: Or pass an array of call_idx's */
|
uint32_t friend_number = *((uint32_t *)data); /* TODO: Or pass an array of call_idx's */
|
||||||
Call *this_call = &CallControl.calls[friend_number];
|
Call *this_call = &CallControl.calls[friend_number];
|
||||||
@ -216,6 +218,7 @@ void callback_video_starting(uint32_t friend_number)
|
|||||||
|
|
||||||
if (error == TOXAV_ERR_CALL_CONTROL_OK) {
|
if (error == TOXAV_ERR_CALL_CONTROL_OK) {
|
||||||
size_t i;
|
size_t i;
|
||||||
|
|
||||||
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
for (i = 0; i < MAX_WINDOWS_NUM; ++i) {
|
||||||
if ( windows[i].is_call && windows[i].num == friend_number ) {
|
if ( windows[i].is_call && windows[i].num == friend_number ) {
|
||||||
if ( 0 != start_video_transmission(&windows[i], CallControl.av, this_call) ) {
|
if ( 0 != start_video_transmission(&windows[i], CallControl.av, this_call) ) {
|
||||||
@ -394,11 +397,11 @@ void cmd_ccur_video_device(WINDOW *window, ToxWindow *self, Tox *m, int argc, ch
|
|||||||
/* If call is active, change device */
|
/* If call is active, change device */
|
||||||
if ( self->is_call ) {
|
if ( self->is_call ) {
|
||||||
Call *this_call = &CallControl.calls[self->num];
|
Call *this_call = &CallControl.calls[self->num];
|
||||||
|
|
||||||
if ( this_call->ttas ) {
|
if ( this_call->ttas ) {
|
||||||
|
|
||||||
if ( type == vdt_output ) {
|
if ( type == vdt_output ) {
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
/* TODO: check for failure */
|
/* TODO: check for failure */
|
||||||
close_video_device(vdt_input, this_call->vin_idx);
|
close_video_device(vdt_input, this_call->vin_idx);
|
||||||
open_video_device(vdt_input, selection, &this_call->vin_idx);
|
open_video_device(vdt_input, selection, &this_call->vin_idx);
|
||||||
|
@ -111,6 +111,7 @@ static void yuv420tobgr(uint16_t width, uint16_t height, const uint8_t *y,
|
|||||||
unsigned int ustride, unsigned int vstride, uint8_t *out)
|
unsigned int ustride, unsigned int vstride, uint8_t *out)
|
||||||
{
|
{
|
||||||
unsigned long int i, j;
|
unsigned long int i, j;
|
||||||
|
|
||||||
for (i = 0; i < height; ++i) {
|
for (i = 0; i < height; ++i) {
|
||||||
for (j = 0; j < width; ++j) {
|
for (j = 0; j < width; ++j) {
|
||||||
uint8_t *point = out + 4 * ((i * width) + j);
|
uint8_t *point = out + 4 * ((i * width) + j);
|
||||||
@ -136,8 +137,10 @@ static void yuv422to420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v,
|
|||||||
uint8_t *input, uint16_t width, uint16_t height)
|
uint8_t *input, uint16_t width, uint16_t height)
|
||||||
{
|
{
|
||||||
uint8_t *end = input + width * height * 2;
|
uint8_t *end = input + width * height * 2;
|
||||||
|
|
||||||
while (input != end) {
|
while (input != end) {
|
||||||
uint8_t *line_end = input + width * 2;
|
uint8_t *line_end = input + width * 2;
|
||||||
|
|
||||||
while (input != line_end) {
|
while (input != line_end) {
|
||||||
*plane_y++ = *input++;
|
*plane_y++ = *input++;
|
||||||
*plane_u++ = *input++;
|
*plane_u++ = *input++;
|
||||||
@ -146,6 +149,7 @@ static void yuv422to420(uint8_t *plane_y, uint8_t *plane_u, uint8_t *plane_v,
|
|||||||
}
|
}
|
||||||
|
|
||||||
line_end = input + width * 2;
|
line_end = input + width * 2;
|
||||||
|
|
||||||
while (input != line_end) {
|
while (input != line_end) {
|
||||||
*plane_y++ = *input++;
|
*plane_y++ = *input++;
|
||||||
input++;//u
|
input++;//u
|
||||||
@ -178,12 +182,14 @@ VideoDeviceError init_video_devices()
|
|||||||
size[vdt_input] = 0;
|
size[vdt_input] = 0;
|
||||||
|
|
||||||
#if defined(__linux__) || defined(__FreeBSD__)
|
#if defined(__linux__) || defined(__FreeBSD__)
|
||||||
|
|
||||||
for (; size[vdt_input] <= MAX_DEVICES; ++size[vdt_input]) {
|
for (; size[vdt_input] <= MAX_DEVICES; ++size[vdt_input]) {
|
||||||
int fd;
|
int fd;
|
||||||
char device_address[] = "/dev/videoXX";
|
char device_address[] = "/dev/videoXX";
|
||||||
snprintf(device_address + 10, sizeof(char) * strlen(device_address) - 10, "%i", size[vdt_input]);
|
snprintf(device_address + 10, sizeof(char) * strlen(device_address) - 10, "%i", size[vdt_input]);
|
||||||
|
|
||||||
fd = open(device_address, O_RDWR | O_NONBLOCK, 0);
|
fd = open(device_address, O_RDWR | O_NONBLOCK, 0);
|
||||||
|
|
||||||
if ( fd == -1 ) {
|
if ( fd == -1 ) {
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
@ -203,6 +209,7 @@ VideoDeviceError init_video_devices()
|
|||||||
strcat(video_input_name, device_address);
|
strcat(video_input_name, device_address);
|
||||||
strcat(video_input_name, ")");
|
strcat(video_input_name, ")");
|
||||||
}
|
}
|
||||||
|
|
||||||
video_devices_names[vdt_input][size[vdt_input]] = video_input_name;
|
video_devices_names[vdt_input][size[vdt_input]] = video_input_name;
|
||||||
|
|
||||||
close(fd);
|
close(fd);
|
||||||
@ -210,8 +217,10 @@ VideoDeviceError init_video_devices()
|
|||||||
}
|
}
|
||||||
|
|
||||||
#else /* __OSX__ */
|
#else /* __OSX__ */
|
||||||
|
|
||||||
if ( osx_video_init((char **)video_devices_names[vdt_input], &size[vdt_input]) != 0 )
|
if ( osx_video_init((char **)video_devices_names[vdt_input], &size[vdt_input]) != 0 )
|
||||||
return vde_InternalError;
|
return vde_InternalError;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
size[vdt_output] = 1;
|
size[vdt_output] = 1;
|
||||||
@ -223,6 +232,7 @@ VideoDeviceError init_video_devices()
|
|||||||
return vde_InternalError;
|
return vde_InternalError;
|
||||||
|
|
||||||
pthread_t thread_id;
|
pthread_t thread_id;
|
||||||
|
|
||||||
if ( pthread_create(&thread_id, NULL, video_thread_poll, NULL) != 0 || pthread_detach(thread_id) != 0 )
|
if ( pthread_create(&thread_id, NULL, video_thread_poll, NULL) != 0 || pthread_detach(thread_id) != 0 )
|
||||||
return vde_InternalError;
|
return vde_InternalError;
|
||||||
|
|
||||||
@ -243,6 +253,7 @@ VideoDeviceError terminate_video_devices()
|
|||||||
usleep(20000);
|
usleep(20000);
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < size[vdt_input]; ++i) {
|
for (i = 0; i < size[vdt_input]; ++i) {
|
||||||
free((void *)video_devices_names[vdt_input][i]);
|
free((void *)video_devices_names[vdt_input][i]);
|
||||||
}
|
}
|
||||||
@ -261,11 +272,16 @@ VideoDeviceError register_video_device_callback(int32_t friend_number, uint32_t
|
|||||||
VideoDataHandleCallback callback, void *data)
|
VideoDataHandleCallback callback, void *data)
|
||||||
{
|
{
|
||||||
#if defined(__linux__) || defined(__FreeBSD__)
|
#if defined(__linux__) || defined(__FreeBSD__)
|
||||||
if ( size[vdt_input] <= device_idx || !video_devices_running[vdt_input][device_idx] || !video_devices_running[vdt_input][device_idx]->fd )
|
|
||||||
|
if ( size[vdt_input] <= device_idx || !video_devices_running[vdt_input][device_idx]
|
||||||
|
|| !video_devices_running[vdt_input][device_idx]->fd )
|
||||||
return vde_InvalidSelection;
|
return vde_InvalidSelection;
|
||||||
|
|
||||||
#else /* __OSX__ */
|
#else /* __OSX__ */
|
||||||
|
|
||||||
if ( size[vdt_input] <= device_idx || !video_devices_running[vdt_input][device_idx] )
|
if ( size[vdt_input] <= device_idx || !video_devices_running[vdt_input][device_idx] )
|
||||||
return vde_InvalidSelection;
|
return vde_InvalidSelection;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
lock;
|
lock;
|
||||||
@ -345,6 +361,7 @@ VideoDeviceError open_video_device(VideoDeviceType type, int32_t selection, uint
|
|||||||
snprintf(device_address + 10 , sizeof(device_address) - 10, "%i", selection);
|
snprintf(device_address + 10 , sizeof(device_address) - 10, "%i", selection);
|
||||||
|
|
||||||
device->fd = open(device_address, O_RDWR);
|
device->fd = open(device_address, O_RDWR);
|
||||||
|
|
||||||
if ( device->fd == -1 ) {
|
if ( device->fd == -1 ) {
|
||||||
unlock;
|
unlock;
|
||||||
return vde_FailedStart;
|
return vde_FailedStart;
|
||||||
@ -352,6 +369,7 @@ VideoDeviceError open_video_device(VideoDeviceType type, int32_t selection, uint
|
|||||||
|
|
||||||
/* Obtain video device capabilities */
|
/* Obtain video device capabilities */
|
||||||
struct v4l2_capability cap;
|
struct v4l2_capability cap;
|
||||||
|
|
||||||
if ( -1 == xioctl(device->fd, VIDIOC_QUERYCAP, &cap) ) {
|
if ( -1 == xioctl(device->fd, VIDIOC_QUERYCAP, &cap) ) {
|
||||||
close(device->fd);
|
close(device->fd);
|
||||||
free(device);
|
free(device);
|
||||||
@ -365,6 +383,7 @@ VideoDeviceError open_video_device(VideoDeviceType type, int32_t selection, uint
|
|||||||
|
|
||||||
fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
|
fmt.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
|
||||||
fmt.fmt.pix.pixelformat = V4L2_PIX_FMT_YUYV;
|
fmt.fmt.pix.pixelformat = V4L2_PIX_FMT_YUYV;
|
||||||
|
|
||||||
if ( -1 == xioctl(device->fd, VIDIOC_S_FMT, &fmt) ) {
|
if ( -1 == xioctl(device->fd, VIDIOC_S_FMT, &fmt) ) {
|
||||||
close(device->fd);
|
close(device->fd);
|
||||||
free(device);
|
free(device);
|
||||||
@ -381,6 +400,7 @@ VideoDeviceError open_video_device(VideoDeviceType type, int32_t selection, uint
|
|||||||
req.count = 4;
|
req.count = 4;
|
||||||
req.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
|
req.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
|
||||||
req.memory = V4L2_MEMORY_MMAP;
|
req.memory = V4L2_MEMORY_MMAP;
|
||||||
|
|
||||||
if ( -1 == xioctl(device->fd, VIDIOC_REQBUFS, &req) ) {
|
if ( -1 == xioctl(device->fd, VIDIOC_REQBUFS, &req) ) {
|
||||||
close(device->fd);
|
close(device->fd);
|
||||||
free(device);
|
free(device);
|
||||||
@ -422,12 +442,14 @@ VideoDeviceError open_video_device(VideoDeviceType type, int32_t selection, uint
|
|||||||
if ( MAP_FAILED == device->buffers[i].start ) {
|
if ( MAP_FAILED == device->buffers[i].start ) {
|
||||||
for (i = 0; i < buf.index; ++i)
|
for (i = 0; i < buf.index; ++i)
|
||||||
munmap(device->buffers[i].start, device->buffers[i].length);
|
munmap(device->buffers[i].start, device->buffers[i].length);
|
||||||
|
|
||||||
close(device->fd);
|
close(device->fd);
|
||||||
free(device);
|
free(device);
|
||||||
unlock;
|
unlock;
|
||||||
return vde_FailedStart;
|
return vde_FailedStart;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
device->n_buffers = i;
|
device->n_buffers = i;
|
||||||
|
|
||||||
enum v4l2_buf_type type;
|
enum v4l2_buf_type type;
|
||||||
@ -443,6 +465,7 @@ VideoDeviceError open_video_device(VideoDeviceType type, int32_t selection, uint
|
|||||||
if ( -1 == xioctl(device->fd, VIDIOC_QBUF, &buf) ) {
|
if ( -1 == xioctl(device->fd, VIDIOC_QBUF, &buf) ) {
|
||||||
for (i = 0; i < device->n_buffers; ++i)
|
for (i = 0; i < device->n_buffers; ++i)
|
||||||
munmap(device->buffers[i].start, device->buffers[i].length);
|
munmap(device->buffers[i].start, device->buffers[i].length);
|
||||||
|
|
||||||
close(device->fd);
|
close(device->fd);
|
||||||
free(device);
|
free(device);
|
||||||
unlock;
|
unlock;
|
||||||
@ -460,11 +483,13 @@ VideoDeviceError open_video_device(VideoDeviceType type, int32_t selection, uint
|
|||||||
}
|
}
|
||||||
|
|
||||||
#else /* __OSX__ */
|
#else /* __OSX__ */
|
||||||
|
|
||||||
if ( osx_video_open_device(selection, &device->video_width, &device->video_height) != 0 ) {
|
if ( osx_video_open_device(selection, &device->video_width, &device->video_height) != 0 ) {
|
||||||
free(device);
|
free(device);
|
||||||
unlock;
|
unlock;
|
||||||
return vde_FailedStart;
|
return vde_FailedStart;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Create X11 window associated to device */
|
/* Create X11 window associated to device */
|
||||||
@ -619,16 +644,19 @@ void* video_thread_poll (void* arg) // TODO: maybe use thread for every input so
|
|||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
lock;
|
lock;
|
||||||
|
|
||||||
if (!video_thread_running) {
|
if (!video_thread_running) {
|
||||||
unlock;
|
unlock;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock;
|
unlock;
|
||||||
|
|
||||||
if ( video_thread_paused ) usleep(10000); /* Wait for unpause. */
|
if ( video_thread_paused ) usleep(10000); /* Wait for unpause. */
|
||||||
else {
|
else {
|
||||||
for (i = 0; i < size[vdt_input]; ++i) {
|
for (i = 0; i < size[vdt_input]; ++i) {
|
||||||
lock;
|
lock;
|
||||||
|
|
||||||
if ( video_devices_running[vdt_input][i] != NULL ) {
|
if ( video_devices_running[vdt_input][i] != NULL ) {
|
||||||
/* Obtain frame image data from device buffers */
|
/* Obtain frame image data from device buffers */
|
||||||
VideoDevice *device = video_devices_running[vdt_input][i];
|
VideoDevice *device = video_devices_running[vdt_input][i];
|
||||||
@ -656,10 +684,12 @@ void* video_thread_poll (void* arg) // TODO: maybe use thread for every input so
|
|||||||
yuv422to420(y, u, v, data, video_width, video_height);
|
yuv422to420(y, u, v, data, video_width, video_height);
|
||||||
|
|
||||||
#else /* __OSX__*/
|
#else /* __OSX__*/
|
||||||
|
|
||||||
if ( osx_video_read_device(y, u, v, &video_width, &video_height) != 0 ) {
|
if ( osx_video_read_device(y, u, v, &video_width, &video_height) != 0 ) {
|
||||||
unlock;
|
unlock;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Send frame data to friend through ToxAV */
|
/* Send frame data to friend through ToxAV */
|
||||||
@ -697,15 +727,19 @@ void* video_thread_poll (void* arg) // TODO: maybe use thread for every input so
|
|||||||
free(img_data);
|
free(img_data);
|
||||||
|
|
||||||
#if defined(__linux__) || defined(__FreeBSD__)
|
#if defined(__linux__) || defined(__FreeBSD__)
|
||||||
|
|
||||||
if ( -1 == xioctl(device->fd, VIDIOC_QBUF, &buf) ) {
|
if ( -1 == xioctl(device->fd, VIDIOC_QBUF, &buf) ) {
|
||||||
unlock;
|
unlock;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* __linux__ */
|
#endif /* __linux__ */
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock;
|
unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
usleep(1000 * 1000 / 24);
|
usleep(1000 * 1000 / 24);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -733,13 +767,16 @@ VideoDeviceError close_video_device(VideoDeviceType type, uint32_t device_idx)
|
|||||||
if ( type == vdt_input ) {
|
if ( type == vdt_input ) {
|
||||||
#if defined(__linux__) || defined(__FreeBSD__)
|
#if defined(__linux__) || defined(__FreeBSD__)
|
||||||
enum v4l2_buf_type buf_type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
|
enum v4l2_buf_type buf_type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
|
||||||
|
|
||||||
if ( -1 == xioctl(device->fd, VIDIOC_STREAMOFF, &buf_type) ) {}
|
if ( -1 == xioctl(device->fd, VIDIOC_STREAMOFF, &buf_type) ) {}
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < device->n_buffers; ++i) {
|
for (i = 0; i < device->n_buffers; ++i) {
|
||||||
if ( -1 == munmap(device->buffers[i].start, device->buffers[i].length) ) {
|
if ( -1 == munmap(device->buffers[i].start, device->buffers[i].length) ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
close(device->fd);
|
close(device->fd);
|
||||||
|
|
||||||
#else /* __OSX__ */
|
#else /* __OSX__ */
|
||||||
@ -765,8 +802,7 @@ VideoDeviceError close_video_device(VideoDeviceType type, uint32_t device_idx)
|
|||||||
free(device);
|
free(device);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
} else device->ref_count--;
|
||||||
else device->ref_count--;
|
|
||||||
|
|
||||||
unlock;
|
unlock;
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -45,7 +45,8 @@ typedef enum VideoDeviceError {
|
|||||||
vde_CaptureError = -9,
|
vde_CaptureError = -9,
|
||||||
} VideoDeviceError;
|
} VideoDeviceError;
|
||||||
|
|
||||||
typedef void (*VideoDataHandleCallback) (int16_t width, int16_t height, const uint8_t* y, const uint8_t* u, const uint8_t* v, void* data);
|
typedef void (*VideoDataHandleCallback) (int16_t width, int16_t height, const uint8_t *y, const uint8_t *u,
|
||||||
|
const uint8_t *v, void *data);
|
||||||
|
|
||||||
#ifdef VIDEO
|
#ifdef VIDEO
|
||||||
VideoDeviceError init_video_devices(ToxAV *av);
|
VideoDeviceError init_video_devices(ToxAV *av);
|
||||||
@ -56,7 +57,8 @@ VideoDeviceError init_video_devices();
|
|||||||
VideoDeviceError terminate_video_devices();
|
VideoDeviceError terminate_video_devices();
|
||||||
|
|
||||||
/* Callback handles ready data from INPUT device */
|
/* Callback handles ready data from INPUT device */
|
||||||
VideoDeviceError register_video_device_callback(int32_t call_idx, uint32_t device_idx, VideoDataHandleCallback callback, void* data);
|
VideoDeviceError register_video_device_callback(int32_t call_idx, uint32_t device_idx, VideoDataHandleCallback callback,
|
||||||
|
void *data);
|
||||||
void *get_video_device_callback_data(uint32_t device_idx);
|
void *get_video_device_callback_data(uint32_t device_idx);
|
||||||
|
|
||||||
VideoDeviceError set_primary_video_device(VideoDeviceType type, int32_t selection);
|
VideoDeviceError set_primary_video_device(VideoDeviceType type, int32_t selection);
|
||||||
@ -67,7 +69,8 @@ VideoDeviceError open_video_device(VideoDeviceType type, int32_t selection, uint
|
|||||||
VideoDeviceError close_video_device(VideoDeviceType type, uint32_t device_idx);
|
VideoDeviceError close_video_device(VideoDeviceType type, uint32_t device_idx);
|
||||||
|
|
||||||
/* Write data to device */
|
/* Write data to device */
|
||||||
VideoDeviceError write_video_out(uint16_t width, uint16_t height, uint8_t const *y, uint8_t const *u, uint8_t const *v, int32_t ystride, int32_t ustride, int32_t vstride, void *user_data);
|
VideoDeviceError write_video_out(uint16_t width, uint16_t height, uint8_t const *y, uint8_t const *u, uint8_t const *v,
|
||||||
|
int32_t ystride, int32_t ustride, int32_t vstride, void *user_data);
|
||||||
|
|
||||||
void print_video_devices(ToxWindow *self, VideoDeviceType type);
|
void print_video_devices(ToxWindow *self, VideoDeviceType type);
|
||||||
void get_primary_video_device_name(VideoDeviceType type, char *buf, int size);
|
void get_primary_video_device_name(VideoDeviceType type, char *buf, int size);
|
||||||
|
@ -445,10 +445,12 @@ void on_window_resize(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef AUDIO
|
#ifdef AUDIO
|
||||||
|
|
||||||
if (w->chatwin->infobox.active) {
|
if (w->chatwin->infobox.active) {
|
||||||
delwin(w->chatwin->infobox.win);
|
delwin(w->chatwin->infobox.win);
|
||||||
w->chatwin->infobox.win = newwin(INFOBOX_HEIGHT, INFOBOX_WIDTH + 1, 1, x2 - INFOBOX_WIDTH);
|
w->chatwin->infobox.win = newwin(INFOBOX_HEIGHT, INFOBOX_WIDTH + 1, 1, x2 - INFOBOX_WIDTH);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* AUDIO */
|
#endif /* AUDIO */
|
||||||
|
|
||||||
scrollok(w->chatwin->history, 0);
|
scrollok(w->chatwin->history, 0);
|
||||||
@ -458,14 +460,18 @@ void on_window_resize(void)
|
|||||||
static void draw_window_tab(ToxWindow *toxwin)
|
static void draw_window_tab(ToxWindow *toxwin)
|
||||||
{
|
{
|
||||||
pthread_mutex_lock(&Winthread.lock);
|
pthread_mutex_lock(&Winthread.lock);
|
||||||
|
|
||||||
if (toxwin->alert != WINDOW_ALERT_NONE) attron(COLOR_PAIR(toxwin->alert));
|
if (toxwin->alert != WINDOW_ALERT_NONE) attron(COLOR_PAIR(toxwin->alert));
|
||||||
|
|
||||||
pthread_mutex_unlock(&Winthread.lock);
|
pthread_mutex_unlock(&Winthread.lock);
|
||||||
|
|
||||||
clrtoeol();
|
clrtoeol();
|
||||||
printw(" [%s]", toxwin->name);
|
printw(" [%s]", toxwin->name);
|
||||||
|
|
||||||
pthread_mutex_lock(&Winthread.lock);
|
pthread_mutex_lock(&Winthread.lock);
|
||||||
|
|
||||||
if (toxwin->alert != WINDOW_ALERT_NONE) attroff(COLOR_PAIR(toxwin->alert));
|
if (toxwin->alert != WINDOW_ALERT_NONE) attroff(COLOR_PAIR(toxwin->alert));
|
||||||
|
|
||||||
pthread_mutex_unlock(&Winthread.lock);
|
pthread_mutex_unlock(&Winthread.lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
25
src/xtra.c
25
src/xtra.c
@ -57,8 +57,7 @@ struct _Xtra {
|
|||||||
Atom expecting_type;
|
Atom expecting_type;
|
||||||
} Xtra;
|
} Xtra;
|
||||||
|
|
||||||
typedef struct _Property
|
typedef struct _Property {
|
||||||
{
|
|
||||||
unsigned char *data;
|
unsigned char *data;
|
||||||
int read_format;
|
int read_format;
|
||||||
unsigned long read_num;
|
unsigned long read_num;
|
||||||
@ -97,9 +96,11 @@ Property read_property(Window s, Atom p)
|
|||||||
Atom get_dnd_type(long *a, int l)
|
Atom get_dnd_type(long *a, int l)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
for (; i < l; i ++) {
|
for (; i < l; i ++) {
|
||||||
if (a[i] != XtraNil) return a[i]; /* Get first valid */
|
if (a[i] != XtraNil) return a[i]; /* Get first valid */
|
||||||
}
|
}
|
||||||
|
|
||||||
return XtraNil;
|
return XtraNil;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -199,12 +200,12 @@ static void handle_xdnd_selection(XSelectionEvent* e)
|
|||||||
|
|
||||||
|
|
||||||
/* Call callback for every entry */
|
/* Call callback for every entry */
|
||||||
if (Xtra.on_drop && p.read_num)
|
if (Xtra.on_drop && p.read_num) {
|
||||||
{
|
|
||||||
char *sptr;
|
char *sptr;
|
||||||
char *str = strtok_r((char *) p.data, "\n\r", &sptr);
|
char *str = strtok_r((char *) p.data, "\n\r", &sptr);
|
||||||
|
|
||||||
if (str) Xtra.on_drop(str, dt);
|
if (str) Xtra.on_drop(str, dt);
|
||||||
|
|
||||||
while ((str = strtok_r(NULL, "\n\r", &sptr)))
|
while ((str = strtok_r(NULL, "\n\r", &sptr)))
|
||||||
Xtra.on_drop(str, dt);
|
Xtra.on_drop(str, dt);
|
||||||
}
|
}
|
||||||
@ -221,30 +222,27 @@ void *event_loop(void* p)
|
|||||||
XEvent event;
|
XEvent event;
|
||||||
int pending;
|
int pending;
|
||||||
|
|
||||||
while (Xtra.display)
|
while (Xtra.display) {
|
||||||
{
|
|
||||||
/* NEEDMOEVENTSFODEMPROGRAMS */
|
/* NEEDMOEVENTSFODEMPROGRAMS */
|
||||||
|
|
||||||
XLockDisplay(Xtra.display);
|
XLockDisplay(Xtra.display);
|
||||||
|
|
||||||
if ((pending = XPending(Xtra.display))) XNextEvent(Xtra.display, &event);
|
if ((pending = XPending(Xtra.display))) XNextEvent(Xtra.display, &event);
|
||||||
|
|
||||||
if (!pending)
|
if (!pending) {
|
||||||
{
|
|
||||||
XUnlockDisplay(Xtra.display);
|
XUnlockDisplay(Xtra.display);
|
||||||
usleep(10000);
|
usleep(10000);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event.type == ClientMessage)
|
if (event.type == ClientMessage) {
|
||||||
{
|
|
||||||
Atom type = event.xclient.message_type;
|
Atom type = event.xclient.message_type;
|
||||||
|
|
||||||
if (type == XdndEnter) handle_xdnd_enter(&event.xclient);
|
if (type == XdndEnter) handle_xdnd_enter(&event.xclient);
|
||||||
else if (type == XdndPosition) handle_xdnd_position(&event.xclient);
|
else if (type == XdndPosition) handle_xdnd_position(&event.xclient);
|
||||||
else if (type == XdndDrop) handle_xdnd_drop(&event.xclient);
|
else if (type == XdndDrop) handle_xdnd_drop(&event.xclient);
|
||||||
else if (type == XtraTerminate) break;
|
else if (type == XtraTerminate) break;
|
||||||
}
|
} else if (event.type == SelectionNotify) handle_xdnd_selection(&event.xselection);
|
||||||
else if (event.type == SelectionNotify) handle_xdnd_selection(&event.xselection);
|
|
||||||
/* AINNOBODYCANHANDLEDEMEVENTS*/
|
/* AINNOBODYCANHANDLEDEMEVENTS*/
|
||||||
else XSendEvent(Xtra.display, Xtra.terminal_window, 0, 0, &event);
|
else XSendEvent(Xtra.display, Xtra.terminal_window, 0, 0, &event);
|
||||||
|
|
||||||
@ -256,6 +254,7 @@ void *event_loop(void* p)
|
|||||||
* otherwise HEWUSAGUDBOI happens
|
* otherwise HEWUSAGUDBOI happens
|
||||||
*/
|
*/
|
||||||
if (Xtra.display) XCloseDisplay(Xtra.display);
|
if (Xtra.display) XCloseDisplay(Xtra.display);
|
||||||
|
|
||||||
return (Xtra.display = NULL);
|
return (Xtra.display = NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -267,6 +266,7 @@ int init_xtra(drop_callback d)
|
|||||||
else Xtra.on_drop = d;
|
else Xtra.on_drop = d;
|
||||||
|
|
||||||
XInitThreads();
|
XInitThreads();
|
||||||
|
|
||||||
if ( !(Xtra.display = XOpenDisplay(NULL))) return -1;
|
if ( !(Xtra.display = XOpenDisplay(NULL))) return -1;
|
||||||
|
|
||||||
Xtra.terminal_window = focused_window_id();
|
Xtra.terminal_window = focused_window_id();
|
||||||
@ -338,6 +338,7 @@ int init_xtra(drop_callback d)
|
|||||||
(unsigned char *)&XdndVersion, 1);
|
(unsigned char *)&XdndVersion, 1);
|
||||||
|
|
||||||
pthread_t id;
|
pthread_t id;
|
||||||
|
|
||||||
if (pthread_create(&id, NULL, event_loop, NULL) != 0)
|
if (pthread_create(&id, NULL, event_loop, NULL) != 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user