X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=src%2Fconf.c;h=9d1f8828d8d28d59dab74bbc71cf8bed4fe54801;hb=549fcb39eb7d3d229550af78b03b53cfcad299b8;hp=b49eeb2440ad4e920660252f7f63ff0d017470c4;hpb=e7981e0e28541e5046c40879a4fdbcc308f143ec;p=ncmpc.git diff --git a/src/conf.c b/src/conf.c index b49eeb2..9d1f882 100644 --- a/src/conf.c +++ b/src/conf.c @@ -1,7 +1,6 @@ -/* - * $Id$ - * - * (c) 2004 by Kalle Wallin +/* ncmpc (Ncurses MPD Client) + * (c) 2004-2010 The Music Player Daemon Project + * Project homepage: http://musicpd.org * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -12,18 +11,19 @@ * 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 this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #include "conf.h" #include "config.h" -#include "ncmpc.h" -#include "support.h" +#include "defaults.h" +#include "i18n.h" #include "command.h" #include "colors.h" +#include "screen_list.h" #include #include @@ -34,137 +34,94 @@ #include #include #include +#include #define MAX_LINE_LENGTH 1024 -#define COMMENT_TOKEN '#' +#define COMMENT_TOKEN '#' /* configuration field names */ -#define CONF_ENABLE_COLORS "enable-colors" -#define CONF_AUTO_CENTER "auto-center" -#define CONF_WIDE_CURSOR "wide-cursor" -#define CONF_ENABLE_BELL "enable-bell" -#define CONF_KEY_DEFINITION "key" -#define CONF_COLOR "color" -#define CONF_COLOR_DEFINITION "colordef" -#define CONF_LIST_FORMAT "list-format" -#define CONF_STATUS_FORMAT "status-format" -#define CONF_XTERM_TITLE_FORMAT "xterm-title-format" -#define CONF_LIST_WRAP "wrap-around" -#define CONF_FIND_WRAP "find-wrap" -#define CONF_FIND_SHOW_LAST "find-show-last" -#define CONF_AUDIBLE_BELL "audible-bell" -#define CONF_VISIBLE_BELL "visible-bell" -#define CONF_XTERM_TITLE "set-xterm-title" -#define CONF_ENABLE_MOUSE "enable-mouse" -#define CONF_CROSSFADE_TIME "crossfade-time" -#define CONF_SEARCH_MODE "search-mode" -#define CONF_HIDE_CURSOR "hide-cursor" -#define CONF_SEEK_TIME "seek-time" -#define CONF_SCREEN_LIST "screen-list" -#define CONF_TIMEDISPLAY_TYPE "timedisplay-type" -#define CONF_HOST "host" -#define CONF_PORT "port" -#define CONF_PASSWORD "password" -#define CONF_LYRICS_TIMEOUT "lyrics-timeout" -#define CONF_SHOW_SPLASH "show-splash" -#define CONF_SCROLL "scroll" -#define CONF_SCROLL_SEP "scroll-sep" - -typedef enum { - KEY_PARSER_UNKNOWN, - KEY_PARSER_CHAR, - KEY_PARSER_DEC, - KEY_PARSER_HEX, - KEY_PARSER_DONE -} key_parser_state_t; - - -extern gint screen_get_id(char *name); - - -static gboolean +#define CONF_ENABLE_COLORS "enable-colors" +#define CONF_SCROLL_OFFSET "scroll-offset" +#define CONF_AUTO_CENTER "auto-center" +#define CONF_WIDE_CURSOR "wide-cursor" +#define CONF_KEY_DEFINITION "key" +#define CONF_COLOR "color" +#define CONF_COLOR_DEFINITION "colordef" +#define CONF_LIST_FORMAT "list-format" +#define CONF_STATUS_FORMAT "status-format" +#define CONF_XTERM_TITLE_FORMAT "xterm-title-format" +#define CONF_LIST_WRAP "wrap-around" +#define CONF_FIND_WRAP "find-wrap" +#define CONF_FIND_SHOW_LAST "find-show-last" +#define CONF_AUDIBLE_BELL "audible-bell" +#define CONF_VISIBLE_BELL "visible-bell" +#define CONF_BELL_ON_WRAP "bell-on-wrap" +#define CONF_STATUS_MESSAGE_TIME "status-message-time" +#define CONF_XTERM_TITLE "set-xterm-title" +#define CONF_ENABLE_MOUSE "enable-mouse" +#define CONF_CROSSFADE_TIME "crossfade-time" +#define CONF_SEARCH_MODE "search-mode" +#define CONF_HIDE_CURSOR "hide-cursor" +#define CONF_SEEK_TIME "seek-time" +#define CONF_SCREEN_LIST "screen-list" +#define CONF_TIMEDISPLAY_TYPE "timedisplay-type" +#define CONF_HOST "host" +#define CONF_PORT "port" +#define CONF_PASSWORD "password" +#define CONF_LYRICS_TIMEOUT "lyrics-timeout" +#define CONF_SCROLL "scroll" +#define CONF_SCROLL_SEP "scroll-sep" +#define CONF_VISIBLE_BITRATE "visible-bitrate" +#define CONF_WELCOME_SCREEN_LIST "welcome-screen-list" +#define CONF_DISPLAY_TIME "display-time" +#define CONF_JUMP_PREFIX_ONLY "jump-prefix-only" +#define CONF_LYRICS_AUTOSAVE "lyrics-autosave" +#define CONF_LYRICS_SHOW_PLUGIN "lyrics-show-plugin" +#define CONF_TEXT_EDITOR "text-editor" +#define CONF_SECOND_COLUMN "second-column" + +static bool str2bool(char *str) { - if (!strcasecmp(str, "yes") || !strcasecmp(str, "true") || - !strcasecmp(str, "on") || !strcasecmp(str, "1")) - return TRUE; - return FALSE; + return strcasecmp(str, "yes") == 0 || strcasecmp(str, "true") == 0 || + strcasecmp(str, "on") == 0 || strcasecmp(str, "1") == 0; } -static int -parse_key_value(char *str, size_t len, char **end) +static void +print_error(const char *msg, const char *input) { - size_t i; - int value; - key_parser_state_t state; + fprintf(stderr, "%s: %s ('%s')\n", + /* To translators: prefix for error messages */ + _("Error"), msg, input); +} - i=0; - value=0; - state=KEY_PARSER_UNKNOWN; - *end = str; - - while (i < len && state != KEY_PARSER_DONE) { - int next = 0; - int c = str[i]; - - if( i+1 str+len ) - *end = str+len; + *end = str + 3; + return str[1]; + } else { + long value = strtol(str, end, 0); + if (*end == str) { + print_error(_("Malformed hotkey definition"), str); + return -1; + } - return value; + return (int)value; + } } static int parse_key_definition(char *str) { char buf[MAX_LINE_LENGTH]; - char *p, *end; + char *p; size_t len = strlen(str), i; int j,key; int keys[MAX_COMMAND_KEYS]; @@ -174,152 +131,170 @@ parse_key_definition(char *str) i=0; j=0; memset(buf, 0, MAX_LINE_LENGTH); - while( i=0 ) { - rgb[i++] = value; - while( p=0 && IS_WHITESPACE(line[i]) ) + char * test; + int mode; + mode= strtol(value, &test, 10); + if (*test == '\0') { - line[i] = '\0'; - i--; - } - len = i+1; - - if( len>0 ) - { - i = 0; - /* skip whitespace */ - while( ienable_colors = str2bool(value); - } - /* auto center */ - else if( !strcasecmp(CONF_AUTO_CENTER, name) ) - { - options->auto_center = str2bool(value); - } - /* color assignment */ - else if( !strcasecmp(CONF_COLOR, name) ) - { - parse_color(value); - } - /* wide cursor */ - else if( !strcasecmp(CONF_WIDE_CURSOR, name) ) - { - options->wide_cursor = str2bool(value); - } - /* timer display type */ - else if( !strcasecmp(CONF_TIMEDISPLAY_TYPE, name) ) - { - g_free(options->timedisplay_type); - options->timedisplay_type=g_strdup(parse_timedisplay_type(value)); - D("deb"); - D(options->timedisplay_type); - } - /* color definition */ - else if( !strcasecmp(CONF_COLOR_DEFINITION, name) ) - { - parse_color_definition(value); - } - /* list format string */ - else if( !strcasecmp(CONF_LIST_FORMAT, name) ) - { - g_free(options->list_format); - options->list_format = get_format(value); - } - /* status format string */ - else if( !strcasecmp(CONF_STATUS_FORMAT, name) ) - { - g_free(options->status_format); - options->status_format = get_format(value); - } - /* xterm title format string */ - else if( !strcasecmp(CONF_XTERM_TITLE_FORMAT, name) ) - { - g_free(options->xterm_title_format); - options->xterm_title_format = get_format(value); - } - else if( !strcasecmp(CONF_LIST_WRAP, name) ) - { - options->list_wrap = str2bool(value); - } - else if( !strcasecmp(CONF_FIND_WRAP, name) ) - { - options->find_wrap = str2bool(value); - } - else if( !strcasecmp(CONF_FIND_SHOW_LAST,name) ) - { - options->find_show_last_pattern = str2bool(value); - } - else if( !strcasecmp(CONF_AUDIBLE_BELL, name) ) - { - options->audible_bell = str2bool(value); - } - else if( !strcasecmp(CONF_VISIBLE_BELL, name) ) - { - options->visible_bell = str2bool(value); - } - else if( !strcasecmp(CONF_XTERM_TITLE, name) ) - { - options->enable_xterm_title = str2bool(value); - } - else if( !strcasecmp(CONF_ENABLE_MOUSE, name) ) - { - options->enable_mouse = str2bool(value); - } - else if( !strcasecmp(CONF_CROSSFADE_TIME, name) ) - { - options->crossfade_time = atoi(value); - } - else if( !strcasecmp(CONF_SEARCH_MODE, name) ) - { - options->search_mode = atoi(value); - } - else if( !strcasecmp(CONF_HIDE_CURSOR, name) ) - { - options->hide_cursor = atoi(value); - } - else if( !strcasecmp(CONF_SEEK_TIME, name) ) - { - options->seek_time = atoi(value); - } - else if( !strcasecmp(CONF_SCREEN_LIST, name) ) - { - g_strfreev(options->screen_list); - options->screen_list = check_screen_list(value); - } - else if( !strcasecmp(CONF_SHOW_SPLASH, name) ) +static bool +parse_line(char *line) +{ + size_t len = strlen(line), i = 0, j = 0; + char name[MAX_LINE_LENGTH]; + char value[MAX_LINE_LENGTH]; + bool match_found; + + /* get the name part */ + while (i < len && line[i] != '=' && !g_ascii_isspace(line[i])) + name[j++] = line[i++]; + + name[j] = '\0'; + + /* skip '=' and whitespace */ + while (i < len && (line[i] == '=' || g_ascii_isspace(line[i]))) + i++; + + /* get the value part */ + j = 0; + while (i < len) + value[j++] = line[i++]; + value[j] = '\0'; + + match_found = true; + + /* key definition */ + if (!strcasecmp(CONF_KEY_DEFINITION, name)) + parse_key_definition(value); + /* enable colors */ + else if(!strcasecmp(CONF_ENABLE_COLORS, name)) +#ifdef ENABLE_COLORS + options.enable_colors = str2bool(value); +#else + {} +#endif + else if (!strcasecmp(CONF_SCROLL_OFFSET, name)) + options.scroll_offset = atoi(value); + /* auto center */ + else if (!strcasecmp(CONF_AUTO_CENTER, name)) + options.auto_center = str2bool(value); + /* color assignment */ + else if (!strcasecmp(CONF_COLOR, name)) +#ifdef ENABLE_COLORS + parse_color(value); +#else + {} +#endif + /* wide cursor */ + else if (!strcasecmp(CONF_WIDE_CURSOR, name)) + options.wide_cursor = str2bool(value); + else if (strcasecmp(name, "hardware-cursor") == 0) + options.hardware_cursor = str2bool(value); + /* welcome screen list */ + else if (!strcasecmp(CONF_WELCOME_SCREEN_LIST, name)) + options.welcome_screen_list = str2bool(value); + /* visible bitrate */ + else if (!strcasecmp(CONF_VISIBLE_BITRATE, name)) + options.visible_bitrate = str2bool(value); + /* timer display type */ + else if (!strcasecmp(CONF_TIMEDISPLAY_TYPE, name)) + options.display_remaining_time = parse_timedisplay_type(value); + /* color definition */ + else if (!strcasecmp(CONF_COLOR_DEFINITION, name)) +#ifdef ENABLE_COLORS + parse_color_definition(value); +#else + {} +#endif + /* list format string */ + else if (!strcasecmp(CONF_LIST_FORMAT, name)) { + g_free(options.list_format); + options.list_format = get_format(value); + /* status format string */ + } else if (!strcasecmp(CONF_STATUS_FORMAT, name)) { + g_free(options.status_format); + options.status_format = get_format(value); + /* xterm title format string */ + } else if (!strcasecmp(CONF_XTERM_TITLE_FORMAT, name)) { + g_free(options.xterm_title_format); + options.xterm_title_format = get_format(value); + } else if (!strcasecmp(CONF_LIST_WRAP, name)) + options.list_wrap = str2bool(value); + else if (!strcasecmp(CONF_FIND_WRAP, name)) + options.find_wrap = str2bool(value); + else if (!strcasecmp(CONF_FIND_SHOW_LAST,name)) + options.find_show_last_pattern = str2bool(value); + else if (!strcasecmp(CONF_AUDIBLE_BELL, name)) + options.audible_bell = str2bool(value); + else if (!strcasecmp(CONF_VISIBLE_BELL, name)) + options.visible_bell = str2bool(value); + else if (!strcasecmp(CONF_BELL_ON_WRAP, name)) + options.bell_on_wrap = str2bool(value); + else if (!strcasecmp(CONF_STATUS_MESSAGE_TIME, name)) + options.status_message_time = atoi(value); + else if (!strcasecmp(CONF_XTERM_TITLE, name)) + options.enable_xterm_title = str2bool(value); + else if (!strcasecmp(CONF_ENABLE_MOUSE, name)) +#ifdef HAVE_GETMOUSE + options.enable_mouse = str2bool(value); +#else + {} +#endif + else if (!strcasecmp(CONF_CROSSFADE_TIME, name)) + options.crossfade_time = atoi(value); + else if (!strcasecmp(CONF_SEARCH_MODE, name)) + options.search_mode = get_search_mode(value); + else if (!strcasecmp(CONF_HIDE_CURSOR, name)) + options.hide_cursor = atoi(value); + else if (!strcasecmp(CONF_SEEK_TIME, name)) + options.seek_time = atoi(value); + else if (!strcasecmp(CONF_SCREEN_LIST, name)) { + g_strfreev(options.screen_list); + options.screen_list = check_screen_list(value); + } else if (!strcasecmp(CONF_HOST, name)) + options.host = get_format(value); + else if (!strcasecmp(CONF_PORT, name)) + options.port = atoi(get_format(value)); + else if (!strcasecmp(CONF_PASSWORD, name)) + options.password = get_format(value); + else if (!strcasecmp(CONF_LYRICS_TIMEOUT, name)) +#ifdef ENABLE_LYRICS_SCREEN + options.lyrics_timeout = atoi(get_format(value)); +#else + {} +#endif + else if (!strcasecmp(CONF_SCROLL, name)) + options.scroll = str2bool(value); + else if (!strcasecmp(CONF_SCROLL_SEP, name)) { + g_free(options.scroll_sep); + options.scroll_sep = get_format(value); + } else if (!strcasecmp(CONF_DISPLAY_TIME, name)) +#ifdef NCMPC_MINI + {} +#else + options.display_time = str2bool(value); +#endif + else if (!strcasecmp(CONF_JUMP_PREFIX_ONLY, name)) +#ifdef NCMPC_MINI + {} +#else + options.jump_prefix_only = str2bool(value); +#endif + else if (!strcasecmp(CONF_LYRICS_AUTOSAVE, name)) +#ifdef ENABLE_LYRICS_SCREEN + options.lyrics_autosave = str2bool(value); +#else + {} +#endif + else if (!strcasecmp(CONF_LYRICS_SHOW_PLUGIN, name)) +#ifdef ENABLE_LYRICS_SCREEN + options.lyrics_show_plugin = str2bool(value); +#else + {} +#endif + else if (!strcasecmp(name, CONF_TEXT_EDITOR)) +#ifdef ENABLE_LYRICS_SCREEN { - /* the splash screen was removed */ + g_free(options.text_editor); + options.text_editor = get_format(value); } - else if( !strcasecmp(CONF_HOST, name)) - { - options->host = get_format(value); - } - else if( !strcasecmp(CONF_PORT, name)) - { - options->port = atoi(get_format(value)); - } - else if( !strcasecmp(CONF_PASSWORD, name)) - { - options->password = get_format(value); - } - else if( !strcasecmp(CONF_LYRICS_TIMEOUT, name)) - { - options->lyrics_timeout = atoi(get_format(value)); - } - else if( !strcasecmp(CONF_SCROLL, name)) - { - options->scroll = str2bool(value); - } - else if( !strcasecmp(CONF_SCROLL_SEP, name)) - { - g_free(options->scroll_sep); - options->scroll_sep = get_format(value); - } - else - { - match_found = 0; +#else + {} +#endif + else if (!strcasecmp(CONF_SECOND_COLUMN, name)) +#ifdef NCMPC_MINI + {} +#else + options.second_column = str2bool(value); +#endif + else + match_found = false; + + if (!match_found) + print_error(_("Unknown configuration parameter"), name); + + return match_found; +} + +static int +read_rc_file(char *filename) +{ + FILE *file; + char line[MAX_LINE_LENGTH]; + + if (filename == NULL) + return -1; + + file = fopen(filename, "r"); + if (file == NULL) { + perror(filename); + return -1; } - if( !match_found ) - fprintf(stderr, - _("Unknown configuration parameter: %s\n"), - name); - D("conf> %s = %s %s\n", name, value, - match_found ? "" : "- UNKNOWN SETTING!" ); - } - } - } - - D("--\n\n"); - - if( free_filename ) - g_free(filename); - - return 0; + while (fgets(line, sizeof(line), file) != NULL) { + char *p = g_strchug(line); + + if (*p != 0 && *p != COMMENT_TOKEN) + parse_line(g_strchomp(p)); + } + + fclose(file); + return 0; } int @@ -604,7 +585,11 @@ check_user_conf_dir(void) return 0; } +#ifndef WIN32 retval = mkdir(directory, 0755); +#else + retval = mkdir(directory); +#endif g_free(directory); return retval; } @@ -615,80 +600,69 @@ get_user_key_binding_filename(void) return g_build_filename(g_get_home_dir(), "." PACKAGE, "keys", NULL); } - int -read_configuration(options_t *options) +read_configuration(void) { - char *filename = NULL; - - /* check for command line configuration file */ - if( options->config_file ) - filename = g_strdup(options->config_file); - - /* check for user configuration ~/.ncmpc/config */ - if( filename == NULL ) - { - filename = g_build_filename(g_get_home_dir(), - "." PACKAGE, "config", NULL); - if( !g_file_test(filename, G_FILE_TEST_IS_REGULAR) ) - { - g_free(filename); - filename = NULL; + char *filename = NULL; + + /* check for command line configuration file */ + if (options.config_file) + filename = g_strdup(options.config_file); + + /* check for user configuration ~/.ncmpc/config */ + if (filename == NULL) { + filename = g_build_filename(g_get_home_dir(), + "." PACKAGE, "config", NULL); + if (!g_file_test(filename, G_FILE_TEST_IS_REGULAR)) { + g_free(filename); + filename = NULL; + } } - } - /* check for global configuration SYSCONFDIR/ncmpc/config */ - if( filename == NULL ) - { - filename = g_build_filename(SYSCONFDIR, PACKAGE, "config", NULL); - if( !g_file_test(filename, G_FILE_TEST_IS_REGULAR) ) - { - g_free(filename); - filename = NULL; + /* check for global configuration SYSCONFDIR/ncmpc/config */ + if (filename == NULL) { + filename = g_build_filename(SYSCONFDIR, PACKAGE, "config", NULL); + if (!g_file_test(filename, G_FILE_TEST_IS_REGULAR)) { + g_free(filename); + filename = NULL; + } } - } - - /* load configuration */ - if( filename ) - { - read_rc_file(filename, options); - g_free(filename); - filename = NULL; - } - - /* check for command line key binding file */ - if( options->key_file ) - filename = g_strdup(options->key_file); - - /* check for user key bindings ~/.ncmpc/keys */ - if( filename == NULL ) - { - filename = get_user_key_binding_filename(); - if( !g_file_test(filename, G_FILE_TEST_IS_REGULAR) ) - { - g_free(filename); - filename = NULL; + + /* load configuration */ + if (filename) { + read_rc_file(filename); + g_free(filename); + filename = NULL; } - } - /* check for global key bindings SYSCONFDIR/ncmpc/keys */ - if( filename == NULL ) - { - filename = g_build_filename(SYSCONFDIR, PACKAGE, "keys", NULL); - if( !g_file_test(filename, G_FILE_TEST_IS_REGULAR) ) - { - g_free(filename); - filename = NULL; + /* check for command line key binding file */ + if (options.key_file) + filename = g_strdup(options.key_file); + + /* check for user key bindings ~/.ncmpc/keys */ + if (filename == NULL) { + filename = get_user_key_binding_filename(); + if (!g_file_test(filename, G_FILE_TEST_IS_REGULAR)) { + g_free(filename); + filename = NULL; + } } - } - /* load key bindings */ - if( filename ) - { - read_rc_file(filename, options); - g_free(filename); - filename = NULL; - } + /* check for global key bindings SYSCONFDIR/ncmpc/keys */ + if (filename == NULL) { + filename = g_build_filename(SYSCONFDIR, PACKAGE, "keys", NULL); + if (!g_file_test(filename, G_FILE_TEST_IS_REGULAR)) { + g_free(filename); + filename = NULL; + } + } + + /* load key bindings */ + if (filename) { + read_rc_file(filename); + g_free(filename); + filename = NULL; + } - return 0; + return 0; }