Added play_selected option, and moved browse_current

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@2322 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Linus Nielsen Feltzing 2002-09-18 10:12:16 +00:00
parent c3a30409dd
commit 78ea93d869
2 changed files with 18 additions and 5 deletions

View file

@ -69,13 +69,14 @@ offset abs
0x0c 0x20 <poweroff timer byte> 0x0c 0x20 <poweroff timer byte>
0x0d 0x21 <resume settings byte> 0x0d 0x21 <resume settings byte>
0x0e 0x22 <shuffle,mp3filter,sort_case,discharge,statusbar,show_hidden, 0x0e 0x22 <shuffle,mp3filter,sort_case,discharge,statusbar,show_hidden,
browse_current> scroll bar>
0x0f 0x23 <scroll speed> 0x0f 0x23 <scroll speed>
0x10 0x24 <ff/rewind min step, acceleration rate> 0x10 0x24 <ff/rewind min step, acceleration rate>
0x11 0x25 <AVC, channel config> 0x11 0x25 <AVC, channel config>
0x12 0x26 <(int) Resume playlist index, or -1 if no playlist resume> 0x12 0x26 <(int) Resume playlist index, or -1 if no playlist resume>
0x16 0x2a <(int) Byte offset into resume file> 0x16 0x2a <(int) Byte offset into resume file>
0x1a 0x2e <time until disk spindown> 0x1a 0x2e <time until disk spindown>
0x1b 0x2f <browse current, play selected>
<all unused space filled with 0xff> <all unused space filled with 0xff>
@ -268,8 +269,7 @@ int settings_save( void )
((global_settings.discharge & 1) << 3) | ((global_settings.discharge & 1) << 3) |
((global_settings.statusbar & 1) << 4) | ((global_settings.statusbar & 1) << 4) |
((global_settings.show_hidden_files & 1) << 5) | ((global_settings.show_hidden_files & 1) << 5) |
((global_settings.scrollbar & 1) << 6) | ((global_settings.scrollbar & 1) << 6));
((global_settings.browse_current & 1) << 7));
config_block[0xf] = (unsigned char)(global_settings.scroll_speed << 3); config_block[0xf] = (unsigned char)(global_settings.scroll_speed << 3);
@ -278,10 +278,15 @@ int settings_save( void )
(global_settings.ff_rewind_accel & 15)); (global_settings.ff_rewind_accel & 15));
config_block[0x11] = (unsigned char)(global_settings.avc || config_block[0x11] = (unsigned char)(global_settings.avc ||
global_settings.channel_config << 2); global_settings.channel_config << 2);
config_block[0x1a] = (unsigned char)global_settings.disk_spindown;
memcpy(&config_block[0x12], &global_settings.resume_index, 4); memcpy(&config_block[0x12], &global_settings.resume_index, 4);
memcpy(&config_block[0x16], &global_settings.resume_offset, 4); memcpy(&config_block[0x16], &global_settings.resume_offset, 4);
config_block[0x1a] = (unsigned char)global_settings.disk_spindown;
config_block[0x1b] = (unsigned char)
(((global_settings.browse_current & 1)) |
((global_settings.play_selected & 1) << 1));
memcpy(&config_block[0xF8], &global_settings.resume_seed, 4); memcpy(&config_block[0xF8], &global_settings.resume_seed, 4);
memcpy(&config_block[0x24], &global_settings.total_uptime, 4); memcpy(&config_block[0x24], &global_settings.total_uptime, 4);
@ -359,7 +364,8 @@ void settings_load(void)
global_settings.statusbar = (config_block[0xe] >> 4) & 1; global_settings.statusbar = (config_block[0xe] >> 4) & 1;
global_settings.show_hidden_files = (config_block[0xe] >> 5) & 1; global_settings.show_hidden_files = (config_block[0xe] >> 5) & 1;
global_settings.scrollbar = (config_block[0xe] >> 6) & 1; global_settings.scrollbar = (config_block[0xe] >> 6) & 1;
global_settings.browse_current = (config_block[0xe] >> 7) & 1; /* Don't use the last bit, it must be unused to detect
an uninitialized entry */
} }
c = config_block[0xf] >> 3; c = config_block[0xf] >> 3;
@ -386,6 +392,11 @@ void settings_load(void)
if (config_block[0x1a] != 0xFF) if (config_block[0x1a] != 0xFF)
global_settings.disk_spindown = config_block[0x1a]; global_settings.disk_spindown = config_block[0x1a];
if (config_block[0x1b] != 0xFF) {
global_settings.browse_current = (config_block[0x1b]) & 1;
global_settings.play_selected = (config_block[0x1b] >> 1) & 1;
}
memcpy(&global_settings.resume_seed, &config_block[0xF8], 4); memcpy(&global_settings.resume_seed, &config_block[0xF8], 4);
if (config_block[0x24] != 0xFF) if (config_block[0x24] != 0xFF)
@ -595,6 +606,7 @@ void settings_reset(void) {
global_settings.resume_offset = -1; global_settings.resume_offset = -1;
global_settings.disk_spindown = 5; global_settings.disk_spindown = 5;
global_settings.browse_current = false; global_settings.browse_current = false;
global_settings.play_selected = true;
} }

View file

@ -81,6 +81,7 @@ struct user_settings
bool sort_case; /* dir sort order: 0=case insensitive, 1=sensitive */ bool sort_case; /* dir sort order: 0=case insensitive, 1=sensitive */
int scroll_speed; /* long texts scrolling speed: 1-30 */ int scroll_speed; /* long texts scrolling speed: 1-30 */
bool playlist_shuffle; bool playlist_shuffle;
bool play_selected; /* Plays selected file even in shuffle mode */
int ff_rewind_min_step; /* FF/Rewind minimum step size */ int ff_rewind_min_step; /* FF/Rewind minimum step size */
int ff_rewind_accel; /* FF/Rewind acceleration (in seconds per doubling) */ int ff_rewind_accel; /* FF/Rewind acceleration (in seconds per doubling) */
int disk_spindown; /* time until disk spindown, in seconds (0=off) */ int disk_spindown; /* time until disk spindown, in seconds (0=off) */