Mercurial > audlegacy-plugins
diff src/Input/adplug/core/a2m.h @ 0:13389e613d67 trunk
[svn] - initial import of audacious-plugins tree (lots to do)
| author | nenolod |
|---|---|
| date | Mon, 18 Sep 2006 01:11:49 -0700 |
| parents | |
| children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/Input/adplug/core/a2m.h Mon Sep 18 01:11:49 2006 -0700 @@ -0,0 +1,80 @@ +/* + * Adplug - Replayer for many OPL2/OPL3 audio file formats. + * Copyright (C) 1999 - 2002 Simon Peter, <dn.tlp@gmx.net>, et al. + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * + * a2m.h - A2M Loader by Simon Peter <dn.tlp@gmx.net> + */ + +#include "protrack.h" + +class Ca2mLoader: public CmodPlayer +{ +public: + static CPlayer *factory(Copl *newopl); + + Ca2mLoader(Copl *newopl) + : CmodPlayer(newopl) + { }; + + bool load(const std::string &filename, const CFileProvider &fp); + float getrefresh(); + + std::string gettype() + { return std::string("AdLib Tracker 2"); }; + std::string gettitle() + { if(*songname) return std::string(songname,1,*songname); else return std::string(); }; + std::string getauthor() + { if(*author) return std::string(author,1,*author); else return std::string(); }; + unsigned int getinstruments() + { return 250; }; + std::string getinstrument(unsigned int n) + { return std::string(instname[n],1,*instname[n]); }; + +private: + +#define ADPLUG_A2M_COPYRANGES 6 +#define ADPLUG_A2M_FIRSTCODE 257 +#define ADPLUG_A2M_MINCOPY 3 +#define ADPLUG_A2M_MAXCOPY 255 +#define ADPLUG_A2M_CODESPERRANGE (ADPLUG_A2M_MAXCOPY - ADPLUG_A2M_MINCOPY + 1) +#define ADPLUG_A2M_MAXCHAR (ADPLUG_A2M_FIRSTCODE + \ + ADPLUG_A2M_COPYRANGES * ADPLUG_A2M_CODESPERRANGE - 1) +#define ADPLUG_A2M_TWICEMAX (2 * ADPLUG_A2M_MAXCHAR + 1) + + static const unsigned int MAXFREQ, MINCOPY, MAXCOPY, COPYRANGES, + CODESPERRANGE, TERMINATE, FIRSTCODE, MAXCHAR, SUCCMAX, TWICEMAX, ROOT, + MAXBUF, MAXDISTANCE, MAXSIZE; + + static const unsigned short bitvalue[14]; + static const signed short copybits[ADPLUG_A2M_COPYRANGES], + copymin[ADPLUG_A2M_COPYRANGES]; + + void inittree(); + void updatefreq(unsigned short a,unsigned short b); + void updatemodel(unsigned short code); + unsigned short inputcode(unsigned short bits); + unsigned short uncompress(); + void decode(); + unsigned short sixdepak(unsigned short *source,unsigned char *dest,unsigned short size); + + char songname[43], author[43], instname[250][33]; + + unsigned short ibitcount, ibitbuffer, ibufcount, obufcount, input_size, + output_size, leftc[ADPLUG_A2M_MAXCHAR+1], rghtc[ADPLUG_A2M_MAXCHAR+1], + dad[ADPLUG_A2M_TWICEMAX+1], freq[ADPLUG_A2M_TWICEMAX+1], *wdbuf; + unsigned char *obuf, *buf; +};
