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

Last change on this file since 1036 was 4, checked in by ktk, 26 years ago

Import

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