summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBjörn Stenberg <bjorn@haxx.se>2003-03-10 16:31:02 +0000
committerBjörn Stenberg <bjorn@haxx.se>2003-03-10 16:31:02 +0000
commitc5aaab4a36e8010e628cf3846d0fcf3039cb27be (patch)
tree78e3d224ca4175ee40007c7ee4788f214336e504
parent5a208d5ae500439f2764a85ad56a613900b68aac (diff)
downloadrockbox-c5aaab4a36e8010e628cf3846d0fcf3039cb27be.zip
rockbox-c5aaab4a36e8010e628cf3846d0fcf3039cb27be.tar.gz
rockbox-c5aaab4a36e8010e628cf3846d0fcf3039cb27be.tar.bz2
rockbox-c5aaab4a36e8010e628cf3846d0fcf3039cb27be.tar.xz
Added .cfg file writing. Patch by Christian Determann.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@3415 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--apps/lang/deutsch.lang15
-rw-r--r--apps/lang/english.lang15
-rw-r--r--apps/settings.c377
-rw-r--r--apps/settings.h1
-rw-r--r--apps/settings_menu.c5
5 files changed, 411 insertions, 2 deletions
diff --git a/apps/lang/deutsch.lang b/apps/lang/deutsch.lang
index f8608a6..75bff3c 100644
--- a/apps/lang/deutsch.lang
+++ b/apps/lang/deutsch.lang
@@ -1526,3 +1526,18 @@ id: LANG_SOKOBAN_ON
desc: how to undo move
eng: "[ON] To Undo"
new: "[ON] = Rückgängig"
+
+id: LANG_SAVE_SETTINGS
+desc: in system_settings_menu()
+eng: "Einstellungen speichern"
+new:
+
+id: LANG_SETTINGS_SAVED1
+desc: Feedback shown when a .cfg file is saved
+eng: "Settings"
+new: "Einstellungen"
+
+id: LANG_SETTINGS_SAVED2
+desc: Feedback shown when a .cfg file is saved
+eng: "Saved"
+new: "gespeichert"
diff --git a/apps/lang/english.lang b/apps/lang/english.lang
index 8018947..35f71b9 100644
--- a/apps/lang/english.lang
+++ b/apps/lang/english.lang
@@ -1429,3 +1429,18 @@ id: LANG_CHANNEL_KARAOKE
desc: in sound_settings
eng: "Karaoke"
new:
+
+id: LANG_SAVE_SETTINGS
+desc: in system_settings_menu()
+eng: "Write .cfg file"
+new:
+
+id: LANG_SETTINGS_SAVED1
+desc: Feedback shown when a .cfg file is saved
+eng: "Settings"
+new:
+
+id: LANG_SETTINGS_SAVED2
+desc: Feedback shown when a .cfg file is saved
+eng: "Saved"
+new:
diff --git a/apps/settings.c b/apps/settings.c
index 39ec408..a2ef3f8 100644
--- a/apps/settings.c
+++ b/apps/settings.c
@@ -54,6 +54,7 @@
#include "wps-display.h"
#include "powermgmt.h"
#include "sprintf.h"
+#include "keyboard.h"
struct user_settings global_settings;
char rockboxdir[] = ROCKBOX_DIR; /* config/font/data file directory */
@@ -1052,6 +1053,382 @@ bool settings_load_config(char* file)
return true;
}
+
+bool settings_save_config(void)
+{
+ bool done = false;
+ int fd, i, value;
+ char buf[MAX_PATH + 32];
+ char filename[MAX_PATH];
+
+ /* find unused filename */
+ for (i=0; ; i++) {
+ snprintf(filename, sizeof filename, "/.rockbox/config%02d.cfg", i);
+ fd = open(filename, O_RDONLY);
+ if (fd < 0)
+ break;
+ close(fd);
+ }
+
+ /* allow user to modify filename */
+ while (!done) {
+ if (!kbd_input(filename, sizeof filename)) {
+ fd = creat(filename,0);
+ if (fd < 0) {
+ lcd_clear_display();
+ lcd_puts(0,0,str(LANG_FAILED));
+ lcd_update();
+ sleep(HZ);
+ }
+ else
+ done = true;
+ }
+ else
+ break;
+ }
+
+ /* abort if file couldn't be created */
+ if (!done) {
+ lcd_clear_display();
+ lcd_puts(0,0,str(LANG_RESET_DONE_CANCEL));
+ lcd_update();
+ sleep(HZ);
+ return false;
+ }
+
+ strncpy(buf, "# >>> .cfg file created by rockbox <<<\r\n", sizeof(buf));
+ write(fd, buf, strlen(buf));
+
+ strncpy(buf, "# >>> http://rockbox.haxx.se <<<\r\n\r\n", sizeof(buf));
+ write(fd, buf, strlen(buf));
+
+ snprintf(buf, sizeof(buf), "#\r\n# wps / language / font \r\n#\r\n");
+ write(fd, buf, strlen(buf));
+
+ if (global_settings.wps_file[0] != 0) {
+ snprintf(buf, sizeof(buf),
+ "wps: /.rockbox/%s.wps\r\n", global_settings.wps_file);
+ write(fd, buf, strlen(buf));
+ }
+
+ if (global_settings.lang_file[0] != 0) {
+ snprintf(buf, sizeof(buf), "lang: /.rockbox/%s.lng\r\n",
+ global_settings.lang_file);
+ write(fd, buf, strlen(buf));
+ }
+
+#ifdef HAVE_LCD_BITMAP
+ if (global_settings.font_file[0] != 0) {
+ snprintf(buf, sizeof(buf), "font: /.rockbox/%s.fnt\r\n",
+ global_settings.font_file);
+ write(fd, buf, strlen(buf));
+ }
+#endif
+
+ snprintf(buf, sizeof(buf), "#\r\n# Sound settings\r\n#\r\n");
+ write(fd, buf, strlen(buf));
+
+ value = mpeg_val2phys(SOUND_VOLUME, global_settings.volume);
+ snprintf(buf, sizeof(buf), "volume: %d\r\n", value);
+ write(fd, buf, strlen(buf));
+
+ value = mpeg_val2phys(SOUND_BASS, global_settings.bass);
+ snprintf(buf, sizeof(buf), "bass: %d\r\n", value);
+ write(fd, buf, strlen(buf));
+
+ value = mpeg_val2phys(SOUND_TREBLE, global_settings.treble);
+ snprintf(buf, sizeof(buf), "treble: %d\r\n", value);
+ write(fd, buf, strlen(buf));
+
+ value = mpeg_val2phys(SOUND_BALANCE, global_settings.balance);
+ snprintf(buf, sizeof(buf), "balance: %d\r\n", value);
+ write(fd, buf, strlen(buf));
+
+ {
+ static char* options[] =
+ {"stereo","stereo narrow","mono","mono left",
+ "mono right","karaoke","stereo wide"};
+ snprintf(buf, sizeof(buf), "channels: %s\r\n",
+ options[global_settings.channel_config]);
+ write(fd, buf, strlen(buf));
+ }
+
+#ifdef HAVE_MAS3587F
+ value = mpeg_val2phys(SOUND_LOUDNESS, global_settings.loudness);
+ snprintf(buf, sizeof(buf), "loudness: %d\r\n", value);
+ write(fd, buf, strlen(buf));
+
+ value = mpeg_val2phys(SOUND_SUPERBASS, global_settings.bass_boost);
+ snprintf(buf, sizeof(buf), "bass boost: %d\r\n", value);
+ write(fd, buf, strlen(buf));
+
+ snprintf(buf, sizeof(buf), "auto volume: %d\r\n", global_settings.avc);
+ write(fd, buf, strlen(buf));
+#endif
+
+ snprintf(buf, sizeof(buf), "#\r\n# Playback\r\n#\r\n");
+ write(fd, buf, strlen(buf));
+
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf), "shuffle: %s\r\n",
+ options[global_settings.playlist_shuffle]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"off", "all", "one"};
+ snprintf(buf, sizeof(buf), "repeat: %s\r\n",
+ options[global_settings.repeat_mode]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf), "play selected: %s\r\n",
+ options[global_settings.play_selected]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"off", "ask", "ask once", "on"};
+ snprintf(buf, sizeof(buf), "resume: %s\r\n",
+ options[global_settings.resume]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] =
+ {"1","2","3","4","5","6","8","10",
+ "15","20","25","30","45","60"};
+ snprintf(buf, sizeof(buf), "scan min step: %s\r\n",
+ options[global_settings.ff_rewind_min_step]);
+ write(fd, buf, strlen(buf));
+ }
+
+ snprintf(buf, sizeof(buf), "scan accel: %d\r\nantiskip: %d\r\n",
+ global_settings.ff_rewind_accel,
+ global_settings.buffer_margin);
+ write(fd, buf, strlen(buf));
+
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf), "volume fade: %s\r\n",
+ options[global_settings.fade_on_stop]);
+ write(fd, buf, strlen(buf));
+ }
+
+ snprintf(buf, sizeof(buf), "#\r\n# File View\r\n#\r\n");
+ write(fd, buf, strlen(buf));
+
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf), "sort case: %s\r\n",
+ options[global_settings.sort_case]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] =
+ {"all", "supported","music", "playlists"};
+ snprintf(buf, sizeof(buf), "show files: %s\r\n",
+ options[global_settings.dirfilter]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf), "follow playlist: %s\r\n",
+ options[global_settings.browse_current]);
+ write(fd, buf, strlen(buf));
+ }
+
+ snprintf(buf, sizeof(buf), "#\r\n# Display\r\n#\r\n");
+ write(fd, buf, strlen(buf));
+
+#ifdef HAVE_LCD_BITMAP
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf), "statusbar: %s\r\nscrollbar: %s\r\n",
+ options[global_settings.statusbar],
+ options[global_settings.scrollbar]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"graphic", "numeric"};
+ snprintf(buf, sizeof(buf),
+ "volume display: %s\r\nbattery display: %s\r\n",
+ options[global_settings.volume_type],
+ options[global_settings.battery_type]);
+ write(fd, buf, strlen(buf));
+ }
+#endif
+
+ snprintf(buf, sizeof(buf), "scroll speed: %d\r\nscroll delay: %d\r\n",
+ global_settings.scroll_speed,
+ global_settings.scroll_delay);
+ write(fd, buf, strlen(buf));
+
+#ifdef HAVE_LCD_BITMAP
+ snprintf(buf, sizeof(buf), "scroll step: %d\r\n",
+ global_settings.scroll_step);
+ write(fd, buf, strlen(buf));
+#endif
+
+ snprintf(buf, sizeof(buf), "bidir limit: %d\r\n",
+ global_settings.bidir_limit);
+ write(fd, buf, strlen(buf));
+
+ {
+ static char* options[] =
+ {"off","on","1","2","3","4","5","6","7","8","9",
+ "10","15","20","25","30","45","60","90"};
+ snprintf(buf, sizeof(buf), "backlight timeout: %s\r\n",
+ options[global_settings.backlight_timeout]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf), "backlight when plugged: %s\r\n",
+ options[global_settings.backlight_on_when_charging]);
+ write(fd, buf, strlen(buf));
+ }
+
+ snprintf(buf, sizeof(buf), "contrast: %d\r\n", global_settings.contrast);
+ write(fd, buf, strlen(buf));
+
+#ifdef HAVE_LCD_BITMAP
+ snprintf(buf, sizeof(buf), "peak meter release: %d\r\n",
+ global_settings.peak_meter_release);
+ write(fd, buf, strlen(buf));
+
+ {
+ static char* options[] =
+ {"off","200ms","300ms","500ms","1","2","3","4","5",
+ "6","7","8","9","10","15","20","30","1min"};
+ snprintf(buf, sizeof(buf), "peak meter hold: %s\r\n",
+ options[global_settings.peak_meter_hold]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] =
+ {"on","1","2","3","4","5","6","7","8","9","10","15","20","25","30",
+ "45","60","90","2min","3min","5min","10min","20min","45min","90min"};
+ snprintf(buf, sizeof(buf), "peak meter clip hold: %s\r\n",
+ options[global_settings.peak_meter_clip_hold]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf),
+ "peak meter busy: %s\r\npeak meter dbfs: %s\r\n",
+ options[global_settings.peak_meter_performance],
+ options[global_settings.peak_meter_dbfs]);
+ write(fd, buf, strlen(buf));
+ }
+
+ snprintf(buf, sizeof(buf), "peak meter min: %d\r\npeak meter max: %d\r\n",
+ global_settings.peak_meter_min,
+ global_settings.peak_meter_max);
+ write(fd, buf, strlen(buf));
+#endif
+
+ snprintf(buf, sizeof(buf), "#\r\n# System\r\n#\r\ndisk spindown: %d\r\n",
+ global_settings.disk_spindown);
+ write(fd, buf, strlen(buf));
+
+#ifdef HAVE_ATA_POWER_OFF
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf), "disk poweroff: %s\r\n",
+ options[global_settings.disk_poweroff]);
+ write(fd, buf, strlen(buf));
+ }
+#endif
+
+ snprintf(buf, sizeof(buf), "battery capacity: %d\r\n",
+ global_settings.battery_capacity);
+ write(fd, buf, strlen(buf));
+
+#ifdef HAVE_CHARGE_CTRL
+ {
+ static char* options[] = {"off","on"};
+ snprintf(buf, sizeof(buf),
+ "deep discharge: %s\r\ntrickle charge: %s\r\n",
+ options[global_settings.discharge],
+ options[global_settings.trickle_charge]);
+ write(fd, buf, strlen(buf));
+ }
+#endif
+
+#ifdef HAVE_LCD_BITMAP
+ {
+ static char* options[] = {"24hour", "12hour"};
+ snprintf(buf, sizeof(buf), "time format: %s\r\n",
+ options[global_settings.timeformat]);
+ write(fd, buf, strlen(buf));
+ }
+#endif
+
+ {
+ static char* options[] =
+ {"off","1","2","3","4","5","6","7","8",
+ "9","10","15","30","45","60"};
+ snprintf(buf, sizeof(buf), "idle poweroff: %s\r\n",
+ options[global_settings.poweroff]);
+ write(fd, buf, strlen(buf));
+ }
+
+#ifdef HAVE_MAS3587F
+ snprintf(buf, sizeof(buf), "#\r\n# Recording\r\n#\r\n");
+ write(fd, buf, strlen(buf));
+
+ snprintf(buf, sizeof(buf), "rec quality: %d\r\n",
+ global_settings.rec_quality);
+ write(fd, buf, strlen(buf));
+
+ {
+ static char* options[] = {"44", "48", "32", "22", "24", "16"};
+ snprintf(buf, sizeof(buf), "rec frequency: %s\r\n",
+ options[global_settings.rec_frequency]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"mic", "line", "spdif"};
+ snprintf(buf, sizeof(buf), "rec source: %s\r\n",
+ options[global_settings.rec_source]);
+ write(fd, buf, strlen(buf));
+ }
+
+ {
+ static char* options[] = {"stereo", "mono"};
+ snprintf(buf, sizeof(buf), "rec channels: %s\r\n",
+ options[global_settings.rec_channels]);
+ write(fd, buf, strlen(buf));
+ }
+
+ snprintf(buf, sizeof(buf),
+ "rec mic gain: %d\r\nrec left gain: %d\r\nrec right gain: %d\r\n",
+ global_settings.rec_mic_gain,
+ global_settings.rec_left_gain,
+ global_settings.rec_right_gain);
+ write(fd, buf, strlen(buf));
+#endif
+ close(fd);
+
+ lcd_clear_display();
+ lcd_puts(0,0,str(LANG_SETTINGS_SAVED1));
+ lcd_puts(0,1,str(LANG_SETTINGS_SAVED2));
+ lcd_update();
+ sleep(HZ);
+ return true;
+}
+
/*
* reset all settings to their default value
*/
diff --git a/apps/settings.h b/apps/settings.h
index 6c383f9..afc4794 100644
--- a/apps/settings.h
+++ b/apps/settings.h
@@ -163,6 +163,7 @@ void settings_apply_pm_range(void);
void settings_display(void);
bool settings_load_config(char* file);
+bool settings_save_config(void);
bool set_bool_options(char* string, bool* variable,
char* yes_str, char* no_str );
diff --git a/apps/settings_menu.c b/apps/settings_menu.c
index f210d79..a8487c5 100644
--- a/apps/settings_menu.c
+++ b/apps/settings_menu.c
@@ -767,8 +767,8 @@ static bool system_settings_menu(void)
{ str(LANG_TIME), timedate_set },
{ str(LANG_TIMEFORMAT), timeformat_set },
#endif
- { str(LANG_POWEROFF_IDLE), poweroff_idle_timer },
- { str(LANG_RESET), reset_settings },
+ { str(LANG_POWEROFF_IDLE), poweroff_idle_timer },
+ { str(LANG_RESET), reset_settings },
};
m=menu_init( items, sizeof items / sizeof(struct menu_items) );
@@ -787,6 +787,7 @@ bool settings_menu(void)
{ str(LANG_FILE), fileview_settings_menu },
{ str(LANG_DISPLAY), display_settings_menu },
{ str(LANG_SYSTEM), system_settings_menu },
+ { str(LANG_SAVE_SETTINGS), settings_save_config },
};
m = menu_init( items, sizeof items / sizeof(struct menu_items) );