mikmod.h.in
上传用户:wstnjxml
上传日期:2014-04-03
资源大小:7248k
文件大小:25k
源码类别:

Windows CE

开发平台:

C/C++

  1. /* MikMod sound library
  2. (c) 1998, 1999, 2000 Miodrag Vallat and others - see file AUTHORS
  3. for complete list.
  4. This library is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU Library General Public License as
  6. published by the Free Software Foundation; either version 2 of
  7. the License, or (at your option) any later version.
  8.  
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12. GNU Library General Public License for more details.
  13.  
  14. You should have received a copy of the GNU Library General Public
  15. License along with this library; if not, write to the Free Software
  16. Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
  17. 02111-1307, USA.
  18. */
  19. /*==============================================================================
  20.   $Id: mikmod.h.in,v 1.11 2004/02/18 14:10:39 raph Exp $
  21.   MikMod sound library include file
  22. ==============================================================================*/
  23. #ifndef _MIKMOD_H_
  24. #define _MIKMOD_H_
  25. #include <stdio.h>
  26. #include <stdlib.h>
  27. #ifdef __cplusplus
  28. extern "C" {
  29. #endif
  30. /*
  31.  * ========== Compiler magic for shared libraries
  32.  */
  33. #if defined WIN32 && defined _DLL
  34. #ifdef DLL_EXPORTS
  35. #define MIKMODAPI __declspec(dllexport)
  36. #else
  37. #define MIKMODAPI __declspec(dllimport)
  38. #endif
  39. #else
  40. #define MIKMODAPI
  41. #endif
  42. /*
  43.  * ========== Library version
  44.  */
  45. #define LIBMIKMOD_VERSION_MAJOR @LIBMIKMOD_MAJOR_VERSION@L
  46. #define LIBMIKMOD_VERSION_MINOR @LIBMIKMOD_MINOR_VERSION@L
  47. #define LIBMIKMOD_REVISION      @LIBMIKMOD_MICRO_VERSION@L
  48. #define LIBMIKMOD_VERSION 
  49. ((LIBMIKMOD_VERSION_MAJOR<<16)| 
  50.  (LIBMIKMOD_VERSION_MINOR<< 8)| 
  51.  (LIBMIKMOD_REVISION))
  52. MIKMODAPI extern long MikMod_GetVersion(void);
  53. /*
  54.  * ========== Platform independent-type definitions
  55.  */
  56. #ifdef WIN32
  57. #define WIN32_LEAN_AND_MEAN
  58. #include <windows.h>
  59. #include <io.h>
  60. #include <mmsystem.h>
  61. #endif
  62. #if defined(__OS2__)||defined(__EMX__)
  63. #define INCL_DOSSEMAPHORES
  64. #include <os2.h>
  65. #else
  66. typedef char CHAR;
  67. #endif
  68. @DOES_NOT_HAVE_SIGNED@
  69. #if defined(__arch64__) || defined(__alpha)
  70. /* 64 bit architectures */
  71. typedef signed char     SBYTE;      /* 1 byte, signed */
  72. typedef unsigned char   UBYTE;      /* 1 byte, unsigned */
  73. typedef signed short    SWORD;      /* 2 bytes, signed */
  74. typedef unsigned short  UWORD;      /* 2 bytes, unsigned */
  75. typedef signed int      SLONG;      /* 4 bytes, signed */
  76. typedef unsigned int    ULONG;      /* 4 bytes, unsigned */
  77. typedef int             BOOL;       /* 0=false, <>0 true */
  78. #else
  79. /* 32 bit architectures */
  80. typedef signed char     SBYTE;      /* 1 byte, signed */
  81. typedef unsigned char   UBYTE;      /* 1 byte, unsigned */
  82. typedef signed short    SWORD;      /* 2 bytes, signed */
  83. typedef unsigned short  UWORD;      /* 2 bytes, unsigned */
  84. typedef signed long     SLONG;      /* 4 bytes, signed */
  85. #if !defined(__OS2__)&&!defined(__EMX__)&&!defined(WIN32)
  86. typedef unsigned long   ULONG;      /* 4 bytes, unsigned */
  87. typedef int             BOOL;       /* 0=false, <>0 true */
  88. #endif
  89. #endif
  90. /*
  91.  * ========== Error codes
  92.  */
  93. enum {
  94. MMERR_OPENING_FILE = 1,
  95. MMERR_OUT_OF_MEMORY,
  96. MMERR_DYNAMIC_LINKING,
  97. MMERR_SAMPLE_TOO_BIG,
  98. MMERR_OUT_OF_HANDLES,
  99. MMERR_UNKNOWN_WAVE_TYPE,
  100. MMERR_LOADING_PATTERN,
  101. MMERR_LOADING_TRACK,
  102. MMERR_LOADING_HEADER,
  103. MMERR_LOADING_SAMPLEINFO,
  104. MMERR_NOT_A_MODULE,
  105. MMERR_NOT_A_STREAM,
  106. MMERR_MED_SYNTHSAMPLES,
  107. MMERR_ITPACK_INVALID_DATA,
  108. MMERR_DETECTING_DEVICE,
  109. MMERR_INVALID_DEVICE,
  110. MMERR_INITIALIZING_MIXER,
  111. MMERR_OPENING_AUDIO,
  112. MMERR_8BIT_ONLY,
  113. MMERR_16BIT_ONLY,
  114. MMERR_STEREO_ONLY,
  115. MMERR_ULAW,
  116. MMERR_NON_BLOCK,
  117. MMERR_AF_AUDIO_PORT,
  118. MMERR_AIX_CONFIG_INIT,
  119. MMERR_AIX_CONFIG_CONTROL,
  120. MMERR_AIX_CONFIG_START,
  121. MMERR_GUS_SETTINGS,
  122. MMERR_GUS_RESET,
  123. MMERR_GUS_TIMER,
  124. MMERR_HP_SETSAMPLESIZE,
  125. MMERR_HP_SETSPEED,
  126. MMERR_HP_CHANNELS,
  127. MMERR_HP_AUDIO_OUTPUT,
  128. MMERR_HP_AUDIO_DESC,
  129. MMERR_HP_BUFFERSIZE,
  130. MMERR_OSS_SETFRAGMENT,
  131. MMERR_OSS_SETSAMPLESIZE,
  132. MMERR_OSS_SETSTEREO,
  133. MMERR_OSS_SETSPEED,
  134. MMERR_SGI_SPEED,
  135. MMERR_SGI_16BIT,
  136. MMERR_SGI_8BIT,
  137. MMERR_SGI_STEREO,
  138. MMERR_SGI_MONO,
  139. MMERR_SUN_INIT,
  140. MMERR_OS2_MIXSETUP,
  141. MMERR_OS2_SEMAPHORE,
  142. MMERR_OS2_TIMER,
  143. MMERR_OS2_THREAD,
  144. MMERR_DS_PRIORITY,
  145. MMERR_DS_BUFFER,
  146. MMERR_DS_FORMAT,
  147. MMERR_DS_NOTIFY,
  148. MMERR_DS_EVENT,
  149. MMERR_DS_THREAD,
  150. MMERR_DS_UPDATE,
  151. MMERR_WINMM_HANDLE,
  152. MMERR_WINMM_ALLOCATED,
  153. MMERR_WINMM_DEVICEID,
  154. MMERR_WINMM_FORMAT,
  155. MMERR_WINMM_UNKNOWN,
  156. MMERR_MAC_SPEED,
  157. MMERR_MAC_START,
  158.     MMERR_OSX_UNKNOWN_DEVICE,
  159.     MMERR_OSX_BAD_PROPERTY,
  160.     MMERR_OSX_UNSUPPORTED_FORMAT,
  161.     MMERR_OSX_SET_STEREO,
  162.     MMERR_OSX_BUFFER_ALLOC,
  163.     MMERR_OSX_ADD_IO_PROC,
  164.     MMERR_OSX_DEVICE_START,
  165. MMERR_OSX_PTHREAD,
  166. MMERR_DOSWSS_STARTDMA,
  167. MMERR_DOSSB_STARTDMA,
  168. MMERR_MAX
  169. };
  170. /*
  171.  * ========== Error handling
  172.  */
  173. typedef void (MikMod_handler)(void);
  174. typedef MikMod_handler *MikMod_handler_t;
  175. MIKMODAPI extern int  MikMod_errno;
  176. MIKMODAPI extern BOOL MikMod_critical;
  177. MIKMODAPI extern char *MikMod_strerror(int);
  178. MIKMODAPI extern MikMod_handler_t MikMod_RegisterErrorHandler(MikMod_handler_t);
  179. /*
  180.  * ========== Library initialization and core functions
  181.  */
  182. struct MDRIVER;
  183. MIKMODAPI extern void   MikMod_RegisterAllDrivers(void);
  184. MIKMODAPI extern CHAR*  MikMod_InfoDriver(void);
  185. MIKMODAPI extern void   MikMod_RegisterDriver(struct MDRIVER*);
  186. MIKMODAPI extern int    MikMod_DriverFromAlias(CHAR*);
  187. MIKMODAPI extern struct MDRIVER *MikMod_DriverByOrdinal(int);
  188. MIKMODAPI extern BOOL   MikMod_Init(CHAR*);
  189. MIKMODAPI extern void   MikMod_Exit(void);
  190. MIKMODAPI extern BOOL   MikMod_Reset(CHAR*);
  191. MIKMODAPI extern BOOL   MikMod_SetNumVoices(int,int);
  192. MIKMODAPI extern BOOL   MikMod_Active(void);
  193. MIKMODAPI extern BOOL   MikMod_EnableOutput(void);
  194. MIKMODAPI extern void   MikMod_DisableOutput(void);
  195. MIKMODAPI extern void   MikMod_Update(void);
  196. MIKMODAPI extern BOOL   MikMod_InitThreads(void);
  197. MIKMODAPI extern void   MikMod_Lock(void);
  198. MIKMODAPI extern void   MikMod_Unlock(void);
  199. /*
  200.  * ========== Reader, Writer
  201.  */
  202. typedef struct MREADER {
  203. BOOL (*Seek)(struct MREADER*,long,int);
  204. long (*Tell)(struct MREADER*);
  205. BOOL (*Read)(struct MREADER*,void*,size_t);
  206. int  (*Get)(struct MREADER*);
  207. BOOL (*Eof)(struct MREADER*);
  208. } MREADER;
  209. typedef struct MWRITER {
  210. BOOL (*Seek)(struct MWRITER*,long,int);
  211. long (*Tell)(struct MWRITER*);
  212. BOOL (*Write)(struct MWRITER*,void*,size_t);
  213. BOOL (*Put)(struct MWRITER*,int);
  214. } MWRITER;
  215. /*
  216.  * ========== Samples
  217.  */
  218. /* Sample playback should not be interrupted */
  219. #define SFX_CRITICAL 1
  220. /* Sample format [loading and in-memory] flags: */
  221. #define SF_16BITS       0x0001
  222. #define SF_STEREO       0x0002
  223. #define SF_SIGNED       0x0004
  224. #define SF_BIG_ENDIAN   0x0008
  225. #define SF_DELTA        0x0010
  226. #define SF_ITPACKED 0x0020
  227. #define SF_FORMATMASK 0x003F
  228. /* General Playback flags */
  229. #define SF_LOOP         0x0100
  230. #define SF_BIDI         0x0200
  231. #define SF_REVERSE      0x0400
  232. #define SF_SUSTAIN      0x0800
  233. #define SF_PLAYBACKMASK 0x0C00
  234. /* Module-only Playback Flags */
  235. #define SF_OWNPAN 0x1000
  236. #define SF_UST_LOOP     0x2000
  237. #define SF_EXTRAPLAYBACKMASK 0x3000
  238. /* Panning constants */
  239. #define PAN_LEFT 0
  240. #define PAN_HALFLEFT  64
  241. #define PAN_CENTER 128
  242. #define PAN_HALFRIGHT 192
  243. #define PAN_RIGHT 255
  244. #define PAN_SURROUND 512 /* panning value for Dolby Surround */
  245. typedef struct SAMPLE {
  246. SWORD  panning;     /* panning (0-255 or PAN_SURROUND) */
  247. ULONG  speed;       /* Base playing speed/frequency of note */
  248. UBYTE  volume;      /* volume 0-64 */
  249. UWORD  inflags; /* sample format on disk */
  250. UWORD  flags;       /* sample format in memory */
  251. ULONG  length;      /* length of sample (in samples!) */
  252. ULONG  loopstart;   /* repeat position (relative to start, in samples) */
  253. ULONG  loopend;     /* repeat end */
  254. ULONG  susbegin;    /* sustain loop begin (in samples)   Not Supported */
  255. ULONG  susend;      /* sustain loop end                /      Yet! */
  256. /* Variables used by the module player only! (ignored for sound effects) */
  257. UBYTE  globvol;     /* global volume */
  258. UBYTE  vibflags;    /* autovibrato flag stuffs */
  259. UBYTE  vibtype;     /* Vibratos moved from INSTRUMENT to SAMPLE */
  260. UBYTE  vibsweep;
  261. UBYTE  vibdepth;
  262. UBYTE  vibrate;
  263. CHAR*  samplename;  /* name of the sample */
  264. /* Values used internally only */
  265. UWORD  avibpos;     /* autovibrato pos [player use] */
  266. UBYTE  divfactor;   /* for sample scaling, maintains proper period slides */
  267. ULONG  seekpos;     /* seek position in file */
  268. SWORD  handle;      /* sample handle used by individual drivers */
  269. } SAMPLE;
  270. /* Sample functions */
  271. MIKMODAPI extern SAMPLE *Sample_Load(CHAR*);
  272. MIKMODAPI extern SAMPLE *Sample_LoadFP(FILE*);
  273. MIKMODAPI extern SAMPLE *Sample_LoadGeneric(MREADER*);
  274. MIKMODAPI extern void   Sample_Free(SAMPLE*);
  275. MIKMODAPI extern SBYTE  Sample_Play(SAMPLE*,ULONG,UBYTE);
  276. MIKMODAPI extern void   Voice_SetVolume(SBYTE,UWORD);
  277. MIKMODAPI extern UWORD  Voice_GetVolume(SBYTE);
  278. MIKMODAPI extern void   Voice_SetFrequency(SBYTE,ULONG);
  279. MIKMODAPI extern ULONG  Voice_GetFrequency(SBYTE);
  280. MIKMODAPI extern void   Voice_SetPanning(SBYTE,ULONG);
  281. MIKMODAPI extern ULONG  Voice_GetPanning(SBYTE);
  282. MIKMODAPI extern void   Voice_Play(SBYTE,SAMPLE*,ULONG);
  283. MIKMODAPI extern void   Voice_Stop(SBYTE);
  284. MIKMODAPI extern BOOL   Voice_Stopped(SBYTE);
  285. MIKMODAPI extern SLONG  Voice_GetPosition(SBYTE);
  286. MIKMODAPI extern ULONG  Voice_RealVolume(SBYTE);
  287. /*
  288.  * ========== Internal module representation (UniMod)
  289.  */
  290. /*
  291. Instrument definition - for information only, the only field which may be
  292. of use in user programs is the name field
  293. */
  294. /* Instrument note count */
  295. #define INSTNOTES 120
  296. /* Envelope point */
  297. typedef struct ENVPT {
  298. SWORD pos;
  299. SWORD val;
  300. } ENVPT;
  301. /* Envelope point count */
  302. #define ENVPOINTS 32
  303. /* Instrument structure */
  304. typedef struct INSTRUMENT {
  305. CHAR* insname;
  306. UBYTE flags;
  307. UWORD samplenumber[INSTNOTES];
  308. UBYTE samplenote[INSTNOTES];
  309. UBYTE nnatype;
  310. UBYTE dca;              /* duplicate check action */
  311. UBYTE dct;              /* duplicate check type */
  312. UBYTE globvol;
  313. UWORD volfade;
  314. SWORD panning;          /* instrument-based panning var */
  315. UBYTE pitpansep;        /* pitch pan separation (0 to 255) */
  316. UBYTE pitpancenter;     /* pitch pan center (0 to 119) */
  317. UBYTE rvolvar;          /* random volume varations (0 - 100%) */
  318. UBYTE rpanvar;          /* random panning varations (0 - 100%) */
  319. /* volume envelope */
  320. UBYTE volflg;           /* bit 0: on 1: sustain 2: loop */
  321. UBYTE volpts;
  322. UBYTE volsusbeg;
  323. UBYTE volsusend;
  324. UBYTE volbeg;
  325. UBYTE volend;
  326. ENVPT volenv[ENVPOINTS];
  327. /* panning envelope */
  328. UBYTE panflg;           /* bit 0: on 1: sustain 2: loop */
  329. UBYTE panpts;
  330. UBYTE pansusbeg;
  331. UBYTE pansusend;
  332. UBYTE panbeg;
  333. UBYTE panend;
  334. ENVPT panenv[ENVPOINTS];
  335. /* pitch envelope */
  336. UBYTE pitflg;           /* bit 0: on 1: sustain 2: loop */
  337. UBYTE pitpts;
  338. UBYTE pitsusbeg;
  339. UBYTE pitsusend;
  340. UBYTE pitbeg;
  341. UBYTE pitend;
  342. ENVPT pitenv[ENVPOINTS];
  343. } INSTRUMENT;
  344. struct MP_CONTROL;
  345. struct MP_VOICE;
  346. /*
  347. Module definition
  348. */
  349. /* maximum master channels supported */
  350. #define UF_MAXCHAN 64
  351. /* Module flags */
  352. #define UF_XMPERIODS 0x0001 /* XM periods / finetuning */
  353. #define UF_LINEAR 0x0002 /* LINEAR periods (UF_XMPERIODS must be set) */
  354. #define UF_INST 0x0004 /* Instruments are used */
  355. #define UF_NNA 0x0008 /* IT: NNA used, set numvoices rather
  356.   than numchn */
  357. #define UF_S3MSLIDES 0x0010 /* uses old S3M volume slides */
  358. #define UF_BGSLIDES 0x0020 /* continue volume slides in the background */
  359. #define UF_HIGHBPM 0x0040 /* MED: can use >255 bpm */
  360. #define UF_NOWRAP 0x0080 /* XM-type (i.e. illogical) pattern break
  361.   semantics */
  362. #define UF_ARPMEM 0x0100 /* IT: need arpeggio memory */
  363. #define UF_FT2QUIRKS 0x0200 /* emulate some FT2 replay quirks */
  364. #define UF_PANNING 0x0400 /* module uses panning effects or have
  365.   non-tracker default initial panning */
  366. typedef struct MODULE {
  367. /* general module information */
  368. CHAR*       songname;    /* name of the song */
  369. CHAR*       modtype;     /* string type of module loaded */
  370. CHAR*       comment;     /* module comments */
  371. UWORD       flags;       /* See module flags above */
  372. UBYTE       numchn;      /* number of module channels */
  373. UBYTE       numvoices;   /* max # voices used for full NNA playback */
  374. UWORD       numpos;      /* number of positions in this song */
  375. UWORD       numpat;      /* number of patterns in this song */
  376. UWORD       numins;      /* number of instruments */
  377. UWORD       numsmp;      /* number of samples */
  378. struct  INSTRUMENT* instruments; /* all instruments */
  379. struct  SAMPLE*     samples;     /* all samples */
  380. UBYTE       realchn;     /* real number of channels used */
  381. UBYTE       totalchn;    /* total number of channels used (incl NNAs) */
  382. /* playback settings */
  383. UWORD       reppos;      /* restart position */
  384. UBYTE       initspeed;   /* initial song speed */
  385. UWORD       inittempo;   /* initial song tempo */
  386. UBYTE       initvolume;  /* initial global volume (0 - 128) */
  387. UWORD       panning[UF_MAXCHAN]; /* panning positions */
  388. UBYTE       chanvol[UF_MAXCHAN]; /* channel positions */
  389. UWORD       bpm;         /* current beats-per-minute speed */
  390. UWORD       sngspd;      /* current song speed */
  391. SWORD       volume;      /* song volume (0-128) (or user volume) */
  392. BOOL        extspd;      /* extended speed flag (default enabled) */
  393. BOOL        panflag;     /* panning flag (default enabled) */
  394. BOOL        wrap;        /* wrap module ? (default disabled) */
  395. BOOL        loop;  /* allow module to loop ? (default enabled) */
  396. BOOL        fadeout;  /* volume fade out during last pattern */
  397. UWORD       patpos;      /* current row number */
  398. SWORD       sngpos;      /* current song position */
  399. ULONG       sngtime;     /* current song time in 2^-10 seconds */
  400. SWORD       relspd;      /* relative speed factor */
  401. /* internal module representation */
  402. UWORD       numtrk;      /* number of tracks */
  403. UBYTE**     tracks;      /* array of numtrk pointers to tracks */
  404. UWORD*      patterns;    /* array of Patterns */
  405. UWORD*      pattrows;    /* array of number of rows for each pattern */
  406. UWORD*      positions;   /* all positions */
  407. BOOL        forbid;      /* if true, no player update! */
  408. UWORD       numrow;      /* number of rows on current pattern */
  409. UWORD       vbtick;      /* tick counter (counts from 0 to sngspd) */
  410. UWORD       sngremainder;/* used for song time computation */
  411. struct MP_CONTROL*  control;     /* Effects Channel info (size pf->numchn) */
  412. struct MP_VOICE*    voice;       /* Audio Voice information (size md_numchn) */
  413. UBYTE       globalslide; /* global volume slide rate */
  414. UBYTE       pat_repcrazy;/* module has just looped to position -1 */
  415. UWORD       patbrk;      /* position where to start a new pattern */
  416. UBYTE       patdly;      /* patterndelay counter (command memory) */
  417. UBYTE       patdly2;     /* patterndelay counter (real one) */
  418. SWORD       posjmp;      /* flag to indicate a jump is needed... */
  419. UWORD bpmlimit;  /* threshold to detect bpm or speed values */
  420. } MODULE;
  421. /* This structure is used to query current playing voices status */
  422. typedef struct VOICEINFO {
  423. INSTRUMENT* i;            /* Current channel instrument */
  424. SAMPLE*     s;            /* Current channel sample */
  425. SWORD       panning;      /* panning position */
  426. SBYTE       volume;       /* channel's "global" volume (0..64) */
  427. UWORD       period;       /* period to play the sample at */
  428. UBYTE       kick;         /* if true = sample has been restarted */
  429. } VOICEINFO;
  430. /*
  431.  * ========== Module loaders
  432.  */
  433. struct MLOADER;
  434. MIKMODAPI extern CHAR*   MikMod_InfoLoader(void);
  435. MIKMODAPI extern void    MikMod_RegisterAllLoaders(void);
  436. MIKMODAPI extern void    MikMod_RegisterLoader(struct MLOADER*);
  437. MIKMODAPI extern struct MLOADER load_669; /* 669 and Extended-669 (by Tran/Renaissance) */
  438. MIKMODAPI extern struct MLOADER load_amf; /* DMP Advanced Module Format (by Otto Chrons) */
  439. MIKMODAPI extern struct MLOADER load_asy; /* ASYLUM Music Format 1.0 */
  440. MIKMODAPI extern struct MLOADER load_dsm; /* DSIK internal module format */
  441. MIKMODAPI extern struct MLOADER load_far; /* Farandole Composer (by Daniel Potter) */
  442. MIKMODAPI extern struct MLOADER load_gdm; /* General DigiMusic (by Edward Schlunder) */
  443. MIKMODAPI extern struct MLOADER load_it;  /* Impulse Tracker (by Jeffrey Lim) */
  444. MIKMODAPI extern struct MLOADER load_imf; /* Imago Orpheus (by Lutz Roeder) */
  445. MIKMODAPI extern struct MLOADER load_med; /* Amiga MED modules (by Teijo Kinnunen) */
  446. MIKMODAPI extern struct MLOADER load_m15; /* Soundtracker 15-instrument */
  447. MIKMODAPI extern struct MLOADER load_mod; /* Standard 31-instrument Module loader */
  448. MIKMODAPI extern struct MLOADER load_mtm; /* Multi-Tracker Module (by Renaissance) */
  449. MIKMODAPI extern struct MLOADER load_okt; /* Amiga Oktalyzer */
  450. MIKMODAPI extern struct MLOADER load_stm; /* ScreamTracker 2 (by Future Crew) */
  451. MIKMODAPI extern struct MLOADER load_stx; /* STMIK 0.2 (by Future Crew) */
  452. MIKMODAPI extern struct MLOADER load_s3m; /* ScreamTracker 3 (by Future Crew) */
  453. MIKMODAPI extern struct MLOADER load_ult; /* UltraTracker (by MAS) */
  454. MIKMODAPI extern struct MLOADER load_uni; /* MikMod and APlayer internal module format */
  455. MIKMODAPI extern struct MLOADER load_xm;  /* FastTracker 2 (by Triton) */
  456. /*
  457.  * ========== Module player
  458.  */
  459. MIKMODAPI extern MODULE* Player_Load(CHAR*,int,BOOL);
  460. MIKMODAPI extern MODULE* Player_LoadFP(FILE*,int,BOOL);
  461. MIKMODAPI extern MODULE* Player_LoadGeneric(MREADER*,int,BOOL);
  462. MIKMODAPI extern CHAR*   Player_LoadTitle(CHAR*);
  463. MIKMODAPI extern CHAR*   Player_LoadTitleFP(FILE*);
  464. MIKMODAPI extern void    Player_Free(MODULE*);
  465. MIKMODAPI extern void    Player_Start(MODULE*);
  466. MIKMODAPI extern BOOL    Player_Active(void);
  467. MIKMODAPI extern void    Player_Stop(void);
  468. MIKMODAPI extern void    Player_TogglePause(void);
  469. MIKMODAPI extern BOOL    Player_Paused(void);
  470. MIKMODAPI extern void    Player_NextPosition(void);
  471. MIKMODAPI extern void    Player_PrevPosition(void);
  472. MIKMODAPI extern void    Player_SetPosition(UWORD);
  473. MIKMODAPI extern BOOL    Player_Muted(UBYTE);
  474. MIKMODAPI extern void    Player_SetVolume(SWORD);
  475. MIKMODAPI extern MODULE* Player_GetModule(void);
  476. MIKMODAPI extern void    Player_SetSpeed(UWORD);
  477. MIKMODAPI extern void    Player_SetTempo(UWORD);
  478. MIKMODAPI extern void    Player_Unmute(SLONG,...);
  479. MIKMODAPI extern void    Player_Mute(SLONG,...);
  480. MIKMODAPI extern void    Player_ToggleMute(SLONG,...);
  481. MIKMODAPI extern int     Player_GetChannelVoice(UBYTE);
  482. MIKMODAPI extern UWORD   Player_GetChannelPeriod(UBYTE);
  483. MIKMODAPI extern int     Player_QueryVoices(UWORD numvoices, VOICEINFO *vinfo); 
  484. typedef void (MikMod_player)(void);
  485. typedef MikMod_player *MikMod_player_t;
  486. MIKMODAPI extern MikMod_player_t MikMod_RegisterPlayer(MikMod_player_t);
  487. #define MUTE_EXCLUSIVE  32000
  488. #define MUTE_INCLUSIVE  32001
  489. /*
  490.  * ========== Drivers
  491.  */
  492. enum {
  493. MD_MUSIC = 0,
  494. MD_SNDFX
  495. };
  496. enum {
  497. MD_HARDWARE = 0,
  498. MD_SOFTWARE
  499. };
  500. /* Mixing flags */
  501. /* These ones take effect only after MikMod_Init or MikMod_Reset */
  502. #define DMODE_16BITS     0x0001 /* enable 16 bit output */
  503. #define DMODE_STEREO     0x0002 /* enable stereo output */
  504. #define DMODE_SOFT_SNDFX 0x0004 /* Process sound effects via software mixer */
  505. #define DMODE_SOFT_MUSIC 0x0008 /* Process music via software mixer */
  506. #define DMODE_HQMIXER    0x0010 /* Use high-quality (slower) software mixer */
  507. #define DMODE_FLOAT      0x0020 /* enable float output */
  508. /* These take effect immediately. */
  509. #define DMODE_SURROUND   0x0100 /* enable surround sound */
  510. #define DMODE_INTERP     0x0200 /* enable interpolation */
  511. #define DMODE_REVERSE    0x0400 /* reverse stereo */
  512. struct SAMPLOAD;
  513. typedef struct MDRIVER {
  514. struct MDRIVER* next;
  515. CHAR*       Name;
  516. CHAR*       Version;
  517. UBYTE       HardVoiceLimit; /* Limit of hardware mixer voices */
  518. UBYTE       SoftVoiceLimit; /* Limit of software mixer voices */
  519. CHAR        *Alias;
  520. CHAR        *CmdLineHelp;
  521. void        (*CommandLine)      (CHAR*);
  522. BOOL        (*IsPresent)        (void);
  523. SWORD       (*SampleLoad)       (struct SAMPLOAD*,int);
  524. void        (*SampleUnload)     (SWORD);
  525. ULONG       (*FreeSampleSpace)  (int);
  526. ULONG       (*RealSampleLength) (int,struct SAMPLE*);
  527. BOOL        (*Init)             (void);
  528. void        (*Exit)             (void);
  529. BOOL        (*Reset)            (void);
  530. BOOL        (*SetNumVoices)     (void);
  531. BOOL        (*PlayStart)        (void);
  532. void        (*PlayStop)         (void);
  533. void        (*Update)           (void);
  534. void (*Pause) (void);
  535. void        (*VoiceSetVolume)   (UBYTE,UWORD);
  536. UWORD       (*VoiceGetVolume)   (UBYTE);
  537. void        (*VoiceSetFrequency)(UBYTE,ULONG);
  538. ULONG       (*VoiceGetFrequency)(UBYTE);
  539. void        (*VoiceSetPanning)  (UBYTE,ULONG);
  540. ULONG       (*VoiceGetPanning)  (UBYTE);
  541. void        (*VoicePlay)        (UBYTE,SWORD,ULONG,ULONG,ULONG,ULONG,UWORD);
  542. void        (*VoiceStop)        (UBYTE);
  543. BOOL        (*VoiceStopped)     (UBYTE);
  544. SLONG       (*VoiceGetPosition) (UBYTE);
  545. ULONG       (*VoiceRealVolume)  (UBYTE);
  546. } MDRIVER;
  547. /* These variables can be changed at ANY time and results will be immediate */
  548. MIKMODAPI extern UBYTE md_volume;      /* global sound volume (0-128) */
  549. MIKMODAPI extern UBYTE md_musicvolume; /* volume of song */
  550. MIKMODAPI extern UBYTE md_sndfxvolume; /* volume of sound effects */
  551. MIKMODAPI extern UBYTE md_reverb;      /* 0 = none;  15 = chaos */
  552. MIKMODAPI extern UBYTE md_pansep;      /* 0 = mono;  128 == 100% (full left/right) */
  553. /* The variables below can be changed at any time, but changes will not be
  554.    implemented until MikMod_Reset is called. A call to MikMod_Reset may result
  555.    in a skip or pop in audio (depending on the soundcard driver and the settings
  556.    changed). */
  557. MIKMODAPI extern UWORD md_device;      /* device */
  558. MIKMODAPI extern UWORD md_mixfreq;     /* mixing frequency */
  559. MIKMODAPI extern UWORD md_mode;        /* mode. See DMODE_? flags above */
  560. /* The following variable should not be changed! */
  561. MIKMODAPI extern MDRIVER* md_driver;   /* Current driver in use. */
  562. /* Known drivers list */
  563. MIKMODAPI extern struct MDRIVER drv_nos;    /* no sound */
  564. MIKMODAPI extern struct MDRIVER drv_pipe;   /* piped output */
  565. MIKMODAPI extern struct MDRIVER drv_raw;    /* raw file disk writer [music.raw] */
  566. MIKMODAPI extern struct MDRIVER drv_stdout; /* output to stdout */
  567. MIKMODAPI extern struct MDRIVER drv_wav;    /* RIFF WAVE file disk writer [music.wav] */
  568. MIKMODAPI extern struct MDRIVER drv_aiff;   /* AIFF file disk writer [music.aiff] */
  569. MIKMODAPI extern struct MDRIVER drv_ultra;  /* Linux Ultrasound driver */
  570. MIKMODAPI extern struct MDRIVER drv_sam9407; /* Linux sam9407 driver */
  571. MIKMODAPI extern struct MDRIVER drv_AF;     /* Dec Alpha AudioFile */
  572. MIKMODAPI extern struct MDRIVER drv_aix;    /* AIX audio device */
  573. MIKMODAPI extern struct MDRIVER drv_alsa;   /* Advanced Linux Sound Architecture (ALSA) */
  574. MIKMODAPI extern struct MDRIVER drv_esd;    /* Enlightened sound daemon (EsounD) */
  575. MIKMODAPI extern struct MDRIVER drv_hp;     /* HP-UX audio device */
  576. MIKMODAPI extern struct MDRIVER drv_oss;    /* OpenSound System (Linux,FreeBSD...) */
  577. MIKMODAPI extern struct MDRIVER drv_sgi;    /* SGI audio library */
  578. MIKMODAPI extern struct MDRIVER drv_sun;    /* Sun/NetBSD/OpenBSD audio device */
  579. MIKMODAPI extern struct MDRIVER drv_dart;   /* OS/2 Direct Audio RealTime */
  580. MIKMODAPI extern struct MDRIVER drv_os2;    /* OS/2 MMPM/2 */
  581. MIKMODAPI extern struct MDRIVER drv_ds;     /* Win32 DirectSound driver */
  582. MIKMODAPI extern struct MDRIVER drv_win;    /* Win32 multimedia API driver */
  583. MIKMODAPI extern struct MDRIVER drv_mac;    /* Macintosh Sound Manager driver */
  584. MIKMODAPI extern struct MDRIVER drv_osx; /* MacOS X CoreAudio Driver */
  585. /*========== Virtual channel mixer interface (for user-supplied drivers only) */
  586. MIKMODAPI extern BOOL  VC_Init(void);
  587. MIKMODAPI extern void  VC_Exit(void);
  588. MIKMODAPI extern BOOL  VC_SetNumVoices(void);
  589. MIKMODAPI extern ULONG VC_SampleSpace(int);
  590. MIKMODAPI extern ULONG VC_SampleLength(int,SAMPLE*);
  591. MIKMODAPI extern BOOL  VC_PlayStart(void);
  592. MIKMODAPI extern void  VC_PlayStop(void);
  593. MIKMODAPI extern SWORD VC_SampleLoad(struct SAMPLOAD*,int);
  594. MIKMODAPI extern void  VC_SampleUnload(SWORD);
  595. MIKMODAPI extern ULONG VC_WriteBytes(SBYTE*,ULONG);
  596. MIKMODAPI extern ULONG VC_SilenceBytes(SBYTE*,ULONG);
  597. MIKMODAPI extern void  VC_VoiceSetVolume(UBYTE,UWORD);
  598. MIKMODAPI extern UWORD VC_VoiceGetVolume(UBYTE);
  599. MIKMODAPI extern void  VC_VoiceSetFrequency(UBYTE,ULONG);
  600. MIKMODAPI extern ULONG VC_VoiceGetFrequency(UBYTE);
  601. MIKMODAPI extern void  VC_VoiceSetPanning(UBYTE,ULONG);
  602. MIKMODAPI extern ULONG VC_VoiceGetPanning(UBYTE);
  603. MIKMODAPI extern void  VC_VoicePlay(UBYTE,SWORD,ULONG,ULONG,ULONG,ULONG,UWORD);
  604. MIKMODAPI extern void  VC_VoiceStop(UBYTE);
  605. MIKMODAPI extern BOOL  VC_VoiceStopped(UBYTE);
  606. MIKMODAPI extern SLONG VC_VoiceGetPosition(UBYTE);
  607. MIKMODAPI extern ULONG VC_VoiceRealVolume(UBYTE);
  608. #ifdef __cplusplus
  609. }
  610. #endif
  611. #endif
  612. /* ex:set ts=4: */