359
|
1 /*
|
|
2 * Adplug - Replayer for many OPL2/OPL3 audio file formats.
|
|
3 * Copyright (C) 1999 - 2002 Simon Peter, <dn.tlp@gmx.net>, et al.
|
|
4 *
|
|
5 * This library is free software; you can redistribute it and/or
|
|
6 * modify it under the terms of the GNU Lesser General Public
|
|
7 * License as published by the Free Software Foundation; either
|
|
8 * version 2.1 of the License, or (at your option) any later version.
|
|
9 *
|
|
10 * This library is distributed in the hope that it will be useful,
|
|
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
13 * Lesser General Public License for more details.
|
|
14 *
|
|
15 * You should have received a copy of the GNU Lesser General Public
|
|
16 * License along with this library; if not, write to the Free Software
|
1459
|
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
359
|
18 *
|
|
19 * a2m.h - A2M Loader by Simon Peter <dn.tlp@gmx.net>
|
|
20 */
|
|
21
|
|
22 #include "protrack.h"
|
|
23
|
|
24 class Ca2mLoader: public CmodPlayer
|
|
25 {
|
|
26 public:
|
|
27 static CPlayer *factory(Copl *newopl);
|
|
28
|
|
29 Ca2mLoader(Copl *newopl)
|
|
30 : CmodPlayer(newopl)
|
|
31 { };
|
|
32
|
|
33 bool load(const std::string &filename, const CFileProvider &fp);
|
|
34 float getrefresh();
|
|
35
|
|
36 std::string gettype()
|
|
37 { return std::string("AdLib Tracker 2"); };
|
|
38 std::string gettitle()
|
|
39 { if(*songname) return std::string(songname,1,*songname); else return std::string(); };
|
|
40 std::string getauthor()
|
|
41 { if(*author) return std::string(author,1,*author); else return std::string(); };
|
|
42 unsigned int getinstruments()
|
|
43 { return 250; };
|
|
44 std::string getinstrument(unsigned int n)
|
|
45 { return std::string(instname[n],1,*instname[n]); };
|
|
46
|
|
47 private:
|
|
48
|
|
49 #define ADPLUG_A2M_COPYRANGES 6
|
|
50 #define ADPLUG_A2M_FIRSTCODE 257
|
|
51 #define ADPLUG_A2M_MINCOPY 3
|
|
52 #define ADPLUG_A2M_MAXCOPY 255
|
|
53 #define ADPLUG_A2M_CODESPERRANGE (ADPLUG_A2M_MAXCOPY - ADPLUG_A2M_MINCOPY + 1)
|
|
54 #define ADPLUG_A2M_MAXCHAR (ADPLUG_A2M_FIRSTCODE + \
|
|
55 ADPLUG_A2M_COPYRANGES * ADPLUG_A2M_CODESPERRANGE - 1)
|
|
56 #define ADPLUG_A2M_TWICEMAX (2 * ADPLUG_A2M_MAXCHAR + 1)
|
|
57
|
|
58 static const unsigned int MAXFREQ, MINCOPY, MAXCOPY, COPYRANGES,
|
|
59 CODESPERRANGE, TERMINATE, FIRSTCODE, MAXCHAR, SUCCMAX, TWICEMAX, ROOT,
|
|
60 MAXBUF, MAXDISTANCE, MAXSIZE;
|
|
61
|
|
62 static const unsigned short bitvalue[14];
|
|
63 static const signed short copybits[ADPLUG_A2M_COPYRANGES],
|
|
64 copymin[ADPLUG_A2M_COPYRANGES];
|
|
65
|
|
66 void inittree();
|
|
67 void updatefreq(unsigned short a,unsigned short b);
|
|
68 void updatemodel(unsigned short code);
|
|
69 unsigned short inputcode(unsigned short bits);
|
|
70 unsigned short uncompress();
|
|
71 void decode();
|
|
72 unsigned short sixdepak(unsigned short *source,unsigned char *dest,unsigned short size);
|
|
73
|
|
74 char songname[43], author[43], instname[250][33];
|
|
75
|
|
76 unsigned short ibitcount, ibitbuffer, ibufcount, obufcount, input_size,
|
|
77 output_size, leftc[ADPLUG_A2M_MAXCHAR+1], rghtc[ADPLUG_A2M_MAXCHAR+1],
|
|
78 dad[ADPLUG_A2M_TWICEMAX+1], freq[ADPLUG_A2M_TWICEMAX+1], *wdbuf;
|
|
79 unsigned char *obuf, *buf;
|
|
80 };
|