source: trunk/include/win/mmsystem.h@ 1566

Last change on this file since 1566 was 1118, checked in by sandervl, 26 years ago

Lots of changes by several people (see changelog for 4 October

File size: 107.2 KB
Line 
1/* $Id: mmsystem.h,v 1.2 1999-10-04 09:55:49 sandervl Exp $ */
2
3/*
4 * MMSYSTEM - Multimedia Wine Extension ... :-)
5 */
6
7#ifndef __WINE_MMSYSTEM_H
8#define __WINE_MMSYSTEM_H
9
10#ifdef __cplusplus
11extern "C" {
12#endif
13#include "windef.h"
14
15typedef LPSTR HPSTR; /* a huge version of LPSTR */
16typedef LPCSTR HPCSTR; /* a huge version of LPCSTR */
17
18#include "pshpack1.h"
19
20#define MAXWAVEDRIVERS 10
21#define MAXMIDIDRIVERS 10
22#define MAXAUXDRIVERS 10
23#define MAXMCIDRIVERS 32
24#define MAXMIXERDRIVERS 10
25
26#define MAXPNAMELEN 32 /* max product name length (including NULL) */
27#define MAXERRORLENGTH 128 /* max error text length (including NULL) */
28#define MAX_JOYSTICKOEMVXDNAME 260
29
30typedef WORD VERSION; /* major (high byte), minor (low byte) */
31
32typedef UINT16 MMVERSION16;
33typedef UINT MMVERSION;
34typedef UINT16 MCIDEVICEID16;
35typedef UINT MCIDEVICEID;
36typedef UINT16 MMRESULT16;
37typedef UINT MMRESULT;
38typedef DWORD MCIERROR;
39
40typedef struct {
41 UINT16 wType; /* indicates the contents of the union */
42 union {
43 DWORD ms; /* milliseconds */
44 DWORD sample; /* samples */
45 DWORD cb; /* byte count */
46 struct { /* SMPTE */
47 BYTE hour; /* hours */
48 BYTE min; /* minutes */
49 BYTE sec; /* seconds */
50 BYTE frame; /* frames */
51 BYTE fps; /* frames per second */
52 BYTE dummy; /* pad */
53 } smpte;
54 struct { /* MIDI */
55 DWORD songptrpos; /* song pointer position */
56 } midi;
57 } u;
58} MMTIME16, *LPMMTIME16;
59
60typedef struct {
61 UINT wType;
62 union {
63 DWORD ms;
64 DWORD sample;
65 DWORD cb;
66 DWORD ticks;
67 struct {
68 BYTE hour;
69 BYTE min;
70 BYTE sec;
71 BYTE frame;
72 BYTE fps;
73 BYTE dummy;
74 BYTE pad[2];
75 } smpte;
76 struct {
77 DWORD songptrpos;
78 } midi;
79 } u;
80} MMTIME, *LPMMTIME;
81
82#define TIME_MS 0x0001 /* time in milliseconds */
83#define TIME_SAMPLES 0x0002 /* number of wave samples */
84#define TIME_BYTES 0x0004 /* current byte offset */
85#define TIME_SMPTE 0x0008 /* SMPTE time */
86#define TIME_MIDI 0x0010 /* MIDI time */
87#define TIME_TICKS 0x0020 /* MIDI ticks */
88
89#define MM_JOY1MOVE 0x3A0 /* joystick */
90#define MM_JOY2MOVE 0x3A1
91#define MM_JOY1ZMOVE 0x3A2
92#define MM_JOY2ZMOVE 0x3A3
93#define MM_JOY1BUTTONDOWN 0x3B5
94#define MM_JOY2BUTTONDOWN 0x3B6
95#define MM_JOY1BUTTONUP 0x3B7
96#define MM_JOY2BUTTONUP 0x3B8
97
98#define MM_MCINOTIFY 0x3B9 /* MCI */
99
100#define MM_WOM_OPEN 0x3BB /* waveform output */
101#define MM_WOM_CLOSE 0x3BC
102#define MM_WOM_DONE 0x3BD
103
104#define MM_WIM_OPEN 0x3BE /* waveform input */
105#define MM_WIM_CLOSE 0x3BF
106#define MM_WIM_DATA 0x3C0
107
108#define MM_MIM_OPEN 0x3C1 /* MIDI input */
109#define MM_MIM_CLOSE 0x3C2
110#define MM_MIM_DATA 0x3C3
111#define MM_MIM_LONGDATA 0x3C4
112#define MM_MIM_ERROR 0x3C5
113#define MM_MIM_LONGERROR 0x3C6
114
115#define MM_MOM_OPEN 0x3C7 /* MIDI output */
116#define MM_MOM_CLOSE 0x3C8
117#define MM_MOM_DONE 0x3C9
118#define MM_MOM_POSITIONCB 0x3CA
119
120#define MMSYSERR_BASE 0
121#define WAVERR_BASE 32
122#define MIDIERR_BASE 64
123#define TIMERR_BASE 96
124#define JOYERR_BASE 160
125#define MCIERR_BASE 256
126
127#define MCI_STRING_OFFSET 512
128#define MCI_VD_OFFSET 1024
129#define MCI_CD_OFFSET 1088
130#define MCI_WAVE_OFFSET 1152
131#define MCI_SEQ_OFFSET 1216
132
133#define MMSYSERR_NOERROR 0 /* no error */
134#define MMSYSERR_ERROR (MMSYSERR_BASE + 1) /* unspecified error */
135#define MMSYSERR_BADDEVICEID (MMSYSERR_BASE + 2) /* device ID out of range */
136#define MMSYSERR_NOTENABLED (MMSYSERR_BASE + 3) /* driver failed enable */
137#define MMSYSERR_ALLOCATED (MMSYSERR_BASE + 4) /* device already allocated */
138#define MMSYSERR_INVALHANDLE (MMSYSERR_BASE + 5) /* device handle is invalid */
139#define MMSYSERR_NODRIVER (MMSYSERR_BASE + 6) /* no device driver present */
140#define MMSYSERR_NOMEM (MMSYSERR_BASE + 7) /* memory allocation error */
141#define MMSYSERR_NOTSUPPORTED (MMSYSERR_BASE + 8) /* function isn't supported */
142#define MMSYSERR_BADERRNUM (MMSYSERR_BASE + 9) /* error value out of range */
143#define MMSYSERR_INVALFLAG (MMSYSERR_BASE + 10) /* invalid flag passed */
144#define MMSYSERR_INVALPARAM (MMSYSERR_BASE + 11) /* invalid parameter passed */
145#define MMSYSERR_HANDLEBUSY (MMSYSERR_BASE + 12) /* handle being used */
146#define MMSYSERR_INVALIDALIAS (MMSYSERR_BASE + 13) /* specified alias not found */
147#define MMSYSERR_BADDB (MMSYSERR_BASE + 14) /* bad registry database */
148#define MMSYSERR_KEYNOTFOUND (MMSYSERR_BASE + 15) /* registry key not found */
149#define MMSYSERR_READERROR (MMSYSERR_BASE + 16) /* registry read error */
150#define MMSYSERR_WRITEERROR (MMSYSERR_BASE + 17) /* registry write error */
151#define MMSYSERR_DELETEERROR (MMSYSERR_BASE + 18) /* registry delete error */
152#define MMSYSERR_VALNOTFOUND (MMSYSERR_BASE + 19) /* registry value not found */
153#define MMSYSERR_NODRIVERCB (MMSYSERR_BASE + 20) /* driver does not call DriverCallback */
154#define MMSYSERR_LASTERROR (MMSYSERR_BASE + 20) /* last error in range */
155
156
157#define CALLBACK_TYPEMASK 0x00070000l /* callback type mask */
158#define CALLBACK_NULL 0x00000000l /* no callback */
159#define CALLBACK_WINDOW 0x00010000l /* dwCallback is a HWND */
160#define CALLBACK_TASK 0x00020000l /* dwCallback is a HTASK */
161#define CALLBACK_THREAD (CALLBACK_TASK) /* dwCallback is a thread ID */
162#define CALLBACK_FUNCTION 0x00030000l /* dwCallback is a FARPROC */
163#define CALLBACK_EVENT 0x00050000l /* dwCallback is an EVENT Handler */
164#define CALLBACK_FUNC32 0x00070000l /* (ugly hack) 32-bit FARPROC */
165#define CALLBACK32CONV(x) ((((x)&CALLBACK_TYPEMASK)==CALLBACK_FUNCTION) ? \
166 (((x)&~CALLBACK_TYPEMASK)|CALLBACK_FUNC32) : (x))
167
168typedef void (* CALLBACK LPDRVCALLBACK16) (HDRVR16 h, UINT16 uMessage, DWORD dwUser, DWORD dw1, DWORD dw2);
169typedef void (* CALLBACK LPDRVCALLBACK) (HDRVR h, UINT uMessage, DWORD dwUser, DWORD dw1, DWORD dw2);
170
171#define MM_MICROSOFT 1 /* Microsoft Corp. */
172
173#define MM_MIDI_MAPPER 1 /* MIDI Mapper */
174#define MM_WAVE_MAPPER 2 /* Wave Mapper */
175
176#define MM_SNDBLST_MIDIOUT 3 /* Sound Blaster MIDI output port */
177#define MM_SNDBLST_MIDIIN 4 /* Sound Blaster MIDI input port */
178#define MM_SNDBLST_SYNTH 5 /* Sound Blaster internal synthesizer */
179#define MM_SNDBLST_WAVEOUT 6 /* Sound Blaster waveform output */
180#define MM_SNDBLST_WAVEIN 7 /* Sound Blaster waveform input */
181
182#define MM_ADLIB 9 /* Ad Lib-compatible synthesizer */
183
184#define MM_MPU401_MIDIOUT 10 /* MPU401-compatible MIDI output port */
185#define MM_MPU401_MIDIIN 11 /* MPU401-compatible MIDI input port */
186
187#define MM_PC_JOYSTICK 12 /* Joystick adapter */
188
189
190UINT16 WINAPI mmsystemGetVersion16(void);
191UINT WINAPI mmsystemGetVersion(void);
192BOOL WINAPI sndPlaySoundA(LPCSTR pszSound, UINT fuSound);
193BOOL WINAPI sndPlaySoundW(LPCWSTR pszSound, UINT fuSound);
194#define sndPlaySound WINELIB_NAME_AW(sndPlaySound)
195BOOL WINAPI PlaySoundA(LPCSTR pszSound, HMODULE hmod, DWORD fdwSound);
196BOOL WINAPI PlaySoundW(LPCWSTR pszSound, HMODULE hmod, DWORD fdwSound);
197#define PlaySound WINELIB_NAME_AW(PlaySound)
198
199#define SND_SYNC 0x0000 /* play synchronously (default) */
200#define SND_ASYNC 0x0001 /* play asynchronously */
201#define SND_NODEFAULT 0x0002 /* don't use default sound */
202#define SND_MEMORY 0x0004 /* lpszSoundName points to a memory file */
203#define SND_LOOP 0x0008 /* loop the sound until next sndPlaySound */
204#define SND_NOSTOP 0x0010 /* don't stop any currently playing sound */
205
206#define SND_NOWAIT 0x00002000L /* don't wait if the driver is busy */
207#define SND_ALIAS 0x00010000L /* name is a registry alias */
208#define SND_ALIAS_ID 0x00110000L /* alias is a predefined ID */
209#define SND_FILENAME 0x00020000L /* name is file name */
210#define SND_RESOURCE 0x00040004L /* name is resource name or atom */
211#define SND_PURGE 0x00000040L /* purge all sounds */
212#define SND_APPLICATION 0x00000080L /* look for application specific association */
213
214/* waveform audio error return values */
215#define WAVERR_BADFORMAT (WAVERR_BASE + 0) /* unsupported wave format */
216#define WAVERR_STILLPLAYING (WAVERR_BASE + 1) /* still something playing */
217#define WAVERR_UNPREPARED (WAVERR_BASE + 2) /* header not prepared */
218#define WAVERR_SYNC (WAVERR_BASE + 3) /* device is synchronous */
219#define WAVERR_LASTERROR (WAVERR_BASE + 3) /* last error in range */
220
221typedef LPDRVCALLBACK16 LPWAVECALLBACK16;
222typedef LPDRVCALLBACK LPWAVECALLBACK;
223
224#define WOM_OPEN MM_WOM_OPEN
225#define WOM_CLOSE MM_WOM_CLOSE
226#define WOM_DONE MM_WOM_DONE
227#define WIM_OPEN MM_WIM_OPEN
228#define WIM_CLOSE MM_WIM_CLOSE
229#define WIM_DATA MM_WIM_DATA
230
231#define WAVE_MAPPER (-1)
232
233#define WAVE_FORMAT_QUERY 0x0001
234#define WAVE_ALLOWSYNC 0x0002
235
236typedef struct wavehdr_tag {
237 LPSTR lpData; /* pointer to locked data buffer */
238 DWORD dwBufferLength; /* length of data buffer */
239 DWORD dwBytesRecorded;/* used for input only */
240 DWORD dwUser; /* for client's use */
241 DWORD dwFlags; /* assorted flags (see defines) */
242 DWORD dwLoops; /* loop control counter */
243
244 struct wavehdr_tag *lpNext; /* reserved for driver */
245 DWORD reserved; /* reserved for driver */
246} WAVEHDR, *LPWAVEHDR;
247
248#define WHDR_DONE 0x00000001 /* done bit */
249#define WHDR_PREPARED 0x00000002 /* set if this header has been prepared */
250#define WHDR_BEGINLOOP 0x00000004 /* loop start block */
251#define WHDR_ENDLOOP 0x00000008 /* loop end block */
252#define WHDR_INQUEUE 0x00000010 /* reserved for driver */
253
254typedef struct {
255 WORD wMid; /* manufacturer ID */
256 WORD wPid; /* product ID */
257 MMVERSION16 vDriverVersion; /* version of the driver */
258 CHAR szPname[MAXPNAMELEN]; /* product name (0 terminated string) */
259 DWORD dwFormats; /* formats supported */
260 WORD wChannels; /* number of sources supported */
261 DWORD dwSupport; /* functionality supported by driver */
262} WAVEOUTCAPS16, *LPWAVEOUTCAPS16;
263
264typedef struct {
265 WORD wMid; /* manufacturer ID */
266 WORD wPid; /* product ID */
267 MMVERSION vDriverVersion; /* version of the driver */
268 CHAR szPname[MAXPNAMELEN]; /* product name (0 terminated string) */
269 DWORD dwFormats; /* formats supported */
270 WORD wChannels; /* number of sources supported */
271 WORD wReserved1; /* padding */
272 DWORD dwSupport; /* functionality supported by driver */
273} WAVEOUTCAPSA, *LPWAVEOUTCAPSA;
274
275typedef struct {
276 WORD wMid; /* manufacturer ID */
277 WORD wPid; /* product ID */
278 MMVERSION vDriverVersion; /* version of the driver */
279 WCHAR szPname[MAXPNAMELEN]; /* product name (0 terminated string) */
280 DWORD dwFormats; /* formats supported */
281 WORD wChannels; /* number of sources supported */
282 WORD wReserved1; /* padding */
283 DWORD dwSupport; /* functionality supported by driver */
284} WAVEOUTCAPSW, *LPWAVEOUTCAPSW;
285DECL_WINELIB_TYPE_AW(WAVEOUTCAPS)
286DECL_WINELIB_TYPE_AW(LPWAVEOUTCAPS)
287
288#define WAVECAPS_PITCH 0x0001 /* supports pitch control */
289#define WAVECAPS_PLAYBACKRATE 0x0002 /* supports playback rate control */
290#define WAVECAPS_VOLUME 0x0004 /* supports volume control */
291#define WAVECAPS_LRVOLUME 0x0008 /* separate left-right volume control */
292#define WAVECAPS_SYNC 0x0010 /* driver is synchrounous and playing is blocking */
293#define WAVECAPS_SAMPLEACCURATE 0x0020 /* position is sample accurate */
294#define WAVECAPS_DIRECTSOUND 0x0040 /* ? */
295
296typedef struct {
297 WORD wMid; /* manufacturer ID */
298 WORD wPid; /* product ID */
299 MMVERSION16 vDriverVersion; /* version of the driver */
300 CHAR szPname[MAXPNAMELEN]; /* product name (0 terminated string) */
301 DWORD dwFormats; /* formats supported */
302 WORD wChannels; /* number of channels supported */
303} WAVEINCAPS16, *LPWAVEINCAPS16;
304
305typedef struct {
306 WORD wMid; /* manufacturer ID */
307 WORD wPid; /* product ID */
308 MMVERSION vDriverVersion; /* version of the driver */
309 CHAR szPname[MAXPNAMELEN]; /* product name (0 terminated string) */
310 DWORD dwFormats; /* formats supported */
311 WORD wChannels; /* number of channels supported */
312 WORD wReserved1;
313} WAVEINCAPSA, *LPWAVEINCAPSA;
314typedef struct {
315 WORD wMid; /* manufacturer ID */
316 WORD wPid; /* product ID */
317 MMVERSION vDriverVersion; /* version of the driver */
318 WCHAR szPname[MAXPNAMELEN]; /* product name (0 terminated string) */
319 DWORD dwFormats; /* formats supported */
320 WORD wChannels; /* number of channels supported */
321 WORD wReserved1;
322} WAVEINCAPSW, *LPWAVEINCAPSW;
323DECL_WINELIB_TYPE_AW(WAVEINCAPS)
324DECL_WINELIB_TYPE_AW(LPWAVEINCAPS)
325
326#define WAVE_INVALIDFORMAT 0x00000000 /* invalid format */
327#define WAVE_FORMAT_1M08 0x00000001 /* 11.025 kHz, Mono, 8-bit */
328#define WAVE_FORMAT_1S08 0x00000002 /* 11.025 kHz, Stereo, 8-bit */
329#define WAVE_FORMAT_1M16 0x00000004 /* 11.025 kHz, Mono, 16-bit */
330#define WAVE_FORMAT_1S16 0x00000008 /* 11.025 kHz, Stereo, 16-bit */
331#define WAVE_FORMAT_2M08 0x00000010 /* 22.05 kHz, Mono, 8-bit */
332#define WAVE_FORMAT_2S08 0x00000020 /* 22.05 kHz, Stereo, 8-bit */
333#define WAVE_FORMAT_2M16 0x00000040 /* 22.05 kHz, Mono, 16-bit */
334#define WAVE_FORMAT_2S16 0x00000080 /* 22.05 kHz, Stereo, 16-bit */
335#define WAVE_FORMAT_4M08 0x00000100 /* 44.1 kHz, Mono, 8-bit */
336#define WAVE_FORMAT_4S08 0x00000200 /* 44.1 kHz, Stereo, 8-bit */
337#define WAVE_FORMAT_4M16 0x00000400 /* 44.1 kHz, Mono, 16-bit */
338#define WAVE_FORMAT_4S16 0x00000800 /* 44.1 kHz, Stereo, 16-bit */
339
340/* General format structure common to all formats, same for Win16 and Win32 */
341typedef struct {
342 WORD wFormatTag; /* format type */
343 WORD nChannels; /* number of channels */
344 DWORD nSamplesPerSec; /* sample rate */
345 DWORD nAvgBytesPerSec;/* for buffer estimation */
346 WORD nBlockAlign; /* block size of data */
347} WAVEFORMAT, *LPWAVEFORMAT;
348
349#define WAVE_FORMAT_PCM 1
350
351typedef struct {
352 WAVEFORMAT wf;
353 WORD wBitsPerSample;
354} PCMWAVEFORMAT, *LPPCMWAVEFORMAT;
355
356#ifndef _WAVEFORMATEX_
357#define _WAVEFORMATEX_
358/* dito same for Win16 / Win32 */
359typedef struct {
360 WORD wFormatTag; /* format type */
361 WORD nChannels; /* number of channels (i.e. mono, stereo...) */
362 DWORD nSamplesPerSec; /* sample rate */
363 DWORD nAvgBytesPerSec;/* for buffer estimation */
364 WORD nBlockAlign; /* block size of data */
365 WORD wBitsPerSample; /* number of bits per sample of mono data */
366 WORD cbSize; /* the count in bytes of the size of */
367 /* extra information (after cbSize) */
368} WAVEFORMATEX, *LPWAVEFORMATEX, *NPWAVEFORMATEX, *PWAVEFORMATEX;
369#endif
370
371UINT16 WINAPI waveOutGetNumDevs16(void);
372UINT WINAPI waveOutGetNumDevs(void);
373UINT16 WINAPI waveOutGetDevCaps16(UINT16,LPWAVEOUTCAPS16,UINT16);
374UINT WINAPI waveOutGetDevCapsA(UINT,LPWAVEOUTCAPSA,UINT);
375UINT WINAPI waveOutGetDevCapsW(UINT,LPWAVEOUTCAPSW,UINT);
376#define waveOutGetDevCaps WINELIB_NAME_AW(waveOutGetDevCaps)
377UINT16 WINAPI waveOutGetVolume16(UINT16,DWORD*);
378UINT WINAPI waveOutGetVolume(HWAVEOUT,DWORD*);
379UINT16 WINAPI waveOutSetVolume16(UINT16,DWORD);
380UINT WINAPI waveOutSetVolume(HWAVEOUT,DWORD);
381UINT16 WINAPI waveOutGetErrorText16(UINT16,LPSTR,UINT16);
382UINT WINAPI waveOutGetErrorTextA(UINT,LPSTR,UINT);
383UINT WINAPI waveOutGetErrorTextW(UINT,LPWSTR,UINT);
384#define waveOutGetErrorText WINELIB_NAME_AW(waveOutGetErrorText)
385UINT16 WINAPI waveOutOpen16(HWAVEOUT16*,UINT16,const LPWAVEFORMATEX,DWORD,DWORD,DWORD);
386UINT WINAPI waveOutOpen(HWAVEOUT*,UINT,const LPWAVEFORMATEX,DWORD,DWORD,DWORD);
387UINT16 WINAPI waveOutClose16(HWAVEOUT16);
388UINT WINAPI waveOutClose(HWAVEOUT);
389UINT16 WINAPI waveOutPrepareHeader16(HWAVEOUT16,WAVEHDR*,UINT16);
390UINT WINAPI waveOutPrepareHeader(HWAVEOUT,WAVEHDR*,UINT);
391UINT16 WINAPI waveOutUnprepareHeader16(HWAVEOUT16,WAVEHDR*,UINT16);
392UINT WINAPI waveOutUnprepareHeader(HWAVEOUT,WAVEHDR*,UINT);
393UINT16 WINAPI waveOutWrite16(HWAVEOUT16,WAVEHDR*,UINT16);
394UINT WINAPI waveOutWrite(HWAVEOUT,WAVEHDR*,UINT);
395UINT16 WINAPI waveOutPause16(HWAVEOUT16);
396UINT WINAPI waveOutPause(HWAVEOUT);
397UINT16 WINAPI waveOutRestart16(HWAVEOUT16);
398UINT WINAPI waveOutRestart(HWAVEOUT);
399UINT16 WINAPI waveOutReset16(HWAVEOUT16);
400UINT WINAPI waveOutReset(HWAVEOUT);
401UINT16 WINAPI waveOutBreakLoop16(HWAVEOUT16);
402UINT WINAPI waveOutBreakLoop(HWAVEOUT);
403UINT16 WINAPI waveOutGetPosition16(HWAVEOUT16,LPMMTIME16,UINT16);
404UINT WINAPI waveOutGetPosition(HWAVEOUT,LPMMTIME,UINT);
405UINT16 WINAPI waveOutGetPitch16(HWAVEOUT16,DWORD*);
406UINT WINAPI waveOutGetPitch(HWAVEOUT,DWORD*);
407UINT16 WINAPI waveOutSetPitch16(HWAVEOUT16,DWORD);
408UINT WINAPI waveOutSetPitch(HWAVEOUT,DWORD);
409UINT16 WINAPI waveOutGetPlaybackRate16(HWAVEOUT16,DWORD*);
410UINT WINAPI waveOutGetPlaybackRate(HWAVEOUT,DWORD*);
411UINT16 WINAPI waveOutSetPlaybackRate16(HWAVEOUT16,DWORD);
412UINT WINAPI waveOutSetPlaybackRate(HWAVEOUT,DWORD);
413UINT16 WINAPI waveOutGetID16(HWAVEOUT16,UINT16*);
414UINT WINAPI waveOutGetID(HWAVEOUT,UINT*);
415UINT16 WINAPI waveOutMessage16(HWAVEOUT16,UINT16,DWORD,DWORD);
416UINT WINAPI waveOutMessage(HWAVEOUT,UINT,DWORD,DWORD);
417
418UINT16 WINAPI waveInGetNumDevs16(void);
419UINT WINAPI waveInGetNumDevs(void);
420UINT16 WINAPI waveInGetDevCaps16(UINT16,LPWAVEINCAPS16,UINT16);
421UINT WINAPI waveInGetDevCapsA(UINT,LPWAVEINCAPSA,UINT);
422UINT WINAPI waveInGetDevCapsW(UINT,LPWAVEINCAPSW,UINT);
423#define waveInGetDevCaps WINELIB_NAME_AW(waveInGetDevCaps)
424UINT16 WINAPI waveInGetErrorText16(UINT16,LPSTR,UINT16);
425UINT WINAPI waveInGetErrorTextA(UINT,LPSTR,UINT);
426UINT WINAPI waveInGetErrorTextW(UINT,LPWSTR,UINT);
427#define waveInGetErrorText WINELIB_NAME_AW(waveInGetErrorText)
428UINT16 WINAPI waveInOpen16(HWAVEIN16*,UINT16,const LPWAVEFORMAT,DWORD,DWORD,DWORD);
429UINT WINAPI waveInOpen(HWAVEIN*,UINT,const LPWAVEFORMATEX,DWORD,DWORD,DWORD);
430UINT16 WINAPI waveInClose16(HWAVEIN16);
431UINT WINAPI waveInClose(HWAVEIN);
432UINT16 WINAPI waveInPrepareHeader16(HWAVEIN16,WAVEHDR*,UINT16);
433UINT WINAPI waveInPrepareHeader(HWAVEIN,WAVEHDR*,UINT);
434UINT16 WINAPI waveInUnprepareHeader16(HWAVEIN16,WAVEHDR*,UINT16);
435UINT WINAPI waveInUnprepareHeader(HWAVEIN,WAVEHDR*,UINT);
436UINT16 WINAPI waveInAddBuffer16(HWAVEIN16,WAVEHDR*,UINT16);
437UINT WINAPI waveInAddBuffer(HWAVEIN,WAVEHDR*,UINT);
438UINT16 WINAPI waveInStart16(HWAVEIN16);
439UINT WINAPI waveInStart(HWAVEIN);
440UINT16 WINAPI waveInStop16(HWAVEIN16);
441UINT WINAPI waveInStop(HWAVEIN);
442UINT16 WINAPI waveInReset16(HWAVEIN16);
443UINT WINAPI waveInReset(HWAVEIN);
444UINT16 WINAPI waveInGetPosition16(HWAVEIN16,LPMMTIME16,UINT16);
445UINT WINAPI waveInGetPosition(HWAVEIN,LPMMTIME,UINT);
446UINT16 WINAPI waveInGetID16(HWAVEIN16,UINT16*);
447UINT WINAPI waveInGetID(HWAVEIN,UINT*);
448
449UINT16 WINAPI waveInMessage16(HWAVEIN16,UINT16,DWORD,DWORD);
450UINT WINAPI waveInMessage(HWAVEIN,UINT,DWORD,DWORD);
451
452#define MIDIERR_UNPREPARED (MIDIERR_BASE + 0) /* header not prepared */
453#define MIDIERR_STILLPLAYING (MIDIERR_BASE + 1) /* still something playing */
454#define MIDIERR_NOMAP (MIDIERR_BASE + 2) /* no current map */
455#define MIDIERR_NOTREADY (MIDIERR_BASE + 3) /* hardware is still busy */
456#define MIDIERR_NODEVICE (MIDIERR_BASE + 4) /* port no longer connected */
457#define MIDIERR_INVALIDSETUP (MIDIERR_BASE + 5) /* invalid setup */
458#define MIDIERR_LASTERROR (MIDIERR_BASE + 5) /* last error in range */
459
460typedef LPDRVCALLBACK16 LPMIDICALLBACK16;
461typedef LPDRVCALLBACK LPMIDICALLBACK;
462#define MIDIPATCHSIZE 128
463typedef WORD PATCHARRAY[MIDIPATCHSIZE];
464typedef WORD *LPPATCHARRAY;
465typedef WORD KEYARRAY[MIDIPATCHSIZE];
466typedef WORD *LPKEYARRAY;
467
468#define MIM_OPEN MM_MIM_OPEN
469#define MIM_CLOSE MM_MIM_CLOSE
470#define MIM_DATA MM_MIM_DATA
471#define MIM_LONGDATA MM_MIM_LONGDATA
472#define MIM_ERROR MM_MIM_ERROR
473#define MIM_LONGERROR MM_MIM_LONGERROR
474#define MOM_OPEN MM_MOM_OPEN
475#define MOM_CLOSE MM_MOM_CLOSE
476#define MOM_DONE MM_MOM_DONE
477
478/* device ID for MIDI mapper */
479
480#define MIDIMAPPER (-1)
481#define MIDI_MAPPER (-1)
482
483/* flags for wFlags parm of
484 midiOutCachePatches(),
485 midiOutCacheDrumPatches() */
486#define MIDI_CACHE_ALL 1
487#define MIDI_CACHE_BESTFIT 2
488#define MIDI_CACHE_QUERY 3
489#define MIDI_UNCACHE 4
490
491typedef struct {
492 WORD wMid; /* manufacturer ID */
493 WORD wPid; /* product ID */
494 MMVERSION16 vDriverVersion; /* version of the driver */
495 CHAR szPname[MAXPNAMELEN];/* product name (NULL terminated string) */
496 WORD wTechnology; /* type of device */
497 WORD wVoices; /* # of voices (internal synth only) */
498 WORD wNotes; /* max # of notes (internal synth only) */
499 WORD wChannelMask; /* channels used (internal synth only) */
500 DWORD dwSupport; /* functionality supported by driver */
501} MIDIOUTCAPS16, *LPMIDIOUTCAPS16;
502
503typedef struct {
504 WORD wMid; /* manufacturer ID */
505 WORD wPid; /* product ID */
506 MMVERSION vDriverVersion; /* version of the driver */
507 CHAR szPname[MAXPNAMELEN];/* product name (NULL terminated string) */
508 WORD wTechnology; /* type of device */
509 WORD wVoices; /* # of voices (internal synth only) */
510 WORD wNotes; /* max # of notes (internal synth only) */
511 WORD wChannelMask; /* channels used (internal synth only) */
512 DWORD dwSupport; /* functionality supported by driver */
513} MIDIOUTCAPSA, *LPMIDIOUTCAPSA;
514
515typedef struct {
516 WORD wMid; /* manufacturer ID */
517 WORD wPid; /* product ID */
518 MMVERSION vDriverVersion; /* version of the driver */
519 WCHAR szPname[MAXPNAMELEN];/* product name (NULL terminated string) */
520 WORD wTechnology; /* type of device */
521 WORD wVoices; /* # of voices (internal synth only) */
522 WORD wNotes; /* max # of notes (internal synth only) */
523 WORD wChannelMask; /* channels used (internal synth only) */
524 DWORD dwSupport; /* functionality supported by driver */
525} MIDIOUTCAPSW, *LPMIDIOUTCAPSW;
526
527DECL_WINELIB_TYPE_AW(MIDIOUTCAPS)
528DECL_WINELIB_TYPE_AW(LPMIDIOUTCAPS)
529
530#define MOD_MIDIPORT 1 /* output port */
531#define MOD_SYNTH 2 /* generic internal synth */
532#define MOD_SQSYNTH 3 /* square wave internal synth */
533#define MOD_FMSYNTH 4 /* FM internal synth */
534#define MOD_MAPPER 5 /* MIDI mapper */
535
536#define MIDICAPS_VOLUME 0x0001 /* supports volume control */
537#define MIDICAPS_LRVOLUME 0x0002 /* separate left-right volume control */
538#define MIDICAPS_CACHE 0x0004
539#define MIDICAPS_STREAM 0x0008 /* capable of supporting stream buffer */
540
541typedef struct {
542 WORD wMid; /* manufacturer ID */
543 WORD wPid; /* product ID */
544 MMVERSION16 vDriverVersion; /* version of the driver */
545 CHAR szPname[MAXPNAMELEN];/* product name (NULL terminated string) */
546 DWORD dwSupport; /* included in win95 and higher */
547} MIDIINCAPS16, *LPMIDIINCAPS16;
548
549typedef struct {
550 WORD wMid; /* manufacturer ID */
551 WORD wPid; /* product ID */
552 MMVERSION vDriverVersion; /* version of the driver */
553 CHAR szPname[MAXPNAMELEN];/* product name (NULL terminated string) */
554 DWORD dwSupport; /* included in win95 and higher */
555} MIDIINCAPSA, *LPMIDIINCAPSA;
556
557typedef struct {
558 WORD wMid; /* manufacturer ID */
559 WORD wPid; /* product ID */
560 MMVERSION vDriverVersion; /* version of the driver */
561 WCHAR szPname[MAXPNAMELEN];/* product name (NULL terminated string) */
562 DWORD dwSupport; /* included in win95 and higher */
563} MIDIINCAPSW, *LPMIDIINCAPSW;
564
565DECL_WINELIB_TYPE_AW(MIDIINCAPS)
566DECL_WINELIB_TYPE_AW(LPMIDIINCAPS)
567
568typedef struct {
569 LPSTR lpData; /* pointer to locked data block */
570 DWORD dwBufferLength; /* length of data in data block */
571 DWORD dwBytesRecorded;/* used for input only */
572 DWORD dwUser; /* for client's use */
573 DWORD dwFlags; /* assorted flags (see defines) */
574 struct midihdr_tag *lpNext; /* reserved for driver */
575 DWORD reserved; /* reserved for driver */
576} MIDIHDR16, *LPMIDIHDR16;
577
578/* It seems that Win32 has a slightly different structure than Win 16.
579 * sigh....
580 */
581typedef struct {
582 LPSTR lpData; /* pointer to locked data block */
583 DWORD dwBufferLength; /* length of data in data block */
584 DWORD dwBytesRecorded;/* used for input only */
585 DWORD dwUser; /* for client's use */
586 DWORD dwFlags; /* assorted flags (see defines) */
587 struct midihdr_tag *lpNext; /* reserved for driver */
588 DWORD reserved; /* reserved for driver */
589 DWORD dwOffset; /* offset of playback in case of
590 * MIDISTRM buffer */
591 DWORD dwReserved[4]; /* reserved for driver */
592} MIDIHDR, *LPMIDIHDR;
593
594#define MHDR_DONE 0x00000001 /* done bit */
595#define MHDR_PREPARED 0x00000002 /* set if header prepared */
596#define MHDR_INQUEUE 0x00000004 /* reserved for driver */
597#define MHDR_ISSTRM 0x00000008 /* data is sent by Stream functions */
598
599typedef struct {
600 DWORD cbStruct;
601 DWORD dwTempo;
602} MIDIPROPTEMPO, *LPMIDIPROPTEMPO;
603
604typedef struct {
605 DWORD cbStruct;
606 DWORD dwTimeDiv;
607} MIDIPROPTIMEDIV, *LPMIDIPROPTIMEDIV;
608
609#define MIDIPROP_GET 0x40000000
610#define MIDIPROP_SET 0x80000000
611#define MIDIPROP_TEMPO 0x00000002
612#define MIDIPROP_TIMEDIV 0x00000001
613
614typedef struct {
615 DWORD dwDeltaTime; /* Time, in MIDI ticks, between the previous
616 * event and the current event. */
617 DWORD dwStreamID; /* Reserved; must be zero. */
618 DWORD dwEvent; /* event => see MEVT_XXX macros */
619#ifdef __WIN32OS2__
620 DWORD dwParms[1]; /* extra pmts to dwEvent if F_LONG is set */
621#else
622 DWORD dwParms[0]; /* extra pmts to dwEvent if F_LONG is set */
623#endif
624} MIDIEVENT, *LPMIDIEVENT;
625
626#define MEVT_EVENTTYPE(x) ((BYTE) (((x)>>24)&0xFF))
627#define MEVT_EVENTPARM(x) ((DWORD) ((x)&0x00FFFFFFL))
628
629#define MEVT_F_CALLBACK 0x40000000l
630#define MEVT_F_LONG 0x80000000l
631#define MEVT_F_SHORT 0x00000000l
632#define MEVT_COMMENT ((BYTE)0x82)
633#define MEVT_LONGMSG ((BYTE)0x80)
634#define MEVT_NOP ((BYTE)0x02)
635#define MEVT_SHORTMSG ((BYTE)0x00)
636#define MEVT_TEMPO ((BYTE)0x01)
637#define MEVT_VERSION ((BYTE)0x84)
638
639UINT16 WINAPI midiOutGetNumDevs16(void);
640UINT WINAPI midiOutGetNumDevs(void);
641UINT16 WINAPI midiOutGetDevCaps16(UINT16,LPMIDIOUTCAPS16,UINT16);
642UINT WINAPI midiOutGetDevCapsA(UINT,LPMIDIOUTCAPSA,UINT);
643UINT WINAPI midiOutGetDevCapsW(UINT,LPMIDIOUTCAPSW,UINT);
644#define midiOutGetDevCaps WINELIB_NAME_AW(midiOutGetDevCaps)
645UINT16 WINAPI midiOutGetVolume16(UINT16,DWORD*);
646UINT WINAPI midiOutGetVolume(HMIDIOUT,DWORD*);
647UINT16 WINAPI midiOutSetVolume16(UINT16,DWORD);
648UINT WINAPI midiOutSetVolume(HMIDIOUT,DWORD);
649UINT16 WINAPI midiOutGetErrorText16(UINT16,LPSTR,UINT16);
650UINT WINAPI midiOutGetErrorTextA(UINT,LPSTR,UINT);
651UINT WINAPI midiOutGetErrorTextW(UINT,LPWSTR,UINT);
652#define midiOutGetErrorText WINELIB_NAME_AW(midiOutGetErrorText)
653UINT16 WINAPI midiGetErrorText(UINT16,LPSTR,UINT16);
654UINT16 WINAPI midiOutOpen16(HMIDIOUT16*,UINT16,DWORD,DWORD,DWORD);
655UINT WINAPI midiOutOpen(HMIDIOUT*,UINT,DWORD,DWORD,DWORD);
656UINT16 WINAPI midiOutClose16(HMIDIOUT16);
657UINT WINAPI midiOutClose(HMIDIOUT);
658UINT16 WINAPI midiOutPrepareHeader16(HMIDIOUT16,MIDIHDR16*,UINT16);
659UINT WINAPI midiOutPrepareHeader(HMIDIOUT,MIDIHDR*,UINT);
660UINT16 WINAPI midiOutUnprepareHeader16(HMIDIOUT16,MIDIHDR16*,UINT16);
661UINT WINAPI midiOutUnprepareHeader(HMIDIOUT,MIDIHDR*,UINT);
662UINT16 WINAPI midiOutShortMsg16(HMIDIOUT16,DWORD);
663UINT WINAPI midiOutShortMsg(HMIDIOUT,DWORD);
664UINT16 WINAPI midiOutLongMsg16(HMIDIOUT16,MIDIHDR16*,UINT16);
665UINT WINAPI midiOutLongMsg(HMIDIOUT,MIDIHDR*,UINT);
666UINT16 WINAPI midiOutReset16(HMIDIOUT16);
667UINT WINAPI midiOutReset(HMIDIOUT);
668UINT16 WINAPI midiOutCachePatches16(HMIDIOUT16,UINT16,WORD*,UINT16);
669UINT WINAPI midiOutCachePatches(HMIDIOUT,UINT,WORD*,UINT);
670UINT16 WINAPI midiOutCacheDrumPatches16(HMIDIOUT16,UINT16,WORD*,UINT16);
671UINT WINAPI midiOutCacheDrumPatches(HMIDIOUT,UINT,WORD*,UINT);
672UINT16 WINAPI midiOutGetID16(HMIDIOUT16,UINT16*);
673UINT WINAPI midiOutGetID(HMIDIOUT,UINT*);
674
675UINT16 WINAPI midiOutMessage16(HMIDIOUT16,UINT16,DWORD,DWORD);
676UINT WINAPI midiOutMessage(HMIDIOUT,UINT,DWORD,DWORD);
677
678UINT16 WINAPI midiInGetNumDevs16(void);
679UINT WINAPI midiInGetNumDevs(void);
680UINT16 WINAPI midiInGetDevCaps16(UINT16,LPMIDIINCAPS16,UINT16);
681UINT WINAPI midiInGetDevCapsA(UINT,LPMIDIINCAPSA,UINT);
682UINT WINAPI midiInGetDevCapsW(UINT,LPMIDIINCAPSW,UINT);
683#define midiInGetDevCaps WINELIB_NAME_AW(midiInGetDevCaps)
684UINT16 WINAPI midiInGetErrorText16(UINT16,LPSTR,UINT16);
685UINT WINAPI midiInGetErrorTextA(UINT,LPSTR,UINT);
686UINT WINAPI midiInGetErrorTextW(UINT,LPWSTR,UINT);
687#define midiInGetErrorText WINELIB_NAME_AW(midiInGetErrorText)
688UINT16 WINAPI midiInOpen16(HMIDIIN16*,UINT16,DWORD,DWORD,DWORD);
689UINT WINAPI midiInOpen(HMIDIIN*,UINT,DWORD,DWORD,DWORD);
690UINT16 WINAPI midiInClose16(HMIDIIN16);
691UINT WINAPI midiInClose(HMIDIIN);
692UINT16 WINAPI midiInPrepareHeader16(HMIDIIN16,MIDIHDR16*,UINT16);
693UINT WINAPI midiInPrepareHeader(HMIDIIN,MIDIHDR*,UINT);
694UINT16 WINAPI midiInUnprepareHeader16(HMIDIIN16,MIDIHDR16*,UINT16);
695UINT WINAPI midiInUnprepareHeader(HMIDIIN,MIDIHDR*,UINT);
696UINT16 WINAPI midiInAddBuffer16(HMIDIIN16,MIDIHDR16*,UINT16);
697UINT WINAPI midiInAddBuffer(HMIDIIN,MIDIHDR*,UINT);
698UINT16 WINAPI midiInStart16(HMIDIIN16);
699UINT WINAPI midiInStart(HMIDIIN);
700UINT16 WINAPI midiInStop16(HMIDIIN16);
701UINT WINAPI midiInStop(HMIDIIN);
702UINT16 WINAPI midiInReset16(HMIDIIN16);
703UINT WINAPI midiInReset(HMIDIIN);
704UINT16 WINAPI midiInGetID16(HMIDIIN16,UINT16*);
705UINT WINAPI midiInGetID(HMIDIIN,UINT*);
706UINT16 WINAPI midiInMessage16(HMIDIIN16,UINT16,DWORD,DWORD);
707UINT WINAPI midiInMessage(HMIDIIN,UINT,DWORD,DWORD);
708
709MMRESULT16 WINAPI midiStreamClose16(HMIDISTRM16 hms);
710MMRESULT WINAPI midiStreamClose(HMIDISTRM hms);
711MMRESULT WINAPI midiStreamOpen(HMIDISTRM* phms, LPUINT uDeviceID, DWORD cMidi,
712 DWORD dwCallback, DWORD dwInstance, DWORD fdwOpen);
713MMRESULT16 WINAPI midiStreamOpen16(HMIDISTRM16* phms, LPUINT16 devid, DWORD cMidi,
714 DWORD dwCallback, DWORD dwInstance, DWORD fdwOpen);
715MMRESULT16 WINAPI midiStreamOut16(HMIDISTRM16 hms, LPMIDIHDR16 lpMidiHdr, UINT16 cbMidiHdr);
716MMRESULT WINAPI midiStreamOut(HMIDISTRM hms, LPMIDIHDR lpMidiHdr, UINT cbMidiHdr);
717MMRESULT16 WINAPI midiStreamPause16(HMIDISTRM16 hms);
718MMRESULT WINAPI midiStreamPause(HMIDISTRM hms);
719MMRESULT16 WINAPI midiStreamPosition16(HMIDISTRM16 hms, LPMMTIME16 lpmmt, UINT16 cbmmt);
720MMRESULT WINAPI midiStreamPosition(HMIDISTRM hms, LPMMTIME lpmmt, UINT cbmmt);
721MMRESULT16 WINAPI midiStreamProperty16(HMIDISTRM16 hms, LPBYTE lpPropData, DWORD dwProperty);
722MMRESULT WINAPI midiStreamProperty(HMIDISTRM hms, LPBYTE lpPropData, DWORD dwProperty);
723MMRESULT16 WINAPI midiStreamRestart16(HMIDISTRM16 hms);
724MMRESULT WINAPI midiStreamRestart(HMIDISTRM hms);
725MMRESULT16 WINAPI midiStreamStop16(HMIDISTRM16 hms);
726MMRESULT WINAPI midiStreamStop(HMIDISTRM hms);
727
728#define AUX_MAPPER (-1)
729
730typedef struct {
731 WORD wMid; /* manufacturer ID */
732 WORD wPid; /* product ID */
733 MMVERSION16 vDriverVersion; /* version of the driver */
734 CHAR szPname[MAXPNAMELEN]; /* product name (NULL terminated string) */
735 WORD wTechnology; /* type of device */
736 DWORD dwSupport; /* functionality supported by driver */
737} AUXCAPS16, *LPAUXCAPS16;
738
739typedef struct {
740 WORD wMid; /* manufacturer ID */
741 WORD wPid; /* product ID */
742 MMVERSION vDriverVersion; /* version of the driver */
743 CHAR szPname[MAXPNAMELEN]; /* product name (NULL terminated string) */
744 WORD wTechnology; /* type of device */
745 WORD wReserved1; /* padding */
746 DWORD dwSupport; /* functionality supported by driver */
747} AUXCAPSA, *LPAUXCAPSA;
748
749typedef struct {
750 WORD wMid; /* manufacturer ID */
751 WORD wPid; /* product ID */
752 MMVERSION vDriverVersion; /* version of the driver */
753 WCHAR szPname[MAXPNAMELEN]; /* product name (NULL terminated string) */
754 WORD wTechnology; /* type of device */
755 WORD wReserved1; /* padding */
756 DWORD dwSupport; /* functionality supported by driver */
757} AUXCAPSW, *LPAUXCAPSW;
758
759#define AUXCAPS_CDAUDIO 1 /* audio from internal CD-ROM drive */
760#define AUXCAPS_AUXIN 2 /* audio from auxiliary input jacks */
761
762#define AUXCAPS_VOLUME 0x0001 /* supports volume control */
763#define AUXCAPS_LRVOLUME 0x0002 /* separate left-right volume control */
764
765UINT16 WINAPI auxGetNumDevs16(void);
766UINT WINAPI auxGetNumDevs(void);
767UINT16 WINAPI auxGetDevCaps16 (UINT16,LPAUXCAPS16,UINT16);
768UINT WINAPI auxGetDevCapsA(UINT,LPAUXCAPSA,UINT);
769UINT WINAPI auxGetDevCapsW(UINT,LPAUXCAPSW,UINT);
770#define auxGetDevCaps WINELIB_NAME_AW(auxGetDevCaps)
771UINT16 WINAPI auxSetVolume16(UINT16,DWORD);
772UINT WINAPI auxSetVolume(UINT,DWORD);
773
774UINT16 WINAPI auxGetVolume16(UINT16,LPDWORD);
775UINT WINAPI auxGetVolume(UINT,LPDWORD);
776
777UINT16 WINAPI auxOutMessage16(UINT16,UINT16,DWORD,DWORD);
778UINT WINAPI auxOutMessage(UINT,UINT,DWORD,DWORD);
779
780#define TIMERR_NOERROR (0) /* no error */
781#define TIMERR_NOCANDO (TIMERR_BASE+1) /* request not completed */
782#define TIMERR_STRUCT (TIMERR_BASE+33) /* time struct size */
783
784typedef void (* CALLBACK LPTIMECALLBACK16)(UINT16 uTimerID, UINT16 uMessage, DWORD dwUser, DWORD dw1, DWORD dw2);
785typedef void (* CALLBACK LPTIMECALLBACK)(UINT uTimerID, UINT uMessage, DWORD dwUser, DWORD dw1, DWORD dw2);
786
787#define TIME_ONESHOT 0x0000 /* program timer for single event */
788#define TIME_PERIODIC 0x0001 /* program for continuous periodic event */
789#define TIME_CALLBACK_FUNCTION 0x0000 /* callback is function */
790#define TIME_CALLBACK_EVENT_SET 0x0010 /* callback is event - use SetEvent */
791#define TIME_CALLBACK_EVENT_PULSE 0x0020 /* callback is event - use PulseEvent */
792
793typedef struct {
794 UINT16 wPeriodMin; /* minimum period supported */
795 UINT16 wPeriodMax; /* maximum period supported */
796} TIMECAPS16,*LPTIMECAPS16;
797
798typedef struct {
799 UINT wPeriodMin;
800 UINT wPeriodMax;
801} TIMECAPS, *LPTIMECAPS;
802
803
804MMRESULT16 WINAPI timeGetSystemTime16(LPMMTIME16,UINT16);
805MMRESULT WINAPI timeGetSystemTime(LPMMTIME,UINT);
806DWORD WINAPI timeGetTime(void); /* same for win32/win16 */
807MMRESULT16 WINAPI timeSetEvent16(UINT16,UINT16,LPTIMECALLBACK16,DWORD,UINT16);
808MMRESULT WINAPI timeSetEvent(UINT,UINT,LPTIMECALLBACK,DWORD,UINT);
809MMRESULT16 WINAPI timeKillEvent16(UINT16);
810MMRESULT WINAPI timeKillEvent(UINT);
811MMRESULT16 WINAPI timeGetDevCaps16(LPTIMECAPS16,UINT16);
812MMRESULT WINAPI timeGetDevCaps(LPTIMECAPS,UINT);
813MMRESULT16 WINAPI timeBeginPeriod16(UINT16);
814MMRESULT WINAPI timeBeginPeriod(UINT);
815MMRESULT16 WINAPI timeEndPeriod16(UINT16);
816MMRESULT WINAPI timeEndPeriod(UINT);
817
818#define JOYERR_NOERROR (0) /* no error */
819#define JOYERR_PARMS (JOYERR_BASE+5) /* bad parameters */
820#define JOYERR_NOCANDO (JOYERR_BASE+6) /* request not completed */
821#define JOYERR_UNPLUGGED (JOYERR_BASE+7) /* joystick is unplugged */
822
823/* JOYINFO, JOYINFOEX, MM_JOY* */
824#define JOY_BUTTON1 0x0001
825#define JOY_BUTTON2 0x0002
826#define JOY_BUTTON3 0x0004
827#define JOY_BUTTON4 0x0008
828#define JOY_BUTTON1CHG 0x0100
829#define JOY_BUTTON2CHG 0x0200
830#define JOY_BUTTON3CHG 0x0400
831#define JOY_BUTTON4CHG 0x0800
832
833#define JOYSTICKID1 0
834#define JOYSTICKID2 1
835
836/* JOYCAPS.wCaps */
837#define JOYCAPS_HASZ 0x0001
838#define JOYCAPS_HASR 0x0002
839#define JOYCAPS_HASU 0x0004
840#define JOYCAPS_HASV 0x0008
841#define JOYCAPS_HASPOV 0x0010
842#define JOYCAPS_POV4DIR 0x0020
843#define JOYCAPS_POVCTS 0x0040
844
845/* JOYINFOEX stuff */
846#define JOY_POVCENTERED (WORD) -1
847#define JOY_POVFORWARD 0
848#define JOY_POVRIGHT 9000
849#define JOY_POVBACKWARD 18000
850#define JOY_POVLEFT 27000
851
852#define JOY_RETURNX 0x00000001
853#define JOY_RETURNY 0x00000002
854#define JOY_RETURNZ 0x00000004
855#define JOY_RETURNR 0x00000008
856#define JOY_RETURNU 0x00000010
857#define JOY_RETURNV 0x00000020
858#define JOY_RETURNPOV 0x00000040
859#define JOY_RETURNBUTTONS 0x00000080
860#define JOY_RETURNRAWDATA 0x00000100
861#define JOY_RETURNPOVCTS 0x00000200
862#define JOY_RETURNCENTERED 0x00000400
863#define JOY_USEDEADZONE 0x00000800
864#define JOY_RETURNALL (JOY_RETURNX | JOY_RETURNY | JOY_RETURNZ | \
865 JOY_RETURNR | JOY_RETURNU | JOY_RETURNV | \
866 JOY_RETURNPOV | JOY_RETURNBUTTONS)
867#define JOY_CAL_READALWAYS 0x00010000
868#define JOY_CAL_READXYONLY 0x00020000
869#define JOY_CAL_READ3 0x00040000
870#define JOY_CAL_READ4 0x00080000
871#define JOY_CAL_READXONLY 0x00100000
872#define JOY_CAL_READYONLY 0x00200000
873#define JOY_CAL_READ5 0x00400000
874#define JOY_CAL_READ6 0x00800000
875#define JOY_CAL_READZONLY 0x01000000
876#define JOY_CAL_READRONLY 0x02000000
877#define JOY_CAL_READUONLY 0x04000000
878#define JOY_CAL_READVONLY 0x08000000
879
880typedef struct {
881 WORD wMid; /* manufacturer ID */
882 WORD wPid; /* product ID */
883 char szPname[MAXPNAMELEN]; /* product name (NULL terminated string) */
884 UINT16 wXmin; /* minimum x position value */
885 UINT16 wXmax; /* maximum x position value */
886 UINT16 wYmin; /* minimum y position value */
887 UINT16 wYmax; /* maximum y position value */
888 UINT16 wZmin; /* minimum z position value */
889 UINT16 wZmax; /* maximum z position value */
890 UINT16 wNumButtons; /* number of buttons */
891 UINT16 wPeriodMin; /* minimum message period when captured */
892 UINT16 wPeriodMax; /* maximum message period when captured */
893 /* win95,nt4 additions: */
894 UINT16 wRmin; /* minimum r position value */
895 UINT16 wRmax; /* maximum r position value */
896 UINT16 wUmin; /* minimum u (5th axis) position value */
897 UINT16 wUmax; /* maximum u (5th axis) position value */
898 UINT16 wVmin; /* minimum v (6th axis) position value */
899 UINT16 wVmax; /* maximum v (6th axis) position value */
900 UINT16 wCaps; /* joystick capabilites */
901 UINT16 wMaxAxes; /* maximum number of axes supported */
902 UINT16 wNumAxes; /* number of axes in use */
903 UINT16 wMaxButtons; /* maximum number of buttons supported */
904 CHAR szRegKey[MAXPNAMELEN]; /* registry key */
905 CHAR szOEMVxD[MAX_JOYSTICKOEMVXDNAME]; /* OEM VxD in use */
906} JOYCAPS16, *LPJOYCAPS16;
907
908typedef struct {
909 WORD wMid;
910 WORD wPid;
911 CHAR szPname[MAXPNAMELEN];
912 UINT wXmin;
913 UINT wXmax;
914 UINT wYmin;
915 UINT wYmax;
916 UINT wZmin;
917 UINT wZmax;
918 UINT wNumButtons;
919 UINT wPeriodMin;
920 UINT wPeriodMax;
921 UINT wRmin;
922 UINT wRmax;
923 UINT wUmin;
924 UINT wUmax;
925 UINT wVmin;
926 UINT wVmax;
927 UINT wCaps;
928 UINT wMaxAxes;
929 UINT wNumAxes;
930 UINT wMaxButtons;
931 CHAR szRegKey[MAXPNAMELEN];
932 CHAR szOEMVxD[MAX_JOYSTICKOEMVXDNAME];
933} JOYCAPSA, *LPJOYCAPSA;
934
935typedef struct {
936 WORD wMid;
937 WORD wPid;
938 WCHAR szPname[MAXPNAMELEN];
939 UINT wXmin;
940 UINT wXmax;
941 UINT wYmin;
942 UINT wYmax;
943 UINT wZmin;
944 UINT wZmax;
945 UINT wNumButtons;
946 UINT wPeriodMin;
947 UINT wPeriodMax;
948 UINT wRmin;
949 UINT wRmax;
950 UINT wUmin;
951 UINT wUmax;
952 UINT wVmin;
953 UINT wVmax;
954 UINT wCaps;
955 UINT wMaxAxes;
956 UINT wNumAxes;
957 UINT wMaxButtons;
958 WCHAR szRegKey[MAXPNAMELEN];
959 WCHAR szOEMVxD[MAX_JOYSTICKOEMVXDNAME];
960} JOYCAPSW, *LPJOYCAPSW;
961DECL_WINELIB_TYPE_AW(JOYCAPS)
962DECL_WINELIB_TYPE_AW(LPJOYCAPS)
963
964typedef struct {
965 UINT16 wXpos; /* x position */
966 UINT16 wYpos; /* y position */
967 UINT16 wZpos; /* z position */
968 UINT16 wButtons; /* button states */
969} JOYINFO16, *LPJOYINFO16;
970
971typedef struct {
972 UINT wXpos;
973 UINT wYpos;
974 UINT wZpos;
975 UINT wButtons;
976} JOYINFO, *LPJOYINFO;
977
978typedef struct {
979 DWORD dwSize; /* size of structure */
980 DWORD dwFlags; /* flags to indicate what to return */
981 DWORD dwXpos; /* x position */
982 DWORD dwYpos; /* y position */
983 DWORD dwZpos; /* z position */
984 DWORD dwRpos; /* rudder/4th axis position */
985 DWORD dwUpos; /* 5th axis position */
986 DWORD dwVpos; /* 6th axis position */
987 DWORD dwButtons; /* button states */
988 DWORD dwButtonNumber; /* current button number pressed */
989 DWORD dwPOV; /* point of view state */
990 DWORD dwReserved1; /* reserved for communication between winmm & driver */
991 DWORD dwReserved2; /* reserved for future expansion */
992} JOYINFOEX,*LPJOYINFOEX;
993
994
995MMRESULT16 WINAPI joyGetDevCaps16 (UINT16,LPJOYCAPS16 ,UINT16);
996MMRESULT WINAPI joyGetDevCapsA(UINT,LPJOYCAPSA,UINT);
997MMRESULT WINAPI joyGetDevCapsW(UINT,LPJOYCAPSW,UINT);
998#define joyGetDevCaps WINELIB_NAME_AW(joyGetDevCaps)
999UINT16 WINAPI joyGetNumDevs16(void);
1000UINT WINAPI joyGetNumDevs(void);
1001MMRESULT16 WINAPI joyGetPos16(UINT16,LPJOYINFO16);
1002MMRESULT WINAPI joyGetPos(UINT,LPJOYINFO);
1003MMRESULT WINAPI joyGetPosEx(UINT,LPJOYINFOEX);
1004MMRESULT16 WINAPI joyGetThreshold16(UINT16,UINT16*);
1005MMRESULT WINAPI joyGetThreshold(UINT,UINT*);
1006MMRESULT16 WINAPI joyReleaseCapture16(UINT16);
1007MMRESULT WINAPI joyReleaseCapture(UINT);
1008MMRESULT16 WINAPI joySetCapture16(HWND16,UINT16,UINT16,BOOL16);
1009MMRESULT WINAPI joySetCapture(HWND,UINT,UINT,BOOL);
1010MMRESULT16 WINAPI joySetThreshold16(UINT16,UINT16);
1011MMRESULT WINAPI joySetThreshold(UINT,UINT);
1012
1013#define MIXERR_BASE 1024
1014#define MIXERR_INVALLINE (MIXERR_BASE + 0)
1015#define MIXERR_INVALCONTROL (MIXERR_BASE + 1)
1016#define MIXERR_INVALVALUE (MIXERR_BASE + 2)
1017#define MIXERR_LASTERROR (MIXERR_BASE + 2)
1018
1019typedef struct {
1020 WORD wMid; /* manufacturer id */
1021 WORD wPid; /* product id */
1022 MMVERSION16 vDriverVersion; /* version of the driver */
1023 CHAR szPname[MAXPNAMELEN]; /* product name */
1024 DWORD fdwSupport; /* misc. support bits */
1025 DWORD cDestinations; /* count of destinations */
1026} MIXERCAPS16,*LPMIXERCAPS16;
1027
1028typedef struct {
1029 WORD wMid;
1030 WORD wPid;
1031 MMVERSION vDriverVersion;
1032 CHAR szPname[MAXPNAMELEN];
1033 DWORD fdwSupport;
1034 DWORD cDestinations;
1035} MIXERCAPSA,*LPMIXERCAPSA;
1036
1037typedef struct {
1038 WORD wMid;
1039 WORD wPid;
1040 MMVERSION vDriverVersion;
1041 WCHAR szPname[MAXPNAMELEN];
1042 DWORD fdwSupport;
1043 DWORD cDestinations;
1044} MIXERCAPSW,*LPMIXERCAPSW;
1045
1046DECL_WINELIB_TYPE_AW(MIXERCAPS)
1047DECL_WINELIB_TYPE_AW(LPMIXERCAPS)
1048
1049#define MIXER_SHORT_NAME_CHARS 16
1050#define MIXER_LONG_NAME_CHARS 64
1051
1052/* MIXERLINE.fdwLine */
1053#define MIXERLINE_LINEF_ACTIVE 0x00000001
1054#define MIXERLINE_LINEF_DISCONNECTED 0x00008000
1055#define MIXERLINE_LINEF_SOURCE 0x80000000
1056
1057/* MIXERLINE.dwComponentType */
1058/* component types for destinations and sources */
1059#define MIXERLINE_COMPONENTTYPE_DST_FIRST 0x00000000L
1060#define MIXERLINE_COMPONENTTYPE_DST_UNDEFINED (MIXERLINE_COMPONENTTYPE_DST_FIRST + 0)
1061#define MIXERLINE_COMPONENTTYPE_DST_DIGITAL (MIXERLINE_COMPONENTTYPE_DST_FIRST + 1)
1062#define MIXERLINE_COMPONENTTYPE_DST_LINE (MIXERLINE_COMPONENTTYPE_DST_FIRST + 2)
1063#define MIXERLINE_COMPONENTTYPE_DST_MONITOR (MIXERLINE_COMPONENTTYPE_DST_FIRST + 3)
1064#define MIXERLINE_COMPONENTTYPE_DST_SPEAKERS (MIXERLINE_COMPONENTTYPE_DST_FIRST + 4)
1065#define MIXERLINE_COMPONENTTYPE_DST_HEADPHONES (MIXERLINE_COMPONENTTYPE_DST_FIRST + 5)
1066#define MIXERLINE_COMPONENTTYPE_DST_TELEPHONE (MIXERLINE_COMPONENTTYPE_DST_FIRST + 6)
1067#define MIXERLINE_COMPONENTTYPE_DST_WAVEIN (MIXERLINE_COMPONENTTYPE_DST_FIRST + 7)
1068#define MIXERLINE_COMPONENTTYPE_DST_VOICEIN (MIXERLINE_COMPONENTTYPE_DST_FIRST + 8)
1069#define MIXERLINE_COMPONENTTYPE_DST_LAST (MIXERLINE_COMPONENTTYPE_DST_FIRST + 8)
1070
1071#define MIXERLINE_COMPONENTTYPE_SRC_FIRST 0x00001000L
1072#define MIXERLINE_COMPONENTTYPE_SRC_UNDEFINED (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 0)
1073#define MIXERLINE_COMPONENTTYPE_SRC_DIGITAL (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 1)
1074#define MIXERLINE_COMPONENTTYPE_SRC_LINE (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 2)
1075#define MIXERLINE_COMPONENTTYPE_SRC_MICROPHONE (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 3)
1076#define MIXERLINE_COMPONENTTYPE_SRC_SYNTHESIZER (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 4)
1077#define MIXERLINE_COMPONENTTYPE_SRC_COMPACTDISC (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 5)
1078#define MIXERLINE_COMPONENTTYPE_SRC_TELEPHONE (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 6)
1079#define MIXERLINE_COMPONENTTYPE_SRC_PCSPEAKER (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 7)
1080#define MIXERLINE_COMPONENTTYPE_SRC_WAVEOUT (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 8)
1081#define MIXERLINE_COMPONENTTYPE_SRC_AUXILIARY (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 9)
1082#define MIXERLINE_COMPONENTTYPE_SRC_ANALOG (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 10)
1083#define MIXERLINE_COMPONENTTYPE_SRC_LAST (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 10)
1084
1085/* MIXERLINE.Target.dwType */
1086#define MIXERLINE_TARGETTYPE_UNDEFINED 0
1087#define MIXERLINE_TARGETTYPE_WAVEOUT 1
1088#define MIXERLINE_TARGETTYPE_WAVEIN 2
1089#define MIXERLINE_TARGETTYPE_MIDIOUT 3
1090#define MIXERLINE_TARGETTYPE_MIDIIN 4
1091#define MIXERLINE_TARGETTYPE_AUX 5
1092
1093typedef struct {
1094 DWORD cbStruct; /* size of MIXERLINE structure */
1095 DWORD dwDestination; /* zero based destination index */
1096 DWORD dwSource; /* zero based source index (if source) */
1097 DWORD dwLineID; /* unique line id for mixer device */
1098 DWORD fdwLine; /* state/information about line */
1099 DWORD dwUser; /* driver specific information */
1100 DWORD dwComponentType; /* component type line connects to */
1101 DWORD cChannels; /* number of channels line supports */
1102 DWORD cConnections; /* number of connections [possible] */
1103 DWORD cControls; /* number of controls at this line */
1104 CHAR szShortName[MIXER_SHORT_NAME_CHARS];
1105 CHAR szName[MIXER_LONG_NAME_CHARS];
1106 struct {
1107 DWORD dwType; /* MIXERLINE_TARGETTYPE_xxxx */
1108 DWORD dwDeviceID; /* target device ID of device type */
1109 WORD wMid; /* of target device */
1110 WORD wPid; /* " */
1111 MMVERSION16 vDriverVersion; /* " */
1112 CHAR szPname[MAXPNAMELEN]; /* " */
1113 } Target;
1114} MIXERLINE16, *LPMIXERLINE16;
1115
1116typedef struct {
1117 DWORD cbStruct;
1118 DWORD dwDestination;
1119 DWORD dwSource;
1120 DWORD dwLineID;
1121 DWORD fdwLine;
1122 DWORD dwUser;
1123 DWORD dwComponentType;
1124 DWORD cChannels;
1125 DWORD cConnections;
1126 DWORD cControls;
1127 CHAR szShortName[MIXER_SHORT_NAME_CHARS];
1128 CHAR szName[MIXER_LONG_NAME_CHARS];
1129 struct {
1130 DWORD dwType;
1131 DWORD dwDeviceID;
1132 WORD wMid;
1133 WORD wPid;
1134 MMVERSION vDriverVersion;
1135 CHAR szPname[MAXPNAMELEN];
1136 } Target;
1137} MIXERLINEA, *LPMIXERLINEA;
1138
1139typedef struct {
1140 DWORD cbStruct;
1141 DWORD dwDestination;
1142 DWORD dwSource;
1143 DWORD dwLineID;
1144 DWORD fdwLine;
1145 DWORD dwUser;
1146 DWORD dwComponentType;
1147 DWORD cChannels;
1148 DWORD cConnections;
1149 DWORD cControls;
1150 WCHAR szShortName[MIXER_SHORT_NAME_CHARS];
1151 WCHAR szName[MIXER_LONG_NAME_CHARS];
1152 struct {
1153 DWORD dwType;
1154 DWORD dwDeviceID;
1155 WORD wMid;
1156 WORD wPid;
1157 MMVERSION vDriverVersion;
1158 WCHAR szPname[MAXPNAMELEN];
1159 } Target;
1160} MIXERLINEW, *LPMIXERLINEW;
1161
1162DECL_WINELIB_TYPE_AW(MIXERLINE)
1163DECL_WINELIB_TYPE_AW(LPMIXERLINE)
1164
1165/* MIXERCONTROL.fdwControl */
1166#define MIXERCONTROL_CONTROLF_UNIFORM 0x00000001L
1167#define MIXERCONTROL_CONTROLF_MULTIPLE 0x00000002L
1168#define MIXERCONTROL_CONTROLF_DISABLED 0x80000000L
1169
1170/* MIXERCONTROL_CONTROLTYPE_xxx building block defines */
1171#define MIXERCONTROL_CT_CLASS_MASK 0xF0000000L
1172#define MIXERCONTROL_CT_CLASS_CUSTOM 0x00000000L
1173#define MIXERCONTROL_CT_CLASS_METER 0x10000000L
1174#define MIXERCONTROL_CT_CLASS_SWITCH 0x20000000L
1175#define MIXERCONTROL_CT_CLASS_NUMBER 0x30000000L
1176#define MIXERCONTROL_CT_CLASS_SLIDER 0x40000000L
1177#define MIXERCONTROL_CT_CLASS_FADER 0x50000000L
1178#define MIXERCONTROL_CT_CLASS_TIME 0x60000000L
1179#define MIXERCONTROL_CT_CLASS_LIST 0x70000000L
1180
1181#define MIXERCONTROL_CT_SUBCLASS_MASK 0x0F000000L
1182
1183#define MIXERCONTROL_CT_SC_SWITCH_BOOLEAN 0x00000000L
1184#define MIXERCONTROL_CT_SC_SWITCH_BUTTON 0x01000000L
1185
1186#define MIXERCONTROL_CT_SC_METER_POLLED 0x00000000L
1187
1188#define MIXERCONTROL_CT_SC_TIME_MICROSECS 0x00000000L
1189#define MIXERCONTROL_CT_SC_TIME_MILLISECS 0x01000000L
1190
1191#define MIXERCONTROL_CT_SC_LIST_SINGLE 0x00000000L
1192#define MIXERCONTROL_CT_SC_LIST_MULTIPLE 0x01000000L
1193
1194#define MIXERCONTROL_CT_UNITS_MASK 0x00FF0000L
1195#define MIXERCONTROL_CT_UNITS_CUSTOM 0x00000000L
1196#define MIXERCONTROL_CT_UNITS_BOOLEAN 0x00010000L
1197#define MIXERCONTROL_CT_UNITS_SIGNED 0x00020000L
1198#define MIXERCONTROL_CT_UNITS_UNSIGNED 0x00030000L
1199#define MIXERCONTROL_CT_UNITS_DECIBELS 0x00040000L /* in 10ths */
1200#define MIXERCONTROL_CT_UNITS_PERCENT 0x00050000L /* in 10ths */
1201
1202/* Commonly used control types for specifying MIXERCONTROL.dwControlType */
1203#define MIXERCONTROL_CONTROLTYPE_CUSTOM (MIXERCONTROL_CT_CLASS_CUSTOM | MIXERCONTROL_CT_UNITS_CUSTOM)
1204#define MIXERCONTROL_CONTROLTYPE_BOOLEANMETER (MIXERCONTROL_CT_CLASS_METER | MIXERCONTROL_CT_SC_METER_POLLED | MIXERCONTROL_CT_UNITS_BOOLEAN)
1205#define MIXERCONTROL_CONTROLTYPE_SIGNEDMETER (MIXERCONTROL_CT_CLASS_METER | MIXERCONTROL_CT_SC_METER_POLLED | MIXERCONTROL_CT_UNITS_SIGNED)
1206#define MIXERCONTROL_CONTROLTYPE_PEAKMETER (MIXERCONTROL_CONTROLTYPE_SIGNEDMETER + 1)
1207#define MIXERCONTROL_CONTROLTYPE_UNSIGNEDMETER (MIXERCONTROL_CT_CLASS_METER | MIXERCONTROL_CT_SC_METER_POLLED | MIXERCONTROL_CT_UNITS_UNSIGNED)
1208#define MIXERCONTROL_CONTROLTYPE_BOOLEAN (MIXERCONTROL_CT_CLASS_SWITCH | MIXERCONTROL_CT_SC_SWITCH_BOOLEAN | MIXERCONTROL_CT_UNITS_BOOLEAN)
1209#define MIXERCONTROL_CONTROLTYPE_ONOFF (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 1)
1210#define MIXERCONTROL_CONTROLTYPE_MUTE (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 2)
1211#define MIXERCONTROL_CONTROLTYPE_MONO (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 3)
1212#define MIXERCONTROL_CONTROLTYPE_LOUDNESS (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 4)
1213#define MIXERCONTROL_CONTROLTYPE_STEREOENH (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 5)
1214#define MIXERCONTROL_CONTROLTYPE_BUTTON (MIXERCONTROL_CT_CLASS_SWITCH | MIXERCONTROL_CT_SC_SWITCH_BUTTON | MIXERCONTROL_CT_UNITS_BOOLEAN)
1215#define MIXERCONTROL_CONTROLTYPE_DECIBELS (MIXERCONTROL_CT_CLASS_NUMBER | MIXERCONTROL_CT_UNITS_DECIBELS)
1216#define MIXERCONTROL_CONTROLTYPE_SIGNED (MIXERCONTROL_CT_CLASS_NUMBER | MIXERCONTROL_CT_UNITS_SIGNED)
1217#define MIXERCONTROL_CONTROLTYPE_UNSIGNED (MIXERCONTROL_CT_CLASS_NUMBER | MIXERCONTROL_CT_UNITS_UNSIGNED)
1218#define MIXERCONTROL_CONTROLTYPE_PERCENT (MIXERCONTROL_CT_CLASS_NUMBER | MIXERCONTROL_CT_UNITS_PERCENT)
1219#define MIXERCONTROL_CONTROLTYPE_SLIDER (MIXERCONTROL_CT_CLASS_SLIDER | MIXERCONTROL_CT_UNITS_SIGNED)
1220#define MIXERCONTROL_CONTROLTYPE_PAN (MIXERCONTROL_CONTROLTYPE_SLIDER + 1)
1221#define MIXERCONTROL_CONTROLTYPE_QSOUNDPAN (MIXERCONTROL_CONTROLTYPE_SLIDER + 2)
1222#define MIXERCONTROL_CONTROLTYPE_FADER (MIXERCONTROL_CT_CLASS_FADER | MIXERCONTROL_CT_UNITS_UNSIGNED)
1223#define MIXERCONTROL_CONTROLTYPE_VOLUME (MIXERCONTROL_CONTROLTYPE_FADER + 1)
1224#define MIXERCONTROL_CONTROLTYPE_BASS (MIXERCONTROL_CONTROLTYPE_FADER + 2)
1225#define MIXERCONTROL_CONTROLTYPE_TREBLE (MIXERCONTROL_CONTROLTYPE_FADER + 3)
1226#define MIXERCONTROL_CONTROLTYPE_EQUALIZER (MIXERCONTROL_CONTROLTYPE_FADER + 4)
1227#define MIXERCONTROL_CONTROLTYPE_SINGLESELECT (MIXERCONTROL_CT_CLASS_LIST | MIXERCONTROL_CT_SC_LIST_SINGLE | MIXERCONTROL_CT_UNITS_BOOLEAN)
1228#define MIXERCONTROL_CONTROLTYPE_MUX (MIXERCONTROL_CONTROLTYPE_SINGLESELECT + 1)
1229#define MIXERCONTROL_CONTROLTYPE_MULTIPLESELECT (MIXERCONTROL_CT_CLASS_LIST | MIXERCONTROL_CT_SC_LIST_MULTIPLE | MIXERCONTROL_CT_UNITS_BOOLEAN)
1230#define MIXERCONTROL_CONTROLTYPE_MIXER (MIXERCONTROL_CONTROLTYPE_MULTIPLESELECT + 1)
1231#define MIXERCONTROL_CONTROLTYPE_MICROTIME (MIXERCONTROL_CT_CLASS_TIME | MIXERCONTROL_CT_SC_TIME_MICROSECS | MIXERCONTROL_CT_UNITS_UNSIGNED)
1232#define MIXERCONTROL_CONTROLTYPE_MILLITIME (MIXERCONTROL_CT_CLASS_TIME | MIXERCONTROL_CT_SC_TIME_MILLISECS | MIXERCONTROL_CT_UNITS_UNSIGNED)
1233
1234
1235typedef struct {
1236 DWORD cbStruct; /* size in bytes of MIXERCONTROL */
1237 DWORD dwControlID; /* unique control id for mixer device */
1238 DWORD dwControlType; /* MIXERCONTROL_CONTROLTYPE_xxx */
1239 DWORD fdwControl; /* MIXERCONTROL_CONTROLF_xxx */
1240 DWORD cMultipleItems; /* if MIXERCONTROL_CONTROLF_MULTIPLE set */
1241 CHAR szShortName[MIXER_SHORT_NAME_CHARS];
1242 CHAR szName[MIXER_LONG_NAME_CHARS];
1243 union {
1244 struct {
1245 LONG lMinimum; /* signed minimum for this control */
1246 LONG lMaximum; /* signed maximum for this control */
1247 } l;
1248 struct {
1249 DWORD dwMinimum; /* unsigned minimum for this control */
1250 DWORD dwMaximum; /* unsigned maximum for this control */
1251 } dw;
1252 DWORD dwReserved[6];
1253 } Bounds;
1254 union {
1255 DWORD cSteps; /* # of steps between min & max */
1256 DWORD cbCustomData; /* size in bytes of custom data */
1257 DWORD dwReserved[6]; /* !!! needed? we have cbStruct.... */
1258 } Metrics;
1259} MIXERCONTROL16, *LPMIXERCONTROL16;
1260
1261typedef struct {
1262 DWORD cbStruct;
1263 DWORD dwControlID;
1264 DWORD dwControlType;
1265 DWORD fdwControl;
1266 DWORD cMultipleItems;
1267 CHAR szShortName[MIXER_SHORT_NAME_CHARS];
1268 CHAR szName[MIXER_LONG_NAME_CHARS];
1269 union {
1270 struct {
1271 LONG lMinimum;
1272 LONG lMaximum;
1273 } l;
1274 struct {
1275 DWORD dwMinimum;
1276 DWORD dwMaximum;
1277 } dw;
1278 DWORD dwReserved[6];
1279 } Bounds;
1280 union {
1281 DWORD cSteps;
1282 DWORD cbCustomData;
1283 DWORD dwReserved[6];
1284 } Metrics;
1285} MIXERCONTROLA, *LPMIXERCONTROLA;
1286
1287typedef struct {
1288 DWORD cbStruct;
1289 DWORD dwControlID;
1290 DWORD dwControlType;
1291 DWORD fdwControl;
1292 DWORD cMultipleItems;
1293 WCHAR szShortName[MIXER_SHORT_NAME_CHARS];
1294 WCHAR szName[MIXER_LONG_NAME_CHARS];
1295 union {
1296 struct {
1297 LONG lMinimum;
1298 LONG lMaximum;
1299 } l;
1300 struct {
1301 DWORD dwMinimum;
1302 DWORD dwMaximum;
1303 } dw;
1304 DWORD dwReserved[6];
1305 } Bounds;
1306 union {
1307 DWORD cSteps;
1308 DWORD cbCustomData;
1309 DWORD dwReserved[6];
1310 } Metrics;
1311} MIXERCONTROLW, *LPMIXERCONTROLW;
1312
1313DECL_WINELIB_TYPE_AW(MIXERCONTROL)
1314DECL_WINELIB_TYPE_AW(LPMIXERCONTROL)
1315
1316typedef struct {
1317 DWORD cbStruct; /* size in bytes of MIXERLINECONTROLS */
1318 DWORD dwLineID; /* line id (from MIXERLINE.dwLineID) */
1319 union {
1320 DWORD dwControlID; /* MIXER_GETLINECONTROLSF_ONEBYID */
1321 DWORD dwControlType; /* MIXER_GETLINECONTROLSF_ONEBYTYPE */
1322 } u;
1323 DWORD cControls; /* count of controls pmxctrl points to */
1324 DWORD cbmxctrl; /* size in bytes of _one_ MIXERCONTROL */
1325 LPMIXERCONTROL16 pamxctrl;/* pointer to first MIXERCONTROL array */
1326} MIXERLINECONTROLS16, *LPMIXERLINECONTROLS16;
1327
1328typedef struct {
1329 DWORD cbStruct;
1330 DWORD dwLineID;
1331 union {
1332 DWORD dwControlID;
1333 DWORD dwControlType;
1334 } u;
1335 DWORD cControls;
1336 DWORD cbmxctrl;
1337 LPMIXERCONTROLA pamxctrl;
1338} MIXERLINECONTROLSA, *LPMIXERLINECONTROLSA;
1339
1340typedef struct {
1341 DWORD cbStruct;
1342 DWORD dwLineID;
1343 union {
1344 DWORD dwControlID;
1345 DWORD dwControlType;
1346 } u;
1347 DWORD cControls;
1348 DWORD cbmxctrl;
1349 LPMIXERCONTROLW pamxctrl;
1350} MIXERLINECONTROLSW, *LPMIXERLINECONTROLSW;
1351
1352DECL_WINELIB_TYPE_AW(MIXERLINECONTROLS)
1353DECL_WINELIB_TYPE_AW(LPMIXERLINECONTROLS)
1354
1355typedef struct {
1356 DWORD cbStruct; /* size in bytes of MIXERCONTROLDETAILS */
1357 DWORD dwControlID; /* control id to get/set details on */
1358 DWORD cChannels; /* number of channels in paDetails array */
1359 union {
1360 HWND16 hwndOwner; /* for MIXER_SETCONTROLDETAILSF_CUSTOM */
1361 DWORD cMultipleItems; /* if _MULTIPLE, the number of items per channel */
1362 } u;
1363 DWORD cbDetails; /* size of _one_ details_XX struct */
1364 LPVOID paDetails; /* pointer to array of details_XX structs */
1365} MIXERCONTROLDETAILS16,*LPMIXERCONTROLDETAILS16;
1366
1367typedef struct {
1368 DWORD cbStruct;
1369 DWORD dwControlID;
1370 DWORD cChannels;
1371 union {
1372 HWND hwndOwner;
1373 DWORD cMultipleItems;
1374 } u;
1375 DWORD cbDetails;
1376 LPVOID paDetails;
1377} MIXERCONTROLDETAILS,*LPMIXERCONTROLDETAILS;
1378
1379
1380typedef struct {
1381 DWORD dwParam1;
1382 DWORD dwParam2;
1383 CHAR szName[MIXER_LONG_NAME_CHARS];
1384} MIXERCONTROLDETAILS_LISTTEXT16,*LPMIXERCONTROLDETAILS_LISTTEXT16;
1385
1386typedef struct {
1387 DWORD dwParam1;
1388 DWORD dwParam2;
1389 CHAR szName[MIXER_LONG_NAME_CHARS];
1390} MIXERCONTROLDETAILS_LISTTEXTA,*LPMIXERCONTROLDETAILS_LISTTEXTA;
1391
1392typedef struct {
1393 DWORD dwParam1;
1394 DWORD dwParam2;
1395 WCHAR szName[MIXER_LONG_NAME_CHARS];
1396} MIXERCONTROLDETAILS_LISTTEXTW,*LPMIXERCONTROLDETAILS_LISTTEXTW;
1397
1398DECL_WINELIB_TYPE_AW(MIXERCONTROLDETAILS_LISTTEXT)
1399DECL_WINELIB_TYPE_AW(LPMIXERCONTROLDETAILS_LISTTEXT)
1400
1401/* MIXER_GETCONTROLDETAILSF_VALUE */
1402typedef struct {
1403 LONG fValue;
1404} MIXERCONTROLDETAILS_BOOLEAN,*LPMIXERCONTROLDETAILS_BOOLEAN;
1405
1406typedef struct {
1407 LONG lValue;
1408} MIXERCONTROLDETAILS_SIGNED,*LPMIXERCONTROLDETAILS_SIGNED;
1409
1410typedef struct {
1411 DWORD dwValue;
1412} MIXERCONTROLDETAILS_UNSIGNED,*LPMIXERCONTROLDETAILS_UNSIGNED;
1413
1414/* bits passed to mixerGetLineInfo.fdwInfo */
1415#define MIXER_GETLINEINFOF_DESTINATION 0x00000000L
1416#define MIXER_GETLINEINFOF_SOURCE 0x00000001L
1417#define MIXER_GETLINEINFOF_LINEID 0x00000002L
1418#define MIXER_GETLINEINFOF_COMPONENTTYPE 0x00000003L
1419#define MIXER_GETLINEINFOF_TARGETTYPE 0x00000004L
1420#define MIXER_GETLINEINFOF_QUERYMASK 0x0000000FL
1421
1422/* bitmask passed to mixerGetLineControl */
1423#define MIXER_GETLINECONTROLSF_ALL 0x00000000L
1424#define MIXER_GETLINECONTROLSF_ONEBYID 0x00000001L
1425#define MIXER_GETLINECONTROLSF_ONEBYTYPE 0x00000002L
1426#define MIXER_GETLINECONTROLSF_QUERYMASK 0x0000000FL
1427
1428/* bitmask passed to mixerGetControlDetails */
1429#define MIXER_GETCONTROLDETAILSF_VALUE 0x00000000L
1430#define MIXER_GETCONTROLDETAILSF_LISTTEXT 0x00000001L
1431#define MIXER_GETCONTROLDETAILSF_QUERYMASK 0x0000000FL
1432
1433/* bitmask passed to mixerSetControlDetails */
1434#define MIXER_SETCONTROLDETAILSF_VALUE 0x00000000L
1435#define MIXER_SETCONTROLDETAILSF_CUSTOM 0x00000001L
1436#define MIXER_SETCONTROLDETAILSF_QUERYMASK 0x0000000FL
1437
1438UINT16 WINAPI mixerGetNumDevs16(void);
1439UINT WINAPI mixerGetNumDevs(void);
1440UINT16 WINAPI mixerOpen16(LPHMIXER16,UINT16,DWORD,DWORD,DWORD);
1441UINT WINAPI mixerOpen(LPHMIXER,UINT,DWORD,DWORD,DWORD);
1442UINT16 WINAPI mixerClose16(HMIXER16);
1443UINT WINAPI mixerClose(HMIXER);
1444UINT16 WINAPI mixerMessage16(HMIXER16,UINT16,DWORD,DWORD);
1445UINT WINAPI mixerMessage(HMIXER,UINT,DWORD,DWORD);
1446UINT16 WINAPI mixerGetDevCaps16(UINT16,LPMIXERCAPS16,UINT16);
1447UINT WINAPI mixerGetDevCapsA(UINT,LPMIXERCAPSA,UINT);
1448UINT WINAPI mixerGetDevCapsW(UINT,LPMIXERCAPSW,UINT);
1449#define mixerGetDevCaps WINELIB_NAME_AW(mixerGetDevCaps)
1450UINT16 WINAPI mixerGetLineInfo16(HMIXEROBJ16,LPMIXERLINE16,DWORD);
1451UINT WINAPI mixerGetLineInfoA(HMIXEROBJ,LPMIXERLINEA,DWORD);
1452UINT WINAPI mixerGetLineInfoW(HMIXEROBJ,LPMIXERLINEW,DWORD);
1453#define mixerGetLineInfo WINELIB_NAME_AW(mixerGetLineInfo)
1454UINT16 WINAPI mixerGetID16(HMIXEROBJ16,LPUINT16,DWORD);
1455UINT WINAPI mixerGetID(HMIXEROBJ,LPUINT,DWORD);
1456UINT16 WINAPI mixerGetLineControls16(HMIXEROBJ16,LPMIXERLINECONTROLS16,DWORD);
1457UINT WINAPI mixerGetLineControlsA(HMIXEROBJ,LPMIXERLINECONTROLSA,DWORD);
1458UINT WINAPI mixerGetLineControlsW(HMIXEROBJ,LPMIXERLINECONTROLSW,DWORD);
1459#define mixerGetLineControls WINELIB_NAME_AW(mixerGetLineControls)
1460UINT16 WINAPI mixerGetControlDetails16(HMIXEROBJ16,LPMIXERCONTROLDETAILS16,DWORD);
1461UINT WINAPI mixerGetControlDetailsA(HMIXEROBJ,LPMIXERCONTROLDETAILS,DWORD);
1462UINT WINAPI mixerGetControlDetailsW(HMIXEROBJ,LPMIXERCONTROLDETAILS,DWORD);
1463#define mixerGetControlDetails WINELIB_NAME_AW(mixerGetControlDetails)
1464UINT16 WINAPI mixerSetControlDetails16(HMIXEROBJ16,LPMIXERCONTROLDETAILS16,DWORD);
1465UINT WINAPI mixerSetControlDetails(HMIXEROBJ,LPMIXERCONTROLDETAILS,DWORD);
1466
1467#define MMIOERR_BASE 256
1468#define MMIOERR_FILENOTFOUND (MMIOERR_BASE + 1) /* file not found */
1469#define MMIOERR_OUTOFMEMORY (MMIOERR_BASE + 2) /* out of memory */
1470#define MMIOERR_CANNOTOPEN (MMIOERR_BASE + 3) /* cannot open */
1471#define MMIOERR_CANNOTCLOSE (MMIOERR_BASE + 4) /* cannot close */
1472#define MMIOERR_CANNOTREAD (MMIOERR_BASE + 5) /* cannot read */
1473#define MMIOERR_CANNOTWRITE (MMIOERR_BASE + 6) /* cannot write */
1474#define MMIOERR_CANNOTSEEK (MMIOERR_BASE + 7) /* cannot seek */
1475#define MMIOERR_CANNOTEXPAND (MMIOERR_BASE + 8) /* cannot expand file */
1476#define MMIOERR_CHUNKNOTFOUND (MMIOERR_BASE + 9) /* chunk not found */
1477#define MMIOERR_UNBUFFERED (MMIOERR_BASE + 10) /* file is unbuffered */
1478
1479#define CFSEPCHAR '+' /* compound file name separator char. */
1480
1481typedef DWORD FOURCC; /* a four character code */
1482typedef LONG (* CALLBACK LPMMIOPROC16)(LPSTR lpmmioinfo, UINT16 uMessage,
1483 LPARAM lParam1, LPARAM lParam2);
1484typedef LONG (* CALLBACK LPMMIOPROC)(LPSTR lpmmioinfo, UINT uMessage,
1485 LPARAM lParam1, LPARAM lParam2);
1486
1487typedef struct {
1488 DWORD dwFlags; /* general status flags */
1489 FOURCC fccIOProc; /* pointer to I/O procedure */
1490 LPMMIOPROC16 pIOProc; /* pointer to I/O procedure */
1491 UINT16 wErrorRet; /* place for error to be returned */
1492 HTASK16 htask; /* alternate local task */
1493 /* fields maintained by MMIO functions during buffered I/O */
1494 LONG cchBuffer; /* size of I/O buffer (or 0L) */
1495 HPSTR pchBuffer; /* start of I/O buffer (or NULL) */
1496 HPSTR pchNext; /* pointer to next byte to read/write */
1497 HPSTR pchEndRead; /* pointer to last valid byte to read */
1498 HPSTR pchEndWrite; /* pointer to last byte to write */
1499 LONG lBufOffset; /* disk offset of start of buffer */
1500 /* fields maintained by I/O procedure */
1501 LONG lDiskOffset; /* disk offset of next read or write */
1502 DWORD adwInfo[3]; /* data specific to type of MMIOPROC */
1503 /* other fields maintained by MMIO */
1504 DWORD dwReserved1; /* reserved for MMIO use */
1505 DWORD dwReserved2; /* reserved for MMIO use */
1506 HMMIO16 hmmio; /* handle to open file */
1507} MMIOINFO16, *LPMMIOINFO16;
1508
1509typedef struct {
1510 DWORD dwFlags;
1511 FOURCC fccIOProc;
1512 LPMMIOPROC pIOProc;
1513 UINT wErrorRet;
1514 HTASK htask;
1515 /* fields maintained by MMIO functions during buffered I/O */
1516 LONG cchBuffer;
1517 HPSTR pchBuffer;
1518 HPSTR pchNext;
1519 HPSTR pchEndRead;
1520 HPSTR pchEndWrite;
1521 LONG lBufOffset;
1522 /* fields maintained by I/O procedure */
1523 LONG lDiskOffset;
1524 DWORD adwInfo[3];
1525 /* other fields maintained by MMIO */
1526 DWORD dwReserved1;
1527 DWORD dwReserved2;
1528 HMMIO hmmio;
1529} MMIOINFO, *PMMIOINFO, *LPMMIOINFO;
1530
1531
1532typedef struct _MMCKINFO
1533{
1534 FOURCC ckid; /* chunk ID */
1535 DWORD cksize; /* chunk size */
1536 FOURCC fccType; /* form type or list type */
1537 DWORD dwDataOffset; /* offset of data portion of chunk */
1538 DWORD dwFlags; /* flags used by MMIO functions */
1539} MMCKINFO, *LPMMCKINFO;
1540
1541#define MMIO_RWMODE 0x00000003 /* open file for reading/writing/both */
1542#define MMIO_SHAREMODE 0x00000070 /* file sharing mode number */
1543
1544#define MMIO_CREATE 0x00001000 /* create new file (or truncate file) */
1545#define MMIO_PARSE 0x00000100 /* parse new file returning path */
1546#define MMIO_DELETE 0x00000200 /* create new file (or truncate file) */
1547#define MMIO_EXIST 0x00004000 /* checks for existence of file */
1548#define MMIO_ALLOCBUF 0x00010000 /* mmioOpen() should allocate a buffer */
1549#define MMIO_GETTEMP 0x00020000 /* mmioOpen() should retrieve temp name */
1550
1551#define MMIO_DIRTY 0x10000000 /* I/O buffer is dirty */
1552
1553#define MMIO_READ 0x00000000 /* open file for reading only */
1554#define MMIO_WRITE 0x00000001 /* open file for writing only */
1555#define MMIO_READWRITE 0x00000002 /* open file for reading and writing */
1556
1557#define MMIO_COMPAT 0x00000000 /* compatibility mode */
1558#define MMIO_EXCLUSIVE 0x00000010 /* exclusive-access mode */
1559#define MMIO_DENYWRITE 0x00000020 /* deny writing to other processes */
1560#define MMIO_DENYREAD 0x00000030 /* deny reading to other processes */
1561#define MMIO_DENYNONE 0x00000040 /* deny nothing to other processes */
1562
1563#define MMIO_FHOPEN 0x0010 /* mmioClose: keep file handle open */
1564#define MMIO_EMPTYBUF 0x0010 /* mmioFlush: empty the I/O buffer */
1565#define MMIO_TOUPPER 0x0010 /* mmioStringToFOURCC: to u-case */
1566#define MMIO_INSTALLPROC 0x00010000 /* mmioInstallIOProc: install MMIOProc */
1567#define MMIO_GLOBALPROC 0x10000000 /* mmioInstallIOProc: install globally */
1568#define MMIO_REMOVEPROC 0x00020000 /* mmioInstallIOProc: remove MMIOProc */
1569#define MMIO_FINDPROC 0x00040000 /* mmioInstallIOProc: find an MMIOProc */
1570#define MMIO_FINDCHUNK 0x0010 /* mmioDescend: find a chunk by ID */
1571#define MMIO_FINDRIFF 0x0020 /* mmioDescend: find a LIST chunk */
1572#define MMIO_FINDLIST 0x0040 /* mmioDescend: find a RIFF chunk */
1573#define MMIO_CREATERIFF 0x0020 /* mmioCreateChunk: make a LIST chunk */
1574#define MMIO_CREATELIST 0x0040 /* mmioCreateChunk: make a RIFF chunk */
1575
1576#define SEEK_SET 0
1577#define SEEK_CUR 1
1578#define SEEK_END 2
1579
1580#define MMIOM_READ MMIO_READ /* read */
1581#define MMIOM_WRITE MMIO_WRITE /* write */
1582#define MMIOM_SEEK 2 /* seek to a new position in file */
1583#define MMIOM_OPEN 3 /* open file */
1584#define MMIOM_CLOSE 4 /* close file */
1585#define MMIOM_WRITEFLUSH 5 /* write and flush */
1586
1587#define MMIOM_RENAME 6 /* rename specified file */
1588
1589#define MMIOM_USER 0x8000 /* beginning of user-defined messages */
1590
1591#define FOURCC_RIFF mmioFOURCC('R', 'I', 'F', 'F')
1592#define FOURCC_LIST mmioFOURCC('L', 'I', 'S', 'T')
1593
1594#define FOURCC_DOS mmioFOURCC('D', 'O', 'S', ' ')
1595#define FOURCC_MEM mmioFOURCC('M', 'E', 'M', ' ')
1596
1597#define MMIO_DEFAULTBUFFER 8192 /* default buffer size */
1598
1599#define mmioFOURCC( ch0, ch1, ch2, ch3 ) \
1600 ( (DWORD)(BYTE)(ch0) | ( (DWORD)(BYTE)(ch1) << 8 ) | \
1601 ( (DWORD)(BYTE)(ch2) << 16 ) | ( (DWORD)(BYTE)(ch3) << 24 ) )
1602
1603LPMMIOPROC16 WINAPI mmioInstallIOProc16(FOURCC,LPMMIOPROC16,DWORD);
1604LPMMIOPROC WINAPI mmioInstallIOProcA(FOURCC,LPMMIOPROC,DWORD);
1605LPMMIOPROC WINAPI mmioInstallIOProcW(FOURCC,LPMMIOPROC,DWORD);
1606#define mmioInstallIOProc WINELIB_NAME_AW(mmioInstallIOProc)
1607
1608FOURCC WINAPI mmioStringToFOURCC16(LPCSTR,UINT16);
1609FOURCC WINAPI mmioStringToFOURCCA(LPCSTR,UINT);
1610FOURCC WINAPI mmioStringToFOURCCW(LPCWSTR,UINT);
1611#define mmioStringToFOURCC WINELIB_NAME_AW(mmioStringToFOURCC)
1612HMMIO16 WINAPI mmioOpen16 (LPSTR ,MMIOINFO16*,DWORD);
1613HMMIO WINAPI mmioOpenA(LPSTR ,MMIOINFO*,DWORD);
1614HMMIO WINAPI mmioOpenW(LPWSTR,MMIOINFO*,DWORD);
1615#define mmioOpen WINELIB_NAME_AW(mmioOpen)
1616
1617UINT16 WINAPI mmioRename16(LPCSTR szFileName, LPCSTR szNewFileName,
1618 MMIOINFO16 * lpmmioinfo, DWORD dwRenameFlags);
1619UINT WINAPI mmioRenameA(LPCSTR szFileName, LPCSTR szNewFileName,
1620 MMIOINFO * lpmmioinfo, DWORD dwRenameFlags);
1621UINT WINAPI mmioRenameW(LPCWSTR szFileName, LPCWSTR szNewFileName,
1622 MMIOINFO * lpmmioinfo, DWORD dwRenameFlags);
1623#define mmioRename WINELIB_NAME_AW(mmioRename)
1624
1625MMRESULT16 WINAPI mmioClose16(HMMIO16,UINT16);
1626MMRESULT WINAPI mmioClose(HMMIO,UINT);
1627LONG WINAPI mmioRead16(HMMIO16,HPSTR,LONG);
1628LONG WINAPI mmioRead(HMMIO,HPSTR,LONG);
1629LONG WINAPI mmioWrite16(HMMIO16,HPCSTR,LONG);
1630LONG WINAPI mmioWrite(HMMIO,HPCSTR,LONG);
1631LONG WINAPI mmioSeek16(HMMIO16,LONG,INT16);
1632LONG WINAPI mmioSeek(HMMIO,LONG,INT);
1633MMRESULT16 WINAPI mmioGetInfo16(HMMIO16,MMIOINFO16*,UINT16);
1634MMRESULT WINAPI mmioGetInfo(HMMIO,MMIOINFO*,UINT);
1635MMRESULT16 WINAPI mmioSetInfo16(HMMIO16,const MMIOINFO16*,UINT16);
1636MMRESULT WINAPI mmioSetInfo(HMMIO,const MMIOINFO*,UINT);
1637UINT16 WINAPI mmioSetBuffer16(HMMIO16,LPSTR,LONG,UINT16);
1638UINT WINAPI mmioSetBuffer(HMMIO,LPSTR,LONG,UINT);
1639UINT16 WINAPI mmioFlush16(HMMIO16,UINT16);
1640UINT WINAPI mmioFlush(HMMIO,UINT);
1641UINT16 WINAPI mmioAdvance16(HMMIO16,MMIOINFO16*,UINT16);
1642UINT WINAPI mmioAdvance(HMMIO,MMIOINFO*,UINT);
1643LONG WINAPI mmioSendMessage(HMMIO,UINT,LPARAM,LPARAM);
1644UINT WINAPI mmioDescend(HMMIO,MMCKINFO*,const MMCKINFO*,UINT);
1645
1646UINT16 WINAPI mmioAscend16(HMMIO16,MMCKINFO*,UINT16);
1647UINT WINAPI mmioAscend(HMMIO,MMCKINFO*,UINT);
1648UINT16 WINAPI mmioCreateChunk16(HMMIO16,MMCKINFO*,UINT16);
1649UINT WINAPI mmioCreateChunk(HMMIO,MMCKINFO*,UINT);
1650
1651typedef UINT16 (* CALLBACK YIELDPROC)(UINT16,DWORD);
1652
1653DWORD WINAPI mciSendCommand16(UINT16,UINT16,DWORD,DWORD);
1654MCIERROR WINAPI mciSendCommandA(MCIDEVICEID,UINT,DWORD,DWORD);
1655MCIERROR WINAPI mciSendCommandW(MCIDEVICEID,UINT,DWORD,DWORD);
1656#define mciSendCommand WINELIB_NAME_AW(mciSendCommand)
1657
1658DWORD WINAPI mciSendString16(LPCSTR,LPSTR,UINT16,HWND16);
1659DWORD WINAPI mciSendStringA(LPCSTR,LPSTR,UINT,HWND);
1660DWORD WINAPI mciSendStringW(LPCWSTR,LPWSTR,UINT,HWND);
1661#define mciSendString WINELIB_NAME_AW(mciSendString)
1662
1663UINT16 WINAPI mciGetDeviceID16(LPCSTR);
1664UINT WINAPI mciGetDeviceIDA(LPCSTR);
1665UINT WINAPI mciGetDeviceIDW(LPCWSTR);
1666#define mciGetDeviceID WINELIB_NAME_AW(mciGetDeviceID)
1667
1668UINT16 WINAPI mciGetDeviceIDFromElementID16(DWORD,LPCSTR);
1669
1670BOOL16 WINAPI mciGetErrorString16 (DWORD,LPSTR,UINT16);
1671BOOL WINAPI mciGetErrorStringA(DWORD,LPSTR,UINT);
1672BOOL WINAPI mciGetErrorStringW(DWORD,LPWSTR,UINT);
1673#define mciGetErrorString WINELIB_NAME_AW(mciGetErrorString)
1674
1675BOOL16 WINAPI mciSetYieldProc16(UINT16,YIELDPROC,DWORD);
1676BOOL WINAPI mciSetYieldProc(UINT,YIELDPROC,DWORD);
1677
1678HTASK16 WINAPI mciGetCreatorTask16(UINT16);
1679HTASK WINAPI mciGetCreatorTask(UINT);
1680
1681YIELDPROC WINAPI mciGetYieldProc16(UINT16,DWORD*);
1682YIELDPROC WINAPI mciGetYieldProc(UINT,DWORD*);
1683
1684#define MCIERR_INVALID_DEVICE_ID (MCIERR_BASE + 1)
1685#define MCIERR_UNRECOGNIZED_KEYWORD (MCIERR_BASE + 3)
1686#define MCIERR_UNRECOGNIZED_COMMAND (MCIERR_BASE + 5)
1687#define MCIERR_HARDWARE (MCIERR_BASE + 6)
1688#define MCIERR_INVALID_DEVICE_NAME (MCIERR_BASE + 7)
1689#define MCIERR_OUT_OF_MEMORY (MCIERR_BASE + 8)
1690#define MCIERR_DEVICE_OPEN (MCIERR_BASE + 9)
1691#define MCIERR_CANNOT_LOAD_DRIVER (MCIERR_BASE + 10)
1692#define MCIERR_MISSING_COMMAND_STRING (MCIERR_BASE + 11)
1693#define MCIERR_PARAM_OVERFLOW (MCIERR_BASE + 12)
1694#define MCIERR_MISSING_STRING_ARGUMENT (MCIERR_BASE + 13)
1695#define MCIERR_BAD_INTEGER (MCIERR_BASE + 14)
1696#define MCIERR_PARSER_INTERNAL (MCIERR_BASE + 15)
1697#define MCIERR_DRIVER_INTERNAL (MCIERR_BASE + 16)
1698#define MCIERR_MISSING_PARAMETER (MCIERR_BASE + 17)
1699#define MCIERR_UNSUPPORTED_FUNCTION (MCIERR_BASE + 18)
1700#define MCIERR_FILE_NOT_FOUND (MCIERR_BASE + 19)
1701#define MCIERR_DEVICE_NOT_READY (MCIERR_BASE + 20)
1702#define MCIERR_INTERNAL (MCIERR_BASE + 21)
1703#define MCIERR_DRIVER (MCIERR_BASE + 22)
1704#define MCIERR_CANNOT_USE_ALL (MCIERR_BASE + 23)
1705#define MCIERR_MULTIPLE (MCIERR_BASE + 24)
1706#define MCIERR_EXTENSION_NOT_FOUND (MCIERR_BASE + 25)
1707#define MCIERR_OUTOFRANGE (MCIERR_BASE + 26)
1708#define MCIERR_FLAGS_NOT_COMPATIBLE (MCIERR_BASE + 28)
1709#define MCIERR_FILE_NOT_SAVED (MCIERR_BASE + 30)
1710#define MCIERR_DEVICE_TYPE_REQUIRED (MCIERR_BASE + 31)
1711#define MCIERR_DEVICE_LOCKED (MCIERR_BASE + 32)
1712#define MCIERR_DUPLICATE_ALIAS (MCIERR_BASE + 33)
1713#define MCIERR_BAD_CONSTANT (MCIERR_BASE + 34)
1714#define MCIERR_MUST_USE_SHAREABLE (MCIERR_BASE + 35)
1715#define MCIERR_MISSING_DEVICE_NAME (MCIERR_BASE + 36)
1716#define MCIERR_BAD_TIME_FORMAT (MCIERR_BASE + 37)
1717#define MCIERR_NO_CLOSING_QUOTE (MCIERR_BASE + 38)
1718#define MCIERR_DUPLICATE_FLAGS (MCIERR_BASE + 39)
1719#define MCIERR_INVALID_FILE (MCIERR_BASE + 40)
1720#define MCIERR_NULL_PARAMETER_BLOCK (MCIERR_BASE + 41)
1721#define MCIERR_UNNAMED_RESOURCE (MCIERR_BASE + 42)
1722#define MCIERR_NEW_REQUIRES_ALIAS (MCIERR_BASE + 43)
1723#define MCIERR_NOTIFY_ON_AUTO_OPEN (MCIERR_BASE + 44)
1724#define MCIERR_NO_ELEMENT_ALLOWED (MCIERR_BASE + 45)
1725#define MCIERR_NONAPPLICABLE_FUNCTION (MCIERR_BASE + 46)
1726#define MCIERR_ILLEGAL_FOR_AUTO_OPEN (MCIERR_BASE + 47)
1727#define MCIERR_FILENAME_REQUIRED (MCIERR_BASE + 48)
1728#define MCIERR_EXTRA_CHARACTERS (MCIERR_BASE + 49)
1729#define MCIERR_DEVICE_NOT_INSTALLED (MCIERR_BASE + 50)
1730#define MCIERR_GET_CD (MCIERR_BASE + 51)
1731#define MCIERR_SET_CD (MCIERR_BASE + 52)
1732#define MCIERR_SET_DRIVE (MCIERR_BASE + 53)
1733#define MCIERR_DEVICE_LENGTH (MCIERR_BASE + 54)
1734#define MCIERR_DEVICE_ORD_LENGTH (MCIERR_BASE + 55)
1735#define MCIERR_NO_INTEGER (MCIERR_BASE + 56)
1736
1737#define MCIERR_WAVE_OUTPUTSINUSE (MCIERR_BASE + 64)
1738#define MCIERR_WAVE_SETOUTPUTINUSE (MCIERR_BASE + 65)
1739#define MCIERR_WAVE_INPUTSINUSE (MCIERR_BASE + 66)
1740#define MCIERR_WAVE_SETINPUTINUSE (MCIERR_BASE + 67)
1741#define MCIERR_WAVE_OUTPUTUNSPECIFIED (MCIERR_BASE + 68)
1742#define MCIERR_WAVE_INPUTUNSPECIFIED (MCIERR_BASE + 69)
1743#define MCIERR_WAVE_OUTPUTSUNSUITABLE (MCIERR_BASE + 70)
1744#define MCIERR_WAVE_SETOUTPUTUNSUITABLE (MCIERR_BASE + 71)
1745#define MCIERR_WAVE_INPUTSUNSUITABLE (MCIERR_BASE + 72)
1746#define MCIERR_WAVE_SETINPUTUNSUITABLE (MCIERR_BASE + 73)
1747
1748#define MCIERR_SEQ_DIV_INCOMPATIBLE (MCIERR_BASE + 80)
1749#define MCIERR_SEQ_PORT_INUSE (MCIERR_BASE + 81)
1750#define MCIERR_SEQ_PORT_NONEXISTENT (MCIERR_BASE + 82)
1751#define MCIERR_SEQ_PORT_MAPNODEVICE (MCIERR_BASE + 83)
1752#define MCIERR_SEQ_PORT_MISCERROR (MCIERR_BASE + 84)
1753#define MCIERR_SEQ_TIMER (MCIERR_BASE + 85)
1754#define MCIERR_SEQ_PORTUNSPECIFIED (MCIERR_BASE + 86)
1755#define MCIERR_SEQ_NOMIDIPRESENT (MCIERR_BASE + 87)
1756
1757#define MCIERR_NO_WINDOW (MCIERR_BASE + 90)
1758#define MCIERR_CREATEWINDOW (MCIERR_BASE + 91)
1759#define MCIERR_FILE_READ (MCIERR_BASE + 92)
1760#define MCIERR_FILE_WRITE (MCIERR_BASE + 93)
1761
1762#define MCIERR_CUSTOM_DRIVER_BASE (MCIERR_BASE + 256)
1763
1764#define MCI_OPEN_DRIVER 0x0801
1765#define MCI_CLOSE_DRIVER 0x0802
1766#define MCI_OPEN 0x0803
1767#define MCI_CLOSE 0x0804
1768#define MCI_ESCAPE 0x0805
1769#define MCI_PLAY 0x0806
1770#define MCI_SEEK 0x0807
1771#define MCI_STOP 0x0808
1772#define MCI_PAUSE 0x0809
1773#define MCI_INFO 0x080A
1774#define MCI_GETDEVCAPS 0x080B
1775#define MCI_SPIN 0x080C
1776#define MCI_SET 0x080D
1777#define MCI_STEP 0x080E
1778#define MCI_RECORD 0x080F
1779#define MCI_SYSINFO 0x0810
1780#define MCI_BREAK 0x0811
1781#define MCI_SOUND 0x0812
1782#define MCI_SAVE 0x0813
1783#define MCI_STATUS 0x0814
1784#define MCI_CUE 0x0830
1785#define MCI_REALIZE 0x0840
1786#define MCI_WINDOW 0x0841
1787#define MCI_PUT 0x0842
1788#define MCI_WHERE 0x0843
1789#define MCI_FREEZE 0x0844
1790#define MCI_UNFREEZE 0x0845
1791#define MCI_LOAD 0x0850
1792#define MCI_CUT 0x0851
1793#define MCI_COPY 0x0852
1794#define MCI_PASTE 0x0853
1795#define MCI_UPDATE 0x0854
1796#define MCI_RESUME 0x0855
1797#define MCI_DELETE 0x0856
1798
1799#define MCI_USER_MESSAGES (0x400 + DRV_MCI_FIRST)
1800
1801#define MCI_ALL_DEVICE_ID 0xFFFF
1802
1803#define MCI_DEVTYPE_VCR (MCI_STRING_OFFSET + 1)
1804#define MCI_DEVTYPE_VIDEODISC (MCI_STRING_OFFSET + 2)
1805#define MCI_DEVTYPE_OVERLAY (MCI_STRING_OFFSET + 3)
1806#define MCI_DEVTYPE_CD_AUDIO (MCI_STRING_OFFSET + 4)
1807#define MCI_DEVTYPE_DAT (MCI_STRING_OFFSET + 5)
1808#define MCI_DEVTYPE_SCANNER (MCI_STRING_OFFSET + 6)
1809#define MCI_DEVTYPE_ANIMATION (MCI_STRING_OFFSET + 7)
1810#define MCI_DEVTYPE_DIGITAL_VIDEO (MCI_STRING_OFFSET + 8)
1811#define MCI_DEVTYPE_OTHER (MCI_STRING_OFFSET + 9)
1812#define MCI_DEVTYPE_WAVEFORM_AUDIO (MCI_STRING_OFFSET + 10)
1813#define MCI_DEVTYPE_SEQUENCER (MCI_STRING_OFFSET + 11)
1814
1815#define MCI_DEVTYPE_FIRST MCI_DEVTYPE_VCR
1816#define MCI_DEVTYPE_LAST MCI_DEVTYPE_SEQUENCER
1817
1818#define MCI_MODE_NOT_READY (MCI_STRING_OFFSET + 12)
1819#define MCI_MODE_STOP (MCI_STRING_OFFSET + 13)
1820#define MCI_MODE_PLAY (MCI_STRING_OFFSET + 14)
1821#define MCI_MODE_RECORD (MCI_STRING_OFFSET + 15)
1822#define MCI_MODE_SEEK (MCI_STRING_OFFSET + 16)
1823#define MCI_MODE_PAUSE (MCI_STRING_OFFSET + 17)
1824#define MCI_MODE_OPEN (MCI_STRING_OFFSET + 18)
1825
1826#define MCI_FORMAT_MILLISECONDS 0
1827#define MCI_FORMAT_HMS 1
1828#define MCI_FORMAT_MSF 2
1829#define MCI_FORMAT_FRAMES 3
1830#define MCI_FORMAT_SMPTE_24 4
1831#define MCI_FORMAT_SMPTE_25 5
1832#define MCI_FORMAT_SMPTE_30 6
1833#define MCI_FORMAT_SMPTE_30DROP 7
1834#define MCI_FORMAT_BYTES 8
1835#define MCI_FORMAT_SAMPLES 9
1836#define MCI_FORMAT_TMSF 10
1837
1838#define MCI_MSF_MINUTE(msf) ((BYTE)(msf))
1839#define MCI_MSF_SECOND(msf) ((BYTE)(((WORD)(msf)) >> 8))
1840#define MCI_MSF_FRAME(msf) ((BYTE)((msf)>>16))
1841
1842#define MCI_MAKE_MSF(m, s, f) ((DWORD)(((BYTE)(m) | \
1843 ((WORD)(s)<<8)) | \
1844 (((DWORD)(BYTE)(f))<<16)))
1845
1846#define MCI_TMSF_TRACK(tmsf) ((BYTE)(tmsf))
1847#define MCI_TMSF_MINUTE(tmsf) ((BYTE)(((WORD)(tmsf)) >> 8))
1848#define MCI_TMSF_SECOND(tmsf) ((BYTE)((tmsf)>>16))
1849#define MCI_TMSF_FRAME(tmsf) ((BYTE)((tmsf)>>24))
1850
1851#define MCI_MAKE_TMSF(t, m, s, f) ((DWORD)(((BYTE)(t) | \
1852 ((WORD)(m)<<8)) | \
1853 (((DWORD)(BYTE)(s) | \
1854 ((WORD)(f)<<8))<<16)))
1855
1856#define MCI_HMS_HOUR(hms) ((BYTE)(hms))
1857#define MCI_HMS_MINUTE(hms) ((BYTE)(((WORD)(hms)) >> 8))
1858#define MCI_HMS_SECOND(hms) ((BYTE)((hms)>>16))
1859
1860#define MCI_MAKE_HMS(h, m, s) ((DWORD)(((BYTE)(h) | \
1861 ((WORD)(m)<<8)) | \
1862 (((DWORD)(BYTE)(s))<<16)))
1863
1864#define MCI_NOTIFY_SUCCESSFUL 0x0001
1865#define MCI_NOTIFY_SUPERSEDED 0x0002
1866#define MCI_NOTIFY_ABORTED 0x0004
1867#define MCI_NOTIFY_FAILURE 0x0008
1868
1869#define MCI_NOTIFY 0x00000001L
1870#define MCI_WAIT 0x00000002L
1871#define MCI_FROM 0x00000004L
1872#define MCI_TO 0x00000008L
1873#define MCI_TRACK 0x00000010L
1874
1875#define MCI_OPEN_SHAREABLE 0x00000100L
1876#define MCI_OPEN_ELEMENT 0x00000200L
1877#define MCI_OPEN_ALIAS 0x00000400L
1878#define MCI_OPEN_ELEMENT_ID 0x00000800L
1879#define MCI_OPEN_TYPE_ID 0x00001000L
1880#define MCI_OPEN_TYPE 0x00002000L
1881
1882#define MCI_SEEK_TO_START 0x00000100L
1883#define MCI_SEEK_TO_END 0x00000200L
1884
1885#define MCI_STATUS_ITEM 0x00000100L
1886#define MCI_STATUS_START 0x00000200L
1887
1888#define MCI_STATUS_LENGTH 0x00000001L
1889#define MCI_STATUS_POSITION 0x00000002L
1890#define MCI_STATUS_NUMBER_OF_TRACKS 0x00000003L
1891#define MCI_STATUS_MODE 0x00000004L
1892#define MCI_STATUS_MEDIA_PRESENT 0x00000005L
1893#define MCI_STATUS_TIME_FORMAT 0x00000006L
1894#define MCI_STATUS_READY 0x00000007L
1895#define MCI_STATUS_CURRENT_TRACK 0x00000008L
1896
1897#define MCI_INFO_PRODUCT 0x00000100L
1898#define MCI_INFO_FILE 0x00000200L
1899
1900#define MCI_GETDEVCAPS_ITEM 0x00000100L
1901
1902#define MCI_GETDEVCAPS_CAN_RECORD 0x00000001L
1903#define MCI_GETDEVCAPS_HAS_AUDIO 0x00000002L
1904#define MCI_GETDEVCAPS_HAS_VIDEO 0x00000003L
1905#define MCI_GETDEVCAPS_DEVICE_TYPE 0x00000004L
1906#define MCI_GETDEVCAPS_USES_FILES 0x00000005L
1907#define MCI_GETDEVCAPS_COMPOUND_DEVICE 0x00000006L
1908#define MCI_GETDEVCAPS_CAN_EJECT 0x00000007L
1909#define MCI_GETDEVCAPS_CAN_PLAY 0x00000008L
1910#define MCI_GETDEVCAPS_CAN_SAVE 0x00000009L
1911
1912#define MCI_SYSINFO_QUANTITY 0x00000100L
1913#define MCI_SYSINFO_OPEN 0x00000200L
1914#define MCI_SYSINFO_NAME 0x00000400L
1915#define MCI_SYSINFO_INSTALLNAME 0x00000800L
1916
1917#define MCI_SET_DOOR_OPEN 0x00000100L
1918#define MCI_SET_DOOR_CLOSED 0x00000200L
1919#define MCI_SET_TIME_FORMAT 0x00000400L
1920#define MCI_SET_AUDIO 0x00000800L
1921#define MCI_SET_VIDEO 0x00001000L
1922#define MCI_SET_ON 0x00002000L
1923#define MCI_SET_OFF 0x00004000L
1924
1925#define MCI_SET_AUDIO_ALL 0x00000000L
1926#define MCI_SET_AUDIO_LEFT 0x00000001L
1927#define MCI_SET_AUDIO_RIGHT 0x00000002L
1928
1929#define MCI_BREAK_KEY 0x00000100L
1930#define MCI_BREAK_HWND 0x00000200L
1931#define MCI_BREAK_OFF 0x00000400L
1932
1933#define MCI_RECORD_INSERT 0x00000100L
1934#define MCI_RECORD_OVERWRITE 0x00000200L
1935
1936#define MCI_SOUND_NAME 0x00000100L
1937
1938#define MCI_SAVE_FILE 0x00000100L
1939
1940#define MCI_LOAD_FILE 0x00000100L
1941
1942typedef struct {
1943 DWORD dwCallback;
1944} MCI_GENERIC_PARMS, *LPMCI_GENERIC_PARMS;
1945
1946typedef struct {
1947 DWORD dwCallback;
1948 WORD wDeviceID;
1949 WORD wReserved0;
1950 LPSTR lpstrDeviceType;
1951 LPSTR lpstrElementName;
1952 LPSTR lpstrAlias;
1953} MCI_OPEN_PARMS16, *LPMCI_OPEN_PARMS16;
1954
1955typedef struct {
1956 DWORD dwCallback;
1957 MCIDEVICEID wDeviceID;
1958 LPSTR lpstrDeviceType;
1959 LPSTR lpstrElementName;
1960 LPSTR lpstrAlias;
1961} MCI_OPEN_PARMSA, *LPMCI_OPEN_PARMSA;
1962
1963typedef struct {
1964 DWORD dwCallback;
1965 MCIDEVICEID wDeviceID;
1966 LPWSTR lpstrDeviceType;
1967 LPWSTR lpstrElementName;
1968 LPWSTR lpstrAlias;
1969} MCI_OPEN_PARMSW, *LPMCI_OPEN_PARMSW;
1970
1971DECL_WINELIB_TYPE_AW(MCI_OPEN_PARMS)
1972DECL_WINELIB_TYPE_AW(LPMCI_OPEN_PARMS)
1973
1974typedef struct {
1975 DWORD dwCallback;
1976 DWORD dwFrom;
1977 DWORD dwTo;
1978} MCI_PLAY_PARMS, *LPMCI_PLAY_PARMS;
1979
1980typedef struct {
1981 DWORD dwCallback;
1982 DWORD dwTo;
1983} MCI_SEEK_PARMS, *LPMCI_SEEK_PARMS;
1984
1985typedef struct {
1986 DWORD dwCallback;
1987 DWORD dwReturn;
1988 DWORD dwItem;
1989 DWORD dwTrack;
1990} MCI_STATUS_PARMS, *LPMCI_STATUS_PARMS;
1991
1992typedef struct {
1993 DWORD dwCallback;
1994 LPSTR lpstrReturn;
1995 DWORD dwRetSize;
1996} MCI_INFO_PARMS16, *LPMCI_INFO_PARMS16;
1997
1998typedef struct {
1999 DWORD dwCallback;
2000 LPSTR lpstrReturn;
2001 DWORD dwRetSize;
2002} MCI_INFO_PARMSA, *LPMCI_INFO_PARMSA;
2003
2004typedef struct {
2005 DWORD dwCallback;
2006 LPSTR lpstrReturn;
2007 DWORD dwRetSize;
2008} MCI_INFO_PARMSW, *LPMCI_INFO_PARMSW;
2009
2010DECL_WINELIB_TYPE_AW(MCI_INFO_PARMS)
2011DECL_WINELIB_TYPE_AW(LPMCI_INFO_PARMS)
2012
2013typedef struct {
2014 DWORD dwCallback;
2015 DWORD dwReturn;
2016 DWORD dwItem;
2017} MCI_GETDEVCAPS_PARMS, *LPMCI_GETDEVCAPS_PARMS;
2018
2019typedef struct {
2020 DWORD dwCallback;
2021 LPSTR lpstrReturn;
2022 DWORD dwRetSize;
2023 DWORD dwNumber;
2024 WORD wDeviceType;
2025 WORD wReserved0;
2026} MCI_SYSINFO_PARMS16, *LPMCI_SYSINFO_PARMS16;
2027
2028typedef struct {
2029 DWORD dwCallback;
2030 LPSTR lpstrReturn;
2031 DWORD dwRetSize;
2032 DWORD dwNumber;
2033 UINT wDeviceType;
2034} MCI_SYSINFO_PARMSA, *LPMCI_SYSINFO_PARMSA;
2035
2036typedef struct {
2037 DWORD dwCallback;
2038 LPWSTR lpstrReturn;
2039 DWORD dwRetSize;
2040 DWORD dwNumber;
2041 UINT wDeviceType;
2042} MCI_SYSINFO_PARMSW, *LPMCI_SYSINFO_PARMSW;
2043
2044DECL_WINELIB_TYPE_AW(MCI_SYSINFO_PARMS)
2045DECL_WINELIB_TYPE_AW(LPMCI_SYSINFO_PARMS)
2046
2047typedef struct {
2048 DWORD dwCallback;
2049 DWORD dwTimeFormat;
2050 DWORD dwAudio;
2051} MCI_SET_PARMS, *LPMCI_SET_PARMS;
2052
2053typedef struct {
2054 DWORD dwCallback;
2055 UINT16 nVirtKey;
2056 WORD wReserved0;
2057 HWND16 hwndBreak;
2058 WORD wReserved1;
2059} MCI_BREAK_PARMS16, *LPMCI_BREAK_PARMS16;
2060
2061typedef struct {
2062 DWORD dwCallback;
2063 INT nVirtKey;
2064 HWND hwndBreak;
2065} MCI_BREAK_PARMS, *LPMCI_BREAK_PARMS;
2066
2067
2068typedef struct {
2069 DWORD dwCallback;
2070 LPCSTR lpstrSoundName;
2071} MCI_SOUND_PARMS, *LPMCI_SOUND_PARMS;
2072
2073typedef struct {
2074 DWORD dwCallback;
2075 LPCSTR lpfilename;
2076} MCI_SAVE_PARMS, *LPMCI_SAVE_PARMS;
2077
2078typedef struct {
2079 DWORD dwCallback;
2080 LPCSTR lpfilename;
2081} MCI_LOAD_PARMS16, *LPMCI_LOAD_PARMS16;
2082
2083typedef struct {
2084 DWORD dwCallback;
2085 LPCSTR lpfilename;
2086} MCI_LOAD_PARMSA, *LPMCI_LOAD_PARMSA;
2087
2088typedef struct {
2089 DWORD dwCallback;
2090 LPCWSTR lpfilename;
2091} MCI_LOAD_PARMSW, *LPMCI_LOAD_PARMSW;
2092
2093DECL_WINELIB_TYPE_AW(MCI_LOAD_PARMS)
2094DECL_WINELIB_TYPE_AW(LPMCI_LOAD_PARMS)
2095
2096typedef struct {
2097 DWORD dwCallback;
2098 DWORD dwFrom;
2099 DWORD dwTo;
2100} MCI_RECORD_PARMS, *LPMCI_RECORD_PARMS;
2101
2102#define MCI_CDA_STATUS_TYPE_TRACK 0x00004001
2103
2104#define MCI_CDA_TRACK_AUDIO (MCI_CD_OFFSET + 0)
2105#define MCI_CDA_TRACK_OTHER (MCI_CD_OFFSET + 1)
2106
2107#define MCI_VD_MODE_PARK (MCI_VD_OFFSET + 1)
2108
2109#define MCI_VD_MEDIA_CLV (MCI_VD_OFFSET + 2)
2110#define MCI_VD_MEDIA_CAV (MCI_VD_OFFSET + 3)
2111#define MCI_VD_MEDIA_OTHER (MCI_VD_OFFSET + 4)
2112
2113#define MCI_VD_FORMAT_TRACK 0x4001
2114
2115#define MCI_VD_PLAY_REVERSE 0x00010000L
2116#define MCI_VD_PLAY_FAST 0x00020000L
2117#define MCI_VD_PLAY_SPEED 0x00040000L
2118#define MCI_VD_PLAY_SCAN 0x00080000L
2119#define MCI_VD_PLAY_SLOW 0x00100000L
2120
2121#define MCI_VD_SEEK_REVERSE 0x00010000L
2122
2123#define MCI_VD_STATUS_SPEED 0x00004002L
2124#define MCI_VD_STATUS_FORWARD 0x00004003L
2125#define MCI_VD_STATUS_MEDIA_TYPE 0x00004004L
2126#define MCI_VD_STATUS_SIDE 0x00004005L
2127#define MCI_VD_STATUS_DISC_SIZE 0x00004006L
2128
2129#define MCI_VD_GETDEVCAPS_CLV 0x00010000L
2130#define MCI_VD_GETDEVCAPS_CAV 0x00020000L
2131
2132#define MCI_VD_SPIN_UP 0x00010000L
2133#define MCI_VD_SPIN_DOWN 0x00020000L
2134
2135#define MCI_VD_GETDEVCAPS_CAN_REVERSE 0x00004002L
2136#define MCI_VD_GETDEVCAPS_FAST_RATE 0x00004003L
2137#define MCI_VD_GETDEVCAPS_SLOW_RATE 0x00004004L
2138#define MCI_VD_GETDEVCAPS_NORMAL_RATE 0x00004005L
2139
2140#define MCI_VD_STEP_FRAMES 0x00010000L
2141#define MCI_VD_STEP_REVERSE 0x00020000L
2142
2143#define MCI_VD_ESCAPE_STRING 0x00000100L
2144
2145typedef struct {
2146 DWORD dwCallback;
2147 DWORD dwFrom;
2148 DWORD dwTo;
2149 DWORD dwSpeed;
2150} MCI_VD_PLAY_PARMS, *LPMCI_VD_PLAY_PARMS;
2151
2152typedef struct {
2153 DWORD dwCallback;
2154 DWORD dwFrames;
2155} MCI_VD_STEP_PARMS, *LPMCI_VD_STEP_PARMS;
2156
2157typedef struct {
2158 DWORD dwCallback;
2159 LPCSTR lpstrCommand;
2160} MCI_VD_ESCAPE_PARMS16, *LPMCI_VD_ESCAPE_PARMS16;
2161
2162typedef struct {
2163 DWORD dwCallback;
2164 LPCSTR lpstrCommand;
2165} MCI_VD_ESCAPE_PARMSA, *LPMCI_VD_ESCAPE_PARMSA;
2166
2167typedef struct {
2168 DWORD dwCallback;
2169 LPCWSTR lpstrCommand;
2170} MCI_VD_ESCAPE_PARMSW, *LPMCI_VD_ESCAPE_PARMSW;
2171
2172DECL_WINELIB_TYPE_AW(MCI_VD_ESCAPE_PARMS)
2173DECL_WINELIB_TYPE_AW(LPMCI_VD_ESCAPE_PARMS)
2174
2175#define MCI_WAVE_OPEN_BUFFER 0x00010000L
2176
2177#define MCI_WAVE_SET_FORMATTAG 0x00010000L
2178#define MCI_WAVE_SET_CHANNELS 0x00020000L
2179#define MCI_WAVE_SET_SAMPLESPERSEC 0x00040000L
2180#define MCI_WAVE_SET_AVGBYTESPERSEC 0x00080000L
2181#define MCI_WAVE_SET_BLOCKALIGN 0x00100000L
2182#define MCI_WAVE_SET_BITSPERSAMPLE 0x00200000L
2183
2184#define MCI_WAVE_INPUT 0x00400000L
2185#define MCI_WAVE_OUTPUT 0x00800000L
2186
2187#define MCI_WAVE_STATUS_FORMATTAG 0x00004001L
2188#define MCI_WAVE_STATUS_CHANNELS 0x00004002L
2189#define MCI_WAVE_STATUS_SAMPLESPERSEC 0x00004003L
2190#define MCI_WAVE_STATUS_AVGBYTESPERSEC 0x00004004L
2191#define MCI_WAVE_STATUS_BLOCKALIGN 0x00004005L
2192#define MCI_WAVE_STATUS_BITSPERSAMPLE 0x00004006L
2193#define MCI_WAVE_STATUS_LEVEL 0x00004007L
2194
2195#define MCI_WAVE_SET_ANYINPUT 0x04000000L
2196#define MCI_WAVE_SET_ANYOUTPUT 0x08000000L
2197
2198#define MCI_WAVE_GETDEVCAPS_INPUTS 0x00004001L
2199#define MCI_WAVE_GETDEVCAPS_OUTPUTS 0x00004002L
2200
2201typedef struct {
2202 DWORD dwCallback;
2203 MCIDEVICEID16 wDeviceID;
2204 WORD wReserved0;
2205 SEGPTR lpstrDeviceType;
2206 SEGPTR lpstrElementName;
2207 SEGPTR lpstrAlias;
2208 DWORD dwBufferSeconds;
2209} MCI_WAVE_OPEN_PARMS16, *LPMCI_WAVE_OPEN_PARMS16;
2210
2211typedef struct {
2212 DWORD dwCallback;
2213 MCIDEVICEID wDeviceID;
2214 LPCSTR lpstrDeviceType;
2215 LPCSTR lpstrElementName;
2216 LPCSTR lpstrAlias;
2217 DWORD dwBufferSeconds;
2218} MCI_WAVE_OPEN_PARMSA, *LPMCI_WAVE_OPEN_PARMSA;
2219
2220typedef struct {
2221 DWORD dwCallback;
2222 MCIDEVICEID wDeviceID;
2223 LPCWSTR lpstrDeviceType;
2224 LPCWSTR lpstrElementName;
2225 LPCWSTR lpstrAlias;
2226 DWORD dwBufferSeconds;
2227} MCI_WAVE_OPEN_PARMSW, *LPMCI_WAVE_OPEN_PARMSW;
2228
2229DECL_WINELIB_TYPE_AW(MCI_WAVE_OPEN_PARMS)
2230DECL_WINELIB_TYPE_AW(LPMCI_WAVE_OPEN_PARMS)
2231
2232typedef struct {
2233 DWORD dwCallback;
2234 DWORD dwFrom;
2235 DWORD dwTo;
2236} MCI_WAVE_DELETE_PARMS, *LPMCI_WAVE_DELETE_PARMS;
2237
2238typedef struct {
2239 DWORD dwCallback;
2240 DWORD dwTimeFormat;
2241 DWORD dwAudio;
2242 UINT16 wInput;
2243 UINT16 wReserved0;
2244 UINT16 wOutput;
2245 UINT16 wReserved1;
2246 UINT16 wFormatTag;
2247 UINT16 wReserved2;
2248 UINT16 nChannels;
2249 UINT16 wReserved3;
2250 DWORD nSamplesPerSec;
2251 DWORD nAvgBytesPerSec;
2252 UINT16 nBlockAlign;
2253 UINT16 wReserved4;
2254 UINT16 wBitsPerSample;
2255 UINT16 wReserved5;
2256} MCI_WAVE_SET_PARMS16, * LPMCI_WAVE_SET_PARMS16;
2257
2258typedef struct {
2259 DWORD dwCallback;
2260 DWORD dwTimeFormat;
2261 DWORD dwAudio;
2262 UINT wInput;
2263 UINT wOutput;
2264 UINT wFormatTag;
2265 UINT nChannels;
2266 DWORD nSamplesPerSec;
2267 DWORD nAvgBytesPerSec;
2268 UINT nBlockAlign;
2269 UINT wBitsPerSample;
2270} MCI_WAVE_SET_PARMS, * LPMCI_WAVE_SET_PARMS;
2271
2272
2273#define MCI_SEQ_DIV_PPQN (0 + MCI_SEQ_OFFSET)
2274#define MCI_SEQ_DIV_SMPTE_24 (1 + MCI_SEQ_OFFSET)
2275#define MCI_SEQ_DIV_SMPTE_25 (2 + MCI_SEQ_OFFSET)
2276#define MCI_SEQ_DIV_SMPTE_30DROP (3 + MCI_SEQ_OFFSET)
2277#define MCI_SEQ_DIV_SMPTE_30 (4 + MCI_SEQ_OFFSET)
2278
2279#define MCI_SEQ_FORMAT_SONGPTR 0x4001
2280#define MCI_SEQ_FILE 0x4002
2281#define MCI_SEQ_MIDI 0x4003
2282#define MCI_SEQ_SMPTE 0x4004
2283#define MCI_SEQ_NONE 65533
2284
2285#define MCI_SEQ_STATUS_TEMPO 0x00004002L
2286#define MCI_SEQ_STATUS_PORT 0x00004003L
2287#define MCI_SEQ_STATUS_SLAVE 0x00004007L
2288#define MCI_SEQ_STATUS_MASTER 0x00004008L
2289#define MCI_SEQ_STATUS_OFFSET 0x00004009L
2290#define MCI_SEQ_STATUS_DIVTYPE 0x0000400AL
2291
2292#define MCI_SEQ_SET_TEMPO 0x00010000L
2293#define MCI_SEQ_SET_PORT 0x00020000L
2294#define MCI_SEQ_SET_SLAVE 0x00040000L
2295#define MCI_SEQ_SET_MASTER 0x00080000L
2296#define MCI_SEQ_SET_OFFSET 0x01000000L
2297
2298typedef struct {
2299 DWORD dwCallback;
2300 DWORD dwTimeFormat;
2301 DWORD dwAudio;
2302 DWORD dwTempo;
2303 DWORD dwPort;
2304 DWORD dwSlave;
2305 DWORD dwMaster;
2306 DWORD dwOffset;
2307} MCI_SEQ_SET_PARMS, *LPMCI_SEQ_SET_PARMS;
2308
2309#define MCI_ANIM_OPEN_WS 0x00010000L
2310#define MCI_ANIM_OPEN_PARENT 0x00020000L
2311#define MCI_ANIM_OPEN_NOSTATIC 0x00040000L
2312
2313#define MCI_ANIM_PLAY_SPEED 0x00010000L
2314#define MCI_ANIM_PLAY_REVERSE 0x00020000L
2315#define MCI_ANIM_PLAY_FAST 0x00040000L
2316#define MCI_ANIM_PLAY_SLOW 0x00080000L
2317#define MCI_ANIM_PLAY_SCAN 0x00100000L
2318
2319#define MCI_ANIM_STEP_REVERSE 0x00010000L
2320#define MCI_ANIM_STEP_FRAMES 0x00020000L
2321
2322#define MCI_ANIM_STATUS_SPEED 0x00004001L
2323#define MCI_ANIM_STATUS_FORWARD 0x00004002L
2324#define MCI_ANIM_STATUS_HWND 0x00004003L
2325#define MCI_ANIM_STATUS_HPAL 0x00004004L
2326#define MCI_ANIM_STATUS_STRETCH 0x00004005L
2327
2328#define MCI_ANIM_INFO_TEXT 0x00010000L
2329
2330#define MCI_ANIM_GETDEVCAPS_CAN_REVERSE 0x00004001L
2331#define MCI_ANIM_GETDEVCAPS_FAST_RATE 0x00004002L
2332#define MCI_ANIM_GETDEVCAPS_SLOW_RATE 0x00004003L
2333#define MCI_ANIM_GETDEVCAPS_NORMAL_RATE 0x00004004L
2334#define MCI_ANIM_GETDEVCAPS_PALETTES 0x00004006L
2335#define MCI_ANIM_GETDEVCAPS_CAN_STRETCH 0x00004007L
2336#define MCI_ANIM_GETDEVCAPS_MAX_WINDOWS 0x00004008L
2337
2338#define MCI_ANIM_REALIZE_NORM 0x00010000L
2339#define MCI_ANIM_REALIZE_BKGD 0x00020000L
2340
2341#define MCI_ANIM_WINDOW_HWND 0x00010000L
2342#define MCI_ANIM_WINDOW_STATE 0x00040000L
2343#define MCI_ANIM_WINDOW_TEXT 0x00080000L
2344#define MCI_ANIM_WINDOW_ENABLE_STRETCH 0x00100000L
2345#define MCI_ANIM_WINDOW_DISABLE_STRETCH 0x00200000L
2346
2347#define MCI_ANIM_WINDOW_DEFAULT 0x00000000L
2348
2349#define MCI_ANIM_RECT 0x00010000L
2350#define MCI_ANIM_PUT_SOURCE 0x00020000L
2351#define MCI_ANIM_PUT_DESTINATION 0x00040000L
2352
2353#define MCI_ANIM_WHERE_SOURCE 0x00020000L
2354#define MCI_ANIM_WHERE_DESTINATION 0x00040000L
2355
2356#define MCI_ANIM_UPDATE_HDC 0x00020000L
2357
2358typedef struct {
2359 DWORD dwCallback;
2360 UINT16 wDeviceID;
2361 UINT16 wReserved0;
2362 SEGPTR lpstrDeviceType;
2363 SEGPTR lpstrElementName;
2364 SEGPTR lpstrAlias;
2365 DWORD dwStyle;
2366 HWND16 hWndParent;
2367 UINT16 wReserved1;
2368} MCI_ANIM_OPEN_PARMS16, *LPMCI_ANIM_OPEN_PARMS16;
2369
2370typedef struct {
2371 DWORD dwCallback;
2372 MCIDEVICEID wDeviceID;
2373 LPCSTR lpstrDeviceType;
2374 LPCSTR lpstrElementName;
2375 LPCSTR lpstrAlias;
2376 DWORD dwStyle;
2377 HWND hWndParent;
2378} MCI_ANIM_OPEN_PARMSA, *LPMCI_ANIM_OPEN_PARMSA;
2379
2380typedef struct {
2381 DWORD dwCallback;
2382 MCIDEVICEID wDeviceID;
2383 LPCSTR lpstrDeviceType;
2384 LPCSTR lpstrElementName;
2385 LPCSTR lpstrAlias;
2386 DWORD dwStyle;
2387 HWND hWndParent;
2388} MCI_ANIM_OPEN_PARMSW, *LPMCI_ANIM_OPEN_PARMSW;
2389
2390DECL_WINELIB_TYPE_AW(MCI_ANIM_OPEN_PARMS)
2391DECL_WINELIB_TYPE_AW(LPMCI_ANIM_OPEN_PARMS)
2392
2393typedef struct {
2394 DWORD dwCallback;
2395 DWORD dwFrom;
2396 DWORD dwTo;
2397 DWORD dwSpeed;
2398} MCI_ANIM_PLAY_PARMS, *LPMCI_ANIM_PLAY_PARMS;
2399
2400typedef struct {
2401 DWORD dwCallback;
2402 DWORD dwFrames;
2403} MCI_ANIM_STEP_PARMS, *LPMCI_ANIM_STEP_PARMS;
2404
2405typedef struct {
2406 DWORD dwCallback;
2407 HWND16 hWnd;
2408 WORD wReserved1;
2409 WORD nCmdShow;
2410 WORD wReserved2;
2411 LPCSTR lpstrText;
2412} MCI_ANIM_WINDOW_PARMS16, *LPMCI_ANIM_WINDOW_PARMS16;
2413
2414typedef struct {
2415 DWORD dwCallback;
2416 HWND hWnd;
2417 UINT nCmdShow;
2418 LPCSTR lpstrText;
2419} MCI_ANIM_WINDOW_PARMSA, *LPMCI_ANIM_WINDOW_PARMSA;
2420
2421typedef struct {
2422 DWORD dwCallback;
2423 HWND hWnd;
2424 UINT nCmdShow;
2425 LPCWSTR lpstrText;
2426} MCI_ANIM_WINDOW_PARMSW, *LPMCI_ANIM_WINDOW_PARMSW;
2427
2428DECL_WINELIB_TYPE_AW(MCI_ANIM_WINDOW_PARMS)
2429DECL_WINELIB_TYPE_AW(LPMCI_ANIM_WINDOW_PARMS)
2430
2431typedef struct {
2432 DWORD dwCallback;
2433#ifdef MCI_USE_OFFEXT
2434 POINT16 ptOffset;
2435 POINT16 ptExtent;
2436#else /* ifdef MCI_USE_OFFEXT */
2437 RECT16 rc;
2438#endif /* ifdef MCI_USE_OFFEXT */
2439} MCI_ANIM_RECT_PARMS16, *LPMCI_ANIM_RECT_PARMS16;
2440
2441typedef struct {
2442 DWORD dwCallback;
2443#ifdef MCI_USE_OFFEXT
2444 POINT ptOffset;
2445 POINT ptExtent;
2446#else /* ifdef MCI_USE_OFFEXT */
2447 RECT rc;
2448#endif /* ifdef MCI_USE_OFFEXT */
2449} MCI_ANIM_RECT_PARMS, *LPMCI_ANIM_RECT_PARMS;
2450
2451
2452typedef struct {
2453 DWORD dwCallback;
2454 RECT16 rc;
2455 HDC16 hDC;
2456} MCI_ANIM_UPDATE_PARMS16, *LPMCI_ANIM_UPDATE_PARMS16;
2457
2458typedef struct {
2459 DWORD dwCallback;
2460 RECT rc;
2461 HDC hDC;
2462} MCI_ANIM_UPDATE_PARMS, *LPMCI_ANIM_UPDATE_PARMS;
2463
2464
2465#define MCI_OVLY_OPEN_WS 0x00010000L
2466#define MCI_OVLY_OPEN_PARENT 0x00020000L
2467
2468#define MCI_OVLY_STATUS_HWND 0x00004001L
2469#define MCI_OVLY_STATUS_STRETCH 0x00004002L
2470
2471#define MCI_OVLY_INFO_TEXT 0x00010000L
2472
2473#define MCI_OVLY_GETDEVCAPS_CAN_STRETCH 0x00004001L
2474#define MCI_OVLY_GETDEVCAPS_CAN_FREEZE 0x00004002L
2475#define MCI_OVLY_GETDEVCAPS_MAX_WINDOWS 0x00004003L
2476
2477#define MCI_OVLY_WINDOW_HWND 0x00010000L
2478#define MCI_OVLY_WINDOW_STATE 0x00040000L
2479#define MCI_OVLY_WINDOW_TEXT 0x00080000L
2480#define MCI_OVLY_WINDOW_ENABLE_STRETCH 0x00100000L
2481#define MCI_OVLY_WINDOW_DISABLE_STRETCH 0x00200000L
2482
2483#define MCI_OVLY_WINDOW_DEFAULT 0x00000000L
2484
2485#define MCI_OVLY_RECT 0x00010000L
2486#define MCI_OVLY_PUT_SOURCE 0x00020000L
2487#define MCI_OVLY_PUT_DESTINATION 0x00040000L
2488#define MCI_OVLY_PUT_FRAME 0x00080000L
2489#define MCI_OVLY_PUT_VIDEO 0x00100000L
2490
2491#define MCI_OVLY_WHERE_SOURCE 0x00020000L
2492#define MCI_OVLY_WHERE_DESTINATION 0x00040000L
2493#define MCI_OVLY_WHERE_FRAME 0x00080000L
2494#define MCI_OVLY_WHERE_VIDEO 0x00100000L
2495
2496typedef struct {
2497 DWORD dwCallback;
2498 MCIDEVICEID16 wDeviceID;
2499 WORD wReserved0;
2500 LPCSTR lpstrDeviceType;
2501 LPCSTR lpstrElementName;
2502 LPCSTR lpstrAlias;
2503 DWORD dwStyle;
2504 HWND16 hWndParent;
2505 WORD wReserved1;
2506} MCI_OVLY_OPEN_PARMS16, *LPMCI_OVLY_OPEN_PARMS16;
2507
2508typedef struct {
2509 DWORD dwCallback;
2510 MCIDEVICEID wDeviceID;
2511 LPCSTR lpstrDeviceType;
2512 LPCSTR lpstrElementName;
2513 LPCSTR lpstrAlias;
2514 DWORD dwStyle;
2515 HWND hWndParent;
2516} MCI_OVLY_OPEN_PARMSA, *LPMCI_OVLY_OPEN_PARMSA;
2517
2518typedef struct {
2519 DWORD dwCallback;
2520 MCIDEVICEID wDeviceID;
2521 LPCWSTR lpstrDeviceType;
2522 LPCWSTR lpstrElementName;
2523 LPCWSTR lpstrAlias;
2524 DWORD dwStyle;
2525 HWND hWndParent;
2526} MCI_OVLY_OPEN_PARMSW, *LPMCI_OVLY_OPEN_PARMSW;
2527
2528DECL_WINELIB_TYPE_AW(MCI_OVLY_OPEN_PARMS)
2529DECL_WINELIB_TYPE_AW(LPMCI_OVLY_OPEN_PARMS)
2530
2531typedef struct {
2532 DWORD dwCallback;
2533 HWND16 hWnd;
2534 WORD wReserved1;
2535 UINT16 nCmdShow;
2536 WORD wReserved2;
2537 LPCSTR lpstrText;
2538} MCI_OVLY_WINDOW_PARMS16, *LPMCI_OVLY_WINDOW_PARMS16;
2539
2540typedef struct {
2541 DWORD dwCallback;
2542 HWND hWnd;
2543 UINT nCmdShow;
2544 LPCSTR lpstrText;
2545} MCI_OVLY_WINDOW_PARMSA, *LPMCI_OVLY_WINDOW_PARMSA;
2546
2547typedef struct {
2548 DWORD dwCallback;
2549 HWND hWnd;
2550 UINT nCmdShow;
2551 LPCWSTR lpstrText;
2552} MCI_OVLY_WINDOW_PARMSW, *LPMCI_OVLY_WINDOW_PARMSW;
2553
2554DECL_WINELIB_TYPE_AW(MCI_OVLY_WINDOW_PARMS)
2555DECL_WINELIB_TYPE_AW(LPMCI_OVLY_WINDOW_PARMS)
2556
2557typedef struct {
2558 DWORD dwCallback;
2559#ifdef MCI_USE_OFFEXT
2560 POINT16 ptOffset;
2561 POINT16 ptExtent;
2562#else /* ifdef MCI_USE_OFFEXT */
2563 RECT16 rc;
2564#endif /* ifdef MCI_USE_OFFEXT */
2565} MCI_OVLY_RECT_PARMS16, *LPMCI_OVLY_RECT_PARMS16;
2566
2567typedef struct {
2568 DWORD dwCallback;
2569#ifdef MCI_USE_OFFEXT
2570 POINT ptOffset;
2571 POINT ptExtent;
2572#else /* ifdef MCI_USE_OFFEXT */
2573 RECT rc;
2574#endif /* ifdef MCI_USE_OFFEXT */
2575} MCI_OVLY_RECT_PARMS, *LPMCI_OVLY_RECT_PARMS;
2576
2577
2578typedef struct {
2579 DWORD dwCallback;
2580 LPCSTR lpfilename;
2581 RECT16 rc;
2582} MCI_OVLY_SAVE_PARMS16, *LPMCI_OVLY_SAVE_PARMS16;
2583
2584typedef struct {
2585 DWORD dwCallback;
2586 LPCSTR lpfilename;
2587 RECT rc;
2588} MCI_OVLY_SAVE_PARMSA, *LPMCI_OVLY_SAVE_PARMSA;
2589
2590typedef struct {
2591 DWORD dwCallback;
2592 LPCWSTR lpfilename;
2593 RECT rc;
2594} MCI_OVLY_SAVE_PARMSW, *LPMCI_OVLY_SAVE_PARMSW;
2595
2596DECL_WINELIB_TYPE_AW(MCI_OVLY_SAVE_PARMS)
2597DECL_WINELIB_TYPE_AW(LPMCI_OVLY_SAVE_PARMS)
2598
2599typedef struct {
2600 DWORD dwCallback;
2601 LPCSTR lpfilename;
2602 RECT16 rc;
2603} MCI_OVLY_LOAD_PARMS16, *LPMCI_OVLY_LOAD_PARMS16;
2604
2605typedef struct {
2606 DWORD dwCallback;
2607 LPCSTR lpfilename;
2608 RECT rc;
2609} MCI_OVLY_LOAD_PARMSA, *LPMCI_OVLY_LOAD_PARMSA;
2610
2611typedef struct {
2612 DWORD dwCallback;
2613 LPCWSTR lpfilename;
2614 RECT rc;
2615} MCI_OVLY_LOAD_PARMSW, *LPMCI_OVLY_LOAD_PARMSW;
2616
2617DECL_WINELIB_TYPE_AW(MCI_OVLY_LOAD_PARMS)
2618DECL_WINELIB_TYPE_AW(LPMCI_OVLY_LOAD_PARMS)
2619
2620/**************************************************************
2621 * Linux MMSYSTEM Internals & Sample Audio Drivers
2622 */
2623
2624#define DRVM_INIT 0x64
2625#define DRVM_EXIT 0x65
2626#define DRVM_DISABLE 0x66
2627#define DRVM_ENABLE 0x67
2628
2629#define WODM_INIT DRVM_INIT
2630#define WIDM_INIT DRVM_INIT
2631#define MODM_INIT DRVM_INIT
2632#define MIDM_INIT DRVM_INIT
2633#define AUXM_INIT DRVM_INIT
2634
2635#define WODM_GETNUMDEVS 3
2636#define WODM_GETDEVCAPS 4
2637#define WODM_OPEN 5
2638#define WODM_CLOSE 6
2639#define WODM_PREPARE 7
2640#define WODM_UNPREPARE 8
2641#define WODM_WRITE 9
2642#define WODM_PAUSE 10
2643#define WODM_RESTART 11
2644#define WODM_RESET 12
2645#define WODM_GETPOS 13
2646#define WODM_GETPITCH 14
2647#define WODM_SETPITCH 15
2648#define WODM_GETVOLUME 16
2649#define WODM_SETVOLUME 17
2650#define WODM_GETPLAYBACKRATE 18
2651#define WODM_SETPLAYBACKRATE 19
2652#define WODM_BREAKLOOP 20
2653#define WODM_STOP 21
2654
2655#define WIDM_GETNUMDEVS 50
2656#define WIDM_GETDEVCAPS 51
2657#define WIDM_OPEN 52
2658#define WIDM_CLOSE 53
2659#define WIDM_PREPARE 54
2660#define WIDM_UNPREPARE 55
2661#define WIDM_ADDBUFFER 56
2662#define WIDM_START 57
2663#define WIDM_STOP 58
2664#define WIDM_RESET 59
2665#define WIDM_GETPOS 60
2666#define WIDM_PAUSE 61
2667
2668#define MODM_GETNUMDEVS 1
2669#define MODM_GETDEVCAPS 2
2670#define MODM_OPEN 3
2671#define MODM_CLOSE 4
2672#define MODM_PREPARE 5
2673#define MODM_UNPREPARE 6
2674#define MODM_DATA 7
2675#define MODM_LONGDATA 8
2676#define MODM_RESET 9
2677#define MODM_GETVOLUME 10
2678#define MODM_SETVOLUME 11
2679#define MODM_CACHEPATCHES 12
2680#define MODM_CACHEDRUMPATCHES 13
2681
2682#define MIDM_GETNUMDEVS 53
2683#define MIDM_GETDEVCAPS 54
2684#define MIDM_OPEN 55
2685#define MIDM_CLOSE 56
2686#define MIDM_PREPARE 57
2687#define MIDM_UNPREPARE 58
2688#define MIDM_ADDBUFFER 59
2689#define MIDM_START 60
2690#define MIDM_STOP 61
2691#define MIDM_RESET 62
2692
2693#define AUXDM_GETNUMDEVS 3
2694#define AUXDM_GETDEVCAPS 4
2695#define AUXDM_GETVOLUME 5
2696#define AUXDM_SETVOLUME 6
2697
2698#define MXDM_GETNUMDEVS 1
2699#define MXDM_GETDEVCAPS 2
2700#define MXDM_OPEN 3
2701#define MXDM_CLOSE 4
2702#define MXDM_GETLINEINFO 5
2703#define MXDM_GETLINECONTROLS 6
2704#define MXDM_GETCONTROLDETAILS 7
2705#define MXDM_SETCONTROLDETAILS 8
2706
2707#define MCI_MAX_DEVICE_TYPE_LENGTH 80
2708
2709#define MCI_FALSE (MCI_STRING_OFFSET + 19)
2710#define MCI_TRUE (MCI_STRING_OFFSET + 20)
2711
2712#define MCI_FORMAT_RETURN_BASE MCI_FORMAT_MILLISECONDS_S
2713#define MCI_FORMAT_MILLISECONDS_S (MCI_STRING_OFFSET + 21)
2714#define MCI_FORMAT_HMS_S (MCI_STRING_OFFSET + 22)
2715#define MCI_FORMAT_MSF_S (MCI_STRING_OFFSET + 23)
2716#define MCI_FORMAT_FRAMES_S (MCI_STRING_OFFSET + 24)
2717#define MCI_FORMAT_SMPTE_24_S (MCI_STRING_OFFSET + 25)
2718#define MCI_FORMAT_SMPTE_25_S (MCI_STRING_OFFSET + 26)
2719#define MCI_FORMAT_SMPTE_30_S (MCI_STRING_OFFSET + 27)
2720#define MCI_FORMAT_SMPTE_30DROP_S (MCI_STRING_OFFSET + 28)
2721#define MCI_FORMAT_BYTES_S (MCI_STRING_OFFSET + 29)
2722#define MCI_FORMAT_SAMPLES_S (MCI_STRING_OFFSET + 30)
2723#define MCI_FORMAT_TMSF_S (MCI_STRING_OFFSET + 31)
2724
2725#define MCI_VD_FORMAT_TRACK_S (MCI_VD_OFFSET + 5)
2726
2727#define WAVE_FORMAT_PCM_S (MCI_WAVE_OFFSET + 0)
2728#define WAVE_MAPPER_S (MCI_WAVE_OFFSET + 1)
2729
2730#define MCI_SEQ_MAPPER_S (MCI_SEQ_OFFSET + 5)
2731#define MCI_SEQ_FILE_S (MCI_SEQ_OFFSET + 6)
2732#define MCI_SEQ_MIDI_S (MCI_SEQ_OFFSET + 7)
2733#define MCI_SEQ_SMPTE_S (MCI_SEQ_OFFSET + 8)
2734#define MCI_SEQ_FORMAT_SONGPTR_S (MCI_SEQ_OFFSET + 9)
2735#define MCI_SEQ_NONE_S (MCI_SEQ_OFFSET + 10)
2736#define MIDIMAPPER_S (MCI_SEQ_OFFSET + 11)
2737
2738#define MCI_RESOURCE_RETURNED 0x00010000 /* resource ID */
2739#define MCI_COLONIZED3_RETURN 0x00020000 /* colonized ID, 3 bytes data */
2740#define MCI_COLONIZED4_RETURN 0x00040000 /* colonized ID, 4 bytes data */
2741#define MCI_INTEGER_RETURNED 0x00080000 /* integer conversion needed */
2742#define MCI_RESOURCE_DRIVER 0x00100000 /* driver owns returned resource */
2743
2744#define MCI_NO_COMMAND_TABLE 0xFFFF
2745
2746#define MCI_COMMAND_HEAD 0
2747#define MCI_STRING 1
2748#define MCI_INTEGER 2
2749#define MCI_END_COMMAND 3
2750#define MCI_RETURN 4
2751#define MCI_FLAG 5
2752#define MCI_END_COMMAND_LIST 6
2753#define MCI_RECT 7
2754#define MCI_CONSTANT 8
2755#define MCI_END_CONSTANT 9
2756
2757/* Mixer flags */
2758#define MIXER_OBJECTF_HANDLE 0x80000000L
2759#define MIXER_OBJECTF_MIXER 0x00000000L
2760#define MIXER_OBJECTF_HMIXER (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_MIXER)
2761#define MIXER_OBJECTF_WAVEOUT 0x10000000L
2762#define MIXER_OBJECTF_HWAVEOUT (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_WAVEOUT)
2763#define MIXER_OBJECTF_WAVEIN 0x20000000L
2764#define MIXER_OBJECTF_HWAVEIN (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_WAVEIN)
2765#define MIXER_OBJECTF_MIDIOUT 0x30000000L
2766#define MIXER_OBJECTF_HMIDIOUT (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_MIDIOUT)
2767#define MIXER_OBJECTF_MIDIIN 0x40000000L
2768#define MIXER_OBJECTF_HMIDIIN (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_MIDIIN)
2769#define MIXER_OBJECTF_AUX 0x50000000L
2770
2771#define MAKEMCIRESOURCE(wRet, wRes) MAKELRESULT((wRet), (wRes))
2772
2773/* the 95 DDK defines those slightly different, but they are internal anyway */
2774typedef struct {
2775 DWORD dwCallback;
2776 DWORD dwInstance;
2777 HMIDIOUT16 hMidi;
2778 DWORD dwFlags;
2779} PORTALLOC, *LPPORTALLOC;
2780
2781typedef struct {
2782 HWAVE16 hWave;
2783 LPWAVEFORMAT lpFormat;
2784 DWORD dwCallBack;
2785 DWORD dwInstance;
2786 UINT16 uDeviceID;
2787} WAVEOPENDESC, *LPWAVEOPENDESC;
2788
2789typedef struct {
2790 DWORD dwStreamID;
2791 WORD wDeviceID;
2792} MIDIOPENSTRMID;
2793
2794/* FIXME: this structure has a different mapping in 16 & 32 bit mode
2795 * Since, I don't plan to add support for native 16 bit low level
2796 * multimedia drivers, it'll do.
2797 */
2798typedef struct {
2799 HMIDI16 hMidi;
2800 DWORD dwCallback;
2801 DWORD dwInstance;
2802 UINT16 wDevID;
2803 DWORD dnDevNode;
2804 DWORD cIds;
2805 MIDIOPENSTRMID rgIds;
2806} MIDIOPENDESC, *LPMIDIOPENDESC;
2807
2808typedef struct {
2809 UINT16 wDelay;
2810 UINT16 wResolution;
2811 LPTIMECALLBACK16 lpFunction;
2812 DWORD dwUser;
2813 UINT16 wFlags;
2814} TIMEREVENT, *LPTIMEREVENT;
2815
2816typedef struct tMIXEROPENDESC
2817{
2818 HMIXEROBJ16 hmx;
2819 DWORD dwCallback;
2820 DWORD dwInstance;
2821 UINT16 uDeviceID;
2822} MIXEROPENDESC,*LPMIXEROPENDESC;
2823
2824typedef struct {
2825 UINT16 wDeviceID; /* device ID */
2826 LPSTR lpstrParams; /* parameter string for entry in SYSTEM.INI */
2827 UINT16 wCustomCommandTable; /* custom command table (0xFFFF if none)
2828 * filled in by the driver */
2829 UINT16 wType; /* driver type (filled in by the driver) */
2830} MCI_OPEN_DRIVER_PARMS16, *LPMCI_OPEN_DRIVER_PARMS16;
2831
2832typedef struct {
2833 UINT wDeviceID; /* device ID */
2834 LPSTR lpstrParams; /* parameter string for entry in SYSTEM.INI */
2835 UINT wCustomCommandTable; /* custom command table (0xFFFF if none) * filled in by the driver */
2836 UINT wType; /* driver type (filled in by the driver) */
2837} MCI_OPEN_DRIVER_PARMSA, *LPMCI_OPEN_DRIVER_PARMSA;
2838
2839typedef struct {
2840 UINT wDeviceID; /* device ID */
2841 LPWSTR lpstrParams; /* parameter string for entry in SYSTEM.INI */
2842 UINT wCustomCommandTable; /* custom command table (0xFFFF if none) * filled in by the driver */
2843 UINT wType; /* driver type (filled in by the driver) */
2844} MCI_OPEN_DRIVER_PARMSW, *LPMCI_OPEN_DRIVER_PARMSW;
2845
2846DWORD WINAPI mciGetDriverData16(UINT16 uDeviceID);
2847DWORD WINAPI mciGetDriverData(UINT uDeviceID);
2848
2849BOOL16 WINAPI mciSetDriverData16(UINT16 uDeviceID, DWORD dwData);
2850BOOL WINAPI mciSetDriverData(UINT uDeviceID, DWORD dwData);
2851
2852UINT16 WINAPI mciDriverYield16(UINT16 uDeviceID);
2853UINT WINAPI mciDriverYield(UINT uDeviceID);
2854
2855BOOL16 WINAPI mciDriverNotify16(HWND16 hwndCallback, UINT16 uDeviceID,
2856 UINT16 uStatus);
2857BOOL WINAPI mciDriverNotify(HWND hwndCallback, UINT uDeviceID,
2858 UINT uStatus);
2859
2860UINT16 WINAPI mciLoadCommandResource16(HINSTANCE16 hInstance,
2861 LPCSTR lpResName, UINT16 uType);
2862UINT WINAPI mciLoadCommandResource(HINSTANCE hInstance,
2863 LPCWSTR lpResName, UINT uType);
2864
2865BOOL16 WINAPI mciFreeCommandResource16(UINT16 uTable);
2866BOOL WINAPI mciFreeCommandResource(UINT uTable);
2867
2868#define DCB_NULL 0x0000
2869#define DCB_WINDOW 0x0001 /* dwCallback is a HWND */
2870#define DCB_TASK 0x0002 /* dwCallback is a HTASK */
2871#define DCB_FUNCTION 0x0003 /* dwCallback is a FARPROC */
2872#define DCB_EVENT 0x0005 /* dwCallback is an EVENT Handler */
2873#define DCB_FUNC32 0x0007 /* (ugly hack) 32-bit FARPROC */
2874#define DCB_TYPEMASK 0x0007
2875#define DCB_NOSWITCH 0x0008 /* don't switch stacks for callback */
2876
2877BOOL16 WINAPI DriverCallback16(DWORD dwCallBack, UINT16 uFlags, HANDLE16 hDev,
2878 WORD wMsg, DWORD dwUser, DWORD dwParam1, DWORD dwParam2);
2879DWORD WINAPI auxMessage(WORD wDevID, WORD wMsg, DWORD dwUser,
2880 DWORD dwParam1, DWORD dwParam2);
2881DWORD WINAPI mixMessage(WORD wDevID, WORD wMsg, DWORD dwUser,
2882 DWORD dwParam1, DWORD dwParam2);
2883DWORD WINAPI midMessage(WORD wDevID, WORD wMsg, DWORD dwUser,
2884 DWORD dwParam1, DWORD dwParam2);
2885DWORD WINAPI modMessage(WORD wDevID, WORD wMsg, DWORD dwUser,
2886 DWORD dwParam1, DWORD dwParam2);
2887DWORD WINAPI widMessage(WORD wDevID, WORD wMsg, DWORD dwUser,
2888 DWORD dwParam1, DWORD dwParam2);
2889DWORD WINAPI wodMessage(WORD wDevID, WORD wMsg, DWORD dwUser,
2890 DWORD dwParam1, DWORD dwParam2);
2891#include "poppack.h"
2892
2893#ifdef __cplusplus
2894}
2895#endif
2896
2897#endif /* __WINE_MMSYSTEM_H */
Note: See TracBrowser for help on using the repository browser.