Mercurial > audlegacy-plugins
view src/adplug/core/adplug.cxx @ 1963:b9b62802b072
Define a preprocessor macro XSDEBUG() for printing debugging messages, if DEBUG is defined.
author | Matti Hamalainen <ccr@tnsp.org> |
---|---|
date | Tue, 02 Oct 2007 19:05:38 +0300 |
parents | 368f8ee0a95f |
children | fa9f85cebade |
line wrap: on
line source
/* * Adplug - Replayer for many OPL2/OPL3 audio file formats. * Copyright (C) 1999 - 2005 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 * * adplug.cpp - CAdPlug utility class, by Simon Peter <dn.tlp@gmx.net> */ #include <string> #include <binfile.h> #include "adplug.h" #include "debug.h" /***** Replayer includes *****/ #include "hsc.h" #include "amd.h" #include "a2m.h" #include "imf.h" #include "sng.h" #include "adtrack.h" #include "bam.h" #include "d00.h" #include "dfm.h" #include "hsp.h" #include "ksm.h" #include "mad.h" #include "mid.h" #include "mkj.h" #include "cff.h" #include "dmo.h" #include "s3m.h" #include "dtm.h" #include "fmc.h" #include "mtk.h" #include "rad.h" #include "raw.h" #include "sa2.h" #include "bmf.h" #include "flash.h" #include "hybrid.h" #include "hyp.h" #include "psi.h" #include "rat.h" #include "lds.h" #include "u6m.h" #include "rol.h" #include "xsm.h" #include "dro.h" #include "msc.h" #include "rix.h" #include "adl.h" #include "jbm.h" /***** Defines *****/ #define VERSION "1.6" // AdPlug library version string /***** CAdPlug *****/ // List of all players that come with the standard AdPlug distribution const CPlayerDesc CAdPlug::allplayers[] = { CPlayerDesc (ChscPlayer::factory, "HSC-Tracker", ".hsc\0"), CPlayerDesc (CsngPlayer::factory, "SNGPlay", ".sng\0"), CPlayerDesc (CimfPlayer::factory, "Apogee IMF", ".imf\0.wlf\0.adlib\0"), CPlayerDesc (Ca2mLoader::factory, "Adlib Tracker 2", ".a2m\0"), CPlayerDesc (CadtrackLoader::factory, "Adlib Tracker", ".sng\0"), CPlayerDesc (CamdLoader::factory, "AMUSIC", ".amd\0"), CPlayerDesc (CbamPlayer::factory, "Bob's Adlib Music", ".bam\0"), CPlayerDesc (Cd00Player::factory, "Packed EdLib", ".d00\0"), CPlayerDesc (CdfmLoader::factory, "Digital-FM", ".dfm\0"), CPlayerDesc (ChspLoader::factory, "HSC Packed", ".hsp\0"), CPlayerDesc (CksmPlayer::factory, "Ken Silverman Music", ".ksm\0"), CPlayerDesc (CmadLoader::factory, "Mlat Adlib Tracker", ".mad\0"), CPlayerDesc (CmidPlayer::factory, "MIDI", ".cmf\0.sci\0.laa\0"), CPlayerDesc (CmkjPlayer::factory, "MKJamz", ".mkj\0"), CPlayerDesc (CcffLoader::factory, "Boomtracker", ".cff\0"), CPlayerDesc (CdmoLoader::factory, "TwinTeam", ".dmo\0"), CPlayerDesc (Cs3mPlayer::factory, "Scream Tracker 3", ".s3m\0"), CPlayerDesc (CdtmLoader::factory, "DeFy Adlib Tracker", ".dtm\0"), CPlayerDesc (CfmcLoader::factory, "Faust Music Creator", ".sng\0"), CPlayerDesc (CmtkLoader::factory, "MPU-401 Trakker", ".mtk\0"), CPlayerDesc (CradLoader::factory, "Reality Adlib Tracker", ".rad\0"), CPlayerDesc (CrawPlayer::factory, "RdosPlay RAW", ".raw\0"), CPlayerDesc (Csa2Loader::factory, "Surprise! Adlib Tracker", ".sat\0.sa2\0"), CPlayerDesc (CxadbmfPlayer::factory, "BMF Adlib Tracker", ".xad\0"), CPlayerDesc (CxadflashPlayer::factory, "Flash", ".xad\0"), CPlayerDesc (CxadhybridPlayer::factory, "Hybrid", ".xad\0"), CPlayerDesc (CxadhypPlayer::factory, "Hypnosis", ".xad\0"), CPlayerDesc (CxadpsiPlayer::factory, "PSI", ".xad\0"), CPlayerDesc (CxadratPlayer::factory, "rat", ".xad\0"), CPlayerDesc (CldsPlayer::factory, "LOUDNESS Sound System", ".lds\0"), CPlayerDesc (Cu6mPlayer::factory, "Ultima 6 Music", ".m\0"), CPlayerDesc (CrolPlayer::factory, "Adlib Visual Composer", ".rol\0"), CPlayerDesc (CxsmPlayer::factory, "eXtra Simple Music", ".xsm\0"), CPlayerDesc (CdroPlayer::factory, "DOSBox Raw OPL", ".dro\0"), CPlayerDesc (CmscPlayer::factory, "Adlib MSC Player", ".msc\0"), CPlayerDesc (CrixPlayer::factory, "Softstar RIX OPL Music", ".rix\0"), CPlayerDesc (CadlPlayer::factory, "Westwood ADL", ".adl\0"), CPlayerDesc (CjbmPlayer::factory, "Johannes Bjerregaard", ".jbm\0"), CPlayerDesc () }; const CPlayers & CAdPlug::init_players (const CPlayerDesc pd[]) { static CPlayers initplayers; unsigned int i; for (i = 0; pd[i].factory; i++) initplayers.push_back (&pd[i]); return initplayers; } const CPlayers CAdPlug::players = CAdPlug::init_players (CAdPlug::allplayers); CAdPlugDatabase * CAdPlug::database = 0; CPlayer * CAdPlug::factory (VFSFile * fd, Copl * opl, const CPlayers & pl, const CFileProvider & fp) { CPlayer *p; CPlayers::const_iterator i; unsigned int j; // Try a direct hit by file extension for (i = pl.begin (); i != pl.end (); i++) for (j = 0; (*i)->get_extension (j); j++) if (fp.extension (fd->uri, (*i)->get_extension (j))) { AdPlug_LogWrite ("Trying direct hit: %s\n", (*i)->filetype.c_str ()); vfs_rewind (fd); if ((p = (*i)->factory (opl))) if (p->load (fd, fp)) { AdPlug_LogWrite ("got it!\n"); AdPlug_LogWrite ("--- CAdPlug::factory ---\n"); return p; } else delete p; } #if 0 // Try all players, one by one for (i = pl.begin (); i != pl.end (); i++) { AdPlug_LogWrite ("Trying: %s\n", (*i)->filetype.c_str ()); if ((p = (*i)->factory (opl))) if (p->load (fd, fp)) { AdPlug_LogWrite ("got it!\n"); AdPlug_LogWrite ("--- CAdPlug::factory ---\n"); return p; } else delete p; } #endif // Unknown file AdPlug_LogWrite ("End of list!\n"); AdPlug_LogWrite ("--- CAdPlug::factory ---\n"); return 0; } void CAdPlug::set_database (CAdPlugDatabase * db) { database = db; } std::string CAdPlug::get_version () { return std::string (VERSION); } void CAdPlug::debug_output (const std::string & filename) { AdPlug_LogFile (filename.c_str ()); AdPlug_LogWrite ("CAdPlug::debug_output(\"%s\"): Redirected.\n", filename.c_str ()); }