summaryrefslogtreecommitdiff
path: root/apps/tagtree.c
diff options
context:
space:
mode:
authorSteve Bavin <pondlife@pondlife.me>2007-12-21 13:31:50 +0000
committerSteve Bavin <pondlife@pondlife.me>2007-12-21 13:31:50 +0000
commitde741cd534f74b9f74fa17f7a4c0741eaf5adea9 (patch)
treefba28fbef3d266bda3797a84bd61033b2b9c0fcb /apps/tagtree.c
parent88f79becd2a8c7348b1544ebd5dbf8873112e552 (diff)
downloadrockbox-de741cd534f74b9f74fa17f7a4c0741eaf5adea9.tar.gz
rockbox-de741cd534f74b9f74fa17f7a4c0741eaf5adea9.zip
FS#6960 - Add random selection option to database, by Mark Reiche. This satisfies FS#6915.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@15957 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'apps/tagtree.c')
-rw-r--r--apps/tagtree.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/apps/tagtree.c b/apps/tagtree.c
index 8298fe24ae..d394491960 100644
--- a/apps/tagtree.c
+++ b/apps/tagtree.c
@@ -1136,7 +1136,15 @@ static int retrieve_entries(struct tree_context *c, struct tagcache_search *tcs,
1136 dptr++; 1136 dptr++;
1137 current_entry_count++; 1137 current_entry_count++;
1138 } 1138 }
1139 special_entry_count++; 1139 if (offset <= 1)
1140 {
1141 dptr->newtable = navibrowse;
1142 dptr->name = str(LANG_TAGNAVI_RANDOM);
1143 dptr->extraseek = -1;
1144 dptr++;
1145 current_entry_count++;
1146 }
1147 special_entry_count+=2;
1140 } 1148 }
1141 1149
1142 total_count += special_entry_count; 1150 total_count += special_entry_count;
@@ -1374,8 +1382,14 @@ int tagtree_enter(struct tree_context* c)
1374 dptr = tagtree_get_entry(c, c->selected_item); 1382 dptr = tagtree_get_entry(c, c->selected_item);
1375 1383
1376 c->dirfull = false; 1384 c->dirfull = false;
1385 seek = dptr->extraseek;
1386 if (seek == -1)
1387 {
1388 srand(current_tick);
1389 dptr = (tagtree_get_entry(c, 2+(rand() % (c->filesindir-2))));
1390 seek = dptr->extraseek;
1391 }
1377 newextra = dptr->newtable; 1392 newextra = dptr->newtable;
1378 seek = dptr->extraseek;
1379 1393
1380 if (c->dirlevel >= MAX_DIR_LEVELS) 1394 if (c->dirlevel >= MAX_DIR_LEVELS)
1381 return 0; 1395 return 0;