1
0
mirror of https://github.com/Tha14/toxic.git synced 2024-11-15 09:33:01 +01:00
toxic/src/settings.c

332 lines
11 KiB
C
Raw Normal View History

2014-04-07 10:42:10 +02:00
/* settings.c
*
*
* Copyright (C) 2014 Toxic All Rights Reserved.
*
* This file is part of Toxic.
*
* Toxic is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Toxic is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Toxic. If not, see <http://www.gnu.org/licenses/>.
*
*/
#include <stdlib.h>
#include <string.h>
2014-07-21 01:12:13 +02:00
#include <libconfig.h>
#include "toxic.h"
#include "windows.h"
#include "configdir.h"
2014-07-21 01:12:13 +02:00
#include "notify.h"
2014-05-29 23:25:09 +02:00
#ifdef _AUDIO
2014-06-21 01:58:00 +02:00
#include "device.h"
#endif /* _AUDIO */
2014-05-29 23:25:09 +02:00
2014-04-07 10:42:10 +02:00
#include "settings.h"
#include "line_info.h"
2014-04-07 10:42:10 +02:00
#ifndef PACKAGE_DATADIR
#define PACKAGE_DATADIR "."
#endif
2014-07-23 20:59:36 +02:00
#define NO_SOUND "silent"
2014-07-21 01:12:13 +02:00
const struct _ui_strings {
const char* self;
const char* timestamps;
const char* alerts;
const char* native_colors;
const char* autolog;
const char* time_format;
const char* history_size;
} ui_strings = {
"ui",
"timestamps",
"alerts",
"native_colors",
"autolog",
"time_format",
"history_size"
2014-04-07 10:42:10 +02:00
};
2014-07-21 01:12:13 +02:00
static void ui_defaults(struct user_settings* settings)
2014-04-08 23:20:21 +02:00
{
2014-07-21 01:12:13 +02:00
settings->timestamps = TIMESTAMPS_ON;
settings->time = TIME_24;
settings->autolog = AUTOLOG_OFF;
settings->alerts = ALERTS_ENABLED;
settings->colour_theme = DFLT_COLS;
settings->history_size = 700;
2014-04-07 10:42:10 +02:00
}
const struct _keys_strings {
const char* self;
const char* keys;
const char* next_tab;
const char* prev_tab;
const char* scroll_line_up;
const char* scroll_line_down;
const char* half_page_up;
const char* half_page_down;
const char* page_bottom;
const char* peer_list_up;
const char* peer_list_down;
} key_strings = {
"keys",
"next_tab",
"prev_tab",
"scroll_line_up",
"scroll_line_down",
"half_page_up",
"half_page_down",
"page_bottom",
"peer_list_up",
"peer_list_down"
};
static void key_defaults(struct user_settings* settings)
{
settings->key_next_tab = 0x10;
settings->key_prev_tab = 0x0F;
settings->key_scroll_line_up = 0523; /* value from libncurses:curses.h */
settings->key_scroll_line_down = 0522;
settings->key_half_page_up = 0x06;
settings->key_half_page_down = 0x16;
settings->key_page_bottom = 0x08;
settings->key_peer_list_up = 0x1B;
settings->key_peer_list_down = 0x1D;
2014-04-07 10:42:10 +02:00
}
2014-07-21 01:12:13 +02:00
const struct _tox_strings {
const char* self;
const char* download_path;
} tox_strings = {
"tox",
"download_path",
};
2014-07-21 01:12:13 +02:00
static void tox_defaults(struct user_settings* settings)
2014-04-07 10:42:10 +02:00
{
strcpy(settings->download_path, ""); /* explicitly set default to pwd */
2014-04-07 10:42:10 +02:00
}
#ifdef _AUDIO
2014-07-21 01:12:13 +02:00
const struct _audio_strings {
const char* self;
const char* input_device;
const char* output_device;
const char* VAD_treshold;
} audio_strings = {
"audio",
"input_device",
"output_device",
"VAD_treshold",
};
static void audio_defaults(struct user_settings* settings)
{
2014-07-21 01:12:13 +02:00
settings->audio_in_dev = 0;
settings->audio_out_dev = 0;
settings->VAD_treshold = 40.0;
}
2014-07-21 01:12:13 +02:00
#endif
#ifdef _SOUND_NOTIFY
2014-07-21 01:12:13 +02:00
const struct _sound_strings {
const char* self;
const char* error;
const char* self_log_in;
const char* self_log_out;
const char* user_log_in;
const char* user_log_out;
const char* call_incoming;
const char* call_outgoing;
const char* generic_message;
const char* transfer_pending;
const char* transfer_completed;
} sound_strings = {
"sounds",
"error",
"self_log_in",
"self_log_out",
"user_log_in",
"user_log_out",
"call_incoming",
"call_outgoing",
"generic_message",
"transfer_pending",
"transfer_completed",
};
#endif
int settings_load(struct user_settings *s, const char *patharg)
2014-04-07 10:42:10 +02:00
{
2014-07-21 01:12:13 +02:00
config_t cfg[1];
config_setting_t *setting;
const char *str;
/* Load default settings */
ui_defaults(s);
tox_defaults(s);
key_defaults(s);
#ifdef _AUDIO
2014-07-21 01:12:13 +02:00
audio_defaults(s);
#endif
config_init(cfg);
char path[MAX_STR_SIZE];
/* use default config file path */
if (patharg == NULL) {
char *user_config_dir = get_user_config_dir();
snprintf(path, sizeof(path), "%s%stoxic.conf", user_config_dir, CONFIGDIR);
free(user_config_dir);
/* make sure path exists or is created on first time running */
FILE *fp = fopen(path, "r");
if (fp == NULL) {
if ((fp = fopen(path, "w")) == NULL)
return -1;
}
fclose(fp);
} else {
snprintf(path, sizeof(path), "%s", patharg);
}
2014-07-21 01:12:13 +02:00
if (!config_read_file(cfg, path)) {
char* chk = config_error_text(cfg);
int lin = config_error_line(cfg);
2014-07-21 01:12:13 +02:00
config_destroy(cfg);
2014-04-20 22:42:37 +02:00
return -1;
}
2014-07-21 01:12:13 +02:00
/* ui */
if ((setting = config_lookup(cfg, ui_strings.self)) != NULL) {
config_setting_lookup_bool(setting, ui_strings.timestamps, &s->timestamps);
config_setting_lookup_bool(setting, ui_strings.alerts, &s->alerts);
config_setting_lookup_bool(setting, ui_strings.autolog, &s->autolog);
config_setting_lookup_bool(setting, ui_strings.native_colors, &s->colour_theme);
config_setting_lookup_int(setting, ui_strings.history_size, &s->history_size);
config_setting_lookup_int(setting, ui_strings.time_format, &s->time);
s->time = s->time == TIME_24 || s->time == TIME_12 ? s->time : TIME_24; /* Check defaults */
}
if ((setting = config_lookup(cfg, tox_strings.self)) != NULL) {
if ( config_setting_lookup_string(setting, tox_strings.download_path, &str) ) {
strcpy(s->download_path, str);
2014-04-07 10:42:10 +02:00
}
}
/* keys */
if((setting = config_lookup(cfg, key_strings.self)) != NULL) {
config_setting_lookup_int(setting, key_strings.next_tab, &s->key_next_tab);
config_setting_lookup_int(setting, key_strings.prev_tab, &s->key_prev_tab);
config_setting_lookup_int(setting, key_strings.scroll_line_up, &s->key_scroll_line_up);
config_setting_lookup_int(setting, key_strings.scroll_line_down, &s->key_scroll_line_down);
config_setting_lookup_int(setting, key_strings.half_page_up, &s->key_half_page_up);
config_setting_lookup_int(setting, key_strings.half_page_down, &s->key_half_page_down);
config_setting_lookup_int(setting, key_strings.page_bottom, &s->key_page_bottom);
config_setting_lookup_int(setting, key_strings.peer_list_up, &s->key_peer_list_up);
//config_setting_lookup_int(setting, key_strings.peer_list_down, &s->key_peer_list_down);
}
2014-07-21 01:12:13 +02:00
#ifdef _AUDIO
2014-07-21 01:12:13 +02:00
if ((setting = config_lookup(cfg, audio_strings.self)) != NULL) {
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;
config_setting_lookup_int(setting, audio_strings.output_device, &s->audio_out_dev);
s->audio_out_dev = s->audio_out_dev < 0 || s->audio_out_dev > MAX_DEVICES ? 0 : s->audio_out_dev;
config_setting_lookup_float(setting, audio_strings.VAD_treshold, &s->VAD_treshold);
}
#endif
#ifdef _SOUND_NOTIFY
2014-07-21 01:12:13 +02:00
if ((setting = config_lookup(cfg, sound_strings.self)) != NULL) {
if ( (config_setting_lookup_string(setting, sound_strings.error, &str) != CONFIG_TRUE) ||
2014-07-23 20:59:36 +02:00
!set_sound(error, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(error, PACKAGE_DATADIR "/sounds/Error.wav");
}
if ( !config_setting_lookup_string(setting, sound_strings.user_log_in, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(user_log_in, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(user_log_in, PACKAGE_DATADIR "/sounds/ContactLogsIn.wav");
}
2014-07-21 01:12:13 +02:00
if ( !config_setting_lookup_string(setting, sound_strings.self_log_in, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(self_log_in, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(self_log_in, PACKAGE_DATADIR "/sounds/LogIn.wav");
}
if ( !config_setting_lookup_string(setting, sound_strings.user_log_out, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(user_log_out, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(user_log_out, PACKAGE_DATADIR "/sounds/ContactLogsOut.wav");
}
if ( !config_setting_lookup_string(setting, sound_strings.self_log_out, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(self_log_out, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(self_log_out, PACKAGE_DATADIR "/sounds/LogOut.wav");
}
2014-07-21 01:12:13 +02:00
if ( !config_setting_lookup_string(setting, sound_strings.call_incoming, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(call_incoming, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(call_incoming, PACKAGE_DATADIR "/sounds/IncomingCall.wav");
}
2014-07-21 01:12:13 +02:00
if ( !config_setting_lookup_string(setting, sound_strings.call_outgoing, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(call_outgoing, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(call_outgoing, PACKAGE_DATADIR "/sounds/OutgoingCall.wav");
}
2014-07-21 01:12:13 +02:00
2014-07-25 02:12:32 +02:00
if ( !config_setting_lookup_string(setting, sound_strings.generic_message, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(generic_message, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(generic_message, PACKAGE_DATADIR "/sounds/NewMessage.wav");
}
2014-07-21 01:12:13 +02:00
if ( !config_setting_lookup_string(setting, sound_strings.transfer_pending, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(transfer_pending, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(transfer_pending, PACKAGE_DATADIR "/sounds/TransferPending.wav");
}
2014-07-21 01:12:13 +02:00
if ( !config_setting_lookup_string(setting, sound_strings.transfer_completed, &str) ||
2014-07-23 20:59:36 +02:00
!set_sound(transfer_completed, str) ) {
2014-07-25 02:12:32 +02:00
if (strcasecmp(str, NO_SOUND) != 0)
2014-07-23 20:59:36 +02:00
set_sound(transfer_completed, PACKAGE_DATADIR "/sounds/TransferComplete.wav");
}
}
else {
set_sound(error, PACKAGE_DATADIR "/sounds/Error.wav");
set_sound(user_log_in, PACKAGE_DATADIR "/sounds/ContactLogsIn.wav");
set_sound(self_log_in, PACKAGE_DATADIR "/sounds/LogIn.wav");
set_sound(user_log_out, PACKAGE_DATADIR "/sounds/ContactLogsOut.wav");
set_sound(self_log_out, PACKAGE_DATADIR "/sounds/LogOut.wav");
set_sound(call_incoming, PACKAGE_DATADIR "/sounds/IncomingCall.wav");
set_sound(call_outgoing, PACKAGE_DATADIR "/sounds/OutgoingCall.wav");
set_sound(generic_message, PACKAGE_DATADIR "/sounds/NewMessage.wav");
set_sound(transfer_pending, PACKAGE_DATADIR "/sounds/TransferPending.wav");
set_sound(transfer_completed, PACKAGE_DATADIR "/sounds/TransferComplete.wav");
2014-07-21 01:12:13 +02:00
}
#endif
config_destroy(cfg);
2014-04-07 10:42:10 +02:00
return 0;
}