annotate music2/koedec.cc @ 47:5f548e5957a8

* get rid of the "deprecated conversion from string constant to ‘char*’" warnings
author thib
date Wed, 15 Apr 2009 20:26:32 +0000
parents 53a311ea8289
children 35ce1a30f3f9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
223b71206888 Initial import
thib
parents:
diff changeset
1 /*
223b71206888 Initial import
thib
parents:
diff changeset
2 * Copyright (c) 2004-2006 Kazunori "jagarl" Ueno
223b71206888 Initial import
thib
parents:
diff changeset
3 * All rights reserved.
223b71206888 Initial import
thib
parents:
diff changeset
4 *
223b71206888 Initial import
thib
parents:
diff changeset
5 * Redistribution and use in source and binary forms, with or without
223b71206888 Initial import
thib
parents:
diff changeset
6 * modification, are permitted provided that the following conditions
223b71206888 Initial import
thib
parents:
diff changeset
7 * are met:
223b71206888 Initial import
thib
parents:
diff changeset
8 * 1. Redistributions of source code must retain the above copyright
223b71206888 Initial import
thib
parents:
diff changeset
9 * notice, this list of conditions and the following disclaimer.
223b71206888 Initial import
thib
parents:
diff changeset
10 * 2. Redistributions in binary form must reproduce the above copyright
223b71206888 Initial import
thib
parents:
diff changeset
11 * notice, this list of conditions and the following disclaimer in the
223b71206888 Initial import
thib
parents:
diff changeset
12 * documentation and/or other materials provided with the distribution.
223b71206888 Initial import
thib
parents:
diff changeset
13 * 3. The name of the author may not be used to endorse or promote products
223b71206888 Initial import
thib
parents:
diff changeset
14 * derived from this software without specific prior written permission.
223b71206888 Initial import
thib
parents:
diff changeset
15 *
223b71206888 Initial import
thib
parents:
diff changeset
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
223b71206888 Initial import
thib
parents:
diff changeset
17 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
223b71206888 Initial import
thib
parents:
diff changeset
18 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
223b71206888 Initial import
thib
parents:
diff changeset
19 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
223b71206888 Initial import
thib
parents:
diff changeset
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
223b71206888 Initial import
thib
parents:
diff changeset
21 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
223b71206888 Initial import
thib
parents:
diff changeset
22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
223b71206888 Initial import
thib
parents:
diff changeset
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
223b71206888 Initial import
thib
parents:
diff changeset
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
223b71206888 Initial import
thib
parents:
diff changeset
25 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
223b71206888 Initial import
thib
parents:
diff changeset
26 */
223b71206888 Initial import
thib
parents:
diff changeset
27
223b71206888 Initial import
thib
parents:
diff changeset
28 #include<stdio.h>
223b71206888 Initial import
thib
parents:
diff changeset
29 #include<stdlib.h>
223b71206888 Initial import
thib
parents:
diff changeset
30 #include<string.h>
223b71206888 Initial import
thib
parents:
diff changeset
31 #include <vector>
223b71206888 Initial import
thib
parents:
diff changeset
32 #include <list>
223b71206888 Initial import
thib
parents:
diff changeset
33 #include <algorithm>
223b71206888 Initial import
thib
parents:
diff changeset
34 #include"music.h"
223b71206888 Initial import
thib
parents:
diff changeset
35 #include"system/file.h"
2
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
36 #include"system/file_impl.h"
0
223b71206888 Initial import
thib
parents:
diff changeset
37
223b71206888 Initial import
thib
parents:
diff changeset
38 using namespace std;
223b71206888 Initial import
thib
parents:
diff changeset
39
223b71206888 Initial import
thib
parents:
diff changeset
40 /*********************************************
223b71206888 Initial import
thib
parents:
diff changeset
41 **
223b71206888 Initial import
thib
parents:
diff changeset
42 ** FindKoe -- RealLive¤Î²»À¼¥¢¡¼¥«¥¤¥Ö½èÍý
223b71206888 Initial import
thib
parents:
diff changeset
43 **
223b71206888 Initial import
thib
parents:
diff changeset
44 */
223b71206888 Initial import
thib
parents:
diff changeset
45
223b71206888 Initial import
thib
parents:
diff changeset
46 /* À¼¥Õ¥¡¥¤¥ë¤Î¥¢¡¼¥«¥¤¥ÖÍѤΥ­¥ã¥Ã¥·¥å */
223b71206888 Initial import
thib
parents:
diff changeset
47 #define koe_cache_size 7
223b71206888 Initial import
thib
parents:
diff changeset
48 struct AvgKoeTable {
223b71206888 Initial import
thib
parents:
diff changeset
49 int koe_num;
223b71206888 Initial import
thib
parents:
diff changeset
50 int length;
223b71206888 Initial import
thib
parents:
diff changeset
51 int offset;
223b71206888 Initial import
thib
parents:
diff changeset
52 AvgKoeTable(int _num, int _len, int _off) :
223b71206888 Initial import
thib
parents:
diff changeset
53 koe_num(_num), length(_len), offset(_off) {}
223b71206888 Initial import
thib
parents:
diff changeset
54 bool operator <(int number) const {
223b71206888 Initial import
thib
parents:
diff changeset
55 return koe_num < number;
223b71206888 Initial import
thib
parents:
diff changeset
56 }
223b71206888 Initial import
thib
parents:
diff changeset
57 bool operator <(const AvgKoeTable& to) const {
223b71206888 Initial import
thib
parents:
diff changeset
58 return koe_num < to.koe_num;
223b71206888 Initial import
thib
parents:
diff changeset
59 }
223b71206888 Initial import
thib
parents:
diff changeset
60 bool operator ==(const AvgKoeTable& to) const {
223b71206888 Initial import
thib
parents:
diff changeset
61 return koe_num == to.koe_num;
223b71206888 Initial import
thib
parents:
diff changeset
62 }
223b71206888 Initial import
thib
parents:
diff changeset
63 bool operator ==(const int to) const {
223b71206888 Initial import
thib
parents:
diff changeset
64 return koe_num == to;
223b71206888 Initial import
thib
parents:
diff changeset
65 }
223b71206888 Initial import
thib
parents:
diff changeset
66 };
223b71206888 Initial import
thib
parents:
diff changeset
67 struct AvgKoeHead {
223b71206888 Initial import
thib
parents:
diff changeset
68 FILE* stream;
223b71206888 Initial import
thib
parents:
diff changeset
69 int file_number;
223b71206888 Initial import
thib
parents:
diff changeset
70 int rate;
223b71206888 Initial import
thib
parents:
diff changeset
71 KoeType type;
223b71206888 Initial import
thib
parents:
diff changeset
72 vector<AvgKoeTable> table;
223b71206888 Initial import
thib
parents:
diff changeset
73 AvgKoeHead(FILE* stream, int file_number, KoeType type);
223b71206888 Initial import
thib
parents:
diff changeset
74 AvgKoeHead(const AvgKoeHead& from);
223b71206888 Initial import
thib
parents:
diff changeset
75 ~AvgKoeHead();
223b71206888 Initial import
thib
parents:
diff changeset
76 AvgKoeTable* Find(int koe_num);
223b71206888 Initial import
thib
parents:
diff changeset
77 bool operator !=(int num) const { return file_number != num; }
223b71206888 Initial import
thib
parents:
diff changeset
78 bool operator ==(int num) const { return file_number == num; }
223b71206888 Initial import
thib
parents:
diff changeset
79 };
223b71206888 Initial import
thib
parents:
diff changeset
80 struct AvgKoeCache {
223b71206888 Initial import
thib
parents:
diff changeset
81 list<AvgKoeHead> cache;
223b71206888 Initial import
thib
parents:
diff changeset
82 AvgKoeInfo Find(int file_number, int index);
223b71206888 Initial import
thib
parents:
diff changeset
83 };
223b71206888 Initial import
thib
parents:
diff changeset
84 static AvgKoeCache koe_cache;
223b71206888 Initial import
thib
parents:
diff changeset
85
223b71206888 Initial import
thib
parents:
diff changeset
86 AvgKoeInfo FindKoe(int file_number, int index) {
223b71206888 Initial import
thib
parents:
diff changeset
87 return koe_cache.Find(file_number, index);
223b71206888 Initial import
thib
parents:
diff changeset
88 };
45
53a311ea8289 Patched an old patch of mine (OGG koe files handling)... It's a bit less ugly, and it works with tremor!
thib
parents: 43
diff changeset
89
0
223b71206888 Initial import
thib
parents:
diff changeset
90 AvgKoeInfo AvgKoeCache::Find(int file_number, int index) {
223b71206888 Initial import
thib
parents:
diff changeset
91 AvgKoeInfo info;
223b71206888 Initial import
thib
parents:
diff changeset
92 info.stream = 0; info.length = 0; info.offset = 0;
223b71206888 Initial import
thib
parents:
diff changeset
93
223b71206888 Initial import
thib
parents:
diff changeset
94 list<AvgKoeHead>::iterator it;
223b71206888 Initial import
thib
parents:
diff changeset
95 it = find(cache.begin(), cache.end(), file_number);
223b71206888 Initial import
thib
parents:
diff changeset
96 if (it == cache.end()) {
223b71206888 Initial import
thib
parents:
diff changeset
97 /* ¿·¤¿¤Ë head ¤òºî¤ë */
223b71206888 Initial import
thib
parents:
diff changeset
98 char fname[100];
223b71206888 Initial import
thib
parents:
diff changeset
99 KoeType type = koe_unknown;
223b71206888 Initial import
thib
parents:
diff changeset
100 sprintf(fname, "z%03d.koe", file_number);
223b71206888 Initial import
thib
parents:
diff changeset
101 ARCINFO* arcinfo = file_searcher.Find(FILESEARCH::KOE,fname,".koe");
223b71206888 Initial import
thib
parents:
diff changeset
102 if (arcinfo == 0) {
223b71206888 Initial import
thib
parents:
diff changeset
103 type = koe_nwk;
223b71206888 Initial import
thib
parents:
diff changeset
104 sprintf(fname, "z%04d.nwk", file_number);
223b71206888 Initial import
thib
parents:
diff changeset
105 arcinfo = file_searcher.Find(FILESEARCH::KOE,fname,".nwk");
223b71206888 Initial import
thib
parents:
diff changeset
106 }
223b71206888 Initial import
thib
parents:
diff changeset
107 if (arcinfo == 0) {
223b71206888 Initial import
thib
parents:
diff changeset
108 type = koe_ovk;
223b71206888 Initial import
thib
parents:
diff changeset
109 sprintf(fname, "z%04d.ovk", file_number);
223b71206888 Initial import
thib
parents:
diff changeset
110 arcinfo = file_searcher.Find(FILESEARCH::KOE,fname,".ovk");
223b71206888 Initial import
thib
parents:
diff changeset
111 }
24
c9e218c2c3f1 Makes xclannad buildable without libvorbis
thib
parents: 2
diff changeset
112 #if HAVE_LIBVORBISFILE || HAVE_LIBVORBISIDEC
2
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
113 if (arcinfo == 0) {
45
53a311ea8289 Patched an old patch of mine (OGG koe files handling)... It's a bit less ugly, and it works with tremor!
thib
parents: 43
diff changeset
114 //FIXME: OMG that's ugly, improve it as soon as you can!
2
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
115 DIRFILE* koedir = (DIRFILE*) file_searcher.MakeARCFILE((FILESEARCH::ARCTYPE)0, "koe");
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
116 sprintf(fname, "%04d", file_number);
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
117 koedir = new DIRFILE(koedir->SearchFile(fname));
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
118 sprintf(fname, "z%04d%05d.ogg", file_number, index);
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
119 arcinfo = koedir->Find(fname, ".ogg");
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
120 delete koedir;
45
53a311ea8289 Patched an old patch of mine (OGG koe files handling)... It's a bit less ugly, and it works with tremor!
thib
parents: 43
diff changeset
121
2
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
122 if (arcinfo == 0) return info;
45
53a311ea8289 Patched an old patch of mine (OGG koe files handling)... It's a bit less ugly, and it works with tremor!
thib
parents: 43
diff changeset
123 FILE* stream = arcinfo->OpenFile(&info.length);
2
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
124 info.type = koe_ogg;
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
125 info.stream = stream;
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
126 return info;
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
127 }
24
c9e218c2c3f1 Makes xclannad buildable without libvorbis
thib
parents: 2
diff changeset
128 #endif
0
223b71206888 Initial import
thib
parents:
diff changeset
129 if (arcinfo == 0) return info;
223b71206888 Initial import
thib
parents:
diff changeset
130 FILE* stream = arcinfo->OpenFile();
223b71206888 Initial import
thib
parents:
diff changeset
131 delete arcinfo;
223b71206888 Initial import
thib
parents:
diff changeset
132 if (stream == 0) return info;
223b71206888 Initial import
thib
parents:
diff changeset
133 cache.push_front(AvgKoeHead(stream, file_number, type));
223b71206888 Initial import
thib
parents:
diff changeset
134 if (cache.size() >= koe_cache_size) cache.pop_back();
223b71206888 Initial import
thib
parents:
diff changeset
135 it = cache.begin();
223b71206888 Initial import
thib
parents:
diff changeset
136 }
223b71206888 Initial import
thib
parents:
diff changeset
137 if (it->file_number != file_number) return info; // Èֹ椬¤ª¤«¤·¤¤
223b71206888 Initial import
thib
parents:
diff changeset
138 AvgKoeTable* table = it->Find(index);
223b71206888 Initial import
thib
parents:
diff changeset
139 if (table == 0) return info; // index ¤¬¸«ÉÕ¤«¤é¤Ê¤¤
223b71206888 Initial import
thib
parents:
diff changeset
140 // info ¤òºîÀ®¤¹¤ë
223b71206888 Initial import
thib
parents:
diff changeset
141 info.length = table->length;
223b71206888 Initial import
thib
parents:
diff changeset
142 info.offset = table->offset;
223b71206888 Initial import
thib
parents:
diff changeset
143 info.rate = it->rate;
223b71206888 Initial import
thib
parents:
diff changeset
144 info.type = it->type;
223b71206888 Initial import
thib
parents:
diff changeset
145 int new_fd = dup(fileno(it->stream));
223b71206888 Initial import
thib
parents:
diff changeset
146 if (new_fd == -1) info.stream = 0;
223b71206888 Initial import
thib
parents:
diff changeset
147 else info.stream = fdopen(new_fd, "rb");
223b71206888 Initial import
thib
parents:
diff changeset
148 return info;
223b71206888 Initial import
thib
parents:
diff changeset
149 }
223b71206888 Initial import
thib
parents:
diff changeset
150
223b71206888 Initial import
thib
parents:
diff changeset
151 AvgKoeHead::AvgKoeHead(const AvgKoeHead& from) {
223b71206888 Initial import
thib
parents:
diff changeset
152 if (from.stream) {
223b71206888 Initial import
thib
parents:
diff changeset
153 int new_fd = dup(fileno(from.stream));
223b71206888 Initial import
thib
parents:
diff changeset
154 if (new_fd == -1) stream = 0;
223b71206888 Initial import
thib
parents:
diff changeset
155 else stream = fdopen(new_fd, "rb");
223b71206888 Initial import
thib
parents:
diff changeset
156 }
223b71206888 Initial import
thib
parents:
diff changeset
157 file_number = from.file_number;
223b71206888 Initial import
thib
parents:
diff changeset
158 rate = from.rate;
223b71206888 Initial import
thib
parents:
diff changeset
159 table = from.table;
223b71206888 Initial import
thib
parents:
diff changeset
160 type = from.type;
223b71206888 Initial import
thib
parents:
diff changeset
161 }
2
422f3cb3614b Enabled voice playing with "%04d/%04d%05d.ogg" format. Don't use a cache for this
thib
parents: 0
diff changeset
162
0
223b71206888 Initial import
thib
parents:
diff changeset
163 AvgKoeHead::AvgKoeHead(FILE* _s, int _file_number, KoeType _type) {
223b71206888 Initial import
thib
parents:
diff changeset
164 char head[0x20];
223b71206888 Initial import
thib
parents:
diff changeset
165 stream = _s; file_number = _file_number;
43
01aa5ddf7dc8 A lot of very minor improvements (deleted some unused variables, and other things like that...)
thib
parents: 24
diff changeset
166 //int offset = ftell(stream);
0
223b71206888 Initial import
thib
parents:
diff changeset
167 rate = 22050;
223b71206888 Initial import
thib
parents:
diff changeset
168 type = _type;
223b71206888 Initial import
thib
parents:
diff changeset
169 if (stream == 0) return;
223b71206888 Initial import
thib
parents:
diff changeset
170 /* header Æɤ߹þ¤ß */
223b71206888 Initial import
thib
parents:
diff changeset
171 if (type == koe_nwk) { // ¿·¤·¤¤·Á¼° : .nwk file
223b71206888 Initial import
thib
parents:
diff changeset
172 rate = 44100;
223b71206888 Initial import
thib
parents:
diff changeset
173 fread(head, 4, 1, stream);
223b71206888 Initial import
thib
parents:
diff changeset
174 int table_len = read_little_endian_int(head);
223b71206888 Initial import
thib
parents:
diff changeset
175 table.reserve(table_len);
223b71206888 Initial import
thib
parents:
diff changeset
176 int i;
223b71206888 Initial import
thib
parents:
diff changeset
177 for (i=0; i<table_len; i++) {
223b71206888 Initial import
thib
parents:
diff changeset
178 fread(head, 12, 1, stream);
223b71206888 Initial import
thib
parents:
diff changeset
179 int sz = read_little_endian_int(head);
223b71206888 Initial import
thib
parents:
diff changeset
180 int off = read_little_endian_int(head+4);
223b71206888 Initial import
thib
parents:
diff changeset
181 int cnt = read_little_endian_int(head+8);
223b71206888 Initial import
thib
parents:
diff changeset
182 table.push_back(AvgKoeTable(cnt, sz, off));
223b71206888 Initial import
thib
parents:
diff changeset
183 }
223b71206888 Initial import
thib
parents:
diff changeset
184 } else if (type == koe_ovk) { // Little Busters! : .ovk file
223b71206888 Initial import
thib
parents:
diff changeset
185 rate = 44100;
223b71206888 Initial import
thib
parents:
diff changeset
186 fread(head, 4, 1, stream);
223b71206888 Initial import
thib
parents:
diff changeset
187 int table_len = read_little_endian_int(head);
223b71206888 Initial import
thib
parents:
diff changeset
188 table.reserve(table_len);
223b71206888 Initial import
thib
parents:
diff changeset
189 int i;
223b71206888 Initial import
thib
parents:
diff changeset
190 for (i=0; i<table_len; i++) {
223b71206888 Initial import
thib
parents:
diff changeset
191 fread(head, 16, 1, stream);
223b71206888 Initial import
thib
parents:
diff changeset
192 int sz = read_little_endian_int(head);
223b71206888 Initial import
thib
parents:
diff changeset
193 int off = read_little_endian_int(head+4);
223b71206888 Initial import
thib
parents:
diff changeset
194 int cnt = read_little_endian_int(head+8);
223b71206888 Initial import
thib
parents:
diff changeset
195 table.push_back(AvgKoeTable(cnt, sz, off));
223b71206888 Initial import
thib
parents:
diff changeset
196 }
223b71206888 Initial import
thib
parents:
diff changeset
197 } else { // .koe file
223b71206888 Initial import
thib
parents:
diff changeset
198 fread(head, 0x20, 1, stream);
223b71206888 Initial import
thib
parents:
diff changeset
199 if (strncmp(head, "KOEPAC", 7) != 0) { // invalid header
223b71206888 Initial import
thib
parents:
diff changeset
200 stream = 0;
223b71206888 Initial import
thib
parents:
diff changeset
201 return;
223b71206888 Initial import
thib
parents:
diff changeset
202 }
223b71206888 Initial import
thib
parents:
diff changeset
203 int table_len = read_little_endian_int(head+0x10);
223b71206888 Initial import
thib
parents:
diff changeset
204 rate = read_little_endian_int(head+0x18);
223b71206888 Initial import
thib
parents:
diff changeset
205 if (rate == 0) rate = 22050;
223b71206888 Initial import
thib
parents:
diff changeset
206 /* table Æɤ߹þ¤ß */
223b71206888 Initial import
thib
parents:
diff changeset
207 table.reserve(table_len);
223b71206888 Initial import
thib
parents:
diff changeset
208 char* buf = new char[table_len*8];
223b71206888 Initial import
thib
parents:
diff changeset
209 fread(buf, table_len, 8, stream);
223b71206888 Initial import
thib
parents:
diff changeset
210 int i; for (i=0; i<table_len; i++) {
223b71206888 Initial import
thib
parents:
diff changeset
211 int cnt = read_little_endian_short(buf+i*8);
223b71206888 Initial import
thib
parents:
diff changeset
212 int sz = read_little_endian_short(buf+i*8+2);
223b71206888 Initial import
thib
parents:
diff changeset
213 int off = read_little_endian_int(buf+i*8+4);
223b71206888 Initial import
thib
parents:
diff changeset
214 table.push_back(AvgKoeTable(cnt, sz, off));
223b71206888 Initial import
thib
parents:
diff changeset
215 }
223b71206888 Initial import
thib
parents:
diff changeset
216 }
223b71206888 Initial import
thib
parents:
diff changeset
217 sort(table.begin(), table.end());
223b71206888 Initial import
thib
parents:
diff changeset
218 }
223b71206888 Initial import
thib
parents:
diff changeset
219
223b71206888 Initial import
thib
parents:
diff changeset
220 AvgKoeHead::~AvgKoeHead(void) {
223b71206888 Initial import
thib
parents:
diff changeset
221 if (stream) fclose(stream);
223b71206888 Initial import
thib
parents:
diff changeset
222 stream = 0;
223b71206888 Initial import
thib
parents:
diff changeset
223 }
223b71206888 Initial import
thib
parents:
diff changeset
224 AvgKoeTable* AvgKoeHead::Find(int koe_num) {
223b71206888 Initial import
thib
parents:
diff changeset
225 if (table.empty()) return 0;
223b71206888 Initial import
thib
parents:
diff changeset
226 vector<AvgKoeTable>::iterator it;
223b71206888 Initial import
thib
parents:
diff changeset
227 it = lower_bound(table.begin(), table.end(), koe_num);
223b71206888 Initial import
thib
parents:
diff changeset
228 if (it == table.end() || it->koe_num != koe_num) return 0;
223b71206888 Initial import
thib
parents:
diff changeset
229 return &table[it-table.begin()];
223b71206888 Initial import
thib
parents:
diff changeset
230 }
223b71206888 Initial import
thib
parents:
diff changeset
231
223b71206888 Initial import
thib
parents:
diff changeset
232 /*********************************************
223b71206888 Initial import
thib
parents:
diff changeset
233 **
223b71206888 Initial import
thib
parents:
diff changeset
234 ** MakeWavHeader : koe ¥Õ¥¡¥¤¥ë¤Ë wave header ¤òÉÕ¤±¤ë
223b71206888 Initial import
thib
parents:
diff changeset
235 **
223b71206888 Initial import
thib
parents:
diff changeset
236 */
223b71206888 Initial import
thib
parents:
diff changeset
237
223b71206888 Initial import
thib
parents:
diff changeset
238 static unsigned char orig_header[0x2c] = {
223b71206888 Initial import
thib
parents:
diff changeset
239 0x52, 0x49, 0x46, 0x46, /* +00 "RIFF" */
223b71206888 Initial import
thib
parents:
diff changeset
240 0x00, 0x00, 0x00, 0x00, /* +04 file size - 8 */
223b71206888 Initial import
thib
parents:
diff changeset
241 0x57, 0x41, 0x56, 0x45, 0x66, 0x6d, 0x74, 0x20, /* +08 "WAVEfmt " */
223b71206888 Initial import
thib
parents:
diff changeset
242 0x10, 0x00, 0x00, 0x00, /* +10 fmt size */
223b71206888 Initial import
thib
parents:
diff changeset
243 0x01, 0x00, /* +14 wFormatTag */
223b71206888 Initial import
thib
parents:
diff changeset
244 0x02, 0x00, /* +16 Channels */
223b71206888 Initial import
thib
parents:
diff changeset
245 0x44, 0xac, 0x00, 0x00, /* +18 rate */
223b71206888 Initial import
thib
parents:
diff changeset
246 0x10, 0xb1, 0x02, 0x00, /* +1c BytesPerSec = rate * BlockAlign */
223b71206888 Initial import
thib
parents:
diff changeset
247 0x04, 0x00, /* +20 BlockAlign = channels*BytesPerSample */
223b71206888 Initial import
thib
parents:
diff changeset
248 0x10, 0x00, /* +22 BitsPerSample */
223b71206888 Initial import
thib
parents:
diff changeset
249 0x64, 0x61, 0x74, 0x61, /* +24 "data" */
223b71206888 Initial import
thib
parents:
diff changeset
250 0x00, 0x00, 0x00, 0x00 /* +28 filesize - 0x2c */
223b71206888 Initial import
thib
parents:
diff changeset
251 };
223b71206888 Initial import
thib
parents:
diff changeset
252
223b71206888 Initial import
thib
parents:
diff changeset
253 const char* MakeWavHeader(int rate, int ch, int bps, int size) {
223b71206888 Initial import
thib
parents:
diff changeset
254 static char header[0x2c];
223b71206888 Initial import
thib
parents:
diff changeset
255 memcpy(header, (const char*)orig_header, 0x2c);
223b71206888 Initial import
thib
parents:
diff changeset
256 write_little_endian_int(header+0x04, size-8);
223b71206888 Initial import
thib
parents:
diff changeset
257 write_little_endian_int(header+0x28, size-0x2c);
223b71206888 Initial import
thib
parents:
diff changeset
258 write_little_endian_int(header+0x18, rate);
223b71206888 Initial import
thib
parents:
diff changeset
259 write_little_endian_int(header+0x1c, rate*ch*bps);
223b71206888 Initial import
thib
parents:
diff changeset
260 header[0x16] = ch;
223b71206888 Initial import
thib
parents:
diff changeset
261 header[0x20] = ch*bps;
223b71206888 Initial import
thib
parents:
diff changeset
262 header[0x22] = bps*8;
223b71206888 Initial import
thib
parents:
diff changeset
263 return header;
223b71206888 Initial import
thib
parents:
diff changeset
264 }
223b71206888 Initial import
thib
parents:
diff changeset
265
223b71206888 Initial import
thib
parents:
diff changeset
266 /*********************************************
223b71206888 Initial import
thib
parents:
diff changeset
267 **
223b71206888 Initial import
thib
parents:
diff changeset
268 ** decode_koe -- ²»À¼¥Ç¡¼¥¿Å¸³«
223b71206888 Initial import
thib
parents:
diff changeset
269 **
223b71206888 Initial import
thib
parents:
diff changeset
270 */
223b71206888 Initial import
thib
parents:
diff changeset
271
223b71206888 Initial import
thib
parents:
diff changeset
272 extern char* decode_koe(AvgKoeInfo info, int* len);
223b71206888 Initial import
thib
parents:
diff changeset
273
223b71206888 Initial import
thib
parents:
diff changeset
274 /* 8bit -> 16bit ¤Ø¤ÎÊÑ´¹¥Æ¡¼¥Ö¥ë¡£ËÜÍè¤Ï signed short ¤À¤¬
223b71206888 Initial import
thib
parents:
diff changeset
275 ** ¤È¤ê¤¢¤¨¤º unsigned ¤Ç°·¤Ã¤Æ¤¤¤ë
223b71206888 Initial import
thib
parents:
diff changeset
276 */
223b71206888 Initial import
thib
parents:
diff changeset
277
223b71206888 Initial import
thib
parents:
diff changeset
278 unsigned short koe_8bit_trans_tbl[256] = {
223b71206888 Initial import
thib
parents:
diff changeset
279 0x8000,0x81ff,0x83f9,0x85ef,0x87e1,0x89cf,0x8bb9,0x8d9f,
223b71206888 Initial import
thib
parents:
diff changeset
280 0x8f81,0x915f,0x9339,0x950f,0x96e1,0x98af,0x9a79,0x9c3f,
223b71206888 Initial import
thib
parents:
diff changeset
281 0x9e01,0x9fbf,0xa179,0xa32f,0xa4e1,0xa68f,0xa839,0xa9df,
223b71206888 Initial import
thib
parents:
diff changeset
282 0xab81,0xad1f,0xaeb9,0xb04f,0xb1e1,0xb36f,0xb4f9,0xb67f,
223b71206888 Initial import
thib
parents:
diff changeset
283 0xb801,0xb97f,0xbaf9,0xbc6f,0xbde1,0xbf4f,0xc0b9,0xc21f,
223b71206888 Initial import
thib
parents:
diff changeset
284 0xc381,0xc4df,0xc639,0xc78f,0xc8e1,0xca2f,0xcb79,0xccbf,
223b71206888 Initial import
thib
parents:
diff changeset
285 0xce01,0xcf3f,0xd079,0xd1af,0xd2e1,0xd40f,0xd539,0xd65f,
223b71206888 Initial import
thib
parents:
diff changeset
286 0xd781,0xd89f,0xd9b9,0xdacf,0xdbe1,0xdcef,0xddf9,0xdeff,
223b71206888 Initial import
thib
parents:
diff changeset
287 0xe001,0xe0ff,0xe1f9,0xe2ef,0xe3e1,0xe4cf,0xe5b9,0xe69f,
223b71206888 Initial import
thib
parents:
diff changeset
288 0xe781,0xe85f,0xe939,0xea0f,0xeae1,0xebaf,0xec79,0xed3f,
223b71206888 Initial import
thib
parents:
diff changeset
289 0xee01,0xeebf,0xef79,0xf02f,0xf0e1,0xf18f,0xf239,0xf2df,
223b71206888 Initial import
thib
parents:
diff changeset
290 0xf381,0xf41f,0xf4b9,0xf54f,0xf5e1,0xf66f,0xf6f9,0xf77f,
223b71206888 Initial import
thib
parents:
diff changeset
291 0xf801,0xf87f,0xf8f9,0xf96f,0xf9e1,0xfa4f,0xfab9,0xfb1f,
223b71206888 Initial import
thib
parents:
diff changeset
292 0xfb81,0xfbdf,0xfc39,0xfc8f,0xfce1,0xfd2f,0xfd79,0xfdbf,
223b71206888 Initial import
thib
parents:
diff changeset
293 0xfe01,0xfe3f,0xfe79,0xfeaf,0xfee1,0xff0f,0xff39,0xff5f,
223b71206888 Initial import
thib
parents:
diff changeset
294 0xff81,0xff9f,0xffb9,0xffcf,0xffe1,0xffef,0xfff9,0xffff,
223b71206888 Initial import
thib
parents:
diff changeset
295 0x0000,0x0001,0x0007,0x0011,0x001f,0x0031,0x0047,0x0061,
223b71206888 Initial import
thib
parents:
diff changeset
296 0x007f,0x00a1,0x00c7,0x00f1,0x011f,0x0151,0x0187,0x01c1,
223b71206888 Initial import
thib
parents:
diff changeset
297 0x01ff,0x0241,0x0287,0x02d1,0x031f,0x0371,0x03c7,0x0421,
223b71206888 Initial import
thib
parents:
diff changeset
298 0x047f,0x04e1,0x0547,0x05b1,0x061f,0x0691,0x0707,0x0781,
223b71206888 Initial import
thib
parents:
diff changeset
299 0x07ff,0x0881,0x0907,0x0991,0x0a1f,0x0ab1,0x0b47,0x0be1,
223b71206888 Initial import
thib
parents:
diff changeset
300 0x0c7f,0x0d21,0x0dc7,0x0e71,0x0f1f,0x0fd1,0x1087,0x1141,
223b71206888 Initial import
thib
parents:
diff changeset
301 0x11ff,0x12c1,0x1387,0x1451,0x151f,0x15f1,0x16c7,0x17a1,
223b71206888 Initial import
thib
parents:
diff changeset
302 0x187f,0x1961,0x1a47,0x1b31,0x1c1f,0x1d11,0x1e07,0x1f01,
223b71206888 Initial import
thib
parents:
diff changeset
303 0x1fff,0x2101,0x2207,0x2311,0x241f,0x2531,0x2647,0x2761,
223b71206888 Initial import
thib
parents:
diff changeset
304 0x287f,0x29a1,0x2ac7,0x2bf1,0x2d1f,0x2e51,0x2f87,0x30c1,
223b71206888 Initial import
thib
parents:
diff changeset
305 0x31ff,0x3341,0x3487,0x35d1,0x371f,0x3871,0x39c7,0x3b21,
223b71206888 Initial import
thib
parents:
diff changeset
306 0x3c7f,0x3de1,0x3f47,0x40b1,0x421f,0x4391,0x4507,0x4681,
223b71206888 Initial import
thib
parents:
diff changeset
307 0x47ff,0x4981,0x4b07,0x4c91,0x4e1f,0x4fb1,0x5147,0x52e1,
223b71206888 Initial import
thib
parents:
diff changeset
308 0x547f,0x5621,0x57c7,0x5971,0x5b1f,0x5cd1,0x5e87,0x6041,
223b71206888 Initial import
thib
parents:
diff changeset
309 0x61ff,0x63c1,0x6587,0x6751,0x691f,0x6af1,0x6cc7,0x6ea1,
223b71206888 Initial import
thib
parents:
diff changeset
310 0x707f,0x7261,0x7447,0x7631,0x781f,0x7a11,0x7c07,0x7fff
223b71206888 Initial import
thib
parents:
diff changeset
311 };
223b71206888 Initial import
thib
parents:
diff changeset
312
223b71206888 Initial import
thib
parents:
diff changeset
313 /* ADPCM¡¦¡¦¡¦¤¸¤ã¤Ê¤¤¤é¤·¤¤¡£¤¿¤À¤ÎDPCM¤Î¥Ê¤á¤¿¥Æ¡¼¥Ö¥ë¡£
223b71206888 Initial import
thib
parents:
diff changeset
314 ** ¼«Æ°À¸À®¤¹¤ê¤ã¤¤¤¤¤ó¤À¤±¤É256byte¤À¤Ã¤¿¤é
223b71206888 Initial import
thib
parents:
diff changeset
315 ** ¥Æ¡¼¥Ö¥ë¤Ç¤âÌäÂê¤Ê¤¤¤Ç¤·¤ç
223b71206888 Initial import
thib
parents:
diff changeset
316 */
223b71206888 Initial import
thib
parents:
diff changeset
317
223b71206888 Initial import
thib
parents:
diff changeset
318 char koe_ad_trans_tbl[256] = {
223b71206888 Initial import
thib
parents:
diff changeset
319 0x00,0xff,0x01,0xfe,0x02,0xfd,0x03,0xfc,0x04,0xfb,0x05,0xfa,0x06,0xf9,0x07,0xf8,
223b71206888 Initial import
thib
parents:
diff changeset
320 0x08,0xf7,0x09,0xf6,0x0a,0xf5,0x0b,0xf4,0x0c,0xf3,0x0d,0xf2,0x0e,0xf1,0x0f,0xf0,
223b71206888 Initial import
thib
parents:
diff changeset
321 0x10,0xef,0x11,0xee,0x12,0xed,0x13,0xec,0x14,0xeb,0x15,0xea,0x16,0xe9,0x17,0xe8,
223b71206888 Initial import
thib
parents:
diff changeset
322 0x18,0xe7,0x19,0xe6,0x1a,0xe5,0x1b,0xe4,0x1c,0xe3,0x1d,0xe2,0x1e,0xe1,0x1f,0xe0,
223b71206888 Initial import
thib
parents:
diff changeset
323 0x20,0xdf,0x21,0xde,0x22,0xdd,0x23,0xdc,0x24,0xdb,0x25,0xda,0x26,0xd9,0x27,0xd8,
223b71206888 Initial import
thib
parents:
diff changeset
324 0x28,0xd7,0x29,0xd6,0x2a,0xd5,0x2b,0xd4,0x2c,0xd3,0x2d,0xd2,0x2e,0xd1,0x2f,0xd0,
223b71206888 Initial import
thib
parents:
diff changeset
325 0x30,0xcf,0x31,0xce,0x32,0xcd,0x33,0xcc,0x34,0xcb,0x35,0xca,0x36,0xc9,0x37,0xc8,
223b71206888 Initial import
thib
parents:
diff changeset
326 0x38,0xc7,0x39,0xc6,0x3a,0xc5,0x3b,0xc4,0x3c,0xc3,0x3d,0xc2,0x3e,0xc1,0x3f,0xc0,
223b71206888 Initial import
thib
parents:
diff changeset
327 0x40,0xbf,0x41,0xbe,0x42,0xbd,0x43,0xbc,0x44,0xbb,0x45,0xba,0x46,0xb9,0x47,0xb8,
223b71206888 Initial import
thib
parents:
diff changeset
328 0x48,0xb7,0x49,0xb6,0x4a,0xb5,0x4b,0xb4,0x4c,0xb3,0x4d,0xb2,0x4e,0xb1,0x4f,0xb0,
223b71206888 Initial import
thib
parents:
diff changeset
329 0x50,0xaf,0x51,0xae,0x52,0xad,0x53,0xac,0x54,0xab,0x55,0xaa,0x56,0xa9,0x57,0xa8,
223b71206888 Initial import
thib
parents:
diff changeset
330 0x58,0xa7,0x59,0xa6,0x5a,0xa5,0x5b,0xa4,0x5c,0xa3,0x5d,0xa2,0x5e,0xa1,0x5f,0xa0,
223b71206888 Initial import
thib
parents:
diff changeset
331 0x60,0x9f,0x61,0x9e,0x62,0x9d,0x63,0x9c,0x64,0x9b,0x65,0x9a,0x66,0x99,0x67,0x98,
223b71206888 Initial import
thib
parents:
diff changeset
332 0x68,0x97,0x69,0x96,0x6a,0x95,0x6b,0x94,0x6c,0x93,0x6d,0x92,0x6e,0x91,0x6f,0x90,
223b71206888 Initial import
thib
parents:
diff changeset
333 0x70,0x8f,0x71,0x8e,0x72,0x8d,0x73,0x8c,0x74,0x8b,0x75,0x8a,0x76,0x89,0x77,0x88,
223b71206888 Initial import
thib
parents:
diff changeset
334 0x78,0x87,0x79,0x86,0x7a,0x85,0x7b,0x84,0x7c,0x83,0x7d,0x82,0x7e,0x81,0x7f,0x80
223b71206888 Initial import
thib
parents:
diff changeset
335 };
223b71206888 Initial import
thib
parents:
diff changeset
336
223b71206888 Initial import
thib
parents:
diff changeset
337 extern int is_koe_ogg(char* head);
223b71206888 Initial import
thib
parents:
diff changeset
338 extern char* decode_koe_ogg(AvgKoeInfo info, int* dest_len);
223b71206888 Initial import
thib
parents:
diff changeset
339
223b71206888 Initial import
thib
parents:
diff changeset
340 char* decode_koe(AvgKoeInfo info, int* dest_len) {
223b71206888 Initial import
thib
parents:
diff changeset
341 char buf[1024]; char* table;
223b71206888 Initial import
thib
parents:
diff changeset
342 unsigned char* src_orig, *src;
223b71206888 Initial import
thib
parents:
diff changeset
343 unsigned short* dest_orig, *dest;
223b71206888 Initial import
thib
parents:
diff changeset
344 int all_len; int i,j;
223b71206888 Initial import
thib
parents:
diff changeset
345 if (info.stream == NULL) {
223b71206888 Initial import
thib
parents:
diff changeset
346 return NULL;
223b71206888 Initial import
thib
parents:
diff changeset
347 }
223b71206888 Initial import
thib
parents:
diff changeset
348 fseek(info.stream, info.offset, 0);
223b71206888 Initial import
thib
parents:
diff changeset
349 if (info.type == koe_nwk) {
223b71206888 Initial import
thib
parents:
diff changeset
350 return decode_koe_nwa(info, dest_len);
223b71206888 Initial import
thib
parents:
diff changeset
351 }
223b71206888 Initial import
thib
parents:
diff changeset
352 fread(buf, 1, 0x20, info.stream);
223b71206888 Initial import
thib
parents:
diff changeset
353 if (is_koe_ogg(buf)) {
223b71206888 Initial import
thib
parents:
diff changeset
354 fseek(info.stream, -20, 1);
223b71206888 Initial import
thib
parents:
diff changeset
355 return decode_koe_ogg(info, dest_len);
223b71206888 Initial import
thib
parents:
diff changeset
356 }
223b71206888 Initial import
thib
parents:
diff changeset
357 /* avg32 ¤ÎÀ¼¥Ç¡¼¥¿Å¸³« */
223b71206888 Initial import
thib
parents:
diff changeset
358 table = (char*)malloc(info.length*2);
223b71206888 Initial import
thib
parents:
diff changeset
359 fseek(info.stream, info.offset, 0);
223b71206888 Initial import
thib
parents:
diff changeset
360 fread(table, 2, info.length, info.stream);
223b71206888 Initial import
thib
parents:
diff changeset
361
223b71206888 Initial import
thib
parents:
diff changeset
362 all_len = 0;
223b71206888 Initial import
thib
parents:
diff changeset
363 for (i=0; i<info.length; i++)
223b71206888 Initial import
thib
parents:
diff changeset
364 all_len += read_little_endian_short(table + i*2);
223b71206888 Initial import
thib
parents:
diff changeset
365 /* ¥Ç¡¼¥¿Æɤ߹þ¤ß */
223b71206888 Initial import
thib
parents:
diff changeset
366 src_orig = (unsigned char*) malloc(all_len);
223b71206888 Initial import
thib
parents:
diff changeset
367 dest_orig = (unsigned short*)malloc(info.length * 0x1000 + 0x2c);
223b71206888 Initial import
thib
parents:
diff changeset
368 if (src_orig == NULL || dest_orig == NULL) return NULL;
223b71206888 Initial import
thib
parents:
diff changeset
369 src = src_orig;
223b71206888 Initial import
thib
parents:
diff changeset
370 fread(src, 1, all_len, info.stream);
223b71206888 Initial import
thib
parents:
diff changeset
371 *dest_len = info.length * 0x400 * 4;
223b71206888 Initial import
thib
parents:
diff changeset
372 const char* header = MakeWavHeader(info.rate, 2, 2, *dest_len);
223b71206888 Initial import
thib
parents:
diff changeset
373 memcpy(dest_orig, header, 0x2c);
223b71206888 Initial import
thib
parents:
diff changeset
374 dest = dest_orig + 0x2c;
223b71206888 Initial import
thib
parents:
diff changeset
375 /* memset(dest_data, 0, table_len * 0x1000); */
223b71206888 Initial import
thib
parents:
diff changeset
376
223b71206888 Initial import
thib
parents:
diff changeset
377 /* Ÿ³« */
223b71206888 Initial import
thib
parents:
diff changeset
378 for (i=0; i<info.length; i++) {
223b71206888 Initial import
thib
parents:
diff changeset
379 int slen = read_little_endian_short(table+i*2);
223b71206888 Initial import
thib
parents:
diff changeset
380 if (slen == 0) { // do nothing
223b71206888 Initial import
thib
parents:
diff changeset
381 memset(dest, 0, 0x1000);
223b71206888 Initial import
thib
parents:
diff changeset
382 dest += 0x800; src += 0;
223b71206888 Initial import
thib
parents:
diff changeset
383 } else if (slen == 0x400) { // table ÊÑ´¹
223b71206888 Initial import
thib
parents:
diff changeset
384 for (j=0; j<0x400; j++) {
223b71206888 Initial import
thib
parents:
diff changeset
385 write_little_endian_short((char*)(dest+0), koe_8bit_trans_tbl[*src]);
223b71206888 Initial import
thib
parents:
diff changeset
386 write_little_endian_short((char*)(dest+1), koe_8bit_trans_tbl[*src]);
223b71206888 Initial import
thib
parents:
diff changeset
387 dest += 2; src++;
223b71206888 Initial import
thib
parents:
diff changeset
388 }
223b71206888 Initial import
thib
parents:
diff changeset
389 } else { // DPCM
223b71206888 Initial import
thib
parents:
diff changeset
390 char d = 0; short o2;
223b71206888 Initial import
thib
parents:
diff changeset
391 int k,j; for (j=0, k=0; j<slen && k < 0x800; j++) {
223b71206888 Initial import
thib
parents:
diff changeset
392 unsigned char s = src[j];
223b71206888 Initial import
thib
parents:
diff changeset
393 if ( (s+1) & 0x0f) {
223b71206888 Initial import
thib
parents:
diff changeset
394 d -= koe_ad_trans_tbl[s & 0x0f];
223b71206888 Initial import
thib
parents:
diff changeset
395 } else {
223b71206888 Initial import
thib
parents:
diff changeset
396 unsigned char s2;
223b71206888 Initial import
thib
parents:
diff changeset
397 s >>= 4; s &= 0x0f; s2 = s;
223b71206888 Initial import
thib
parents:
diff changeset
398 s = src[++j]; s2 |= (s<<4) & 0xf0;
223b71206888 Initial import
thib
parents:
diff changeset
399 d -= koe_ad_trans_tbl[s2];
223b71206888 Initial import
thib
parents:
diff changeset
400 }
223b71206888 Initial import
thib
parents:
diff changeset
401 o2 = koe_8bit_trans_tbl[ (unsigned char)d];
223b71206888 Initial import
thib
parents:
diff changeset
402 write_little_endian_short((char*)(dest+k), o2);
223b71206888 Initial import
thib
parents:
diff changeset
403 write_little_endian_short((char*)(dest+k+1), o2);
223b71206888 Initial import
thib
parents:
diff changeset
404 k+=2;
223b71206888 Initial import
thib
parents:
diff changeset
405 s >>= 4;
223b71206888 Initial import
thib
parents:
diff changeset
406 if ((s+1) & 0x0f) {
223b71206888 Initial import
thib
parents:
diff changeset
407 d -= koe_ad_trans_tbl[s & 0x0f];
223b71206888 Initial import
thib
parents:
diff changeset
408 } else {
223b71206888 Initial import
thib
parents:
diff changeset
409 d -= koe_ad_trans_tbl[ src[++j] ];
223b71206888 Initial import
thib
parents:
diff changeset
410 }
223b71206888 Initial import
thib
parents:
diff changeset
411 o2 = koe_8bit_trans_tbl[ (unsigned char)d];
223b71206888 Initial import
thib
parents:
diff changeset
412 write_little_endian_short((char*)(dest+k), o2);
223b71206888 Initial import
thib
parents:
diff changeset
413 write_little_endian_short((char*)(dest+k+1), o2);
223b71206888 Initial import
thib
parents:
diff changeset
414 k+=2;
223b71206888 Initial import
thib
parents:
diff changeset
415 }
223b71206888 Initial import
thib
parents:
diff changeset
416 dest += 0x800; src += slen;
223b71206888 Initial import
thib
parents:
diff changeset
417 }
223b71206888 Initial import
thib
parents:
diff changeset
418 }
223b71206888 Initial import
thib
parents:
diff changeset
419 free( (void*) table);
223b71206888 Initial import
thib
parents:
diff changeset
420 free( (void*) src_orig);
223b71206888 Initial import
thib
parents:
diff changeset
421 return (char*)dest_orig;
223b71206888 Initial import
thib
parents:
diff changeset
422 }
223b71206888 Initial import
thib
parents:
diff changeset
423
223b71206888 Initial import
thib
parents:
diff changeset
424