VirtualBox

source: vbox/trunk/src/VBox/Devices/Graphics/shaderlib/wine/include/mmsystem.h@ 85805

Last change on this file since 85805 was 53206, checked in by vboxsync, 10 years ago

Devices/vmsvga: header fixes

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 92.0 KB
Line 
1/*
2 * MMSYSTEM - Multimedia Wine Extension ... :-)
3 *
4 * Copyright (C) the Wine project
5 *
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
10 *
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 */
20
21/*
22 * Oracle LGPL Disclaimer: For the avoidance of doubt, except that if any license choice
23 * other than GPL or LGPL is available it will apply instead, Oracle elects to use only
24 * the Lesser General Public License version 2.1 (LGPLv2) at this time for any software where
25 * a choice of LGPL license versions is made available with the language indicating
26 * that LGPLv2 or any later version may be used, or where a choice of which version
27 * of the LGPL is applied is otherwise unspecified.
28 */
29
30#ifndef __WINE_MMSYSTEM_H
31#define __WINE_MMSYSTEM_H
32
33#ifdef __cplusplus
34extern "C" {
35#endif
36
37typedef LPSTR HPSTR; /* a huge version of LPSTR */
38typedef LPCSTR HPCSTR; /* a huge version of LPCSTR */
39typedef UINT* LPUINT;
40
41DECLARE_HANDLE(HDRVR);
42DECLARE_HANDLE(HWAVE);
43DECLARE_HANDLE(HWAVEIN);
44DECLARE_HANDLE(HWAVEOUT);
45DECLARE_HANDLE(HMIDI);
46DECLARE_HANDLE(HMIDIIN);
47DECLARE_HANDLE(HMIDIOUT);
48DECLARE_HANDLE(HMIDISTRM);
49DECLARE_HANDLE(HMIXER);
50DECLARE_HANDLE(HMIXEROBJ);
51DECLARE_HANDLE(HMMIO);
52
53typedef HMIDI *LPHMIDI;
54typedef HMIDIIN *LPHMIDIIN;
55typedef HMIDIOUT *LPHMIDIOUT;
56typedef HMIDISTRM *LPHMIDISTRM;
57typedef HMIXER *LPHMIXER;
58typedef HMIXEROBJ *LPHMIXEROBJ;
59typedef HWAVEIN *LPHWAVEIN;
60typedef HWAVEOUT *LPHWAVEOUT;
61
62#include <pshpack1.h>
63
64typedef LRESULT (CALLBACK *DRIVERPROC)(DWORD_PTR,HDRVR,UINT,LPARAM,LPARAM);
65
66#define MAXWAVEDRIVERS 10
67#define MAXMIDIDRIVERS 10
68#define MAXAUXDRIVERS 10
69#define MAXMCIDRIVERS 32
70#define MAXMIXERDRIVERS 10
71
72#define MAXPNAMELEN 32 /* max product name length (including NULL) */
73#define MAXERRORLENGTH 256 /* max error text length (including NULL) */
74#define MAX_JOYSTICKOEMVXDNAME 260
75
76#ifndef _MCIERROR_
77#define _MCIERROR_
78typedef DWORD MCIERROR;
79#endif
80typedef UINT MMVERSION;
81#ifndef _MCIDEVICEID_
82#define _MCIDEVICEID_
83typedef UINT MCIDEVICEID;
84#endif
85typedef UINT MMRESULT;
86
87typedef struct mmtime_tag {
88 UINT wType;
89 union {
90 DWORD ms;
91 DWORD sample;
92 DWORD cb;
93 DWORD ticks;
94 struct {
95 BYTE hour;
96 BYTE min;
97 BYTE sec;
98 BYTE frame;
99 BYTE fps;
100 BYTE dummy;
101 BYTE pad[2];
102 } smpte;
103 struct {
104 DWORD songptrpos;
105 } midi;
106 } u;
107} MMTIME, *PMMTIME, *LPMMTIME;
108
109#define TIME_MS 0x0001 /* time in milliseconds */
110#define TIME_SAMPLES 0x0002 /* number of wave samples */
111#define TIME_BYTES 0x0004 /* current byte offset */
112#define TIME_SMPTE 0x0008 /* SMPTE time */
113#define TIME_MIDI 0x0010 /* MIDI time */
114#define TIME_TICKS 0x0020 /* MIDI ticks */
115
116#define MM_JOY1MOVE 0x3A0 /* joystick */
117#define MM_JOY2MOVE 0x3A1
118#define MM_JOY1ZMOVE 0x3A2
119#define MM_JOY2ZMOVE 0x3A3
120#define MM_JOY1BUTTONDOWN 0x3B5
121#define MM_JOY2BUTTONDOWN 0x3B6
122#define MM_JOY1BUTTONUP 0x3B7
123#define MM_JOY2BUTTONUP 0x3B8
124
125#define MM_MCINOTIFY 0x3B9 /* MCI */
126
127#define MM_WOM_OPEN 0x3BB /* waveform output */
128#define MM_WOM_CLOSE 0x3BC
129#define MM_WOM_DONE 0x3BD
130
131#define MM_WIM_OPEN 0x3BE /* waveform input */
132#define MM_WIM_CLOSE 0x3BF
133#define MM_WIM_DATA 0x3C0
134
135#define MM_MIM_OPEN 0x3C1 /* MIDI input */
136#define MM_MIM_CLOSE 0x3C2
137#define MM_MIM_DATA 0x3C3
138#define MM_MIM_LONGDATA 0x3C4
139#define MM_MIM_ERROR 0x3C5
140#define MM_MIM_LONGERROR 0x3C6
141
142#define MM_MOM_OPEN 0x3C7 /* MIDI output */
143#define MM_MOM_CLOSE 0x3C8
144#define MM_MOM_DONE 0x3C9
145#define MM_MOM_POSITIONCB 0x3CA
146
147#define MM_MIM_MOREDATA 0x3CC
148
149#define MM_MIXM_LINE_CHANGE 0x3D0
150#define MM_MIXM_CONTROL_CHANGE 0x3D1
151
152#define MMSYSERR_BASE 0
153#define WAVERR_BASE 32
154#define MIDIERR_BASE 64
155#define TIMERR_BASE 96
156#define JOYERR_BASE 160
157#define MCIERR_BASE 256
158
159#define MCI_STRING_OFFSET 512
160#define MCI_VD_OFFSET 1024
161#define MCI_CD_OFFSET 1088
162#define MCI_WAVE_OFFSET 1152
163#define MCI_SEQ_OFFSET 1216
164
165#define MMSYSERR_NOERROR 0
166#define MMSYSERR_ERROR (MMSYSERR_BASE + 1)
167#define MMSYSERR_BADDEVICEID (MMSYSERR_BASE + 2)
168#define MMSYSERR_NOTENABLED (MMSYSERR_BASE + 3)
169#define MMSYSERR_ALLOCATED (MMSYSERR_BASE + 4)
170#define MMSYSERR_INVALHANDLE (MMSYSERR_BASE + 5)
171#define MMSYSERR_NODRIVER (MMSYSERR_BASE + 6)
172#define MMSYSERR_NOMEM (MMSYSERR_BASE + 7)
173#define MMSYSERR_NOTSUPPORTED (MMSYSERR_BASE + 8)
174#define MMSYSERR_BADERRNUM (MMSYSERR_BASE + 9)
175#define MMSYSERR_INVALFLAG (MMSYSERR_BASE + 10)
176#define MMSYSERR_INVALPARAM (MMSYSERR_BASE + 11)
177#define MMSYSERR_HANDLEBUSY (MMSYSERR_BASE + 12)
178#define MMSYSERR_INVALIDALIAS (MMSYSERR_BASE + 13)
179#define MMSYSERR_BADDB (MMSYSERR_BASE + 14)
180#define MMSYSERR_KEYNOTFOUND (MMSYSERR_BASE + 15)
181#define MMSYSERR_READERROR (MMSYSERR_BASE + 16)
182#define MMSYSERR_WRITEERROR (MMSYSERR_BASE + 17)
183#define MMSYSERR_DELETEERROR (MMSYSERR_BASE + 18)
184#define MMSYSERR_VALNOTFOUND (MMSYSERR_BASE + 19)
185#define MMSYSERR_NODRIVERCB (MMSYSERR_BASE + 20)
186#define MMSYSERR_MOREDATA (MMSYSERR_BASE + 21)
187#define MMSYSERR_LASTERROR (MMSYSERR_BASE + 21)
188
189#define CALLBACK_TYPEMASK __MSABI_LONG(0x00070000) /* callback type mask */
190#define CALLBACK_NULL __MSABI_LONG(0x00000000) /* no callback */
191#define CALLBACK_WINDOW __MSABI_LONG(0x00010000) /* dwCallback is a HWND */
192#define CALLBACK_TASK __MSABI_LONG(0x00020000) /* dwCallback is a HTASK */
193#define CALLBACK_THREAD (CALLBACK_TASK) /* dwCallback is a thread ID */
194#define CALLBACK_FUNCTION __MSABI_LONG(0x00030000) /* dwCallback is a FARPROC */
195#define CALLBACK_EVENT __MSABI_LONG(0x00050000) /* dwCallback is an EVENT Handler */
196
197#define DRV_LOAD 0x0001
198#define DRV_ENABLE 0x0002
199#define DRV_OPEN 0x0003
200#define DRV_CLOSE 0x0004
201#define DRV_DISABLE 0x0005
202#define DRV_FREE 0x0006
203#define DRV_CONFIGURE 0x0007
204#define DRV_QUERYCONFIGURE 0x0008
205#define DRV_INSTALL 0x0009
206#define DRV_REMOVE 0x000A
207#define DRV_EXITSESSION 0x000B
208#define DRV_EXITAPPLICATION 0x000C
209#define DRV_POWER 0x000F
210
211#define DRV_RESERVED 0x0800
212#define DRV_MCI_FIRST DRV_RESERVED
213#define DRV_MCI_LAST (0xFFF + DRV_MCI_FIRST)
214#define DRV_USER 0x4000
215
216#define DRVCNF_CANCEL 0x0000
217#define DRVCNF_OK 0x0001
218#define DRVCNF_RESTART 0x0002
219
220#define DRVEA_NORMALEXIT 0x0001
221#define DRVEA_ABNORMALEXIT 0x0002
222
223#define DRV_SUCCESS 0x0001
224#define DRV_FAILURE 0x0000
225
226#define GND_FIRSTINSTANCEONLY 0x00000001
227
228#define GND_FORWARD 0x00000000
229#define GND_REVERSE 0x00000002
230
231typedef struct tagDRVCONFIGINFO {
232 DWORD dwDCISize;
233 LPCWSTR lpszDCISectionName;
234 LPCWSTR lpszDCIAliasName;
235} DRVCONFIGINFO, *LPDRVCONFIGINFO;
236
237
238LRESULT WINAPI DefDriverProc(DWORD_PTR,HDRVR,UINT,LPARAM,LPARAM);
239/* this sounds odd, but it's the way it is. OpenDriverA even disappeared
240 * from latest SDK
241 */
242HDRVR WINAPI OpenDriverA(LPCSTR szDriverName, LPCSTR szSectionName,
243 LPARAM lParam2);
244HDRVR WINAPI OpenDriver(LPCWSTR szDriverName, LPCWSTR szSectionName,
245 LPARAM lParam2);
246LRESULT WINAPI CloseDriver(HDRVR hDriver, LPARAM lParam1, LPARAM lParam2);
247LRESULT WINAPI SendDriverMessage(HDRVR hDriver, UINT message,
248 LPARAM lParam1, LPARAM lParam2);
249HMODULE WINAPI GetDriverModuleHandle(HDRVR hDriver);
250
251DWORD WINAPI GetDriverFlags(HDRVR hDriver);
252
253typedef void (CALLBACK *LPDRVCALLBACK)(HDRVR,UINT,DWORD_PTR,DWORD_PTR,DWORD_PTR);
254
255#define MM_MICROSOFT 1 /* Microsoft Corp. */
256#define MM_CREATIVE 2 /* Creative labs */
257
258#define MM_MIDI_MAPPER 1 /* MIDI Mapper */
259#define MM_WAVE_MAPPER 2 /* Wave Mapper */
260
261#define MM_SNDBLST_MIDIOUT 3 /* Sound Blaster MIDI output port */
262#define MM_SNDBLST_MIDIIN 4 /* Sound Blaster MIDI input port */
263#define MM_SNDBLST_SYNTH 5 /* Sound Blaster internal synthesizer */
264#define MM_SNDBLST_WAVEOUT 6 /* Sound Blaster waveform output */
265#define MM_SNDBLST_WAVEIN 7 /* Sound Blaster waveform input */
266
267#define MM_ADLIB 9 /* Ad Lib-compatible synthesizer */
268
269#define MM_MPU401_MIDIOUT 10 /* MPU401-compatible MIDI output port */
270#define MM_MPU401_MIDIIN 11 /* MPU401-compatible MIDI input port */
271
272#define MM_PC_JOYSTICK 12 /* Joystick adapter */
273
274#define MM_CREATIVE_SBP16_WAVEOUT 104
275
276UINT WINAPI mmsystemGetVersion(void);
277BOOL WINAPI sndPlaySoundA(LPCSTR lpszSound, UINT fuSound);
278BOOL WINAPI sndPlaySoundW(LPCWSTR lpszSound, UINT fuSound);
279#define sndPlaySound WINELIB_NAME_AW(sndPlaySound)
280BOOL WINAPI PlaySoundA(LPCSTR pszSound, HMODULE hmod, DWORD fdwSound);
281BOOL WINAPI PlaySoundW(LPCWSTR pszSound, HMODULE hmod, DWORD fdwSound);
282#define PlaySound WINELIB_NAME_AW(PlaySound)
283
284#define SND_SYNC 0x0000 /* play synchronously (default) */
285#define SND_ASYNC 0x0001 /* play asynchronously */
286#define SND_NODEFAULT 0x0002 /* don't use default sound */
287#define SND_MEMORY 0x0004 /* lpszSoundName points to a memory file */
288#define SND_LOOP 0x0008 /* loop the sound until next sndPlaySound */
289#define SND_NOSTOP 0x0010 /* don't stop any currently playing sound */
290
291#define SND_NOWAIT __MSABI_LONG(0x00002000) /* don't wait if the driver is busy */
292#define SND_ALIAS __MSABI_LONG(0x00010000) /* name is a registry alias */
293#define SND_ALIAS_ID __MSABI_LONG(0x00110000) /* alias is a predefined ID */
294#define SND_FILENAME __MSABI_LONG(0x00020000) /* name is file name */
295#define SND_RESOURCE __MSABI_LONG(0x00040004) /* name is resource name or atom */
296#define SND_PURGE __MSABI_LONG(0x00000040) /* purge all sounds */
297#define SND_APPLICATION __MSABI_LONG(0x00000080) /* look for application specific association */
298
299#define SND_ALIAS_START 0
300
301#define sndAlias(ch0, ch1) (SND_ALIAS_START + ((DWORD)(BYTE)(ch0) | ((DWORD)(BYTE)(ch1) << 8)))
302
303#define SND_ALIAS_SYSTEMASTERISK sndAlias('S', '*')
304#define SND_ALIAS_SYSTEMQUESTION sndAlias('S', '?')
305#define SND_ALIAS_SYSTEMHAND sndAlias('S', 'H')
306#define SND_ALIAS_SYSTEMEXIT sndAlias('S', 'E')
307#define SND_ALIAS_SYSTEMSTART sndAlias('S', 'S')
308#define SND_ALIAS_SYSTEMWELCOME sndAlias('S', 'W')
309#define SND_ALIAS_SYSTEMEXCLAMATION sndAlias('S', '!')
310#define SND_ALIAS_SYSTEMDEFAULT sndAlias('S', 'D')
311
312/* waveform audio error return values */
313#define WAVERR_BADFORMAT (WAVERR_BASE + 0) /* unsupported wave format */
314#define WAVERR_STILLPLAYING (WAVERR_BASE + 1) /* still something playing */
315#define WAVERR_UNPREPARED (WAVERR_BASE + 2) /* header not prepared */
316#define WAVERR_SYNC (WAVERR_BASE + 3) /* device is synchronous */
317#define WAVERR_LASTERROR (WAVERR_BASE + 3) /* last error in range */
318
319typedef LPDRVCALLBACK LPWAVECALLBACK;
320
321#define WOM_OPEN MM_WOM_OPEN
322#define WOM_CLOSE MM_WOM_CLOSE
323#define WOM_DONE MM_WOM_DONE
324#define WIM_OPEN MM_WIM_OPEN
325#define WIM_CLOSE MM_WIM_CLOSE
326#define WIM_DATA MM_WIM_DATA
327
328#define WAVE_MAPPER (-1)
329
330#define WAVE_FORMAT_QUERY 0x0001
331#define WAVE_ALLOWSYNC 0x0002
332#define WAVE_MAPPED 0x0004
333#define WAVE_FORMAT_DIRECT 0x0008
334#define WAVE_FORMAT_DIRECT_QUERY (WAVE_FORMAT_QUERY | WAVE_FORMAT_DIRECT)
335
336typedef struct wavehdr_tag {
337 LPSTR lpData;
338 DWORD dwBufferLength;
339 DWORD dwBytesRecorded;
340 DWORD_PTR dwUser;
341 DWORD dwFlags;
342 DWORD dwLoops;
343 struct wavehdr_tag *lpNext;
344 DWORD_PTR reserved;
345} WAVEHDR, *PWAVEHDR, *NPWAVEHDR, *LPWAVEHDR;
346
347#define WHDR_DONE 0x00000001
348#define WHDR_PREPARED 0x00000002
349#define WHDR_BEGINLOOP 0x00000004
350#define WHDR_ENDLOOP 0x00000008
351#define WHDR_INQUEUE 0x00000010
352
353typedef struct tagWAVEOUTCAPSA {
354 WORD wMid;
355 WORD wPid;
356 MMVERSION vDriverVersion;
357 CHAR szPname[MAXPNAMELEN];
358 DWORD dwFormats;
359 WORD wChannels;
360 WORD wReserved1;
361 DWORD dwSupport;
362} WAVEOUTCAPSA, *LPWAVEOUTCAPSA;
363
364typedef struct tagWAVEOUTCAPSW {
365 WORD wMid;
366 WORD wPid;
367 MMVERSION vDriverVersion;
368 WCHAR szPname[MAXPNAMELEN];
369 DWORD dwFormats;
370 WORD wChannels;
371 WORD wReserved1;
372 DWORD dwSupport;
373} WAVEOUTCAPSW, *LPWAVEOUTCAPSW;
374DECL_WINELIB_TYPE_AW(WAVEOUTCAPS)
375DECL_WINELIB_TYPE_AW(LPWAVEOUTCAPS)
376
377typedef struct tagWAVEOUTCAPS2A {
378 WORD wMid;
379 WORD wPid;
380 MMVERSION vDriverVersion;
381 CHAR szPname[MAXPNAMELEN];
382 DWORD dwFormats;
383 WORD wChannels;
384 WORD wReserved1;
385 DWORD dwSupport;
386 GUID ManufacturerGuid;
387 GUID ProductGuid;
388 GUID NameGuid;
389} WAVEOUTCAPS2A, *LPWAVEOUTCAPS2A;
390
391typedef struct tagWAVEOUTCAPS2W {
392 WORD wMid;
393 WORD wPid;
394 MMVERSION vDriverVersion;
395 WCHAR szPname[MAXPNAMELEN];
396 DWORD dwFormats;
397 WORD wChannels;
398 WORD wReserved1;
399 DWORD dwSupport;
400 GUID ManufacturerGuid;
401 GUID ProductGuid;
402 GUID NameGuid;
403} WAVEOUTCAPS2W, *LPWAVEOUTCAPS2W;
404DECL_WINELIB_TYPE_AW(WAVEOUTCAPS2)
405DECL_WINELIB_TYPE_AW(LPWAVEOUTCAPS2)
406
407#define WAVECAPS_PITCH 0x0001 /* supports pitch control */
408#define WAVECAPS_PLAYBACKRATE 0x0002 /* supports playback rate control */
409#define WAVECAPS_VOLUME 0x0004 /* supports volume control */
410#define WAVECAPS_LRVOLUME 0x0008 /* separate left-right volume control */
411#define WAVECAPS_SYNC 0x0010 /* driver is synchronous and playing is blocking */
412#define WAVECAPS_SAMPLEACCURATE 0x0020 /* position is sample accurate */
413#define WAVECAPS_DIRECTSOUND 0x0040 /* ? */
414
415typedef struct tagWAVEINCAPSA {
416 WORD wMid;
417 WORD wPid;
418 MMVERSION vDriverVersion;
419 CHAR szPname[MAXPNAMELEN];
420 DWORD dwFormats;
421 WORD wChannels;
422 WORD wReserved1;
423} WAVEINCAPSA, *LPWAVEINCAPSA;
424typedef struct tagWAVEINCAPSW {
425 WORD wMid;
426 WORD wPid;
427 MMVERSION vDriverVersion;
428 WCHAR szPname[MAXPNAMELEN];
429 DWORD dwFormats;
430 WORD wChannels;
431 WORD wReserved1;
432} WAVEINCAPSW, *LPWAVEINCAPSW;
433DECL_WINELIB_TYPE_AW(WAVEINCAPS)
434DECL_WINELIB_TYPE_AW(LPWAVEINCAPS)
435
436typedef struct tagWAVEINCAPS2A {
437 WORD wMid;
438 WORD wPid;
439 MMVERSION vDriverVersion;
440 CHAR szPname[MAXPNAMELEN];
441 DWORD dwFormats;
442 WORD wChannels;
443 WORD wReserved1;
444 GUID ManufacturerGuid;
445 GUID ProductGuid;
446 GUID NameGuid;
447} WAVEINCAPS2A, *LPWAVEINCAPS2A;
448typedef struct tagWAVEINCAPS2W {
449 WORD wMid;
450 WORD wPid;
451 MMVERSION vDriverVersion;
452 WCHAR szPname[MAXPNAMELEN];
453 DWORD dwFormats;
454 WORD wChannels;
455 WORD wReserved1;
456 GUID ManufacturerGuid;
457 GUID ProductGuid;
458 GUID NameGuid;
459} WAVEINCAPS2W, *LPWAVEINCAPS2W;
460DECL_WINELIB_TYPE_AW(WAVEINCAPS2)
461DECL_WINELIB_TYPE_AW(LPWAVEINCAPS2)
462
463#define WAVE_INVALIDFORMAT 0x00000000 /* invalid format */
464#define WAVE_FORMAT_1M08 0x00000001 /* 11.025 kHz, Mono, 8-bit */
465#define WAVE_FORMAT_1S08 0x00000002 /* 11.025 kHz, Stereo, 8-bit */
466#define WAVE_FORMAT_1M16 0x00000004 /* 11.025 kHz, Mono, 16-bit */
467#define WAVE_FORMAT_1S16 0x00000008 /* 11.025 kHz, Stereo, 16-bit */
468#define WAVE_FORMAT_2M08 0x00000010 /* 22.05 kHz, Mono, 8-bit */
469#define WAVE_FORMAT_2S08 0x00000020 /* 22.05 kHz, Stereo, 8-bit */
470#define WAVE_FORMAT_2M16 0x00000040 /* 22.05 kHz, Mono, 16-bit */
471#define WAVE_FORMAT_2S16 0x00000080 /* 22.05 kHz, Stereo, 16-bit */
472#define WAVE_FORMAT_4M08 0x00000100 /* 44.1 kHz, Mono, 8-bit */
473#define WAVE_FORMAT_4S08 0x00000200 /* 44.1 kHz, Stereo, 8-bit */
474#define WAVE_FORMAT_4M16 0x00000400 /* 44.1 kHz, Mono, 16-bit */
475#define WAVE_FORMAT_4S16 0x00000800 /* 44.1 kHz, Stereo, 16-bit */
476#define WAVE_FORMAT_48M08 0x00001000 /* 48 kHz, Mono, 8-bit */
477#define WAVE_FORMAT_48S08 0x00002000 /* 48 kHz, Stereo, 8-bit */
478#define WAVE_FORMAT_48M16 0x00004000 /* 48 kHz, Mono, 16-bit */
479#define WAVE_FORMAT_48S16 0x00008000 /* 48 kHz, Stereo, 16-bit */
480#define WAVE_FORMAT_96M08 0x00010000 /* 96 kHz, Mono, 8-bit */
481#define WAVE_FORMAT_96S08 0x00020000 /* 96 kHz, Stereo, 8-bit */
482#define WAVE_FORMAT_96M16 0x00040000 /* 96 kHz, Mono, 16-bit */
483#define WAVE_FORMAT_96S16 0x00080000 /* 96 kHz, Stereo, 16-bit */
484
485/* General format structure common to all formats, same for Win16 and Win32 */
486typedef struct waveformat_tag {
487 WORD wFormatTag;
488 WORD nChannels;
489 DWORD nSamplesPerSec;
490 DWORD nAvgBytesPerSec;
491 WORD nBlockAlign;
492} WAVEFORMAT, *LPWAVEFORMAT;
493
494#define WAVE_FORMAT_PCM 1
495
496typedef struct pcmwaveformat_tag {
497 WAVEFORMAT wf;
498 WORD wBitsPerSample;
499} PCMWAVEFORMAT, *LPPCMWAVEFORMAT;
500
501#ifndef _WAVEFORMATEX_
502#define _WAVEFORMATEX_
503/* ditto same for Win16 / Win32 */
504typedef struct tWAVEFORMATEX {
505 WORD wFormatTag;
506 WORD nChannels;
507 DWORD nSamplesPerSec;
508 DWORD nAvgBytesPerSec;
509 WORD nBlockAlign;
510 WORD wBitsPerSample;
511 WORD cbSize;
512} WAVEFORMATEX, *LPWAVEFORMATEX, *NPWAVEFORMATEX, *PWAVEFORMATEX;
513#endif
514typedef const WAVEFORMATEX *LPCWAVEFORMATEX;
515
516UINT WINAPI waveOutGetNumDevs(void);
517UINT WINAPI waveOutGetDevCapsA(UINT_PTR,LPWAVEOUTCAPSA,UINT);
518UINT WINAPI waveOutGetDevCapsW(UINT_PTR,LPWAVEOUTCAPSW,UINT);
519#define waveOutGetDevCaps WINELIB_NAME_AW(waveOutGetDevCaps)
520UINT WINAPI waveOutGetVolume(HWAVEOUT,DWORD*);
521UINT WINAPI waveOutSetVolume(HWAVEOUT,DWORD);
522UINT WINAPI waveOutGetErrorTextA(UINT,LPSTR,UINT);
523UINT WINAPI waveOutGetErrorTextW(UINT,LPWSTR,UINT);
524#define waveOutGetErrorText WINELIB_NAME_AW(waveOutGetErrorText)
525MMRESULT WINAPI waveOutOpen(HWAVEOUT*,UINT,LPCWAVEFORMATEX,DWORD_PTR,DWORD_PTR,DWORD);
526UINT WINAPI waveOutClose(HWAVEOUT);
527UINT WINAPI waveOutPrepareHeader(HWAVEOUT,WAVEHDR*,UINT);
528UINT WINAPI waveOutUnprepareHeader(HWAVEOUT,WAVEHDR*,UINT);
529UINT WINAPI waveOutWrite(HWAVEOUT,WAVEHDR*,UINT);
530UINT WINAPI waveOutPause(HWAVEOUT);
531UINT WINAPI waveOutRestart(HWAVEOUT);
532UINT WINAPI waveOutReset(HWAVEOUT);
533UINT WINAPI waveOutBreakLoop(HWAVEOUT);
534UINT WINAPI waveOutGetPosition(HWAVEOUT,LPMMTIME,UINT);
535UINT WINAPI waveOutGetPitch(HWAVEOUT,DWORD*);
536UINT WINAPI waveOutSetPitch(HWAVEOUT,DWORD);
537UINT WINAPI waveOutGetPlaybackRate(HWAVEOUT,DWORD*);
538UINT WINAPI waveOutSetPlaybackRate(HWAVEOUT,DWORD);
539UINT WINAPI waveOutGetID(HWAVEOUT,UINT*);
540UINT WINAPI waveOutMessage(HWAVEOUT,UINT,DWORD_PTR,DWORD_PTR);
541UINT WINAPI waveInGetNumDevs(void);
542UINT WINAPI waveInGetDevCapsA(UINT_PTR,LPWAVEINCAPSA,UINT);
543UINT WINAPI waveInGetDevCapsW(UINT_PTR,LPWAVEINCAPSW,UINT);
544#define waveInGetDevCaps WINELIB_NAME_AW(waveInGetDevCaps)
545UINT WINAPI waveInGetErrorTextA(UINT,LPSTR,UINT);
546UINT WINAPI waveInGetErrorTextW(UINT,LPWSTR,UINT);
547#define waveInGetErrorText WINELIB_NAME_AW(waveInGetErrorText)
548MMRESULT WINAPI waveInOpen(HWAVEIN*,UINT,LPCWAVEFORMATEX,DWORD_PTR,DWORD_PTR,DWORD);
549UINT WINAPI waveInClose(HWAVEIN);
550UINT WINAPI waveInPrepareHeader(HWAVEIN,WAVEHDR*,UINT);
551UINT WINAPI waveInUnprepareHeader(HWAVEIN,WAVEHDR*,UINT);
552UINT WINAPI waveInAddBuffer(HWAVEIN,WAVEHDR*,UINT);
553UINT WINAPI waveInStart(HWAVEIN);
554UINT WINAPI waveInStop(HWAVEIN);
555UINT WINAPI waveInReset(HWAVEIN);
556UINT WINAPI waveInGetPosition(HWAVEIN,LPMMTIME,UINT);
557UINT WINAPI waveInGetID(HWAVEIN,UINT*);
558UINT WINAPI waveInMessage(HWAVEIN,UINT,DWORD_PTR,DWORD_PTR);
559
560#define MIDIERR_UNPREPARED (MIDIERR_BASE + 0)
561#define MIDIERR_STILLPLAYING (MIDIERR_BASE + 1)
562#define MIDIERR_NOMAP (MIDIERR_BASE + 2)
563#define MIDIERR_NOTREADY (MIDIERR_BASE + 3)
564#define MIDIERR_NODEVICE (MIDIERR_BASE + 4)
565#define MIDIERR_INVALIDSETUP (MIDIERR_BASE + 5)
566#define MIDIERR_BADOPENMODE (MIDIERR_BASE + 6)
567#define MIDIERR_DONT_CONTINUE (MIDIERR_BASE + 7)
568#define MIDIERR_LASTERROR (MIDIERR_BASE + 7)
569
570typedef LPDRVCALLBACK LPMIDICALLBACK;
571#define MIDIPATCHSIZE 128
572typedef WORD PATCHARRAY[MIDIPATCHSIZE];
573typedef WORD *LPPATCHARRAY;
574typedef WORD KEYARRAY[MIDIPATCHSIZE];
575typedef WORD *LPKEYARRAY;
576
577#define MIM_OPEN MM_MIM_OPEN
578#define MIM_CLOSE MM_MIM_CLOSE
579#define MIM_DATA MM_MIM_DATA
580#define MIM_LONGDATA MM_MIM_LONGDATA
581#define MIM_ERROR MM_MIM_ERROR
582#define MIM_LONGERROR MM_MIM_LONGERROR
583#define MIM_MOREDATA MM_MIM_MOREDATA
584
585#define MOM_OPEN MM_MOM_OPEN
586#define MOM_CLOSE MM_MOM_CLOSE
587#define MOM_DONE MM_MOM_DONE
588#define MOM_POSITIONCB MM_MOM_POSITIONCB
589
590/* device ID for MIDI mapper */
591
592#define MIDIMAPPER (-1)
593#define MIDI_MAPPER (-1)
594
595/* Only on Win95 and up */
596#define MIDI_IO_STATUS __MSABI_LONG(0x00000020)
597
598/* flags for wFlags parm of
599 midiOutCachePatches(),
600 midiOutCacheDrumPatches() */
601#define MIDI_CACHE_ALL 1
602#define MIDI_CACHE_BESTFIT 2
603#define MIDI_CACHE_QUERY 3
604#define MIDI_UNCACHE 4
605
606typedef struct tagMIDIOUTCAPSA {
607 WORD wMid;
608 WORD wPid;
609 MMVERSION vDriverVersion;
610 CHAR szPname[MAXPNAMELEN];
611 WORD wTechnology;
612 WORD wVoices;
613 WORD wNotes;
614 WORD wChannelMask;
615 DWORD dwSupport;
616} MIDIOUTCAPSA, *LPMIDIOUTCAPSA;
617
618typedef struct tagMIDIOUTCAPSW {
619 WORD wMid;
620 WORD wPid;
621 MMVERSION vDriverVersion;
622 WCHAR szPname[MAXPNAMELEN];
623 WORD wTechnology;
624 WORD wVoices;
625 WORD wNotes;
626 WORD wChannelMask;
627 DWORD dwSupport;
628} MIDIOUTCAPSW, *LPMIDIOUTCAPSW;
629
630DECL_WINELIB_TYPE_AW(MIDIOUTCAPS)
631DECL_WINELIB_TYPE_AW(LPMIDIOUTCAPS)
632
633typedef struct tagMIDIOUTCAPS2A {
634 WORD wMid;
635 WORD wPid;
636 MMVERSION vDriverVersion;
637 CHAR szPname[MAXPNAMELEN];
638 WORD wTechnology;
639 WORD wVoices;
640 WORD wNotes;
641 WORD wChannelMask;
642 DWORD dwSupport;
643 GUID ManufacturerGuid;
644 GUID ProductGuid;
645 GUID NameGuid;
646} MIDIOUTCAPS2A, *LPMIDIOUTCAPS2A;
647
648typedef struct tagMIDIOUTCAPS2W {
649 WORD wMid;
650 WORD wPid;
651 MMVERSION vDriverVersion;
652 WCHAR szPname[MAXPNAMELEN];
653 WORD wTechnology;
654 WORD wVoices;
655 WORD wNotes;
656 WORD wChannelMask;
657 DWORD dwSupport;
658 GUID ManufacturerGuid;
659 GUID ProductGuid;
660 GUID NameGuid;
661} MIDIOUTCAPS2W, *LPMIDIOUTCAPS2W;
662
663DECL_WINELIB_TYPE_AW(MIDIOUTCAPS2)
664DECL_WINELIB_TYPE_AW(LPMIDIOUTCAPS2)
665
666#define MOD_MIDIPORT 1 /* output port */
667#define MOD_SYNTH 2 /* generic internal synth */
668#define MOD_SQSYNTH 3 /* square wave internal synth */
669#define MOD_FMSYNTH 4 /* FM internal synth */
670#define MOD_MAPPER 5 /* MIDI mapper */
671#define MOD_WAVETABLE 6 /* hardware wavetable internal synth */
672#define MOD_SWSYNTH 7 /* software synth */
673
674#define MIDICAPS_VOLUME 0x0001 /* supports volume control */
675#define MIDICAPS_LRVOLUME 0x0002 /* separate left-right volume control */
676#define MIDICAPS_CACHE 0x0004
677#define MIDICAPS_STREAM 0x0008 /* capable of supporting stream buffer */
678
679typedef struct tagMIDIINCAPSA {
680 WORD wMid;
681 WORD wPid;
682 MMVERSION vDriverVersion;
683 CHAR szPname[MAXPNAMELEN];
684 DWORD dwSupport;
685} MIDIINCAPSA, *LPMIDIINCAPSA;
686
687typedef struct tagMIDIINCAPSW {
688 WORD wMid;
689 WORD wPid;
690 MMVERSION vDriverVersion;
691 WCHAR szPname[MAXPNAMELEN];
692 DWORD dwSupport;
693} MIDIINCAPSW, *LPMIDIINCAPSW;
694
695DECL_WINELIB_TYPE_AW(MIDIINCAPS)
696DECL_WINELIB_TYPE_AW(LPMIDIINCAPS)
697
698typedef struct tagMIDIINCAPS2A {
699 WORD wMid;
700 WORD wPid;
701 MMVERSION vDriverVersion;
702 CHAR szPname[MAXPNAMELEN];
703 DWORD dwSupport;
704 GUID ManufacturerGuid;
705 GUID ProductGuid;
706 GUID NameGuid;
707} MIDIINCAPS2A, *LPMIDIINCAPS2A;
708
709typedef struct tagMIDIINCAPS2W {
710 WORD wMid;
711 WORD wPid;
712 MMVERSION vDriverVersion;
713 WCHAR szPname[MAXPNAMELEN];
714 DWORD dwSupport;
715 GUID ManufacturerGuid;
716 GUID ProductGuid;
717 GUID NameGuid;
718} MIDIINCAPS2W, *LPMIDIINCAPS2W;
719
720DECL_WINELIB_TYPE_AW(MIDIINCAPS2)
721DECL_WINELIB_TYPE_AW(LPMIDIINCAPS2)
722
723/* It seems that Win32 has a slightly different structure than Win 16.
724 * sigh....
725 */
726typedef struct midihdr_tag {
727 LPSTR lpData;
728 DWORD dwBufferLength;
729 DWORD dwBytesRecorded;
730 DWORD_PTR dwUser;
731 DWORD dwFlags;
732 struct midihdr_tag *lpNext;
733 DWORD_PTR reserved;
734 /* Win 32 extended the structure with these 2 fields */
735 DWORD dwOffset;
736 DWORD_PTR dwReserved[8];
737} MIDIHDR, *LPMIDIHDR;
738
739#define MHDR_DONE 0x00000001 /* done bit */
740#define MHDR_PREPARED 0x00000002 /* set if header prepared */
741#define MHDR_INQUEUE 0x00000004 /* reserved for driver */
742#define MHDR_ISSTRM 0x00000008 /* data is sent by Stream functions */
743
744typedef struct midiproptempo_tag {
745 DWORD cbStruct;
746 DWORD dwTempo;
747} MIDIPROPTEMPO, *LPMIDIPROPTEMPO;
748
749typedef struct midiproptimediv_tag {
750 DWORD cbStruct;
751 DWORD dwTimeDiv;
752} MIDIPROPTIMEDIV, *LPMIDIPROPTIMEDIV;
753
754#define MIDIPROP_GET 0x40000000
755#define MIDIPROP_SET 0x80000000
756#define MIDIPROP_TEMPO 0x00000002
757#define MIDIPROP_TIMEDIV 0x00000001
758
759typedef struct midievent_tag {
760 DWORD dwDeltaTime; /* Time, in MIDI ticks, between the previous
761 * event and the current event. */
762 DWORD dwStreamID; /* Reserved; must be zero. */
763 DWORD dwEvent; /* event => see MEVT_XXX macros */
764 DWORD dwParms[1]; /* extra pmts to dwEvent if F_LONG is set */
765} MIDIEVENT, *LPMIDIEVENT;
766
767#define MEVT_EVENTTYPE(x) ((BYTE) (((x)>>24)&0xFF))
768#define MEVT_EVENTPARM(x) ((DWORD) ((x)&0x00FFFFFF))
769
770#define MEVT_F_CALLBACK __MSABI_LONG(0x40000000)
771#define MEVT_F_LONG __MSABI_LONG(0x80000000)
772#define MEVT_F_SHORT __MSABI_LONG(0x00000000)
773#define MEVT_COMMENT ((BYTE)0x82)
774#define MEVT_LONGMSG ((BYTE)0x80)
775#define MEVT_NOP ((BYTE)0x02)
776#define MEVT_SHORTMSG ((BYTE)0x00)
777#define MEVT_TEMPO ((BYTE)0x01)
778#define MEVT_VERSION ((BYTE)0x84)
779
780UINT WINAPI midiOutGetNumDevs(void);
781UINT WINAPI midiOutGetDevCapsA(UINT_PTR,LPMIDIOUTCAPSA,UINT);
782UINT WINAPI midiOutGetDevCapsW(UINT_PTR,LPMIDIOUTCAPSW,UINT);
783#define midiOutGetDevCaps WINELIB_NAME_AW(midiOutGetDevCaps)
784UINT WINAPI midiOutGetVolume(HMIDIOUT,DWORD*);
785UINT WINAPI midiOutSetVolume(HMIDIOUT,DWORD);
786UINT WINAPI midiOutGetErrorTextA(UINT,LPSTR,UINT);
787UINT WINAPI midiOutGetErrorTextW(UINT,LPWSTR,UINT);
788#define midiOutGetErrorText WINELIB_NAME_AW(midiOutGetErrorText)
789UINT WINAPI midiOutOpen(LPHMIDIOUT,UINT,DWORD_PTR,DWORD_PTR,DWORD);
790UINT WINAPI midiOutClose(HMIDIOUT);
791UINT WINAPI midiOutPrepareHeader(HMIDIOUT,MIDIHDR*,UINT);
792UINT WINAPI midiOutUnprepareHeader(HMIDIOUT,MIDIHDR*,UINT);
793UINT WINAPI midiOutShortMsg(HMIDIOUT,DWORD);
794UINT WINAPI midiOutLongMsg(HMIDIOUT,MIDIHDR*,UINT);
795UINT WINAPI midiOutReset(HMIDIOUT);
796UINT WINAPI midiOutCachePatches(HMIDIOUT,UINT,WORD*,UINT);
797UINT WINAPI midiOutCacheDrumPatches(HMIDIOUT,UINT,WORD*,UINT);
798UINT WINAPI midiOutGetID(HMIDIOUT,UINT*);
799UINT WINAPI midiOutMessage(HMIDIOUT,UINT,DWORD_PTR,DWORD_PTR);
800
801UINT WINAPI midiInGetNumDevs(void);
802UINT WINAPI midiInGetDevCapsA(UINT_PTR,LPMIDIINCAPSA,UINT);
803UINT WINAPI midiInGetDevCapsW(UINT_PTR,LPMIDIINCAPSW,UINT);
804#define midiInGetDevCaps WINELIB_NAME_AW(midiInGetDevCaps)
805UINT WINAPI midiInGetErrorTextA(UINT,LPSTR,UINT);
806UINT WINAPI midiInGetErrorTextW(UINT,LPWSTR,UINT);
807#define midiInGetErrorText WINELIB_NAME_AW(midiInGetErrorText)
808UINT WINAPI midiInOpen(LPHMIDIIN,UINT,DWORD_PTR,DWORD_PTR,DWORD);
809UINT WINAPI midiInClose(HMIDIIN);
810UINT WINAPI midiInPrepareHeader(HMIDIIN,MIDIHDR*,UINT);
811UINT WINAPI midiInUnprepareHeader(HMIDIIN,MIDIHDR*,UINT);
812UINT WINAPI midiInAddBuffer(HMIDIIN,MIDIHDR*,UINT);
813UINT WINAPI midiInStart(HMIDIIN);
814UINT WINAPI midiInStop(HMIDIIN);
815UINT WINAPI midiInReset(HMIDIIN);
816UINT WINAPI midiInGetID(HMIDIIN,UINT*);
817UINT WINAPI midiInMessage(HMIDIIN,UINT,DWORD_PTR,DWORD_PTR);
818MMRESULT WINAPI midiStreamClose(HMIDISTRM hms);
819MMRESULT WINAPI midiStreamOpen(LPHMIDISTRM,LPUINT,DWORD,DWORD_PTR,DWORD_PTR,DWORD);
820MMRESULT WINAPI midiStreamOut(HMIDISTRM hms, LPMIDIHDR lpMidiHdr, UINT cbMidiHdr);
821MMRESULT WINAPI midiStreamPause(HMIDISTRM hms);
822MMRESULT WINAPI midiStreamPosition(HMIDISTRM hms, LPMMTIME lpmmt, UINT cbmmt);
823MMRESULT WINAPI midiStreamProperty(HMIDISTRM hms, LPBYTE lpPropData, DWORD dwProperty);
824MMRESULT WINAPI midiStreamRestart(HMIDISTRM hms);
825MMRESULT WINAPI midiStreamStop(HMIDISTRM hms);
826
827#define AUX_MAPPER (-1)
828
829typedef struct tagAUXCAPSA {
830 WORD wMid;
831 WORD wPid;
832 MMVERSION vDriverVersion;
833 CHAR szPname[MAXPNAMELEN];
834 WORD wTechnology;
835 WORD wReserved1;
836 DWORD dwSupport;
837} AUXCAPSA, *LPAUXCAPSA;
838
839typedef struct tagAUXCAPSW {
840 WORD wMid;
841 WORD wPid;
842 MMVERSION vDriverVersion;
843 WCHAR szPname[MAXPNAMELEN];
844 WORD wTechnology;
845 WORD wReserved1;
846 DWORD dwSupport;
847} AUXCAPSW, *LPAUXCAPSW;
848
849DECL_WINELIB_TYPE_AW(AUXCAPS)
850DECL_WINELIB_TYPE_AW(LPAUXCAPS)
851
852typedef struct tagAUXCAPS2A {
853 WORD wMid;
854 WORD wPid;
855 MMVERSION vDriverVersion;
856 CHAR szPname[MAXPNAMELEN];
857 WORD wTechnology;
858 WORD wReserved1;
859 DWORD dwSupport;
860 GUID ManufacturerGuid;
861 GUID ProductGuid;
862 GUID NameGuid;
863} AUXCAPS2A, *LPAUXCAPS2A;
864
865typedef struct tagAUXCAPS2W {
866 WORD wMid;
867 WORD wPid;
868 MMVERSION vDriverVersion;
869 WCHAR szPname[MAXPNAMELEN];
870 WORD wTechnology;
871 WORD wReserved1;
872 DWORD dwSupport;
873 GUID ManufacturerGuid;
874 GUID ProductGuid;
875 GUID NameGuid;
876} AUXCAPS2W, *LPAUXCAPS2W;
877
878DECL_WINELIB_TYPE_AW(AUXCAPS2)
879DECL_WINELIB_TYPE_AW(LPAUXCAPS2)
880
881#define AUXCAPS_CDAUDIO 1 /* audio from internal CD-ROM drive */
882#define AUXCAPS_AUXIN 2 /* audio from auxiliary input jacks */
883
884#define AUXCAPS_VOLUME 0x0001 /* supports volume control */
885#define AUXCAPS_LRVOLUME 0x0002 /* separate left-right volume control */
886
887UINT WINAPI auxGetNumDevs(void);
888UINT WINAPI auxGetDevCapsA(UINT_PTR,LPAUXCAPSA,UINT);
889UINT WINAPI auxGetDevCapsW(UINT_PTR,LPAUXCAPSW,UINT);
890#define auxGetDevCaps WINELIB_NAME_AW(auxGetDevCaps)
891UINT WINAPI auxSetVolume(UINT,DWORD);
892UINT WINAPI auxGetVolume(UINT,LPDWORD);
893UINT WINAPI auxOutMessage(UINT,UINT,DWORD_PTR,DWORD_PTR);
894
895#define TIMERR_NOERROR (0) /* no error */
896#define TIMERR_NOCANDO (TIMERR_BASE+1) /* request not completed */
897#define TIMERR_STRUCT (TIMERR_BASE+33) /* time struct size */
898
899typedef void (CALLBACK *LPTIMECALLBACK)(UINT,UINT,DWORD_PTR,DWORD_PTR,DWORD_PTR);
900
901#define TIME_ONESHOT 0x0000 /* program timer for single event */
902#define TIME_PERIODIC 0x0001 /* program for continuous periodic event */
903#define TIME_CALLBACK_FUNCTION 0x0000 /* callback is function */
904#define TIME_CALLBACK_EVENT_SET 0x0010 /* callback is event - use SetEvent */
905#define TIME_CALLBACK_EVENT_PULSE 0x0020 /* callback is event - use PulseEvent */
906#define TIME_KILL_SYNCHRONOUS 0x0100
907
908typedef struct timecaps_tag {
909 UINT wPeriodMin;
910 UINT wPeriodMax;
911} TIMECAPS, *LPTIMECAPS;
912
913
914MMRESULT WINAPI timeGetSystemTime(LPMMTIME,UINT);
915DWORD WINAPI timeGetTime(void); /* same for win32/win16 */
916MMRESULT WINAPI timeSetEvent(UINT,UINT,LPTIMECALLBACK,DWORD_PTR,UINT);
917MMRESULT WINAPI timeKillEvent(UINT);
918MMRESULT WINAPI timeGetDevCaps(LPTIMECAPS,UINT);
919MMRESULT WINAPI timeBeginPeriod(UINT);
920MMRESULT WINAPI timeEndPeriod(UINT);
921
922#define JOYERR_NOERROR (0) /* no error */
923#define JOYERR_PARMS (JOYERR_BASE+5) /* bad parameters */
924#define JOYERR_NOCANDO (JOYERR_BASE+6) /* request not completed */
925#define JOYERR_UNPLUGGED (JOYERR_BASE+7) /* joystick is unplugged */
926
927/* JOYINFO, JOYINFOEX, MM_JOY* */
928#define JOY_BUTTON1 0x0001
929#define JOY_BUTTON2 0x0002
930#define JOY_BUTTON3 0x0004
931#define JOY_BUTTON4 0x0008
932#define JOY_BUTTON1CHG 0x0100
933#define JOY_BUTTON2CHG 0x0200
934#define JOY_BUTTON3CHG 0x0400
935#define JOY_BUTTON4CHG 0x0800
936
937#define JOYSTICKID1 0
938#define JOYSTICKID2 1
939
940/* JOYCAPS.wCaps */
941#define JOYCAPS_HASZ 0x0001
942#define JOYCAPS_HASR 0x0002
943#define JOYCAPS_HASU 0x0004
944#define JOYCAPS_HASV 0x0008
945#define JOYCAPS_HASPOV 0x0010
946#define JOYCAPS_POV4DIR 0x0020
947#define JOYCAPS_POVCTS 0x0040
948
949/* JOYINFOEX stuff */
950#define JOY_POVCENTERED (WORD) -1
951#define JOY_POVFORWARD 0
952#define JOY_POVRIGHT 9000
953#define JOY_POVBACKWARD 18000
954#define JOY_POVLEFT 27000
955
956#define JOY_RETURNX 0x00000001
957#define JOY_RETURNY 0x00000002
958#define JOY_RETURNZ 0x00000004
959#define JOY_RETURNR 0x00000008
960#define JOY_RETURNU 0x00000010
961#define JOY_RETURNV 0x00000020
962#define JOY_RETURNPOV 0x00000040
963#define JOY_RETURNBUTTONS 0x00000080
964#define JOY_RETURNRAWDATA 0x00000100
965#define JOY_RETURNPOVCTS 0x00000200
966#define JOY_RETURNCENTERED 0x00000400
967#define JOY_USEDEADZONE 0x00000800
968#define JOY_RETURNALL (JOY_RETURNX | JOY_RETURNY | JOY_RETURNZ | \
969 JOY_RETURNR | JOY_RETURNU | JOY_RETURNV | \
970 JOY_RETURNPOV | JOY_RETURNBUTTONS)
971#define JOY_CAL_READALWAYS 0x00010000
972#define JOY_CAL_READXYONLY 0x00020000
973#define JOY_CAL_READ3 0x00040000
974#define JOY_CAL_READ4 0x00080000
975#define JOY_CAL_READXONLY 0x00100000
976#define JOY_CAL_READYONLY 0x00200000
977#define JOY_CAL_READ5 0x00400000
978#define JOY_CAL_READ6 0x00800000
979#define JOY_CAL_READZONLY 0x01000000
980#define JOY_CAL_READRONLY 0x02000000
981#define JOY_CAL_READUONLY 0x04000000
982#define JOY_CAL_READVONLY 0x08000000
983
984typedef struct tagJOYCAPSA {
985 WORD wMid;
986 WORD wPid;
987 CHAR szPname[MAXPNAMELEN];
988 UINT wXmin;
989 UINT wXmax;
990 UINT wYmin;
991 UINT wYmax;
992 UINT wZmin;
993 UINT wZmax;
994 UINT wNumButtons;
995 UINT wPeriodMin;
996 UINT wPeriodMax;
997 UINT wRmin;
998 UINT wRmax;
999 UINT wUmin;
1000 UINT wUmax;
1001 UINT wVmin;
1002 UINT wVmax;
1003 UINT wCaps;
1004 UINT wMaxAxes;
1005 UINT wNumAxes;
1006 UINT wMaxButtons;
1007 CHAR szRegKey[MAXPNAMELEN];
1008 CHAR szOEMVxD[MAX_JOYSTICKOEMVXDNAME];
1009} JOYCAPSA, *LPJOYCAPSA;
1010
1011typedef struct tagJOYCAPSW {
1012 WORD wMid;
1013 WORD wPid;
1014 WCHAR szPname[MAXPNAMELEN];
1015 UINT wXmin;
1016 UINT wXmax;
1017 UINT wYmin;
1018 UINT wYmax;
1019 UINT wZmin;
1020 UINT wZmax;
1021 UINT wNumButtons;
1022 UINT wPeriodMin;
1023 UINT wPeriodMax;
1024 UINT wRmin;
1025 UINT wRmax;
1026 UINT wUmin;
1027 UINT wUmax;
1028 UINT wVmin;
1029 UINT wVmax;
1030 UINT wCaps;
1031 UINT wMaxAxes;
1032 UINT wNumAxes;
1033 UINT wMaxButtons;
1034 WCHAR szRegKey[MAXPNAMELEN];
1035 WCHAR szOEMVxD[MAX_JOYSTICKOEMVXDNAME];
1036} JOYCAPSW, *LPJOYCAPSW;
1037DECL_WINELIB_TYPE_AW(JOYCAPS)
1038DECL_WINELIB_TYPE_AW(LPJOYCAPS)
1039
1040typedef struct tagJOYCAPS2A {
1041 WORD wMid;
1042 WORD wPid;
1043 CHAR szPname[MAXPNAMELEN];
1044 UINT wXmin;
1045 UINT wXmax;
1046 UINT wYmin;
1047 UINT wYmax;
1048 UINT wZmin;
1049 UINT wZmax;
1050 UINT wNumButtons;
1051 UINT wPeriodMin;
1052 UINT wPeriodMax;
1053 UINT wRmin;
1054 UINT wRmax;
1055 UINT wUmin;
1056 UINT wUmax;
1057 UINT wVmin;
1058 UINT wVmax;
1059 UINT wCaps;
1060 UINT wMaxAxes;
1061 UINT wNumAxes;
1062 UINT wMaxButtons;
1063 CHAR szRegKey[MAXPNAMELEN];
1064 CHAR szOEMVxD[MAX_JOYSTICKOEMVXDNAME];
1065 GUID ManufacturerGuid;
1066 GUID ProductGuid;
1067 GUID NameGuid;
1068} JOYCAPS2A, *LPJOYCAPS2A;
1069
1070typedef struct tagJOYCAPS2W {
1071 WORD wMid;
1072 WORD wPid;
1073 WCHAR szPname[MAXPNAMELEN];
1074 UINT wXmin;
1075 UINT wXmax;
1076 UINT wYmin;
1077 UINT wYmax;
1078 UINT wZmin;
1079 UINT wZmax;
1080 UINT wNumButtons;
1081 UINT wPeriodMin;
1082 UINT wPeriodMax;
1083 UINT wRmin;
1084 UINT wRmax;
1085 UINT wUmin;
1086 UINT wUmax;
1087 UINT wVmin;
1088 UINT wVmax;
1089 UINT wCaps;
1090 UINT wMaxAxes;
1091 UINT wNumAxes;
1092 UINT wMaxButtons;
1093 WCHAR szRegKey[MAXPNAMELEN];
1094 WCHAR szOEMVxD[MAX_JOYSTICKOEMVXDNAME];
1095 GUID ManufacturerGuid;
1096 GUID ProductGuid;
1097 GUID NameGuid;
1098} JOYCAPS2W, *LPJOYCAPS2W;
1099DECL_WINELIB_TYPE_AW(JOYCAPS2)
1100DECL_WINELIB_TYPE_AW(LPJOYCAPS2)
1101
1102typedef struct joyinfo_tag {
1103 UINT wXpos;
1104 UINT wYpos;
1105 UINT wZpos;
1106 UINT wButtons;
1107} JOYINFO, *LPJOYINFO;
1108
1109typedef struct joyinfoex_tag {
1110 DWORD dwSize;
1111 DWORD dwFlags;
1112 DWORD dwXpos;
1113 DWORD dwYpos;
1114 DWORD dwZpos;
1115 DWORD dwRpos;
1116 DWORD dwUpos;
1117 DWORD dwVpos;
1118 DWORD dwButtons;
1119 DWORD dwButtonNumber;
1120 DWORD dwPOV;
1121 DWORD dwReserved1;
1122 DWORD dwReserved2;
1123} JOYINFOEX,*LPJOYINFOEX;
1124
1125
1126MMRESULT WINAPI joyGetDevCapsA(UINT_PTR,LPJOYCAPSA,UINT);
1127MMRESULT WINAPI joyGetDevCapsW(UINT_PTR,LPJOYCAPSW,UINT);
1128#define joyGetDevCaps WINELIB_NAME_AW(joyGetDevCaps)
1129UINT WINAPI joyGetNumDevs(void);
1130MMRESULT WINAPI joyGetPos(UINT,LPJOYINFO);
1131MMRESULT WINAPI joyGetPosEx(UINT,LPJOYINFOEX);
1132MMRESULT WINAPI joyGetThreshold(UINT,UINT*);
1133MMRESULT WINAPI joyReleaseCapture(UINT);
1134MMRESULT WINAPI joySetCapture(HWND,UINT,UINT,BOOL);
1135MMRESULT WINAPI joySetThreshold(UINT,UINT);
1136
1137#define MIXERR_BASE 1024
1138#define MIXERR_INVALLINE (MIXERR_BASE + 0)
1139#define MIXERR_INVALCONTROL (MIXERR_BASE + 1)
1140#define MIXERR_INVALVALUE (MIXERR_BASE + 2)
1141#define MIXERR_LASTERROR (MIXERR_BASE + 2)
1142
1143typedef struct tagMIXERCAPSA {
1144 WORD wMid;
1145 WORD wPid;
1146 MMVERSION vDriverVersion;
1147 CHAR szPname[MAXPNAMELEN];
1148 DWORD fdwSupport;
1149 DWORD cDestinations;
1150} MIXERCAPSA,*LPMIXERCAPSA;
1151
1152typedef struct tagMIXERCAPSW {
1153 WORD wMid;
1154 WORD wPid;
1155 MMVERSION vDriverVersion;
1156 WCHAR szPname[MAXPNAMELEN];
1157 DWORD fdwSupport;
1158 DWORD cDestinations;
1159} MIXERCAPSW,*LPMIXERCAPSW;
1160
1161DECL_WINELIB_TYPE_AW(MIXERCAPS)
1162DECL_WINELIB_TYPE_AW(LPMIXERCAPS)
1163
1164typedef struct tagMIXERCAPS2A {
1165 WORD wMid;
1166 WORD wPid;
1167 MMVERSION vDriverVersion;
1168 CHAR szPname[MAXPNAMELEN];
1169 DWORD fdwSupport;
1170 DWORD cDestinations;
1171 GUID ManufacturerGuid;
1172 GUID ProductGuid;
1173 GUID NameGuid;
1174} MIXERCAPS2A,*LPMIXERCAPS2A;
1175
1176typedef struct tagMIXERCAPS2W {
1177 WORD wMid;
1178 WORD wPid;
1179 MMVERSION vDriverVersion;
1180 WCHAR szPname[MAXPNAMELEN];
1181 DWORD fdwSupport;
1182 DWORD cDestinations;
1183 GUID ManufacturerGuid;
1184 GUID ProductGuid;
1185 GUID NameGuid;
1186} MIXERCAPS2W,*LPMIXERCAPS2W;
1187
1188DECL_WINELIB_TYPE_AW(MIXERCAPS2)
1189DECL_WINELIB_TYPE_AW(LPMIXERCAPS2)
1190
1191#define MIXER_SHORT_NAME_CHARS 16
1192#define MIXER_LONG_NAME_CHARS 64
1193
1194/* MIXERLINE.fdwLine */
1195#define MIXERLINE_LINEF_ACTIVE 0x00000001
1196#define MIXERLINE_LINEF_DISCONNECTED 0x00008000
1197#define MIXERLINE_LINEF_SOURCE 0x80000000
1198
1199/* Mixer flags */
1200#define MIXER_OBJECTF_HANDLE __MSABI_LONG(0x80000000)
1201#define MIXER_OBJECTF_MIXER __MSABI_LONG(0x00000000)
1202#define MIXER_OBJECTF_HMIXER (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_MIXER)
1203#define MIXER_OBJECTF_WAVEOUT __MSABI_LONG(0x10000000)
1204#define MIXER_OBJECTF_HWAVEOUT (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_WAVEOUT)
1205#define MIXER_OBJECTF_WAVEIN __MSABI_LONG(0x20000000)
1206#define MIXER_OBJECTF_HWAVEIN (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_WAVEIN)
1207#define MIXER_OBJECTF_MIDIOUT __MSABI_LONG(0x30000000)
1208#define MIXER_OBJECTF_HMIDIOUT (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_MIDIOUT)
1209#define MIXER_OBJECTF_MIDIIN __MSABI_LONG(0x40000000)
1210#define MIXER_OBJECTF_HMIDIIN (MIXER_OBJECTF_HANDLE|MIXER_OBJECTF_MIDIIN)
1211#define MIXER_OBJECTF_AUX __MSABI_LONG(0x50000000)
1212
1213/* MIXERLINE.dwComponentType */
1214/* component types for destinations and sources */
1215#define MIXERLINE_COMPONENTTYPE_DST_FIRST __MSABI_LONG(0x00000000)
1216#define MIXERLINE_COMPONENTTYPE_DST_UNDEFINED (MIXERLINE_COMPONENTTYPE_DST_FIRST + 0)
1217#define MIXERLINE_COMPONENTTYPE_DST_DIGITAL (MIXERLINE_COMPONENTTYPE_DST_FIRST + 1)
1218#define MIXERLINE_COMPONENTTYPE_DST_LINE (MIXERLINE_COMPONENTTYPE_DST_FIRST + 2)
1219#define MIXERLINE_COMPONENTTYPE_DST_MONITOR (MIXERLINE_COMPONENTTYPE_DST_FIRST + 3)
1220#define MIXERLINE_COMPONENTTYPE_DST_SPEAKERS (MIXERLINE_COMPONENTTYPE_DST_FIRST + 4)
1221#define MIXERLINE_COMPONENTTYPE_DST_HEADPHONES (MIXERLINE_COMPONENTTYPE_DST_FIRST + 5)
1222#define MIXERLINE_COMPONENTTYPE_DST_TELEPHONE (MIXERLINE_COMPONENTTYPE_DST_FIRST + 6)
1223#define MIXERLINE_COMPONENTTYPE_DST_WAVEIN (MIXERLINE_COMPONENTTYPE_DST_FIRST + 7)
1224#define MIXERLINE_COMPONENTTYPE_DST_VOICEIN (MIXERLINE_COMPONENTTYPE_DST_FIRST + 8)
1225#define MIXERLINE_COMPONENTTYPE_DST_LAST (MIXERLINE_COMPONENTTYPE_DST_FIRST + 8)
1226
1227#define MIXERLINE_COMPONENTTYPE_SRC_FIRST __MSABI_LONG(0x00001000)
1228#define MIXERLINE_COMPONENTTYPE_SRC_UNDEFINED (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 0)
1229#define MIXERLINE_COMPONENTTYPE_SRC_DIGITAL (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 1)
1230#define MIXERLINE_COMPONENTTYPE_SRC_LINE (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 2)
1231#define MIXERLINE_COMPONENTTYPE_SRC_MICROPHONE (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 3)
1232#define MIXERLINE_COMPONENTTYPE_SRC_SYNTHESIZER (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 4)
1233#define MIXERLINE_COMPONENTTYPE_SRC_COMPACTDISC (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 5)
1234#define MIXERLINE_COMPONENTTYPE_SRC_TELEPHONE (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 6)
1235#define MIXERLINE_COMPONENTTYPE_SRC_PCSPEAKER (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 7)
1236#define MIXERLINE_COMPONENTTYPE_SRC_WAVEOUT (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 8)
1237#define MIXERLINE_COMPONENTTYPE_SRC_AUXILIARY (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 9)
1238#define MIXERLINE_COMPONENTTYPE_SRC_ANALOG (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 10)
1239#define MIXERLINE_COMPONENTTYPE_SRC_LAST (MIXERLINE_COMPONENTTYPE_SRC_FIRST + 10)
1240
1241/* MIXERLINE.Target.dwType */
1242#define MIXERLINE_TARGETTYPE_UNDEFINED 0
1243#define MIXERLINE_TARGETTYPE_WAVEOUT 1
1244#define MIXERLINE_TARGETTYPE_WAVEIN 2
1245#define MIXERLINE_TARGETTYPE_MIDIOUT 3
1246#define MIXERLINE_TARGETTYPE_MIDIIN 4
1247#define MIXERLINE_TARGETTYPE_AUX 5
1248
1249typedef struct tagMIXERLINEA {
1250 DWORD cbStruct;
1251 DWORD dwDestination;
1252 DWORD dwSource;
1253 DWORD dwLineID;
1254 DWORD fdwLine;
1255 DWORD_PTR dwUser;
1256 DWORD dwComponentType;
1257 DWORD cChannels;
1258 DWORD cConnections;
1259 DWORD cControls;
1260 CHAR szShortName[MIXER_SHORT_NAME_CHARS];
1261 CHAR szName[MIXER_LONG_NAME_CHARS];
1262 struct {
1263 DWORD dwType;
1264 DWORD dwDeviceID;
1265 WORD wMid;
1266 WORD wPid;
1267 MMVERSION vDriverVersion;
1268 CHAR szPname[MAXPNAMELEN];
1269 } Target;
1270} MIXERLINEA, *LPMIXERLINEA;
1271
1272typedef struct tagMIXERLINEW {
1273 DWORD cbStruct;
1274 DWORD dwDestination;
1275 DWORD dwSource;
1276 DWORD dwLineID;
1277 DWORD fdwLine;
1278 DWORD_PTR dwUser;
1279 DWORD dwComponentType;
1280 DWORD cChannels;
1281 DWORD cConnections;
1282 DWORD cControls;
1283 WCHAR szShortName[MIXER_SHORT_NAME_CHARS];
1284 WCHAR szName[MIXER_LONG_NAME_CHARS];
1285 struct {
1286 DWORD dwType;
1287 DWORD dwDeviceID;
1288 WORD wMid;
1289 WORD wPid;
1290 MMVERSION vDriverVersion;
1291 WCHAR szPname[MAXPNAMELEN];
1292 } Target;
1293} MIXERLINEW, *LPMIXERLINEW;
1294
1295DECL_WINELIB_TYPE_AW(MIXERLINE)
1296DECL_WINELIB_TYPE_AW(LPMIXERLINE)
1297
1298/* MIXERCONTROL.fdwControl */
1299#define MIXERCONTROL_CONTROLF_UNIFORM __MSABI_LONG(0x00000001)
1300#define MIXERCONTROL_CONTROLF_MULTIPLE __MSABI_LONG(0x00000002)
1301#define MIXERCONTROL_CONTROLF_DISABLED __MSABI_LONG(0x80000000)
1302
1303/* MIXERCONTROL_CONTROLTYPE_xxx building block defines */
1304#define MIXERCONTROL_CT_CLASS_MASK __MSABI_LONG(0xF0000000)
1305#define MIXERCONTROL_CT_CLASS_CUSTOM __MSABI_LONG(0x00000000)
1306#define MIXERCONTROL_CT_CLASS_METER __MSABI_LONG(0x10000000)
1307#define MIXERCONTROL_CT_CLASS_SWITCH __MSABI_LONG(0x20000000)
1308#define MIXERCONTROL_CT_CLASS_NUMBER __MSABI_LONG(0x30000000)
1309#define MIXERCONTROL_CT_CLASS_SLIDER __MSABI_LONG(0x40000000)
1310#define MIXERCONTROL_CT_CLASS_FADER __MSABI_LONG(0x50000000)
1311#define MIXERCONTROL_CT_CLASS_TIME __MSABI_LONG(0x60000000)
1312#define MIXERCONTROL_CT_CLASS_LIST __MSABI_LONG(0x70000000)
1313
1314#define MIXERCONTROL_CT_SUBCLASS_MASK __MSABI_LONG(0x0F000000)
1315
1316#define MIXERCONTROL_CT_SC_SWITCH_BOOLEAN __MSABI_LONG(0x00000000)
1317#define MIXERCONTROL_CT_SC_SWITCH_BUTTON __MSABI_LONG(0x01000000)
1318
1319#define MIXERCONTROL_CT_SC_METER_POLLED __MSABI_LONG(0x00000000)
1320
1321#define MIXERCONTROL_CT_SC_TIME_MICROSECS __MSABI_LONG(0x00000000)
1322#define MIXERCONTROL_CT_SC_TIME_MILLISECS __MSABI_LONG(0x01000000)
1323
1324#define MIXERCONTROL_CT_SC_LIST_SINGLE __MSABI_LONG(0x00000000)
1325#define MIXERCONTROL_CT_SC_LIST_MULTIPLE __MSABI_LONG(0x01000000)
1326
1327#define MIXERCONTROL_CT_UNITS_MASK __MSABI_LONG(0x00FF0000)
1328#define MIXERCONTROL_CT_UNITS_CUSTOM __MSABI_LONG(0x00000000)
1329#define MIXERCONTROL_CT_UNITS_BOOLEAN __MSABI_LONG(0x00010000)
1330#define MIXERCONTROL_CT_UNITS_SIGNED __MSABI_LONG(0x00020000)
1331#define MIXERCONTROL_CT_UNITS_UNSIGNED __MSABI_LONG(0x00030000)
1332#define MIXERCONTROL_CT_UNITS_DECIBELS __MSABI_LONG(0x00040000) /* in 10ths */
1333#define MIXERCONTROL_CT_UNITS_PERCENT __MSABI_LONG(0x00050000) /* in 10ths */
1334
1335/* Commonly used control types for specifying MIXERCONTROL.dwControlType */
1336#define MIXERCONTROL_CONTROLTYPE_CUSTOM (MIXERCONTROL_CT_CLASS_CUSTOM | MIXERCONTROL_CT_UNITS_CUSTOM)
1337#define MIXERCONTROL_CONTROLTYPE_BOOLEANMETER (MIXERCONTROL_CT_CLASS_METER | MIXERCONTROL_CT_SC_METER_POLLED | MIXERCONTROL_CT_UNITS_BOOLEAN)
1338#define MIXERCONTROL_CONTROLTYPE_SIGNEDMETER (MIXERCONTROL_CT_CLASS_METER | MIXERCONTROL_CT_SC_METER_POLLED | MIXERCONTROL_CT_UNITS_SIGNED)
1339#define MIXERCONTROL_CONTROLTYPE_PEAKMETER (MIXERCONTROL_CONTROLTYPE_SIGNEDMETER + 1)
1340#define MIXERCONTROL_CONTROLTYPE_UNSIGNEDMETER (MIXERCONTROL_CT_CLASS_METER | MIXERCONTROL_CT_SC_METER_POLLED | MIXERCONTROL_CT_UNITS_UNSIGNED)
1341#define MIXERCONTROL_CONTROLTYPE_BOOLEAN (MIXERCONTROL_CT_CLASS_SWITCH | MIXERCONTROL_CT_SC_SWITCH_BOOLEAN | MIXERCONTROL_CT_UNITS_BOOLEAN)
1342#define MIXERCONTROL_CONTROLTYPE_ONOFF (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 1)
1343#define MIXERCONTROL_CONTROLTYPE_MUTE (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 2)
1344#define MIXERCONTROL_CONTROLTYPE_MONO (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 3)
1345#define MIXERCONTROL_CONTROLTYPE_LOUDNESS (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 4)
1346#define MIXERCONTROL_CONTROLTYPE_STEREOENH (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 5)
1347#define MIXERCONTROL_CONTROLTYPE_BASS_BOOST (MIXERCONTROL_CONTROLTYPE_BOOLEAN + 0x00002277)
1348#define MIXERCONTROL_CONTROLTYPE_BUTTON (MIXERCONTROL_CT_CLASS_SWITCH | MIXERCONTROL_CT_SC_SWITCH_BUTTON | MIXERCONTROL_CT_UNITS_BOOLEAN)
1349#define MIXERCONTROL_CONTROLTYPE_DECIBELS (MIXERCONTROL_CT_CLASS_NUMBER | MIXERCONTROL_CT_UNITS_DECIBELS)
1350#define MIXERCONTROL_CONTROLTYPE_SIGNED (MIXERCONTROL_CT_CLASS_NUMBER | MIXERCONTROL_CT_UNITS_SIGNED)
1351#define MIXERCONTROL_CONTROLTYPE_UNSIGNED (MIXERCONTROL_CT_CLASS_NUMBER | MIXERCONTROL_CT_UNITS_UNSIGNED)
1352#define MIXERCONTROL_CONTROLTYPE_PERCENT (MIXERCONTROL_CT_CLASS_NUMBER | MIXERCONTROL_CT_UNITS_PERCENT)
1353#define MIXERCONTROL_CONTROLTYPE_SLIDER (MIXERCONTROL_CT_CLASS_SLIDER | MIXERCONTROL_CT_UNITS_SIGNED)
1354#define MIXERCONTROL_CONTROLTYPE_PAN (MIXERCONTROL_CONTROLTYPE_SLIDER + 1)
1355#define MIXERCONTROL_CONTROLTYPE_QSOUNDPAN (MIXERCONTROL_CONTROLTYPE_SLIDER + 2)
1356#define MIXERCONTROL_CONTROLTYPE_FADER (MIXERCONTROL_CT_CLASS_FADER | MIXERCONTROL_CT_UNITS_UNSIGNED)
1357#define MIXERCONTROL_CONTROLTYPE_VOLUME (MIXERCONTROL_CONTROLTYPE_FADER + 1)
1358#define MIXERCONTROL_CONTROLTYPE_BASS (MIXERCONTROL_CONTROLTYPE_FADER + 2)
1359#define MIXERCONTROL_CONTROLTYPE_TREBLE (MIXERCONTROL_CONTROLTYPE_FADER + 3)
1360#define MIXERCONTROL_CONTROLTYPE_EQUALIZER (MIXERCONTROL_CONTROLTYPE_FADER + 4)
1361#define MIXERCONTROL_CONTROLTYPE_SINGLESELECT (MIXERCONTROL_CT_CLASS_LIST | MIXERCONTROL_CT_SC_LIST_SINGLE | MIXERCONTROL_CT_UNITS_BOOLEAN)
1362#define MIXERCONTROL_CONTROLTYPE_MUX (MIXERCONTROL_CONTROLTYPE_SINGLESELECT + 1)
1363#define MIXERCONTROL_CONTROLTYPE_MULTIPLESELECT (MIXERCONTROL_CT_CLASS_LIST | MIXERCONTROL_CT_SC_LIST_MULTIPLE | MIXERCONTROL_CT_UNITS_BOOLEAN)
1364#define MIXERCONTROL_CONTROLTYPE_MIXER (MIXERCONTROL_CONTROLTYPE_MULTIPLESELECT + 1)
1365#define MIXERCONTROL_CONTROLTYPE_MICROTIME (MIXERCONTROL_CT_CLASS_TIME | MIXERCONTROL_CT_SC_TIME_MICROSECS | MIXERCONTROL_CT_UNITS_UNSIGNED)
1366#define MIXERCONTROL_CONTROLTYPE_MILLITIME (MIXERCONTROL_CT_CLASS_TIME | MIXERCONTROL_CT_SC_TIME_MILLISECS | MIXERCONTROL_CT_UNITS_UNSIGNED)
1367
1368
1369typedef struct tagMIXERCONTROLA {
1370 DWORD cbStruct;
1371 DWORD dwControlID;
1372 DWORD dwControlType;
1373 DWORD fdwControl;
1374 DWORD cMultipleItems;
1375 CHAR szShortName[MIXER_SHORT_NAME_CHARS];
1376 CHAR szName[MIXER_LONG_NAME_CHARS];
1377 union {
1378 struct {
1379 LONG lMinimum;
1380 LONG lMaximum;
1381 } DUMMYSTRUCTNAME;
1382 struct {
1383 DWORD dwMinimum;
1384 DWORD dwMaximum;
1385 } DUMMYSTRUCTNAME1;
1386 DWORD dwReserved[6];
1387 } Bounds;
1388 union {
1389 DWORD cSteps;
1390 DWORD cbCustomData;
1391 DWORD dwReserved[6];
1392 } Metrics;
1393} MIXERCONTROLA, *LPMIXERCONTROLA;
1394
1395typedef struct MIXERCONTROLW {
1396 DWORD cbStruct;
1397 DWORD dwControlID;
1398 DWORD dwControlType;
1399 DWORD fdwControl;
1400 DWORD cMultipleItems;
1401 WCHAR szShortName[MIXER_SHORT_NAME_CHARS];
1402 WCHAR szName[MIXER_LONG_NAME_CHARS];
1403 union {
1404 struct {
1405 LONG lMinimum;
1406 LONG lMaximum;
1407 } DUMMYSTRUCTNAME;
1408 struct {
1409 DWORD dwMinimum;
1410 DWORD dwMaximum;
1411 } DUMMYSTRUCTNAME1;
1412 DWORD dwReserved[6];
1413 } Bounds;
1414 union {
1415 DWORD cSteps;
1416 DWORD cbCustomData;
1417 DWORD dwReserved[6];
1418 } Metrics;
1419} MIXERCONTROLW, *LPMIXERCONTROLW;
1420
1421DECL_WINELIB_TYPE_AW(MIXERCONTROL)
1422DECL_WINELIB_TYPE_AW(LPMIXERCONTROL)
1423
1424typedef struct tagMIXERLINECONTROLSA {
1425 DWORD cbStruct;
1426 DWORD dwLineID;
1427 union {
1428 DWORD dwControlID;
1429 DWORD dwControlType;
1430 } DUMMYUNIONNAME;
1431 DWORD cControls;
1432 DWORD cbmxctrl;
1433 LPMIXERCONTROLA pamxctrl;
1434} MIXERLINECONTROLSA, *LPMIXERLINECONTROLSA;
1435
1436typedef struct tagMIXERLINECONTROLSW {
1437 DWORD cbStruct;
1438 DWORD dwLineID;
1439 union {
1440 DWORD dwControlID;
1441 DWORD dwControlType;
1442 } DUMMYUNIONNAME;
1443 DWORD cControls;
1444 DWORD cbmxctrl;
1445 LPMIXERCONTROLW pamxctrl;
1446} MIXERLINECONTROLSW, *LPMIXERLINECONTROLSW;
1447
1448DECL_WINELIB_TYPE_AW(MIXERLINECONTROLS)
1449DECL_WINELIB_TYPE_AW(LPMIXERLINECONTROLS)
1450
1451typedef struct tMIXERCONTROLDETAILS {
1452 DWORD cbStruct;
1453 DWORD dwControlID;
1454 DWORD cChannels;
1455 union {
1456 HWND hwndOwner;
1457 DWORD cMultipleItems;
1458 } DUMMYUNIONNAME;
1459 DWORD cbDetails;
1460 LPVOID paDetails;
1461} MIXERCONTROLDETAILS,*LPMIXERCONTROLDETAILS;
1462
1463typedef struct tagMIXERCONTROLDETAILS_LISTTEXTA {
1464 DWORD dwParam1;
1465 DWORD dwParam2;
1466 CHAR szName[MIXER_LONG_NAME_CHARS];
1467} MIXERCONTROLDETAILS_LISTTEXTA,*LPMIXERCONTROLDETAILS_LISTTEXTA;
1468
1469typedef struct tagMIXERCONTROLDETAILS_LISTTEXTW {
1470 DWORD dwParam1;
1471 DWORD dwParam2;
1472 WCHAR szName[MIXER_LONG_NAME_CHARS];
1473} MIXERCONTROLDETAILS_LISTTEXTW,*LPMIXERCONTROLDETAILS_LISTTEXTW;
1474
1475DECL_WINELIB_TYPE_AW(MIXERCONTROLDETAILS_LISTTEXT)
1476DECL_WINELIB_TYPE_AW(LPMIXERCONTROLDETAILS_LISTTEXT)
1477
1478/* MIXER_GETCONTROLDETAILSF_VALUE */
1479typedef struct {
1480 LONG fValue;
1481} MIXERCONTROLDETAILS_BOOLEAN,*LPMIXERCONTROLDETAILS_BOOLEAN;
1482
1483typedef struct {
1484 LONG lValue;
1485} MIXERCONTROLDETAILS_SIGNED,*LPMIXERCONTROLDETAILS_SIGNED;
1486
1487typedef struct {
1488 DWORD dwValue;
1489} MIXERCONTROLDETAILS_UNSIGNED,*LPMIXERCONTROLDETAILS_UNSIGNED;
1490
1491/* bits passed to mixerGetLineInfo.fdwInfo */
1492#define MIXER_GETLINEINFOF_DESTINATION __MSABI_LONG(0x00000000)
1493#define MIXER_GETLINEINFOF_SOURCE __MSABI_LONG(0x00000001)
1494#define MIXER_GETLINEINFOF_LINEID __MSABI_LONG(0x00000002)
1495#define MIXER_GETLINEINFOF_COMPONENTTYPE __MSABI_LONG(0x00000003)
1496#define MIXER_GETLINEINFOF_TARGETTYPE __MSABI_LONG(0x00000004)
1497#define MIXER_GETLINEINFOF_QUERYMASK __MSABI_LONG(0x0000000F)
1498
1499/* bitmask passed to mixerGetLineControl */
1500#define MIXER_GETLINECONTROLSF_ALL __MSABI_LONG(0x00000000)
1501#define MIXER_GETLINECONTROLSF_ONEBYID __MSABI_LONG(0x00000001)
1502#define MIXER_GETLINECONTROLSF_ONEBYTYPE __MSABI_LONG(0x00000002)
1503#define MIXER_GETLINECONTROLSF_QUERYMASK __MSABI_LONG(0x0000000F)
1504
1505/* bitmask passed to mixerGetControlDetails */
1506#define MIXER_GETCONTROLDETAILSF_VALUE __MSABI_LONG(0x00000000)
1507#define MIXER_GETCONTROLDETAILSF_LISTTEXT __MSABI_LONG(0x00000001)
1508#define MIXER_GETCONTROLDETAILSF_QUERYMASK __MSABI_LONG(0x0000000F)
1509
1510/* bitmask passed to mixerSetControlDetails */
1511#define MIXER_SETCONTROLDETAILSF_VALUE __MSABI_LONG(0x00000000)
1512#define MIXER_SETCONTROLDETAILSF_CUSTOM __MSABI_LONG(0x00000001)
1513#define MIXER_SETCONTROLDETAILSF_QUERYMASK __MSABI_LONG(0x0000000F)
1514
1515UINT WINAPI mixerGetNumDevs(void);
1516UINT WINAPI mixerOpen(LPHMIXER,UINT,DWORD_PTR,DWORD_PTR,DWORD);
1517UINT WINAPI mixerClose(HMIXER);
1518DWORD WINAPI mixerMessage(HMIXER,UINT,DWORD_PTR,DWORD_PTR);
1519UINT WINAPI mixerGetDevCapsA(UINT_PTR,LPMIXERCAPSA,UINT);
1520UINT WINAPI mixerGetDevCapsW(UINT_PTR,LPMIXERCAPSW,UINT);
1521#define mixerGetDevCaps WINELIB_NAME_AW(mixerGetDevCaps)
1522UINT WINAPI mixerGetLineInfoA(HMIXEROBJ,LPMIXERLINEA,DWORD);
1523UINT WINAPI mixerGetLineInfoW(HMIXEROBJ,LPMIXERLINEW,DWORD);
1524#define mixerGetLineInfo WINELIB_NAME_AW(mixerGetLineInfo)
1525UINT WINAPI mixerGetID(HMIXEROBJ,LPUINT,DWORD);
1526UINT WINAPI mixerGetLineControlsA(HMIXEROBJ,LPMIXERLINECONTROLSA,DWORD);
1527UINT WINAPI mixerGetLineControlsW(HMIXEROBJ,LPMIXERLINECONTROLSW,DWORD);
1528#define mixerGetLineControls WINELIB_NAME_AW(mixerGetLineControls)
1529UINT WINAPI mixerGetControlDetailsA(HMIXEROBJ,LPMIXERCONTROLDETAILS,DWORD);
1530UINT WINAPI mixerGetControlDetailsW(HMIXEROBJ,LPMIXERCONTROLDETAILS,DWORD);
1531#define mixerGetControlDetails WINELIB_NAME_AW(mixerGetControlDetails)
1532UINT WINAPI mixerSetControlDetails(HMIXEROBJ,LPMIXERCONTROLDETAILS,DWORD);
1533
1534#define MMIOERR_BASE 256
1535#define MMIOERR_FILENOTFOUND (MMIOERR_BASE + 1) /* file not found */
1536#define MMIOERR_OUTOFMEMORY (MMIOERR_BASE + 2) /* out of memory */
1537#define MMIOERR_CANNOTOPEN (MMIOERR_BASE + 3) /* cannot open */
1538#define MMIOERR_CANNOTCLOSE (MMIOERR_BASE + 4) /* cannot close */
1539#define MMIOERR_CANNOTREAD (MMIOERR_BASE + 5) /* cannot read */
1540#define MMIOERR_CANNOTWRITE (MMIOERR_BASE + 6) /* cannot write */
1541#define MMIOERR_CANNOTSEEK (MMIOERR_BASE + 7) /* cannot seek */
1542#define MMIOERR_CANNOTEXPAND (MMIOERR_BASE + 8) /* cannot expand file */
1543#define MMIOERR_CHUNKNOTFOUND (MMIOERR_BASE + 9) /* chunk not found */
1544#define MMIOERR_UNBUFFERED (MMIOERR_BASE + 10) /* file is unbuffered */
1545#define MMIOERR_PATHNOTFOUND (MMIOERR_BASE + 11)
1546#define MMIOERR_ACCESSDENIED (MMIOERR_BASE + 12)
1547#define MMIOERR_SHARINGVIOLATION (MMIOERR_BASE + 13)
1548#define MMIOERR_NETWORKERROR (MMIOERR_BASE + 14)
1549#define MMIOERR_TOOMANYOPENFILES (MMIOERR_BASE + 15)
1550#define MMIOERR_INVALIDFILE (MMIOERR_BASE + 16)
1551
1552#define CFSEPCHAR '+' /* compound file name separator char. */
1553
1554typedef DWORD FOURCC; /* a four character code */
1555typedef LRESULT (CALLBACK *LPMMIOPROC) (LPSTR lpmmioinfo, UINT uMessage,
1556 LPARAM lParam1, LPARAM lParam2);
1557
1558typedef struct _MMIOINFO {
1559 DWORD dwFlags;
1560 FOURCC fccIOProc;
1561 LPMMIOPROC pIOProc;
1562 UINT wErrorRet;
1563 HTASK hTask;
1564 /* fields maintained by MMIO functions during buffered I/O */
1565 LONG cchBuffer;
1566 HPSTR pchBuffer;
1567 HPSTR pchNext;
1568 HPSTR pchEndRead;
1569 HPSTR pchEndWrite;
1570 LONG lBufOffset;
1571 /* fields maintained by I/O procedure */
1572 LONG lDiskOffset;
1573 DWORD adwInfo[3];
1574 /* other fields maintained by MMIO */
1575 DWORD dwReserved1;
1576 DWORD dwReserved2;
1577 HMMIO hmmio;
1578} MMIOINFO, *PMMIOINFO, *LPMMIOINFO;
1579
1580
1581typedef struct _MMCKINFO
1582{
1583 FOURCC ckid; /* chunk ID */
1584 DWORD cksize; /* chunk size */
1585 FOURCC fccType; /* form type or list type */
1586 DWORD dwDataOffset; /* offset of data portion of chunk */
1587 DWORD dwFlags; /* flags used by MMIO functions */
1588} MMCKINFO, *LPMMCKINFO;
1589
1590#define MMIO_RWMODE 0x00000003 /* open file for reading/writing/both */
1591#define MMIO_SHAREMODE 0x00000070 /* file sharing mode number */
1592
1593#define MMIO_CREATE 0x00001000 /* create new file (or truncate file) */
1594#define MMIO_PARSE 0x00000100 /* parse new file returning path */
1595#define MMIO_DELETE 0x00000200 /* create new file (or truncate file) */
1596#define MMIO_EXIST 0x00004000 /* checks for existence of file */
1597#define MMIO_ALLOCBUF 0x00010000 /* mmioOpen() should allocate a buffer */
1598#define MMIO_GETTEMP 0x00020000 /* mmioOpen() should retrieve temp name */
1599
1600#define MMIO_DIRTY 0x10000000 /* I/O buffer is dirty */
1601
1602#define MMIO_READ 0x00000000 /* open file for reading only */
1603#define MMIO_WRITE 0x00000001 /* open file for writing only */
1604#define MMIO_READWRITE 0x00000002 /* open file for reading and writing */
1605
1606#define MMIO_COMPAT 0x00000000 /* compatibility mode */
1607#define MMIO_EXCLUSIVE 0x00000010 /* exclusive-access mode */
1608#define MMIO_DENYWRITE 0x00000020 /* deny writing to other processes */
1609#define MMIO_DENYREAD 0x00000030 /* deny reading to other processes */
1610#define MMIO_DENYNONE 0x00000040 /* deny nothing to other processes */
1611
1612#define MMIO_FHOPEN 0x0010 /* mmioClose: keep file handle open */
1613#define MMIO_EMPTYBUF 0x0010 /* mmioFlush: empty the I/O buffer */
1614#define MMIO_TOUPPER 0x0010 /* mmioStringToFOURCC: to u-case */
1615#define MMIO_INSTALLPROC 0x00010000 /* mmioInstallIOProc: install MMIOProc */
1616#define MMIO_GLOBALPROC 0x10000000 /* mmioInstallIOProc: install globally */
1617#define MMIO_REMOVEPROC 0x00020000 /* mmioInstallIOProc: remove MMIOProc */
1618#define MMIO_FINDPROC 0x00040000 /* mmioInstallIOProc: find an MMIOProc */
1619#define MMIO_FINDCHUNK 0x0010 /* mmioDescend: find a chunk by ID */
1620#define MMIO_FINDRIFF 0x0020 /* mmioDescend: find a LIST chunk */
1621#define MMIO_FINDLIST 0x0040 /* mmioDescend: find a RIFF chunk */
1622#define MMIO_CREATERIFF 0x0020 /* mmioCreateChunk: make a LIST chunk */
1623#define MMIO_CREATELIST 0x0040 /* mmioCreateChunk: make a RIFF chunk */
1624
1625#ifndef SEEK_SET
1626#define SEEK_SET 0
1627#define SEEK_CUR 1
1628#define SEEK_END 2
1629#endif /* SEEK_SET */
1630
1631#define MMIOM_READ MMIO_READ /* read */
1632#define MMIOM_WRITE MMIO_WRITE /* write */
1633#define MMIOM_SEEK 2 /* seek to a new position in file */
1634#define MMIOM_OPEN 3 /* open file */
1635#define MMIOM_CLOSE 4 /* close file */
1636#define MMIOM_WRITEFLUSH 5 /* write and flush */
1637
1638#define MMIOM_RENAME 6 /* rename specified file */
1639
1640#define MMIOM_USER 0x8000 /* beginning of user-defined messages */
1641
1642#define FOURCC_RIFF mmioFOURCC('R', 'I', 'F', 'F')
1643#define FOURCC_LIST mmioFOURCC('L', 'I', 'S', 'T')
1644
1645#define FOURCC_DOS mmioFOURCC('D', 'O', 'S', ' ')
1646#define FOURCC_MEM mmioFOURCC('M', 'E', 'M', ' ')
1647
1648#define MMIO_DEFAULTBUFFER 8192 /* default buffer size */
1649
1650#define mmioFOURCC( ch0, ch1, ch2, ch3 ) \
1651 ( (DWORD)(BYTE)(ch0) | ( (DWORD)(BYTE)(ch1) << 8 ) | \
1652 ( (DWORD)(BYTE)(ch2) << 16 ) | ( (DWORD)(BYTE)(ch3) << 24 ) )
1653
1654LPMMIOPROC WINAPI mmioInstallIOProcA(FOURCC,LPMMIOPROC,DWORD);
1655LPMMIOPROC WINAPI mmioInstallIOProcW(FOURCC,LPMMIOPROC,DWORD);
1656#define mmioInstallIOProc WINELIB_NAME_AW(mmioInstallIOProc)
1657
1658FOURCC WINAPI mmioStringToFOURCCA(LPCSTR,UINT);
1659FOURCC WINAPI mmioStringToFOURCCW(LPCWSTR,UINT);
1660#define mmioStringToFOURCC WINELIB_NAME_AW(mmioStringToFOURCC)
1661HMMIO WINAPI mmioOpenA(LPSTR,MMIOINFO*,DWORD);
1662HMMIO WINAPI mmioOpenW(LPWSTR,MMIOINFO*,DWORD);
1663#define mmioOpen WINELIB_NAME_AW(mmioOpen)
1664
1665MMRESULT WINAPI mmioRenameA(LPCSTR szFileName, LPCSTR szNewFileName,
1666 const MMIOINFO * lpmmioinfo, DWORD dwRenameFlags);
1667MMRESULT WINAPI mmioRenameW(LPCWSTR szFileName, LPCWSTR szNewFileName,
1668 const MMIOINFO * lpmmioinfo, DWORD dwRenameFlags);
1669#define mmioRename WINELIB_NAME_AW(mmioRename)
1670
1671MMRESULT WINAPI mmioClose(HMMIO,UINT);
1672LONG WINAPI mmioRead(HMMIO,HPSTR,LONG);
1673LONG WINAPI mmioWrite(HMMIO,HPCSTR,LONG);
1674LONG WINAPI mmioSeek(HMMIO,LONG,INT);
1675MMRESULT WINAPI mmioGetInfo(HMMIO,MMIOINFO*,UINT);
1676MMRESULT WINAPI mmioSetInfo(HMMIO,const MMIOINFO*,UINT);
1677MMRESULT WINAPI mmioSetBuffer(HMMIO,LPSTR,LONG,UINT);
1678MMRESULT WINAPI mmioFlush(HMMIO,UINT);
1679MMRESULT WINAPI mmioAdvance(HMMIO,MMIOINFO*,UINT);
1680LRESULT WINAPI mmioSendMessage(HMMIO,UINT,LPARAM,LPARAM);
1681MMRESULT WINAPI mmioDescend(HMMIO,MMCKINFO*,const MMCKINFO*,UINT);
1682MMRESULT WINAPI mmioAscend(HMMIO,MMCKINFO*,UINT);
1683MMRESULT WINAPI mmioCreateChunk(HMMIO,MMCKINFO*,UINT);
1684
1685typedef UINT (CALLBACK *YIELDPROC)(MCIDEVICEID,DWORD);
1686
1687BOOL WINAPI mciExecute(LPCSTR);
1688DWORD WINAPI mciSendCommandA(MCIDEVICEID,UINT,DWORD_PTR,DWORD_PTR);
1689DWORD WINAPI mciSendCommandW(MCIDEVICEID,UINT,DWORD_PTR,DWORD_PTR);
1690#define mciSendCommand WINELIB_NAME_AW(mciSendCommand)
1691DWORD WINAPI mciSendStringA(LPCSTR,LPSTR,UINT,HWND);
1692DWORD WINAPI mciSendStringW(LPCWSTR,LPWSTR,UINT,HWND);
1693#define mciSendString WINELIB_NAME_AW(mciSendString)
1694MCIDEVICEID WINAPI mciGetDeviceIDA(LPCSTR);
1695MCIDEVICEID WINAPI mciGetDeviceIDW(LPCWSTR);
1696#define mciGetDeviceID WINELIB_NAME_AW(mciGetDeviceID)
1697MCIDEVICEID WINAPI mciGetDeviceIDFromElementIDA(DWORD,LPCSTR);
1698MCIDEVICEID WINAPI mciGetDeviceIDFromElementIDW(DWORD,LPCWSTR);
1699#define mciGetDeviceIDFromElementID WINELIB_NAME_AW(mciGetDeviceIDFromElementID)
1700BOOL WINAPI mciGetErrorStringA(MCIERROR,LPSTR,UINT);
1701BOOL WINAPI mciGetErrorStringW(MCIERROR,LPWSTR,UINT);
1702#define mciGetErrorString WINELIB_NAME_AW(mciGetErrorString)
1703BOOL WINAPI mciSetYieldProc(MCIDEVICEID,YIELDPROC,DWORD);
1704HTASK WINAPI mciGetCreatorTask(MCIDEVICEID);
1705YIELDPROC WINAPI mciGetYieldProc(MCIDEVICEID,DWORD*);
1706
1707#define MCIERR_INVALID_DEVICE_ID (MCIERR_BASE + 1)
1708#define MCIERR_UNRECOGNIZED_KEYWORD (MCIERR_BASE + 3)
1709#define MCIERR_UNRECOGNIZED_COMMAND (MCIERR_BASE + 5)
1710#define MCIERR_HARDWARE (MCIERR_BASE + 6)
1711#define MCIERR_INVALID_DEVICE_NAME (MCIERR_BASE + 7)
1712#define MCIERR_OUT_OF_MEMORY (MCIERR_BASE + 8)
1713#define MCIERR_DEVICE_OPEN (MCIERR_BASE + 9)
1714#define MCIERR_CANNOT_LOAD_DRIVER (MCIERR_BASE + 10)
1715#define MCIERR_MISSING_COMMAND_STRING (MCIERR_BASE + 11)
1716#define MCIERR_PARAM_OVERFLOW (MCIERR_BASE + 12)
1717#define MCIERR_MISSING_STRING_ARGUMENT (MCIERR_BASE + 13)
1718#define MCIERR_BAD_INTEGER (MCIERR_BASE + 14)
1719#define MCIERR_PARSER_INTERNAL (MCIERR_BASE + 15)
1720#define MCIERR_DRIVER_INTERNAL (MCIERR_BASE + 16)
1721#define MCIERR_MISSING_PARAMETER (MCIERR_BASE + 17)
1722#define MCIERR_UNSUPPORTED_FUNCTION (MCIERR_BASE + 18)
1723#define MCIERR_FILE_NOT_FOUND (MCIERR_BASE + 19)
1724#define MCIERR_DEVICE_NOT_READY (MCIERR_BASE + 20)
1725#define MCIERR_INTERNAL (MCIERR_BASE + 21)
1726#define MCIERR_DRIVER (MCIERR_BASE + 22)
1727#define MCIERR_CANNOT_USE_ALL (MCIERR_BASE + 23)
1728#define MCIERR_MULTIPLE (MCIERR_BASE + 24)
1729#define MCIERR_EXTENSION_NOT_FOUND (MCIERR_BASE + 25)
1730#define MCIERR_OUTOFRANGE (MCIERR_BASE + 26)
1731#define MCIERR_FLAGS_NOT_COMPATIBLE (MCIERR_BASE + 28)
1732#define MCIERR_FILE_NOT_SAVED (MCIERR_BASE + 30)
1733#define MCIERR_DEVICE_TYPE_REQUIRED (MCIERR_BASE + 31)
1734#define MCIERR_DEVICE_LOCKED (MCIERR_BASE + 32)
1735#define MCIERR_DUPLICATE_ALIAS (MCIERR_BASE + 33)
1736#define MCIERR_BAD_CONSTANT (MCIERR_BASE + 34)
1737#define MCIERR_MUST_USE_SHAREABLE (MCIERR_BASE + 35)
1738#define MCIERR_MISSING_DEVICE_NAME (MCIERR_BASE + 36)
1739#define MCIERR_BAD_TIME_FORMAT (MCIERR_BASE + 37)
1740#define MCIERR_NO_CLOSING_QUOTE (MCIERR_BASE + 38)
1741#define MCIERR_DUPLICATE_FLAGS (MCIERR_BASE + 39)
1742#define MCIERR_INVALID_FILE (MCIERR_BASE + 40)
1743#define MCIERR_NULL_PARAMETER_BLOCK (MCIERR_BASE + 41)
1744#define MCIERR_UNNAMED_RESOURCE (MCIERR_BASE + 42)
1745#define MCIERR_NEW_REQUIRES_ALIAS (MCIERR_BASE + 43)
1746#define MCIERR_NOTIFY_ON_AUTO_OPEN (MCIERR_BASE + 44)
1747#define MCIERR_NO_ELEMENT_ALLOWED (MCIERR_BASE + 45)
1748#define MCIERR_NONAPPLICABLE_FUNCTION (MCIERR_BASE + 46)
1749#define MCIERR_ILLEGAL_FOR_AUTO_OPEN (MCIERR_BASE + 47)
1750#define MCIERR_FILENAME_REQUIRED (MCIERR_BASE + 48)
1751#define MCIERR_EXTRA_CHARACTERS (MCIERR_BASE + 49)
1752#define MCIERR_DEVICE_NOT_INSTALLED (MCIERR_BASE + 50)
1753#define MCIERR_GET_CD (MCIERR_BASE + 51)
1754#define MCIERR_SET_CD (MCIERR_BASE + 52)
1755#define MCIERR_SET_DRIVE (MCIERR_BASE + 53)
1756#define MCIERR_DEVICE_LENGTH (MCIERR_BASE + 54)
1757#define MCIERR_DEVICE_ORD_LENGTH (MCIERR_BASE + 55)
1758#define MCIERR_NO_INTEGER (MCIERR_BASE + 56)
1759
1760#define MCIERR_WAVE_OUTPUTSINUSE (MCIERR_BASE + 64)
1761#define MCIERR_WAVE_SETOUTPUTINUSE (MCIERR_BASE + 65)
1762#define MCIERR_WAVE_INPUTSINUSE (MCIERR_BASE + 66)
1763#define MCIERR_WAVE_SETINPUTINUSE (MCIERR_BASE + 67)
1764#define MCIERR_WAVE_OUTPUTUNSPECIFIED (MCIERR_BASE + 68)
1765#define MCIERR_WAVE_INPUTUNSPECIFIED (MCIERR_BASE + 69)
1766#define MCIERR_WAVE_OUTPUTSUNSUITABLE (MCIERR_BASE + 70)
1767#define MCIERR_WAVE_SETOUTPUTUNSUITABLE (MCIERR_BASE + 71)
1768#define MCIERR_WAVE_INPUTSUNSUITABLE (MCIERR_BASE + 72)
1769#define MCIERR_WAVE_SETINPUTUNSUITABLE (MCIERR_BASE + 73)
1770
1771#define MCIERR_SEQ_DIV_INCOMPATIBLE (MCIERR_BASE + 80)
1772#define MCIERR_SEQ_PORT_INUSE (MCIERR_BASE + 81)
1773#define MCIERR_SEQ_PORT_NONEXISTENT (MCIERR_BASE + 82)
1774#define MCIERR_SEQ_PORT_MAPNODEVICE (MCIERR_BASE + 83)
1775#define MCIERR_SEQ_PORT_MISCERROR (MCIERR_BASE + 84)
1776#define MCIERR_SEQ_TIMER (MCIERR_BASE + 85)
1777#define MCIERR_SEQ_PORTUNSPECIFIED (MCIERR_BASE + 86)
1778#define MCIERR_SEQ_NOMIDIPRESENT (MCIERR_BASE + 87)
1779
1780#define MCIERR_NO_WINDOW (MCIERR_BASE + 90)
1781#define MCIERR_CREATEWINDOW (MCIERR_BASE + 91)
1782#define MCIERR_FILE_READ (MCIERR_BASE + 92)
1783#define MCIERR_FILE_WRITE (MCIERR_BASE + 93)
1784
1785#define MCIERR_NO_IDENTITY (MCIERR_BASE + 94)
1786
1787#define MCIERR_CUSTOM_DRIVER_BASE (MCIERR_BASE + 256)
1788
1789#define MCI_OPEN_DRIVER 0x0801
1790#define MCI_CLOSE_DRIVER 0x0802
1791#define MCI_OPEN 0x0803
1792#define MCI_CLOSE 0x0804
1793#define MCI_ESCAPE 0x0805
1794#define MCI_PLAY 0x0806
1795#define MCI_SEEK 0x0807
1796#define MCI_STOP 0x0808
1797#define MCI_PAUSE 0x0809
1798#define MCI_INFO 0x080A
1799#define MCI_GETDEVCAPS 0x080B
1800#define MCI_SPIN 0x080C
1801#define MCI_SET 0x080D
1802#define MCI_STEP 0x080E
1803#define MCI_RECORD 0x080F
1804#define MCI_SYSINFO 0x0810
1805#define MCI_BREAK 0x0811
1806#define MCI_SOUND 0x0812
1807#define MCI_SAVE 0x0813
1808#define MCI_STATUS 0x0814
1809#define MCI_CUE 0x0830
1810#define MCI_REALIZE 0x0840
1811#define MCI_WINDOW 0x0841
1812#define MCI_PUT 0x0842
1813#define MCI_WHERE 0x0843
1814#define MCI_FREEZE 0x0844
1815#define MCI_UNFREEZE 0x0845
1816#define MCI_LOAD 0x0850
1817#define MCI_CUT 0x0851
1818#define MCI_COPY 0x0852
1819#define MCI_PASTE 0x0853
1820#define MCI_UPDATE 0x0854
1821#define MCI_RESUME 0x0855
1822#define MCI_DELETE 0x0856
1823
1824#define MCI_USER_MESSAGES (0x400 + DRV_MCI_FIRST)
1825
1826#define MCI_ALL_DEVICE_ID 0xFFFFFFFF
1827
1828#define MCI_DEVTYPE_VCR (MCI_STRING_OFFSET + 1)
1829#define MCI_DEVTYPE_VIDEODISC (MCI_STRING_OFFSET + 2)
1830#define MCI_DEVTYPE_OVERLAY (MCI_STRING_OFFSET + 3)
1831#define MCI_DEVTYPE_CD_AUDIO (MCI_STRING_OFFSET + 4)
1832#define MCI_DEVTYPE_DAT (MCI_STRING_OFFSET + 5)
1833#define MCI_DEVTYPE_SCANNER (MCI_STRING_OFFSET + 6)
1834#define MCI_DEVTYPE_ANIMATION (MCI_STRING_OFFSET + 7)
1835#define MCI_DEVTYPE_DIGITAL_VIDEO (MCI_STRING_OFFSET + 8)
1836#define MCI_DEVTYPE_OTHER (MCI_STRING_OFFSET + 9)
1837#define MCI_DEVTYPE_WAVEFORM_AUDIO (MCI_STRING_OFFSET + 10)
1838#define MCI_DEVTYPE_SEQUENCER (MCI_STRING_OFFSET + 11)
1839
1840#define MCI_DEVTYPE_FIRST MCI_DEVTYPE_VCR
1841#define MCI_DEVTYPE_LAST MCI_DEVTYPE_SEQUENCER
1842
1843#define MCI_MODE_NOT_READY (MCI_STRING_OFFSET + 12)
1844#define MCI_MODE_STOP (MCI_STRING_OFFSET + 13)
1845#define MCI_MODE_PLAY (MCI_STRING_OFFSET + 14)
1846#define MCI_MODE_RECORD (MCI_STRING_OFFSET + 15)
1847#define MCI_MODE_SEEK (MCI_STRING_OFFSET + 16)
1848#define MCI_MODE_PAUSE (MCI_STRING_OFFSET + 17)
1849#define MCI_MODE_OPEN (MCI_STRING_OFFSET + 18)
1850
1851#define MCI_FORMAT_MILLISECONDS 0
1852#define MCI_FORMAT_HMS 1
1853#define MCI_FORMAT_MSF 2
1854#define MCI_FORMAT_FRAMES 3
1855#define MCI_FORMAT_SMPTE_24 4
1856#define MCI_FORMAT_SMPTE_25 5
1857#define MCI_FORMAT_SMPTE_30 6
1858#define MCI_FORMAT_SMPTE_30DROP 7
1859#define MCI_FORMAT_BYTES 8
1860#define MCI_FORMAT_SAMPLES 9
1861#define MCI_FORMAT_TMSF 10
1862
1863#define MCI_MSF_MINUTE(msf) ((BYTE)(msf))
1864#define MCI_MSF_SECOND(msf) ((BYTE)(((WORD)(msf)) >> 8))
1865#define MCI_MSF_FRAME(msf) ((BYTE)((msf)>>16))
1866
1867#define MCI_MAKE_MSF(m, s, f) ((DWORD)(((BYTE)(m) | \
1868 ((WORD)(s)<<8)) | \
1869 (((DWORD)(BYTE)(f))<<16)))
1870
1871#define MCI_TMSF_TRACK(tmsf) ((BYTE)(tmsf))
1872#define MCI_TMSF_MINUTE(tmsf) ((BYTE)(((WORD)(tmsf)) >> 8))
1873#define MCI_TMSF_SECOND(tmsf) ((BYTE)((tmsf)>>16))
1874#define MCI_TMSF_FRAME(tmsf) ((BYTE)((tmsf)>>24))
1875
1876#define MCI_MAKE_TMSF(t, m, s, f) ((DWORD)(((BYTE)(t) | \
1877 ((WORD)(m)<<8)) | \
1878 (((DWORD)(BYTE)(s) | \
1879 ((WORD)(f)<<8))<<16)))
1880
1881#define MCI_HMS_HOUR(hms) ((BYTE)(hms))
1882#define MCI_HMS_MINUTE(hms) ((BYTE)(((WORD)(hms)) >> 8))
1883#define MCI_HMS_SECOND(hms) ((BYTE)((hms)>>16))
1884
1885#define MCI_MAKE_HMS(h, m, s) ((DWORD)(((BYTE)(h) | \
1886 ((WORD)(m)<<8)) | \
1887 (((DWORD)(BYTE)(s))<<16)))
1888
1889#define MCI_NOTIFY_SUCCESSFUL 0x0001
1890#define MCI_NOTIFY_SUPERSEDED 0x0002
1891#define MCI_NOTIFY_ABORTED 0x0004
1892#define MCI_NOTIFY_FAILURE 0x0008
1893
1894#define MCI_NOTIFY __MSABI_LONG(0x00000001)
1895#define MCI_WAIT __MSABI_LONG(0x00000002)
1896#define MCI_FROM __MSABI_LONG(0x00000004)
1897#define MCI_TO __MSABI_LONG(0x00000008)
1898#define MCI_TRACK __MSABI_LONG(0x00000010)
1899
1900#define MCI_OPEN_SHAREABLE __MSABI_LONG(0x00000100)
1901#define MCI_OPEN_ELEMENT __MSABI_LONG(0x00000200)
1902#define MCI_OPEN_ALIAS __MSABI_LONG(0x00000400)
1903#define MCI_OPEN_ELEMENT_ID __MSABI_LONG(0x00000800)
1904#define MCI_OPEN_TYPE_ID __MSABI_LONG(0x00001000)
1905#define MCI_OPEN_TYPE __MSABI_LONG(0x00002000)
1906
1907#define MCI_SEEK_TO_START __MSABI_LONG(0x00000100)
1908#define MCI_SEEK_TO_END __MSABI_LONG(0x00000200)
1909
1910#define MCI_STATUS_ITEM __MSABI_LONG(0x00000100)
1911#define MCI_STATUS_START __MSABI_LONG(0x00000200)
1912
1913#define MCI_STATUS_LENGTH __MSABI_LONG(0x00000001)
1914#define MCI_STATUS_POSITION __MSABI_LONG(0x00000002)
1915#define MCI_STATUS_NUMBER_OF_TRACKS __MSABI_LONG(0x00000003)
1916#define MCI_STATUS_MODE __MSABI_LONG(0x00000004)
1917#define MCI_STATUS_MEDIA_PRESENT __MSABI_LONG(0x00000005)
1918#define MCI_STATUS_TIME_FORMAT __MSABI_LONG(0x00000006)
1919#define MCI_STATUS_READY __MSABI_LONG(0x00000007)
1920#define MCI_STATUS_CURRENT_TRACK __MSABI_LONG(0x00000008)
1921
1922#define MCI_INFO_PRODUCT __MSABI_LONG(0x00000100)
1923#define MCI_INFO_FILE __MSABI_LONG(0x00000200)
1924#define MCI_INFO_MEDIA_UPC __MSABI_LONG(0x00000400)
1925#define MCI_INFO_MEDIA_IDENTITY __MSABI_LONG(0x00000800)
1926#define MCI_INFO_NAME __MSABI_LONG(0x00001000)
1927#define MCI_INFO_COPYRIGHT __MSABI_LONG(0x00002000)
1928
1929#define MCI_GETDEVCAPS_ITEM __MSABI_LONG(0x00000100)
1930
1931#define MCI_GETDEVCAPS_CAN_RECORD __MSABI_LONG(0x00000001)
1932#define MCI_GETDEVCAPS_HAS_AUDIO __MSABI_LONG(0x00000002)
1933#define MCI_GETDEVCAPS_HAS_VIDEO __MSABI_LONG(0x00000003)
1934#define MCI_GETDEVCAPS_DEVICE_TYPE __MSABI_LONG(0x00000004)
1935#define MCI_GETDEVCAPS_USES_FILES __MSABI_LONG(0x00000005)
1936#define MCI_GETDEVCAPS_COMPOUND_DEVICE __MSABI_LONG(0x00000006)
1937#define MCI_GETDEVCAPS_CAN_EJECT __MSABI_LONG(0x00000007)
1938#define MCI_GETDEVCAPS_CAN_PLAY __MSABI_LONG(0x00000008)
1939#define MCI_GETDEVCAPS_CAN_SAVE __MSABI_LONG(0x00000009)
1940
1941#define MCI_SYSINFO_QUANTITY __MSABI_LONG(0x00000100)
1942#define MCI_SYSINFO_OPEN __MSABI_LONG(0x00000200)
1943#define MCI_SYSINFO_NAME __MSABI_LONG(0x00000400)
1944#define MCI_SYSINFO_INSTALLNAME __MSABI_LONG(0x00000800)
1945
1946#define MCI_SET_DOOR_OPEN __MSABI_LONG(0x00000100)
1947#define MCI_SET_DOOR_CLOSED __MSABI_LONG(0x00000200)
1948#define MCI_SET_TIME_FORMAT __MSABI_LONG(0x00000400)
1949#define MCI_SET_AUDIO __MSABI_LONG(0x00000800)
1950#define MCI_SET_VIDEO __MSABI_LONG(0x00001000)
1951#define MCI_SET_ON __MSABI_LONG(0x00002000)
1952#define MCI_SET_OFF __MSABI_LONG(0x00004000)
1953
1954#define MCI_SET_AUDIO_ALL __MSABI_LONG(0x00000000)
1955#define MCI_SET_AUDIO_LEFT __MSABI_LONG(0x00000001)
1956#define MCI_SET_AUDIO_RIGHT __MSABI_LONG(0x00000002)
1957
1958#define MCI_BREAK_KEY __MSABI_LONG(0x00000100)
1959#define MCI_BREAK_HWND __MSABI_LONG(0x00000200)
1960#define MCI_BREAK_OFF __MSABI_LONG(0x00000400)
1961
1962#define MCI_RECORD_INSERT __MSABI_LONG(0x00000100)
1963#define MCI_RECORD_OVERWRITE __MSABI_LONG(0x00000200)
1964
1965#define MCI_SOUND_NAME __MSABI_LONG(0x00000100)
1966
1967#define MCI_SAVE_FILE __MSABI_LONG(0x00000100)
1968
1969#define MCI_LOAD_FILE __MSABI_LONG(0x00000100)
1970
1971typedef struct tagMCI_GENERIC_PARMS {
1972 DWORD_PTR dwCallback;
1973} MCI_GENERIC_PARMS, *LPMCI_GENERIC_PARMS;
1974
1975typedef struct tagMCI_OPEN_PARMSA {
1976 DWORD_PTR dwCallback;
1977 MCIDEVICEID wDeviceID;
1978 LPCSTR lpstrDeviceType;
1979 LPCSTR lpstrElementName;
1980 LPCSTR lpstrAlias;
1981} MCI_OPEN_PARMSA, *LPMCI_OPEN_PARMSA;
1982
1983typedef struct tagMCI_OPEN_PARMSW {
1984 DWORD_PTR dwCallback;
1985 MCIDEVICEID wDeviceID;
1986 LPCWSTR lpstrDeviceType;
1987 LPCWSTR lpstrElementName;
1988 LPCWSTR lpstrAlias;
1989} MCI_OPEN_PARMSW, *LPMCI_OPEN_PARMSW;
1990
1991DECL_WINELIB_TYPE_AW(MCI_OPEN_PARMS)
1992DECL_WINELIB_TYPE_AW(LPMCI_OPEN_PARMS)
1993
1994typedef struct tagMCI_PLAY_PARMS{
1995 DWORD_PTR dwCallback;
1996 DWORD dwFrom;
1997 DWORD dwTo;
1998} MCI_PLAY_PARMS, *LPMCI_PLAY_PARMS;
1999
2000typedef struct tagMCI_SEEK_PARMS {
2001 DWORD_PTR dwCallback;
2002 DWORD dwTo;
2003} MCI_SEEK_PARMS, *LPMCI_SEEK_PARMS;
2004
2005typedef struct tagMCI_STATUS_PARMS {
2006 DWORD_PTR dwCallback;
2007 DWORD_PTR dwReturn;
2008 DWORD dwItem;
2009 DWORD dwTrack;
2010} MCI_STATUS_PARMS, *LPMCI_STATUS_PARMS;
2011
2012typedef struct tagMCI_INFO_PARMSA {
2013 DWORD_PTR dwCallback;
2014 LPSTR lpstrReturn;
2015 DWORD dwRetSize;
2016} MCI_INFO_PARMSA, *LPMCI_INFO_PARMSA;
2017
2018typedef struct tagMCI_INFO_PARMSW {
2019 DWORD_PTR dwCallback;
2020 LPWSTR lpstrReturn;
2021 DWORD dwRetSize;
2022} MCI_INFO_PARMSW, *LPMCI_INFO_PARMSW;
2023
2024DECL_WINELIB_TYPE_AW(MCI_INFO_PARMS)
2025DECL_WINELIB_TYPE_AW(LPMCI_INFO_PARMS)
2026
2027typedef struct tagMCI_GETDEVCAPS_PARMS {
2028 DWORD_PTR dwCallback;
2029 DWORD dwReturn;
2030 DWORD dwItem;
2031} MCI_GETDEVCAPS_PARMS, *LPMCI_GETDEVCAPS_PARMS;
2032
2033typedef struct tagMCI_SYSINFO_PARMSA {
2034 DWORD_PTR dwCallback;
2035 LPSTR lpstrReturn;
2036 DWORD dwRetSize;
2037 DWORD dwNumber;
2038 UINT wDeviceType;
2039} MCI_SYSINFO_PARMSA, *LPMCI_SYSINFO_PARMSA;
2040
2041typedef struct tagMCI_SYSINFO_PARMSW {
2042 DWORD_PTR dwCallback;
2043 LPWSTR lpstrReturn;
2044 DWORD dwRetSize;
2045 DWORD dwNumber;
2046 UINT wDeviceType;
2047} MCI_SYSINFO_PARMSW, *LPMCI_SYSINFO_PARMSW;
2048
2049DECL_WINELIB_TYPE_AW(MCI_SYSINFO_PARMS)
2050DECL_WINELIB_TYPE_AW(LPMCI_SYSINFO_PARMS)
2051
2052typedef struct tagMCI_SET_PARMS {
2053 DWORD_PTR dwCallback;
2054 DWORD dwTimeFormat;
2055 DWORD dwAudio;
2056} MCI_SET_PARMS, *LPMCI_SET_PARMS;
2057
2058typedef struct tagMCI_BREAK_PARMS {
2059 DWORD_PTR dwCallback;
2060 INT nVirtKey;
2061 HWND hwndBreak;
2062} MCI_BREAK_PARMS, *LPMCI_BREAK_PARMS;
2063
2064
2065typedef struct tagMCI_SOUND_PARMSA {
2066 DWORD_PTR dwCallback;
2067 LPCSTR lpstrSoundName;
2068} MCI_SOUND_PARMSA, *LPMCI_SOUND_PARMSA;
2069
2070typedef struct tagMCI_SOUND_PARMSW {
2071 DWORD_PTR dwCallback;
2072 LPCWSTR lpstrSoundName;
2073} MCI_SOUND_PARMSW, *LPMCI_SOUND_PARMSW;
2074
2075DECL_WINELIB_TYPE_AW(MCI_SOUND_PARMS)
2076DECL_WINELIB_TYPE_AW(LPMCI_SOUND_PARMS)
2077
2078typedef struct tagMCI_SAVE_PARMSA {
2079 DWORD_PTR dwCallback;
2080 LPCSTR lpfilename;
2081} MCI_SAVE_PARMSA, *LPMCI_SAVE_PARMSA;
2082
2083typedef struct tagMCI_SAVE_PARMSW {
2084 DWORD_PTR dwCallback;
2085 LPCWSTR lpfilename;
2086} MCI_SAVE_PARMSW, *LPMCI_SAVE_PARMSW;
2087
2088DECL_WINELIB_TYPE_AW(MCI_SAVE_PARMS)
2089DECL_WINELIB_TYPE_AW(LPMCI_SAVE_PARMS)
2090
2091typedef struct tagMCI_LOAD_PARMSA {
2092 DWORD_PTR dwCallback;
2093 LPCSTR lpfilename;
2094} MCI_LOAD_PARMSA, *LPMCI_LOAD_PARMSA;
2095
2096typedef struct tagMCI_LOAD_PARMSW {
2097 DWORD_PTR dwCallback;
2098 LPCWSTR lpfilename;
2099} MCI_LOAD_PARMSW, *LPMCI_LOAD_PARMSW;
2100
2101DECL_WINELIB_TYPE_AW(MCI_LOAD_PARMS)
2102DECL_WINELIB_TYPE_AW(LPMCI_LOAD_PARMS)
2103
2104typedef struct tagMCI_RECORD_PARMS {
2105 DWORD_PTR dwCallback;
2106 DWORD dwFrom;
2107 DWORD dwTo;
2108} MCI_RECORD_PARMS, *LPMCI_RECORD_PARMS;
2109
2110#define MCI_CDA_STATUS_TYPE_TRACK 0x00004001
2111
2112#define MCI_CDA_TRACK_AUDIO (MCI_CD_OFFSET + 0)
2113#define MCI_CDA_TRACK_OTHER (MCI_CD_OFFSET + 1)
2114
2115#define MCI_VD_MODE_PARK (MCI_VD_OFFSET + 1)
2116
2117#define MCI_VD_MEDIA_CLV (MCI_VD_OFFSET + 2)
2118#define MCI_VD_MEDIA_CAV (MCI_VD_OFFSET + 3)
2119#define MCI_VD_MEDIA_OTHER (MCI_VD_OFFSET + 4)
2120
2121#define MCI_VD_FORMAT_TRACK 0x4001
2122
2123#define MCI_VD_PLAY_REVERSE __MSABI_LONG(0x00010000)
2124#define MCI_VD_PLAY_FAST __MSABI_LONG(0x00020000)
2125#define MCI_VD_PLAY_SPEED __MSABI_LONG(0x00040000)
2126#define MCI_VD_PLAY_SCAN __MSABI_LONG(0x00080000)
2127#define MCI_VD_PLAY_SLOW __MSABI_LONG(0x00100000)
2128
2129#define MCI_VD_SEEK_REVERSE __MSABI_LONG(0x00010000)
2130
2131#define MCI_VD_STATUS_SPEED __MSABI_LONG(0x00004002)
2132#define MCI_VD_STATUS_FORWARD __MSABI_LONG(0x00004003)
2133#define MCI_VD_STATUS_MEDIA_TYPE __MSABI_LONG(0x00004004)
2134#define MCI_VD_STATUS_SIDE __MSABI_LONG(0x00004005)
2135#define MCI_VD_STATUS_DISC_SIZE __MSABI_LONG(0x00004006)
2136
2137#define MCI_VD_GETDEVCAPS_CLV __MSABI_LONG(0x00010000)
2138#define MCI_VD_GETDEVCAPS_CAV __MSABI_LONG(0x00020000)
2139
2140#define MCI_VD_SPIN_UP __MSABI_LONG(0x00010000)
2141#define MCI_VD_SPIN_DOWN __MSABI_LONG(0x00020000)
2142
2143#define MCI_VD_GETDEVCAPS_CAN_REVERSE __MSABI_LONG(0x00004002)
2144#define MCI_VD_GETDEVCAPS_FAST_RATE __MSABI_LONG(0x00004003)
2145#define MCI_VD_GETDEVCAPS_SLOW_RATE __MSABI_LONG(0x00004004)
2146#define MCI_VD_GETDEVCAPS_NORMAL_RATE __MSABI_LONG(0x00004005)
2147
2148#define MCI_VD_STEP_FRAMES __MSABI_LONG(0x00010000)
2149#define MCI_VD_STEP_REVERSE __MSABI_LONG(0x00020000)
2150
2151#define MCI_VD_ESCAPE_STRING __MSABI_LONG(0x00000100)
2152
2153typedef struct tagMCI_VD_PLAY_PARMS {
2154 DWORD_PTR dwCallback;
2155 DWORD dwFrom;
2156 DWORD dwTo;
2157 DWORD dwSpeed;
2158} MCI_VD_PLAY_PARMS, *LPMCI_VD_PLAY_PARMS;
2159
2160typedef struct tagMCI_VD_STEP_PARMS {
2161 DWORD_PTR dwCallback;
2162 DWORD dwFrames;
2163} MCI_VD_STEP_PARMS, *LPMCI_VD_STEP_PARMS;
2164
2165typedef struct tagMCI_VD_ESCAPE_PARMSA {
2166 DWORD_PTR dwCallback;
2167 LPCSTR lpstrCommand;
2168} MCI_VD_ESCAPE_PARMSA, *LPMCI_VD_ESCAPE_PARMSA;
2169
2170typedef struct tagMCI_VD_ESCAPE_PARMSW {
2171 DWORD_PTR dwCallback;
2172 LPCWSTR lpstrCommand;
2173} MCI_VD_ESCAPE_PARMSW, *LPMCI_VD_ESCAPE_PARMSW;
2174
2175DECL_WINELIB_TYPE_AW(MCI_VD_ESCAPE_PARMS)
2176DECL_WINELIB_TYPE_AW(LPMCI_VD_ESCAPE_PARMS)
2177
2178#define MCI_WAVE_OPEN_BUFFER __MSABI_LONG(0x00010000)
2179
2180#define MCI_WAVE_SET_FORMATTAG __MSABI_LONG(0x00010000)
2181#define MCI_WAVE_SET_CHANNELS __MSABI_LONG(0x00020000)
2182#define MCI_WAVE_SET_SAMPLESPERSEC __MSABI_LONG(0x00040000)
2183#define MCI_WAVE_SET_AVGBYTESPERSEC __MSABI_LONG(0x00080000)
2184#define MCI_WAVE_SET_BLOCKALIGN __MSABI_LONG(0x00100000)
2185#define MCI_WAVE_SET_BITSPERSAMPLE __MSABI_LONG(0x00200000)
2186
2187#define MCI_WAVE_INPUT __MSABI_LONG(0x00400000)
2188#define MCI_WAVE_OUTPUT __MSABI_LONG(0x00800000)
2189
2190#define MCI_WAVE_STATUS_FORMATTAG __MSABI_LONG(0x00004001)
2191#define MCI_WAVE_STATUS_CHANNELS __MSABI_LONG(0x00004002)
2192#define MCI_WAVE_STATUS_SAMPLESPERSEC __MSABI_LONG(0x00004003)
2193#define MCI_WAVE_STATUS_AVGBYTESPERSEC __MSABI_LONG(0x00004004)
2194#define MCI_WAVE_STATUS_BLOCKALIGN __MSABI_LONG(0x00004005)
2195#define MCI_WAVE_STATUS_BITSPERSAMPLE __MSABI_LONG(0x00004006)
2196#define MCI_WAVE_STATUS_LEVEL __MSABI_LONG(0x00004007)
2197
2198#define MCI_WAVE_SET_ANYINPUT __MSABI_LONG(0x04000000)
2199#define MCI_WAVE_SET_ANYOUTPUT __MSABI_LONG(0x08000000)
2200
2201#define MCI_WAVE_GETDEVCAPS_INPUTS __MSABI_LONG(0x00004001)
2202#define MCI_WAVE_GETDEVCAPS_OUTPUTS __MSABI_LONG(0x00004002)
2203
2204typedef struct tagMCI_WAVE_OPEN_PARMSA {
2205 DWORD_PTR dwCallback;
2206 MCIDEVICEID wDeviceID;
2207 LPCSTR lpstrDeviceType;
2208 LPCSTR lpstrElementName;
2209 LPCSTR lpstrAlias;
2210 DWORD dwBufferSeconds;
2211} MCI_WAVE_OPEN_PARMSA, *LPMCI_WAVE_OPEN_PARMSA;
2212
2213typedef struct tagMCI_WAVE_OPEN_PARMSW {
2214 DWORD_PTR dwCallback;
2215 MCIDEVICEID wDeviceID;
2216 LPCWSTR lpstrDeviceType;
2217 LPCWSTR lpstrElementName;
2218 LPCWSTR lpstrAlias;
2219 DWORD dwBufferSeconds;
2220} MCI_WAVE_OPEN_PARMSW, *LPMCI_WAVE_OPEN_PARMSW;
2221
2222DECL_WINELIB_TYPE_AW(MCI_WAVE_OPEN_PARMS)
2223DECL_WINELIB_TYPE_AW(LPMCI_WAVE_OPEN_PARMS)
2224
2225typedef struct tagMCI_WAVE_DELETE_PARMS {
2226 DWORD_PTR dwCallback;
2227 DWORD dwFrom;
2228 DWORD dwTo;
2229} MCI_WAVE_DELETE_PARMS, *LPMCI_WAVE_DELETE_PARMS;
2230
2231typedef struct tagMCI_WAVE_SET_PARMS {
2232 DWORD_PTR dwCallback;
2233 DWORD dwTimeFormat;
2234 DWORD dwAudio;
2235 UINT wInput;
2236 UINT wOutput;
2237 UINT wFormatTag;
2238 UINT nChannels;
2239 DWORD nSamplesPerSec;
2240 DWORD nAvgBytesPerSec;
2241 UINT nBlockAlign;
2242 UINT wBitsPerSample;
2243} MCI_WAVE_SET_PARMS, * LPMCI_WAVE_SET_PARMS;
2244
2245
2246#define MCI_SEQ_DIV_PPQN (0 + MCI_SEQ_OFFSET)
2247#define MCI_SEQ_DIV_SMPTE_24 (1 + MCI_SEQ_OFFSET)
2248#define MCI_SEQ_DIV_SMPTE_25 (2 + MCI_SEQ_OFFSET)
2249#define MCI_SEQ_DIV_SMPTE_30DROP (3 + MCI_SEQ_OFFSET)
2250#define MCI_SEQ_DIV_SMPTE_30 (4 + MCI_SEQ_OFFSET)
2251
2252#define MCI_SEQ_FORMAT_SONGPTR 0x4001
2253#define MCI_SEQ_FILE 0x4002
2254#define MCI_SEQ_MIDI 0x4003
2255#define MCI_SEQ_SMPTE 0x4004
2256#define MCI_SEQ_NONE 65533
2257
2258#define MCI_SEQ_STATUS_TEMPO __MSABI_LONG(0x00004002)
2259#define MCI_SEQ_STATUS_PORT __MSABI_LONG(0x00004003)
2260#define MCI_SEQ_STATUS_SLAVE __MSABI_LONG(0x00004007)
2261#define MCI_SEQ_STATUS_MASTER __MSABI_LONG(0x00004008)
2262#define MCI_SEQ_STATUS_OFFSET __MSABI_LONG(0x00004009)
2263#define MCI_SEQ_STATUS_DIVTYPE __MSABI_LONG(0x0000400A)
2264
2265#define MCI_SEQ_SET_TEMPO __MSABI_LONG(0x00010000)
2266#define MCI_SEQ_SET_PORT __MSABI_LONG(0x00020000)
2267#define MCI_SEQ_SET_SLAVE __MSABI_LONG(0x00040000)
2268#define MCI_SEQ_SET_MASTER __MSABI_LONG(0x00080000)
2269#define MCI_SEQ_SET_OFFSET __MSABI_LONG(0x01000000)
2270
2271typedef struct tagMCI_SEQ_SET_PARMS {
2272 DWORD_PTR dwCallback;
2273 DWORD dwTimeFormat;
2274 DWORD dwAudio;
2275 DWORD dwTempo;
2276 DWORD dwPort;
2277 DWORD dwSlave;
2278 DWORD dwMaster;
2279 DWORD dwOffset;
2280} MCI_SEQ_SET_PARMS, *LPMCI_SEQ_SET_PARMS;
2281
2282#define MCI_ANIM_OPEN_WS __MSABI_LONG(0x00010000)
2283#define MCI_ANIM_OPEN_PARENT __MSABI_LONG(0x00020000)
2284#define MCI_ANIM_OPEN_NOSTATIC __MSABI_LONG(0x00040000)
2285
2286#define MCI_ANIM_PLAY_SPEED __MSABI_LONG(0x00010000)
2287#define MCI_ANIM_PLAY_REVERSE __MSABI_LONG(0x00020000)
2288#define MCI_ANIM_PLAY_FAST __MSABI_LONG(0x00040000)
2289#define MCI_ANIM_PLAY_SLOW __MSABI_LONG(0x00080000)
2290#define MCI_ANIM_PLAY_SCAN __MSABI_LONG(0x00100000)
2291
2292#define MCI_ANIM_STEP_REVERSE __MSABI_LONG(0x00010000)
2293#define MCI_ANIM_STEP_FRAMES __MSABI_LONG(0x00020000)
2294
2295#define MCI_ANIM_STATUS_SPEED __MSABI_LONG(0x00004001)
2296#define MCI_ANIM_STATUS_FORWARD __MSABI_LONG(0x00004002)
2297#define MCI_ANIM_STATUS_HWND __MSABI_LONG(0x00004003)
2298#define MCI_ANIM_STATUS_HPAL __MSABI_LONG(0x00004004)
2299#define MCI_ANIM_STATUS_STRETCH __MSABI_LONG(0x00004005)
2300
2301#define MCI_ANIM_INFO_TEXT __MSABI_LONG(0x00010000)
2302
2303#define MCI_ANIM_GETDEVCAPS_CAN_REVERSE __MSABI_LONG(0x00004001)
2304#define MCI_ANIM_GETDEVCAPS_FAST_RATE __MSABI_LONG(0x00004002)
2305#define MCI_ANIM_GETDEVCAPS_SLOW_RATE __MSABI_LONG(0x00004003)
2306#define MCI_ANIM_GETDEVCAPS_NORMAL_RATE __MSABI_LONG(0x00004004)
2307#define MCI_ANIM_GETDEVCAPS_PALETTES __MSABI_LONG(0x00004006)
2308#define MCI_ANIM_GETDEVCAPS_CAN_STRETCH __MSABI_LONG(0x00004007)
2309#define MCI_ANIM_GETDEVCAPS_MAX_WINDOWS __MSABI_LONG(0x00004008)
2310
2311#define MCI_ANIM_REALIZE_NORM __MSABI_LONG(0x00010000)
2312#define MCI_ANIM_REALIZE_BKGD __MSABI_LONG(0x00020000)
2313
2314#define MCI_ANIM_WINDOW_HWND __MSABI_LONG(0x00010000)
2315#define MCI_ANIM_WINDOW_STATE __MSABI_LONG(0x00040000)
2316#define MCI_ANIM_WINDOW_TEXT __MSABI_LONG(0x00080000)
2317#define MCI_ANIM_WINDOW_ENABLE_STRETCH __MSABI_LONG(0x00100000)
2318#define MCI_ANIM_WINDOW_DISABLE_STRETCH __MSABI_LONG(0x00200000)
2319
2320#define MCI_ANIM_WINDOW_DEFAULT __MSABI_LONG(0x00000000)
2321
2322#define MCI_ANIM_RECT __MSABI_LONG(0x00010000)
2323#define MCI_ANIM_PUT_SOURCE __MSABI_LONG(0x00020000)
2324#define MCI_ANIM_PUT_DESTINATION __MSABI_LONG(0x00040000)
2325
2326#define MCI_ANIM_WHERE_SOURCE __MSABI_LONG(0x00020000)
2327#define MCI_ANIM_WHERE_DESTINATION __MSABI_LONG(0x00040000)
2328
2329#define MCI_ANIM_UPDATE_HDC __MSABI_LONG(0x00020000)
2330
2331typedef struct tagMCI_ANIM_OPEN_PARMSA {
2332 DWORD_PTR dwCallback;
2333 MCIDEVICEID wDeviceID;
2334 LPCSTR lpstrDeviceType;
2335 LPCSTR lpstrElementName;
2336 LPCSTR lpstrAlias;
2337 DWORD dwStyle;
2338 HWND hWndParent;
2339} MCI_ANIM_OPEN_PARMSA, *LPMCI_ANIM_OPEN_PARMSA;
2340
2341typedef struct tagMCI_ANIM_OPEN_PARMSW {
2342 DWORD_PTR dwCallback;
2343 MCIDEVICEID wDeviceID;
2344 LPCWSTR lpstrDeviceType;
2345 LPCWSTR lpstrElementName;
2346 LPCWSTR lpstrAlias;
2347 DWORD dwStyle;
2348 HWND hWndParent;
2349} MCI_ANIM_OPEN_PARMSW, *LPMCI_ANIM_OPEN_PARMSW;
2350
2351DECL_WINELIB_TYPE_AW(MCI_ANIM_OPEN_PARMS)
2352DECL_WINELIB_TYPE_AW(LPMCI_ANIM_OPEN_PARMS)
2353
2354typedef struct tagMCI_ANIM_PLAY_PARMS {
2355 DWORD_PTR dwCallback;
2356 DWORD dwFrom;
2357 DWORD dwTo;
2358 DWORD dwSpeed;
2359} MCI_ANIM_PLAY_PARMS, *LPMCI_ANIM_PLAY_PARMS;
2360
2361typedef struct tagMCI_ANIM_STEP_PARMS {
2362 DWORD_PTR dwCallback;
2363 DWORD dwFrames;
2364} MCI_ANIM_STEP_PARMS, *LPMCI_ANIM_STEP_PARMS;
2365
2366typedef struct tagMCI_ANIM_WINDOW_PARMSA {
2367 DWORD_PTR dwCallback;
2368 HWND hWnd;
2369 UINT nCmdShow;
2370 LPCSTR lpstrText;
2371} MCI_ANIM_WINDOW_PARMSA, *LPMCI_ANIM_WINDOW_PARMSA;
2372
2373typedef struct tagMCI_ANIM_WINDOW_PARMSW {
2374 DWORD_PTR dwCallback;
2375 HWND hWnd;
2376 UINT nCmdShow;
2377 LPCWSTR lpstrText;
2378} MCI_ANIM_WINDOW_PARMSW, *LPMCI_ANIM_WINDOW_PARMSW;
2379
2380DECL_WINELIB_TYPE_AW(MCI_ANIM_WINDOW_PARMS)
2381DECL_WINELIB_TYPE_AW(LPMCI_ANIM_WINDOW_PARMS)
2382
2383typedef struct tagMCI_ANIM_RECT_PARMS {
2384 DWORD_PTR dwCallback;
2385#ifdef MCI_USE_OFFEXT
2386 POINT ptOffset;
2387 POINT ptExtent;
2388#else /* ifdef MCI_USE_OFFEXT */
2389 RECT rc;
2390#endif /* ifdef MCI_USE_OFFEXT */
2391} MCI_ANIM_RECT_PARMS, *LPMCI_ANIM_RECT_PARMS;
2392
2393
2394typedef struct tagMCI_ANIM_UPDATE_PARMS {
2395 DWORD_PTR dwCallback;
2396 RECT rc;
2397 HDC hDC;
2398} MCI_ANIM_UPDATE_PARMS, *LPMCI_ANIM_UPDATE_PARMS;
2399
2400
2401#define MCI_OVLY_OPEN_WS __MSABI_LONG(0x00010000)
2402#define MCI_OVLY_OPEN_PARENT __MSABI_LONG(0x00020000)
2403
2404#define MCI_OVLY_STATUS_HWND __MSABI_LONG(0x00004001)
2405#define MCI_OVLY_STATUS_STRETCH __MSABI_LONG(0x00004002)
2406
2407#define MCI_OVLY_INFO_TEXT __MSABI_LONG(0x00010000)
2408
2409#define MCI_OVLY_GETDEVCAPS_CAN_STRETCH __MSABI_LONG(0x00004001)
2410#define MCI_OVLY_GETDEVCAPS_CAN_FREEZE __MSABI_LONG(0x00004002)
2411#define MCI_OVLY_GETDEVCAPS_MAX_WINDOWS __MSABI_LONG(0x00004003)
2412
2413#define MCI_OVLY_WINDOW_HWND __MSABI_LONG(0x00010000)
2414#define MCI_OVLY_WINDOW_STATE __MSABI_LONG(0x00040000)
2415#define MCI_OVLY_WINDOW_TEXT __MSABI_LONG(0x00080000)
2416#define MCI_OVLY_WINDOW_ENABLE_STRETCH __MSABI_LONG(0x00100000)
2417#define MCI_OVLY_WINDOW_DISABLE_STRETCH __MSABI_LONG(0x00200000)
2418
2419#define MCI_OVLY_WINDOW_DEFAULT __MSABI_LONG(0x00000000)
2420
2421#define MCI_OVLY_RECT __MSABI_LONG(0x00010000)
2422#define MCI_OVLY_PUT_SOURCE __MSABI_LONG(0x00020000)
2423#define MCI_OVLY_PUT_DESTINATION __MSABI_LONG(0x00040000)
2424#define MCI_OVLY_PUT_FRAME __MSABI_LONG(0x00080000)
2425#define MCI_OVLY_PUT_VIDEO __MSABI_LONG(0x00100000)
2426
2427#define MCI_OVLY_WHERE_SOURCE __MSABI_LONG(0x00020000)
2428#define MCI_OVLY_WHERE_DESTINATION __MSABI_LONG(0x00040000)
2429#define MCI_OVLY_WHERE_FRAME __MSABI_LONG(0x00080000)
2430#define MCI_OVLY_WHERE_VIDEO __MSABI_LONG(0x00100000)
2431
2432typedef struct tagMCI_OVLY_OPEN_PARMSA {
2433 DWORD_PTR dwCallback;
2434 MCIDEVICEID wDeviceID;
2435 LPCSTR lpstrDeviceType;
2436 LPCSTR lpstrElementName;
2437 LPCSTR lpstrAlias;
2438 DWORD dwStyle;
2439 HWND hWndParent;
2440} MCI_OVLY_OPEN_PARMSA, *LPMCI_OVLY_OPEN_PARMSA;
2441
2442typedef struct tagMCI_OVLY_OPEN_PARMSW {
2443 DWORD_PTR dwCallback;
2444 MCIDEVICEID wDeviceID;
2445 LPCWSTR lpstrDeviceType;
2446 LPCWSTR lpstrElementName;
2447 LPCWSTR lpstrAlias;
2448 DWORD dwStyle;
2449 HWND hWndParent;
2450} MCI_OVLY_OPEN_PARMSW, *LPMCI_OVLY_OPEN_PARMSW;
2451
2452DECL_WINELIB_TYPE_AW(MCI_OVLY_OPEN_PARMS)
2453DECL_WINELIB_TYPE_AW(LPMCI_OVLY_OPEN_PARMS)
2454
2455typedef struct tagMCI_OVLY_WINDOW_PARMSA {
2456 DWORD_PTR dwCallback;
2457 HWND hWnd;
2458 UINT nCmdShow;
2459 LPCSTR lpstrText;
2460} MCI_OVLY_WINDOW_PARMSA, *LPMCI_OVLY_WINDOW_PARMSA;
2461
2462typedef struct tagMCI_OVLY_WINDOW_PARMSW {
2463 DWORD_PTR dwCallback;
2464 HWND hWnd;
2465 UINT nCmdShow;
2466 LPCWSTR lpstrText;
2467} MCI_OVLY_WINDOW_PARMSW, *LPMCI_OVLY_WINDOW_PARMSW;
2468
2469DECL_WINELIB_TYPE_AW(MCI_OVLY_WINDOW_PARMS)
2470DECL_WINELIB_TYPE_AW(LPMCI_OVLY_WINDOW_PARMS)
2471
2472typedef struct tagMCI_OVLY_RECT_PARMS {
2473 DWORD_PTR dwCallback;
2474#ifdef MCI_USE_OFFEXT
2475 POINT ptOffset;
2476 POINT ptExtent;
2477#else /* ifdef MCI_USE_OFFEXT */
2478 RECT rc;
2479#endif /* ifdef MCI_USE_OFFEXT */
2480} MCI_OVLY_RECT_PARMS, *LPMCI_OVLY_RECT_PARMS;
2481
2482
2483typedef struct tagMCI_OVLY_SAVE_PARMSA {
2484 DWORD_PTR dwCallback;
2485 LPCSTR lpfilename;
2486 RECT rc;
2487} MCI_OVLY_SAVE_PARMSA, *LPMCI_OVLY_SAVE_PARMSA;
2488
2489typedef struct tagMCI_OVLY_SAVE_PARMSW {
2490 DWORD_PTR dwCallback;
2491 LPCWSTR lpfilename;
2492 RECT rc;
2493} MCI_OVLY_SAVE_PARMSW, *LPMCI_OVLY_SAVE_PARMSW;
2494
2495DECL_WINELIB_TYPE_AW(MCI_OVLY_SAVE_PARMS)
2496DECL_WINELIB_TYPE_AW(LPMCI_OVLY_SAVE_PARMS)
2497
2498typedef struct tagMCI_OVLY_LOAD_PARMSA {
2499 DWORD_PTR dwCallback;
2500 LPCSTR lpfilename;
2501 RECT rc;
2502} MCI_OVLY_LOAD_PARMSA, *LPMCI_OVLY_LOAD_PARMSA;
2503
2504typedef struct tagMCI_OVLY_LOAD_PARMSW {
2505 DWORD_PTR dwCallback;
2506 LPCWSTR lpfilename;
2507 RECT rc;
2508} MCI_OVLY_LOAD_PARMSW, *LPMCI_OVLY_LOAD_PARMSW;
2509
2510DECL_WINELIB_TYPE_AW(MCI_OVLY_LOAD_PARMS)
2511DECL_WINELIB_TYPE_AW(LPMCI_OVLY_LOAD_PARMS)
2512
2513#ifndef NEWTRANSPARENT
2514#define NEWTRANSPARENT 3
2515#define QUERYROPSUPPORT 40
2516#endif
2517
2518#define SELECTDIB 41
2519#define DIBINDEX(n) MAKELONG((n),0x10FF)
2520
2521#ifndef SC_SCREENSAVE
2522#define SC_SCREENSAVE 0xf140
2523#endif
2524
2525#include <poppack.h>
2526
2527#ifdef __cplusplus
2528}
2529#endif
2530
2531#endif /* __WINE_MMSYSTEM_H */
Note: See TracBrowser for help on using the repository browser.

© 2025 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette