summaryrefslogtreecommitdiff
path: root/apps/talk.c
diff options
context:
space:
mode:
authorJörg Hohensohn <hohensoh@rockbox.org>2004-04-03 20:52:24 +0000
committerJörg Hohensohn <hohensoh@rockbox.org>2004-04-03 20:52:24 +0000
commitf9495cba65c108ac99759cf3a0b978c0a58c9233 (patch)
tree9350c3f0c791772a1f3cd1d2eda61dbda9a2a443 /apps/talk.c
parent5248641b40d1a49545b61b61d269eb40c1ccf0ce (diff)
Changed concept for voice IDs: the voice-only IDs now are in a separate range, don't generate an empty language string. This saves memory, but requires a new voice file format with 2 tables.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@4463 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'apps/talk.c')
-rw-r--r--apps/talk.c30
1 files changed, 22 insertions, 8 deletions
diff --git a/apps/talk.c b/apps/talk.c
index f65b594b92..7ba858b47d 100644
--- a/apps/talk.c
+++ b/apps/talk.c
@@ -51,9 +51,10 @@ struct clip_entry /* one entry of the index table */
struct voicefont /* file format of our "voicefont" */
{
int version; /* version of the voicefont */
- int headersize; /* size of the header, =offset to index */
- int id_max; /* number of clips contained */
- struct clip_entry index[]; /* followed by the index table */
+ int table; /* offset to index table, (=header size) */
+ int id1_max; /* number of "normal" clips contained in above index */
+ int id2_max; /* number of "voice only" clips contained in above index */
+ struct clip_entry index[]; /* followed by the index tables */
/* and finally the bitswapped mp3 clips, not visible here */
};
@@ -104,7 +105,7 @@ static int load_voicefont(void)
size = read(fd, mp3buf, mp3end - mp3buf);
if (size > 1000
- && ((struct voicefont*)mp3buf)->headersize
+ && ((struct voicefont*)mp3buf)->table
== offsetof(struct voicefont, index))
{
p_voicefont = (struct voicefont*)mp3buf;
@@ -294,9 +295,12 @@ int talk_id(int id, bool enqueue)
if (p_voicefont == NULL) /* still no voices? */
return -1;
+ if (id == -1) /* -1 is an indication for silence */
+ return -1;
+
/* check if this is a special ID, with a value */
unit = ((unsigned)id) >> UNIT_SHIFT;
- if (id != -1 && unit)
+ if (unit)
{ /* sign-extend the value */
//splash(200, true,"unit=%d", unit);
id = (unsigned)id << (32-UNIT_SHIFT);
@@ -305,9 +309,19 @@ int talk_id(int id, bool enqueue)
return 0; /* and stop, end of special case */
}
- if (id < 0 || id >= p_voicefont->id_max)
- return -1;
-
+ if (id > VOICEONLY_DELIMITER)
+ { /* voice-only entries use the second part of the table */
+ id -= VOICEONLY_DELIMITER + 1;
+ if (id >= p_voicefont->id2_max)
+ return -1; /* must be newer than we have */
+ id += p_voicefont->id1_max; /* table 2 is behind table 1 */
+ }
+ else
+ { /* normal use of the first table */
+ if (id >= p_voicefont->id1_max)
+ return -1; /* must be newer than we have */
+ }
+
clipsize = p_voicefont->index[id].size;
if (clipsize == 0) /* clip not included in voicefont */
return -1;