; Copyright (c) 1998-1999 Microsoft Corporation ; general constants MAXPNAMELEN EQU 32 ; max product name length (including NULL) MAXERRORLENGTH EQU 256 ; max error text length (including NULL) MAX_JOYSTICKOEMVXDNAME EQU 260 ; max oem vxd name length (including NULL) MMTIME STRUC mmt_wType DW ? mmt_TimeUnion DD ? MMTIME ENDS SMPTE STRUC smpte_hour DB ? smpte_min DB ? smpte_sec DB ? smpte_frame DB ? smpte_fps DB ? smpte_reserved DB ? SMPTE ENDS ; types for wType field in MMTIME struct TIME_MS EQU 0001H ; time in milliseconds TIME_SAMPLES EQU 0002H ; number of wave samples TIME_BYTES EQU 0004H ; current byte offset TIME_SMPTE EQU 0008H ; SMPTE time TIME_MIDI EQU 0010H ; MIDI time TIME_TICKS EQU 0020H ; Ticks within MIDI stream MM_JOY1MOVE EQU 3A0H ; joystick MM_JOY2MOVE EQU 3A1H MM_JOY1ZMOVE EQU 3A2H MM_JOY2ZMOVE EQU 3A3H MM_JOY1BUTTONDOWN EQU 3B5H MM_JOY2BUTTONDOWN EQU 3B6H MM_JOY1BUTTONUP EQU 3B7H MM_JOY2BUTTONUP EQU 3B8H MM_MCINOTIFY EQU 3B9H ; MCI ;internal; 0x3BA is open MM_WOM_OPEN EQU 3BBH ; waveform output MM_WOM_CLOSE EQU 3BCH MM_WOM_DONE EQU 3BDH MM_WIM_OPEN EQU 3BEH ; waveform input MM_WIM_CLOSE EQU 3BFH MM_WIM_DATA EQU 3C0H MM_MIM_OPEN EQU 3C1H ; MIDI input MM_MIM_CLOSE EQU 3C2H MM_MIM_DATA EQU 3C3H MM_MIM_LONGDATA EQU 3C4H MM_MIM_ERROR EQU 3C5H MM_MIM_LONGERROR EQU 3C6H MM_MOM_OPEN EQU 3C7H ; MIDI output MM_MOM_CLOSE EQU 3C8H MM_MOM_DONE EQU 3C9H MMSYSERR_BASE EQU 0 WAVERR_BASE EQU 32 MIDIERR_BASE EQU 64 TIMERR_BASE EQU 96 JOYERR_BASE EQU 160 MCIERR_BASE EQU 256 MIXERR_BASE EQU 1024 MCI_STRING_OFFSET EQU 512 MCI_VD_OFFSET EQU 1024 MCI_CD_OFFSET EQU 1088 MCI_WAVE_OFFSET EQU 1152 MCI_SEQ_OFFSET EQU 1216 ;*************************************************************************** ; General error return values ;************************************************************************* ; general error return values MMSYSERR_NOERROR EQU 0 ; no error MMSYSERR_ERROR EQU (MMSYSERR_BASE+1) ; unspecified error MMSYSERR_BADDEVICEID EQU (MMSYSERR_BASE+2) ; device ID out of range MMSYSERR_NOTENABLED EQU (MMSYSERR_BASE+3) ; driver failed enable MMSYSERR_ALLOCATED EQU (MMSYSERR_BASE+4) ; device already allocated MMSYSERR_INVALHANDLE EQU (MMSYSERR_BASE+5) ; device handle is invalid MMSYSERR_NODRIVER EQU (MMSYSERR_BASE+6) ; no device driver present MMSYSERR_NOMEM EQU (MMSYSERR_BASE+7) ; memory allocation error MMSYSERR_NOTSUPPORTED EQU (MMSYSERR_BASE+8) ; function isn't supported MMSYSERR_BADERRNUM EQU (MMSYSERR_BASE+9) ; error value out of range MMSYSERR_INVALFLAG EQU (MMSYSERR_BASE+10) ; invalid flag passed MMSYSERR_INVALPARAM EQU (MMSYSERR_BASE+11) ; invalid parameter passed MMSYSERR_HANDLEBUSY EQU (MMSYSERR_BASE+12) ; handle being used ; simultaneously on another ; thread (eg callback) MMSYSERR_INVALIDALIAS EQU (MMSYSERR_BASE+13) ; specified alias not found MMSYSERR_BADDB EQU (MMSYSERR_BASE+14) ; bad registry database MMSYSERR_KEYNOTFOUND EQU (MMSYSERR_BASE+15) ; registry key not found MMSYSERR_READERROR EQU (MMSYSERR_BASE+16) ; registry read error MMSYSERR_WRITEERROR EQU (MMSYSERR_BASE+17) ; registry write error MMSYSERR_DELETEERROR EQU (MMSYSERR_BASE+18) ; registry delete error MMSYSERR_VALNOTFOUND EQU (MMSYSERR_BASE+19) ; registry value not found MMSYSERR_NODRIVERCB EQU (MMSYSERR_BASE+20) ; driver does not call DriverCallback MMSYSERR_LASTERROR EQU (MMSYSERR_BASE+20) ; last error in range ifndef MMNODRV ;both ifndef DRV_RESERVED DRV_RESERVED EQU 0800H DRV_USER EQU 4000H endif DRV_MCI_FIRST EQU DRV_RESERVED DRV_MCI_LAST EQU (DRV_RESERVED+0FFFH) endif ;both; ifndef MMNODRV ;*************************************************************************** ; Driver callback support ;************************************************************************* ; flags used with waveOutOpen(), waveInOpen(), midiInOpen(), and ; midiOutOpen() to specify the type of the dwCallback parameter. CALLBACK_TYPEMASK EQU 00070000H ; callback type mask CALLBACK_NULL EQU 00000000H ; no callback CALLBACK_WINDOW EQU 00010000H ; dwCallback is a HWND CALLBACK_TASK EQU 00020000H ; dwCallback is a HTASK CALLBACK_FUNCTION EQU 00030000H ; dwCallback is a FARPROC CALLBACK_THUNK EQU 00040000H ;internal; dwCallback is a Ring0 Thread Handle ifdef _WIN32 CALLBACK_THREAD EQU (CALLBACK_TASK); thread ID replaces 16 bit task CALLBACK_EVENT EQU 00050000H ; dwCallback is an EVENT Handle endif CALLBACK_EVENT16 EQU 00060000H ;internal; dwCallback is an EVENT under Win16 SND_SYNC EQU 0000H ; play synchronously (default) SND_ASYNC EQU 0001H ; play asynchronously SND_NODEFAULT EQU 0002H ; silence (!default) if sound not found SND_MEMORY EQU 0004H ; pszSound points to a memory file SND_LOOP EQU 0008H ; loop the sound until next sndPlaySound SND_NOSTOP EQU 0010H ; don't stop any currently playing sound ifndef MMNOWAVE ;both ;*************************************************************************** ; Waveform audio support ;************************************************************************* ; waveform audio error return values WAVERR_BADFORMAT EQU (WAVERR_BASE+0) ; unsupported wave format WAVERR_STILLPLAYING EQU (WAVERR_BASE+1) ; still something playing WAVERR_UNPREPARED EQU (WAVERR_BASE+2) ; header not prepared WAVERR_SYNC EQU (WAVERR_BASE+3) ; device is synchronous WAVERR_LASTERROR EQU (WAVERR_BASE+3) ; last error in range ; wave callback messages WOM_OPEN EQU MM_WOM_OPEN WOM_CLOSE EQU MM_WOM_CLOSE WOM_DONE EQU MM_WOM_DONE WIM_OPEN EQU MM_WIM_OPEN WIM_CLOSE EQU MM_WIM_CLOSE WIM_DATA EQU MM_WIM_DATA ; device ID for wave device mapper WAVE_MAPPER EQU (-1) ; flags for dwFlags parameter in waveOutOpen() and waveInOpen() WAVE_FORMAT_QUERY EQU 0001H WAVE_ALLOWSYNC EQU 0002H WAVE_VALID EQU 800FH ;internal WAVEHDR STRUC lpWaveData DD ? dwWaveBufferLength DD ? dwWaveBytesRecorded DD ? dwWaveUser DD ? dwWaveFlags DD ? dwWaveLoops DD ? lpWaveNext DD ? Wavereserved DD ? WAVEHDR ENDS ; flags for dwFlags field of WAVEHDR WHDR_DONE EQU 00000001H ; done bit WHDR_PREPARED EQU 00000002H ; set if this header has been prepared WHDR_BEGINLOOP EQU 00000004H ; loop start block WHDR_ENDLOOP EQU 00000008H ; loop end block WHDR_INQUEUE EQU 00000010H ; reserved for driver WHDR_MAPPED EQU 00001000H ;internal; thunked header WHDR_VALID EQU 0000101FH ;internal; valid flags WAVEOUTCAPS STRUC woc_wMid DW ? woc_wPid DW ? woc_vDriverVersion DW ? woc_szPname DB MAXPNAMELEN DUP (?) woc_dwFormats DD ? woc_wChannels DW ? woc_dwSupport DD ? WAVEOUTCAPS ENDS ; flags for dwSupport field of WAVEOUTCAPS WAVECAPS_PITCH EQU 0001H ; supports pitch control WAVECAPS_PLAYBACKRATE EQU 0002H ; supports playback rate control WAVECAPS_VOLUME EQU 0004H ; supports volume control WAVECAPS_LRVOLUME EQU 0008H ; separate left-right volume control WAVECAPS_SYNC EQU 0010H WAVECAPS_SAMPLEACCURATE EQU 0020H WAVECAPS_DIRECTSOUND EQU 0040H WAVEINCAPS STRUC wic_wMid DW ? wic_wPid DW ? wic_vDriverVersion DW ? wic_szPname DB MAXPNAMELEN DUP (?) wic_dwFormats DD ? wic_wChannels DW ? WAVEINCAPS ENDS ; defines for dwFormat field of WAVEINCAPS and WAVEOUTCAPS WAVE_INVALIDFORMAT EQU 00000000H ; invalid format WAVE_FORMAT_1M08 EQU 00000001H ; 11.025 kHz, Mono, 8-bit WAVE_FORMAT_1S08 EQU 00000002H ; 11.025 kHz, Stereo, 8-bit WAVE_FORMAT_1M16 EQU 00000004H ; 11.025 kHz, Mono, 16-bit WAVE_FORMAT_1S16 EQU 00000008H ; 11.025 kHz, Stereo, 16-bit WAVE_FORMAT_2M08 EQU 00000010H ; 22.05 kHz, Mono, 8-bit WAVE_FORMAT_2S08 EQU 00000020H ; 22.05 kHz, Stereo, 8-bit WAVE_FORMAT_2M16 EQU 00000040H ; 22.05 kHz, Mono, 16-bit WAVE_FORMAT_2S16 EQU 00000080H ; 22.05 kHz, Stereo, 16-bit WAVE_FORMAT_4M08 EQU 00000100H ; 44.1 kHz, Mono, 8-bit WAVE_FORMAT_4S08 EQU 00000200H ; 44.1 kHz, Stereo, 8-bit WAVE_FORMAT_4M16 EQU 00000400H ; 44.1 kHz, Mono, 16-bit WAVE_FORMAT_4S16 EQU 00000800H ; 44.1 kHz, Stereo, 16-bit WAVEFORMAT STRUC wfmt_wFormatTag DW ? wfmt_nChannels DW ? wfmt_nSamplesPerSec DD ? wfmt_nAvgBytesPerSec DD ? wfmt_nBlockAlign DW ? WAVEFORMAT ENDS ; flags for wFormatTag field of WAVEFORMAT WAVE_FORMAT_PCM EQU 1 PCMWAVEFORMAT STRUC pcm_wf DB SIZE WAVEFORMAT DUP (?) pcm_wBitsPerSample DW ? PCMWAVEFORMAT ENDS endif ;both; ifndef MMNOWAVE ifndef MMNOMIDI ;both ;*************************************************************************** ; MIDI audio support ;************************************************************************* ; MIDI error return values MIDIERR_UNPREPARED EQU (MIDIERR_BASE+0) ; header not prepared MIDIERR_STILLPLAYING EQU (MIDIERR_BASE+1) ; still something playing MIDIERR_NOMAP EQU (MIDIERR_BASE+2) ; no configured instruments MIDIERR_NOTREADY EQU (MIDIERR_BASE+3) ; hardware is still busy MIDIERR_NODEVICE EQU (MIDIERR_BASE+4) ; port no longer connected MIDIERR_INVALIDSETUP EQU (MIDIERR_BASE+5) ; invalid MIF MIDIERR_BADOPENMODE EQU (MIDIERR_BASE+6) ; operation unsupported w/ open mode MIDIERR_DONT_CONTINUE EQU (MIDIERR_BASE+7) ; thru device 'eating' a message MIDIERR_LASTERROR EQU (MIDIERR_BASE+7) ; last error in range MIDIPATCHSIZE EQU 128 ; MIDI callback messages MIM_OPEN EQU MM_MIM_OPEN MIM_CLOSE EQU MM_MIM_CLOSE MIM_DATA EQU MM_MIM_DATA MIM_LONGDATA EQU MM_MIM_LONGDATA MIM_ERROR EQU MM_MIM_ERROR MIM_LONGERROR EQU MM_MIM_LONGERROR MOM_OPEN EQU MM_MOM_OPEN MOM_CLOSE EQU MM_MOM_CLOSE MOM_DONE EQU MM_MOM_DONE ; device ID for MIDI mapper MIDIMAPPER EQU (-1) MIDI_MAPPER EQU (-1) ; flags for wFlags parm of midiOutCachePatches(), midiOutCacheDrumPatches() MIDI_CACHE_ALL EQU 1 MIDI_CACHE_BESTFIT EQU 2 MIDI_CACHE_QUERY EQU 3 MIDI_UNCACHE EQU 4 MIDI_CACHE_VALID EQU (MIDI_CACHE_ALL OR MIDI_CACHE_BESTFIT OR MIDI_CACHE_QUERY OR MIDI_UNCACHE) ;internal MIDIOUTCAPS STRUC moc_wMid DW ? moc_wPid DW ? moc_vDriverVersion DW ? moc_szPname DB MAXPNAMELEN DUP (?) moc_wTechnology DW ? moc_wVoices DW ? moc_wNotes DW ? moc_wChannelMask DW ? moc_dwSupport DD ? MIDIOUTCAPS ENDS ; flags for wTechnology field of MIDIOUTCAPS structure MOD_MIDIPORT EQU 1 ; output port MOD_SYNTH EQU 2 ; generic internal synth MOD_SQSYNTH EQU 3 ; square wave internal synth MOD_FMSYNTH EQU 4 ; FM internal synth MOD_MAPPER EQU 5 ; MIDI mapper ; flags for dwSupport field of MIDIOUTCAPS structure MIDICAPS_VOLUME EQU 0001H ; supports volume control MIDICAPS_LRVOLUME EQU 0002H ; separate left-right volume control MIDICAPS_CACHE EQU 0004H MIDIINCAPS STRUC mic_wMid DW ? mic_wPid DW ? mic_vDriverVersion DW ? mic_szPname DB MAXPNAMELEN DUP (?) MIDIINCAPS ENDS MIDIHDR STRUC lpMidiData DD ? dwMidiBufferLength DD ? dwMidiBytesRecorded DD ? dwMidiUser DD ? dwMidiFlags DD ? lpMidiNext DD ? Midireserved DD ? MididwOffset DD ? MididwReserved DD 4 DUP (?) MIDIHDR ENDS MIDIHDR31 STRUC w31lpMidiData DD ? w31dwMidiBufferLength DD ? w31dwMidiBytesRecorded DD ? w31dwMidiUser DD ? w31dwMidiFlags DD ? w31lpMidiNext DD ? w31Midireserved DD ? MIDIHDR31 ENDS ; flags for dwFlags field of MIDIHDR structure MHDR_DONE EQU 00000001H ; done bit MHDR_PREPARED EQU 00000002H ; set if header prepared MHDR_INQUEUE EQU 00000004H ; reserved for driver MHDR_ISSTRM EQU 00000008H ; Buffer is stream buffer MHDR_SENDING EQU 00000020H ;internal MHDR_MAPPED EQU 00001000H ;internal; thunked header MHDR_SHADOWHDR EQU 00002000H ;internal; MIDIHDR is 16-bit shadow MHDR_VALID EQU 0000302FH ;internal; valid flags ;internal */;#define MHDR_VALID 0xFFFF000F /* valid flags MHDR_SAVE EQU 00003000H ;internal; Save these flags ;internal; past driver calls endif ;both; ifndef MMNOMIDI ifndef MMNOAUX ;both ;*************************************************************************** ; Auxiliary audio support ;************************************************************************* ; device ID for aux device mapper AUX_MAPPER EQU (-1) AUXCAPS STRUC acaps_wMid DW ? acaps_wPid DW ? acaps_vDriverVersion DW ? acaps_szPname DB MAXPNAMELEN DUP (?) acaps_wTechnology DW ? acaps_dwSupport DD ? AUXCAPS ENDS ; flags for wTechnology field in AUXCAPS structure AUXCAPS_CDAUDIO EQU 1 ; audio from internal CD-ROM drive AUXCAPS_AUXIN EQU 2 ; audio from auxiliary input jacks ; flags for dwSupport field in AUXCAPS structure AUXCAPS_VOLUME EQU 0001H ; supports volume control AUXCAPS_LRVOLUME EQU 0002H ; separate left-right volume control endif ;both; ifndef MMNOAUX ifndef MMNOTIMER ;both ifndef _WIN32_VXD ;*************************************************************************** ; Timer support ;************************************************************************* ; timer error return values TIMERR_NOERROR EQU (0) ; no error TIMERR_NOCANDO EQU (TIMERR_BASE+1) ; request not completed TIMERR_STRUCT EQU (TIMERR_BASE+33) ; time struct size ; flags for fuEvent parameter of timeSetEvent() function TIME_ONESHOT EQU 0000H ; program timer for single event TIME_PERIODIC EQU 0001H ; program for continuous periodic event ifdef _WIN32 TIME_CALLBACK_FUNCTION EQU 0000H ; callback is function TIME_CALLBACK_EVENT_SET EQU 0010H ; callback is event - use SetEvent TIME_CALLBACK_EVENT_PULSE EQU 0020H ; callback is event - use PulseEvent TIME_CALLBACK_TYPEMASK EQU 00F0H ;internal endif TIMECAPS STRUC tc_wPeriodMin DW ? tc_wPeriodMax DW ? TIMECAPS ENDS endif ; ifndef _WIN32_VXD endif ;both; ifndef MMNOTIMER ifndef MMNOJOY ;both ;*************************************************************************** ; Joystick support ;************************************************************************* ; joystick error return values JOYERR_NOERROR EQU (0) ; no error JOYERR_PARMS EQU (JOYERR_BASE+5) ; bad parameters JOYERR_NOCANDO EQU (JOYERR_BASE+6) ; request not completed JOYERR_UNPLUGGED EQU (JOYERR_BASE+7) ; joystick is unplugged ; constants used with JOYINFO and JOYINFOEX structures and MM_JOY* messages JOY_BUTTON1 EQU 0001H JOY_BUTTON2 EQU 0002H JOY_BUTTON3 EQU 0004H JOY_BUTTON4 EQU 0008H JOY_BUTTON1CHG EQU 0100H JOY_BUTTON2CHG EQU 0200H JOY_BUTTON3CHG EQU 0400H JOY_BUTTON4CHG EQU 0800H ; constants used with JOYINFOEX JOY_BUTTON5 EQU 00000010H JOY_BUTTON6 EQU 00000020H JOY_BUTTON7 EQU 00000040H JOY_BUTTON8 EQU 00000080H JOY_BUTTON9 EQU 00000100H JOY_BUTTON10 EQU 00000200H JOY_BUTTON11 EQU 00000400H JOY_BUTTON12 EQU 00000800H JOY_BUTTON13 EQU 00001000H JOY_BUTTON14 EQU 00002000H JOY_BUTTON15 EQU 00004000H JOY_BUTTON16 EQU 00008000H JOY_BUTTON17 EQU 00010000H JOY_BUTTON18 EQU 00020000H JOY_BUTTON19 EQU 00040000H JOY_BUTTON20 EQU 00080000H JOY_BUTTON21 EQU 00100000H JOY_BUTTON22 EQU 00200000H JOY_BUTTON23 EQU 00400000H JOY_BUTTON24 EQU 00800000H JOY_BUTTON25 EQU 01000000H JOY_BUTTON26 EQU 02000000H JOY_BUTTON27 EQU 04000000H JOY_BUTTON28 EQU 08000000H JOY_BUTTON29 EQU 10000000H JOY_BUTTON30 EQU 20000000H JOY_BUTTON31 EQU 40000000H JOY_BUTTON32 EQU 80000000H ; constants used with JOYINFOEX structure JOY_POVCENTERED EQU -1 JOY_POVFORWARD EQU 0 JOY_POVRIGHT EQU 9000 JOY_POVBACKWARD EQU 18000 JOY_POVLEFT EQU 27000 JOY_RETURNX EQU 00000001H JOY_RETURNY EQU 00000002H JOY_RETURNZ EQU 00000004H JOY_RETURNR EQU 00000008H JOY_RETURNU EQU 00000010H ; axis 5 JOY_RETURNV EQU 00000020H ; axis 6 JOY_RETURNPOV EQU 00000040H JOY_RETURNBUTTONS EQU 00000080H JOY_RETURNRAWDATA EQU 00000100H JOY_RETURNPOVCTS EQU 00000200H JOY_RETURNCENTERED EQU 00000400H JOY_USEDEADZONE EQU 00000800H JOY_RETURNALL EQU (JOY_RETURNX OR JOY_RETURNY OR JOY_RETURNZ OR JOY_RETURNR OR JOY_RETURNU OR JOY_RETURNV OR JOY_RETURNPOV OR JOY_RETURNBUTTONS) JOY_CAL_READALWAYS EQU 00010000H JOY_CAL_READXYONLY EQU 00020000H JOY_CAL_READ3 EQU 00040000H JOY_CAL_READ4 EQU 00080000H JOY_CAL_READXONLY EQU 00100000H JOY_CAL_READYONLY EQU 00200000H JOY_CAL_READ5 EQU 00400000H JOY_CAL_READ6 EQU 00800000H JOY_CAL_READZONLY EQU 01000000H JOY_CAL_READRONLY EQU 02000000H JOY_CAL_READUONLY EQU 04000000H JOY_CAL_READVONLY EQU 08000000H ; joystick ID constants JOYSTICKID1 EQU 0 JOYSTICKID2 EQU 1 ; joystick driver capabilites JOYCAPS_HASZ EQU 0001H JOYCAPS_HASR EQU 0002H JOYCAPS_HASU EQU 0004H JOYCAPS_HASV EQU 0008H JOYCAPS_HASPOV EQU 0010H JOYCAPS_POV4DIR EQU 0020H JOYCAPS_POVCTS EQU 0040H JOYCAPS STRUC jcaps_wMid DW ? jcaps_wPid DW ? jcaps_szPname DB MAXPNAMELEN DUP (?) jcaps_wXmin DW ? jcaps_wXmax DW ? jcaps_wYmin DW ? jcaps_wYmax DW ? jcaps_wZmin DW ? jcaps_wZmax DW ? jcaps_wNumButtons DW ? jcaps_wPeriodMin DW ? jcaps_wPeriodMax DW ? jcaps_wRmin DW ? jcaps_wRmax DW ? jcaps_wUmin DW ? jcaps_wUmax DW ? jcaps_wVmin DW ? jcaps_wVmax DW ? jcaps_wCaps DW ? jcaps_wMaxAxes DW ? jcaps_wNumAxes DW ? jcaps_wMaxButtons DW ? jcaps_szRegKey DB MAXPNAMELEN DUP (?) jcaps_szOEMVxD DB MAX_JOYSTICKOEMVXDNAME DUP (?) JOYCAPS ENDS JOYINFO STRUC jinfo_wXpos DW ? jinfo_wYpos DW ? jinfo_wZpos DW ? jinfo_wButtons DW ? JOYINFO ENDS JOYINFOEX STRUC jinfoex_dwSize DD ? jinfoex_dwFlags DD ? jinfoex_dwXpos DD ? jinfoex_dwYpos DD ? jinfoex_dwZpos DD ? jinfoex_dwRpos DD ? jinfoex_dwUpos DD ? jinfoex_dwVpos DD ? jinfoex_dwButtons DD ? jinfoex_dwButtonNumber DD ? jinfoex_dwPOV DD ? jinfoex_dwReserved1 DD ? jinfoex_dwReserved2 DD ? JOYINFOEX ENDS endif ;both; ifndef MMNOJOY ifndef MMNOMMIO ;both ifndef _WIN32_VXD ;*************************************************************************** ; Multimedia File I/O support ;************************************************************************* ; MMIO error return values MMIOERR_BASE EQU 256 MMIOERR_FILENOTFOUND EQU (MMIOERR_BASE+1) ; file not found MMIOERR_OUTOFMEMORY EQU (MMIOERR_BASE+2) ; out of memory MMIOERR_CANNOTOPEN EQU (MMIOERR_BASE+3) ; cannot open MMIOERR_CANNOTCLOSE EQU (MMIOERR_BASE+4) ; cannot close MMIOERR_CANNOTREAD EQU (MMIOERR_BASE+5) ; cannot read MMIOERR_CANNOTWRITE EQU (MMIOERR_BASE+6) ; cannot write MMIOERR_CANNOTSEEK EQU (MMIOERR_BASE+7) ; cannot seek MMIOERR_CANNOTEXPAND EQU (MMIOERR_BASE+8) ; cannot expand file MMIOERR_CHUNKNOTFOUND EQU (MMIOERR_BASE+9) ; chunk not found MMIOERR_UNBUFFERED EQU (MMIOERR_BASE+10) ; MMIOERR_PATHNOTFOUND EQU (MMIOERR_BASE+11) ; path incorrect MMIOERR_ACCESSDENIED EQU (MMIOERR_BASE+12) ; file was protected MMIOERR_SHARINGVIOLATION EQU (MMIOERR_BASE+13) ; file in use MMIOERR_NETWORKERROR EQU (MMIOERR_BASE+14) ; network not responding MMIOERR_TOOMANYOPENFILES EQU (MMIOERR_BASE+15) ; no more file handles MMIOERR_INVALIDFILE EQU (MMIOERR_BASE+16) ; default error file error ; MMIO constants CFSEPCHAR EQU <'+'> ; compound file name separator char. MMIOINFO STRUC mmio_dwFlags DD ? mmio_fccIOProc DD ? mmio_pIOProc DD ? mmio_wErrorRet DW ? mmio_htask DW ? mmio_cchBuffer DD ? mmio_pchBuffer DD ? mmio_pchNext DD ? mmio_pchEndRead DD ? mmio_pchEndWrite DD ? mmio_lBufOffset DD ? mmio_lDiskOffset DD ? mmio_adwInfo DD 3 DUP (?) mmio_dwReserved1 DD ? mmio_dwReserved2 DD ? mmio_hmmio DW ? MMIOINFO ENDS ; bit field masks MMIO_RWMODE EQU 00000003H ; open file for reading/writing/both MMIO_SHAREMODE EQU 00000070H ; file sharing mode number ; constants for dwFlags field of MMIOINFO MMIO_CREATE EQU 00001000H ; create new file (or truncate file) MMIO_PARSE EQU 00000100H ; parse new file returning path MMIO_DELETE EQU 00000200H ; create new file (or truncate file) MMIO_EXIST EQU 00004000H ; checks for existence of file MMIO_ALLOCBUF EQU 00010000H ; mmioOpen() should allocate a buffer MMIO_GETTEMP EQU 00020000H ; mmioOpen() should retrieve temp name MMIO_DIRTY EQU 10000000H ; I/O buffer is dirty ; read/write mode numbers (bit field MMIO_RWMODE) MMIO_READ EQU 00000000H ; open file for reading only MMIO_WRITE EQU 00000001H ; open file for writing only MMIO_READWRITE EQU 00000002H ; open file for reading and writing ; share mode numbers (bit field MMIO_SHAREMODE) MMIO_COMPAT EQU 00000000H ; compatibility mode MMIO_EXCLUSIVE EQU 00000010H ; exclusive-access mode MMIO_DENYWRITE EQU 00000020H ; deny writing to other processes MMIO_DENYREAD EQU 00000030H ; deny reading to other processes MMIO_DENYNONE EQU 00000040H ; deny nothing to other processes ; various MMIO flags MMIO_FHOPEN EQU 0010H ; mmioClose: keep file handle open MMIO_EMPTYBUF EQU 0010H ; mmioFlush: empty the I/O buffer MMIO_TOUPPER EQU 0010H ; mmioStringToFOURCC: to u-case MMIO_INSTALLPROC EQU 00010000H ; mmioInstallIOProc: install MMIOProc MMIO_GLOBALPROC EQU 10000000H ; mmioInstallIOProc: install globally MMIO_REMOVEPROC EQU 00020000H ; mmioInstallIOProc: remove MMIOProc MMIO_UNICODEPROC EQU 01000000H ; mmioInstallIOProc: Unicode MMIOProc MMIO_FINDPROC EQU 00040000H ; mmioInstallIOProc: find an MMIOProc MMIO_FINDCHUNK EQU 0010H ; mmioDescend: find a chunk by ID MMIO_FINDRIFF EQU 0020H ; mmioDescend: find a LIST chunk MMIO_FINDLIST EQU 0040H ; mmioDescend: find a RIFF chunk MMIO_CREATERIFF EQU 0020H ; mmioCreateChunk: make a LIST chunk MMIO_CREATELIST EQU 0040H ; mmioCreateChunk: make a RIFF chunk ; message numbers for MMIOPROC I/O procedure functions MMIOM_READ EQU MMIO_READ ; read MMIOM_WRITE EQU MMIO_WRITE ; write MMIOM_SEEK EQU 2 ; seek to a new position in file MMIOM_OPEN EQU 3 ; open file MMIOM_CLOSE EQU 4 ; close file MMIOM_WRITEFLUSH EQU 5 ; write and flush MMIOM_RENAME EQU 6 ; rename specified file MMIOM_USER EQU 8000H ; beginning of user-defined messages ; flags for mmioSeek() ifndef SEEK_SET SEEK_SET EQU 0 ; seek to an absolute position SEEK_CUR EQU 1 ; seek relative to current position SEEK_END EQU 2 ; seek relative to end of file endif ; ifndef SEEK_SET ; other constants MMIO_DEFAULTBUFFER EQU 8192 ; default buffer size endif ; ifndef _WIN32_VXD endif ;both; ifndef MMNOMMIO ifndef MMNOMCI ;both ifndef _WIN32_VXD ; MCI error return values MCIERR_INVALID_DEVICE_ID EQU (MCIERR_BASE+1) MCIERR_UNRECOGNIZED_KEYWORD EQU (MCIERR_BASE+3) MCIERR_UNRECOGNIZED_COMMAND EQU (MCIERR_BASE+5) MCIERR_HARDWARE EQU (MCIERR_BASE+6) MCIERR_INVALID_DEVICE_NAME EQU (MCIERR_BASE+7) MCIERR_OUT_OF_MEMORY EQU (MCIERR_BASE+8) MCIERR_DEVICE_OPEN EQU (MCIERR_BASE+9) MCIERR_CANNOT_LOAD_DRIVER EQU (MCIERR_BASE+10) MCIERR_MISSING_COMMAND_STRING EQU (MCIERR_BASE+11) MCIERR_PARAM_OVERFLOW EQU (MCIERR_BASE+12) MCIERR_MISSING_STRING_ARGUMENT EQU (MCIERR_BASE+13) MCIERR_BAD_INTEGER EQU (MCIERR_BASE+14) MCIERR_PARSER_INTERNAL EQU (MCIERR_BASE+15) MCIERR_DRIVER_INTERNAL EQU (MCIERR_BASE+16) MCIERR_MISSING_PARAMETER EQU (MCIERR_BASE+17) MCIERR_UNSUPPORTED_FUNCTION EQU (MCIERR_BASE+18) MCIERR_FILE_NOT_FOUND EQU (MCIERR_BASE+19) MCIERR_DEVICE_NOT_READY EQU (MCIERR_BASE+20) MCIERR_INTERNAL EQU (MCIERR_BASE+21) MCIERR_DRIVER EQU (MCIERR_BASE+22) MCIERR_CANNOT_USE_ALL EQU (MCIERR_BASE+23) MCIERR_MULTIPLE EQU (MCIERR_BASE+24) MCIERR_EXTENSION_NOT_FOUND EQU (MCIERR_BASE+25) MCIERR_OUTOFRANGE EQU (MCIERR_BASE+26) MCIERR_FLAGS_NOT_COMPATIBLE EQU (MCIERR_BASE+28) MCIERR_FILE_NOT_SAVED EQU (MCIERR_BASE+30) MCIERR_DEVICE_TYPE_REQUIRED EQU (MCIERR_BASE+31) MCIERR_DEVICE_LOCKED EQU (MCIERR_BASE+32) MCIERR_DUPLICATE_ALIAS EQU (MCIERR_BASE+33) MCIERR_BAD_CONSTANT EQU (MCIERR_BASE+34) MCIERR_MUST_USE_SHAREABLE EQU (MCIERR_BASE+35) MCIERR_MISSING_DEVICE_NAME EQU (MCIERR_BASE+36) MCIERR_BAD_TIME_FORMAT EQU (MCIERR_BASE+37) MCIERR_NO_CLOSING_QUOTE EQU (MCIERR_BASE+38) MCIERR_DUPLICATE_FLAGS EQU (MCIERR_BASE+39) MCIERR_INVALID_FILE EQU (MCIERR_BASE+40) MCIERR_NULL_PARAMETER_BLOCK EQU (MCIERR_BASE+41) MCIERR_UNNAMED_RESOURCE EQU (MCIERR_BASE+42) MCIERR_NEW_REQUIRES_ALIAS EQU (MCIERR_BASE+43) MCIERR_NOTIFY_ON_AUTO_OPEN EQU (MCIERR_BASE+44) MCIERR_NO_ELEMENT_ALLOWED EQU (MCIERR_BASE+45) MCIERR_NONAPPLICABLE_FUNCTION EQU (MCIERR_BASE+46) MCIERR_ILLEGAL_FOR_AUTO_OPEN EQU (MCIERR_BASE+47) MCIERR_FILENAME_REQUIRED EQU (MCIERR_BASE+48) MCIERR_EXTRA_CHARACTERS EQU (MCIERR_BASE+49) MCIERR_DEVICE_NOT_INSTALLED EQU (MCIERR_BASE+50) MCIERR_GET_CD EQU (MCIERR_BASE+51) MCIERR_SET_CD EQU (MCIERR_BASE+52) MCIERR_SET_DRIVE EQU (MCIERR_BASE+53) MCIERR_DEVICE_LENGTH EQU (MCIERR_BASE+54) MCIERR_DEVICE_ORD_LENGTH EQU (MCIERR_BASE+55) MCIERR_NO_INTEGER EQU (MCIERR_BASE+56) MCIERR_WAVE_OUTPUTSINUSE EQU (MCIERR_BASE+64) MCIERR_WAVE_SETOUTPUTINUSE EQU (MCIERR_BASE+65) MCIERR_WAVE_INPUTSINUSE EQU (MCIERR_BASE+66) MCIERR_WAVE_SETINPUTINUSE EQU (MCIERR_BASE+67) MCIERR_WAVE_OUTPUTUNSPECIFIED EQU (MCIERR_BASE+68) MCIERR_WAVE_INPUTUNSPECIFIED EQU (MCIERR_BASE+69) MCIERR_WAVE_OUTPUTSUNSUITABLE EQU (MCIERR_BASE+70) MCIERR_WAVE_SETOUTPUTUNSUITABLE EQU (MCIERR_BASE+71) MCIERR_WAVE_INPUTSUNSUITABLE EQU (MCIERR_BASE+72) MCIERR_WAVE_SETINPUTUNSUITABLE EQU (MCIERR_BASE+73) MCIERR_SEQ_DIV_INCOMPATIBLE EQU (MCIERR_BASE+80) MCIERR_SEQ_PORT_INUSE EQU (MCIERR_BASE+81) MCIERR_SEQ_PORT_NONEXISTENT EQU (MCIERR_BASE+82) MCIERR_SEQ_PORT_MAPNODEVICE EQU (MCIERR_BASE+83) MCIERR_SEQ_PORT_MISCERROR EQU (MCIERR_BASE+84) MCIERR_SEQ_TIMER EQU (MCIERR_BASE+85) MCIERR_SEQ_PORTUNSPECIFIED EQU (MCIERR_BASE+86) MCIERR_SEQ_NOMIDIPRESENT EQU (MCIERR_BASE+87) MCIERR_NO_WINDOW EQU (MCIERR_BASE+90) MCIERR_CREATEWINDOW EQU (MCIERR_BASE+91) MCIERR_FILE_READ EQU (MCIERR_BASE+92) MCIERR_FILE_WRITE EQU (MCIERR_BASE+93) MCIERR_NO_IDENTITY EQU (MCIERR_BASE+94) ; all custom device driver errors must be >= than this value MCIERR_CUSTOM_DRIVER_BASE EQU (MCIERR_BASE+256) MCI_FIRST EQU DRV_MCI_FIRST ; 0x0800 ; MCI command message identifiers MCI_OPEN EQU 0803H MCI_CLOSE EQU 0804H MCI_ESCAPE EQU 0805H MCI_PLAY EQU 0806H MCI_SEEK EQU 0807H MCI_STOP EQU 0808H MCI_PAUSE EQU 0809H MCI_INFO EQU 080AH MCI_GETDEVCAPS EQU 080BH MCI_SPIN EQU 080CH MCI_SET EQU 080DH MCI_STEP EQU 080EH MCI_RECORD EQU 080FH MCI_SYSINFO EQU 0810H MCI_BREAK EQU 0811H MCI_SOUND EQU 0812H ;internal MCI_SAVE EQU 0813H MCI_STATUS EQU 0814H MCI_CUE EQU 0830H MCI_REALIZE EQU 0840H MCI_WINDOW EQU 0841H MCI_PUT EQU 0842H MCI_WHERE EQU 0843H MCI_FREEZE EQU 0844H MCI_UNFREEZE EQU 0845H MCI_LOAD EQU 0850H MCI_CUT EQU 0851H MCI_COPY EQU 0852H MCI_PASTE EQU 0853H MCI_UPDATE EQU 0854H MCI_RESUME EQU 0855H MCI_DELETE EQU 0856H MCI_WIN32CLIENT EQU 0857H ;internal ; all custom MCI command messages must be >= than this value MCI_USER_MESSAGES EQU (DRV_MCI_FIRST+400H) MCI_LAST EQU 0FFFH MCI_ALL_DEVICE_ID EQU -1 ; constants for predefined MCI device types MCI_DEVTYPE_VCR EQU 513 ; (MCI_STRING_OFFSET + 1) MCI_DEVTYPE_VIDEODISC EQU 514 ; (MCI_STRING_OFFSET + 2) MCI_DEVTYPE_OVERLAY EQU 515 ; (MCI_STRING_OFFSET + 3) MCI_DEVTYPE_CD_AUDIO EQU 516 ; (MCI_STRING_OFFSET + 4) MCI_DEVTYPE_DAT EQU 517 ; (MCI_STRING_OFFSET + 5) MCI_DEVTYPE_SCANNER EQU 518 ; (MCI_STRING_OFFSET + 6) MCI_DEVTYPE_ANIMATION EQU 519 ; (MCI_STRING_OFFSET + 7) MCI_DEVTYPE_DIGITAL_VIDEO EQU 520 ; (MCI_STRING_OFFSET + 8) MCI_DEVTYPE_OTHER EQU 521 ; (MCI_STRING_OFFSET + 9) MCI_DEVTYPE_WAVEFORM_AUDIO EQU 522 ; (MCI_STRING_OFFSET + 10) MCI_DEVTYPE_SEQUENCER EQU 523 ; (MCI_STRING_OFFSET + 11) MCI_DEVTYPE_FIRST EQU MCI_DEVTYPE_VCR MCI_DEVTYPE_LAST EQU MCI_DEVTYPE_SEQUENCER MCI_DEVTYPE_FIRST_USER EQU 1000H ; return values for 'status mode' command MCI_MODE_NOT_READY EQU (MCI_STRING_OFFSET+12) MCI_MODE_STOP EQU (MCI_STRING_OFFSET+13) MCI_MODE_PLAY EQU (MCI_STRING_OFFSET+14) MCI_MODE_RECORD EQU (MCI_STRING_OFFSET+15) MCI_MODE_SEEK EQU (MCI_STRING_OFFSET+16) MCI_MODE_PAUSE EQU (MCI_STRING_OFFSET+17) MCI_MODE_OPEN EQU (MCI_STRING_OFFSET+18) ; constants used in 'set time format' and 'status time format' commands MCI_FORMAT_MILLISECONDS EQU 0 MCI_FORMAT_HMS EQU 1 MCI_FORMAT_MSF EQU 2 MCI_FORMAT_FRAMES EQU 3 MCI_FORMAT_SMPTE_24 EQU 4 MCI_FORMAT_SMPTE_25 EQU 5 MCI_FORMAT_SMPTE_30 EQU 6 MCI_FORMAT_SMPTE_30DROP EQU 7 MCI_FORMAT_BYTES EQU 8 MCI_FORMAT_SAMPLES EQU 9 MCI_FORMAT_TMSF EQU 10 ; flags for wParam of MM_MCINOTIFY message MCI_NOTIFY_SUCCESSFUL EQU 0001H MCI_NOTIFY_SUPERSEDED EQU 0002H MCI_NOTIFY_ABORTED EQU 0004H MCI_NOTIFY_FAILURE EQU 0008H ; common flags for dwFlags parameter of MCI command messages MCI_NOTIFY EQU 00000001H MCI_WAIT EQU 00000002H MCI_FROM EQU 00000004H MCI_TO EQU 00000008H MCI_TRACK EQU 00000010H ; flags for dwFlags parameter of MCI_OPEN command message MCI_OPEN_SHAREABLE EQU 00000100H MCI_OPEN_ELEMENT EQU 00000200H MCI_OPEN_ALIAS EQU 00000400H MCI_OPEN_ELEMENT_ID EQU 00000800H MCI_OPEN_TYPE_ID EQU 00001000H MCI_OPEN_TYPE EQU 00002000H ; flags for dwFlags parameter of MCI_SEEK command message MCI_SEEK_TO_START EQU 00000100H MCI_SEEK_TO_END EQU 00000200H ; flags for dwFlags parameter of MCI_STATUS command message MCI_STATUS_ITEM EQU 00000100H MCI_STATUS_START EQU 00000200H ; flags for dwItem field of the MCI_STATUS_PARMS parameter block MCI_STATUS_LENGTH EQU 00000001H MCI_STATUS_POSITION EQU 00000002H MCI_STATUS_NUMBER_OF_TRACKS EQU 00000003H MCI_STATUS_MODE EQU 00000004H MCI_STATUS_MEDIA_PRESENT EQU 00000005H MCI_STATUS_TIME_FORMAT EQU 00000006H MCI_STATUS_READY EQU 00000007H MCI_STATUS_CURRENT_TRACK EQU 00000008H ; flags for dwFlags parameter of MCI_INFO command message MCI_INFO_PRODUCT EQU 00000100H MCI_INFO_FILE EQU 00000200H MCI_INFO_MEDIA_UPC EQU 00000400H MCI_INFO_MEDIA_IDENTITY EQU 00000800H MCI_INFO_NAME EQU 00001000H MCI_INFO_COPYRIGHT EQU 00002000H ; flags for dwFlags parameter of MCI_GETDEVCAPS command message MCI_GETDEVCAPS_ITEM EQU 00000100H ; flags for dwItem field of the MCI_GETDEVCAPS_PARMS parameter block MCI_GETDEVCAPS_CAN_RECORD EQU 00000001H MCI_GETDEVCAPS_HAS_AUDIO EQU 00000002H MCI_GETDEVCAPS_HAS_VIDEO EQU 00000003H MCI_GETDEVCAPS_DEVICE_TYPE EQU 00000004H MCI_GETDEVCAPS_USES_FILES EQU 00000005H MCI_GETDEVCAPS_COMPOUND_DEVICE EQU 00000006H MCI_GETDEVCAPS_CAN_EJECT EQU 00000007H MCI_GETDEVCAPS_CAN_PLAY EQU 00000008H MCI_GETDEVCAPS_CAN_SAVE EQU 00000009H ; flags for dwFlags parameter of MCI_SYSINFO command message MCI_SYSINFO_QUANTITY EQU 00000100H MCI_SYSINFO_OPEN EQU 00000200H MCI_SYSINFO_NAME EQU 00000400H MCI_SYSINFO_INSTALLNAME EQU 00000800H ; flags for dwFlags parameter of MCI_SET command message MCI_SET_DOOR_OPEN EQU 00000100H MCI_SET_DOOR_CLOSED EQU 00000200H MCI_SET_TIME_FORMAT EQU 00000400H MCI_SET_AUDIO EQU 00000800H MCI_SET_VIDEO EQU 00001000H MCI_SET_ON EQU 00002000H MCI_SET_OFF EQU 00004000H ; flags for dwAudio field of MCI_SET_PARMS or MCI_SEQ_SET_PARMS MCI_SET_AUDIO_ALL EQU 00000000H MCI_SET_AUDIO_LEFT EQU 00000001H MCI_SET_AUDIO_RIGHT EQU 00000002H ; flags for dwFlags parameter of MCI_BREAK command message MCI_BREAK_KEY EQU 00000100H MCI_BREAK_HWND EQU 00000200H MCI_BREAK_OFF EQU 00000400H ; flags for dwFlags parameter of MCI_RECORD command message MCI_RECORD_INSERT EQU 00000100H MCI_RECORD_OVERWRITE EQU 00000200H ;internal; flags for dwFlags parameter of MCI_SOUND command message MCI_SOUND_NAME EQU 00000100H ;internal ;internal ; flags for dwFlags parameter of MCI_SAVE command message MCI_SAVE_FILE EQU 00000100H ; flags for dwFlags parameter of MCI_LOAD command message MCI_LOAD_FILE EQU 00000100H MCI_GENERIC_PARMS STRUC mcigen_dwCallback DD ? MCI_GENERIC_PARMS ENDS MCI_OPEN_PARMS STRUC mciopen_dwCallback DD ? mciopen_wDeviceID DW ? mciopen_wReserved0 DW ? mciopen_lpstrDeviceType DD ? mciopen_lpstrElementName DD ? mciopen_lpstrAlias DD ? MCI_OPEN_PARMS ENDS MCI_PLAY_PARMS STRUC mciplay_dwCallback DD ? mciplay_dwFrom DD ? mciplay_dwTo DD ? MCI_PLAY_PARMS ENDS MCI_SEEK_PARMS STRUC mciseek_dwCallback DD ? mciseek_dwTo DD ? MCI_SEEK_PARMS ENDS MCI_STATUS_PARMS STRUC mcistat_dwCallback DD ? mcistat_dwReturn DD ? mcistat_dwItem DD ? mcistat_dwTrack DD ? MCI_STATUS_PARMS ENDS MCI_INFO_PARMS STRUC mciinfo_dwCallback DD ? mciinfo_lpstrReturn DD ? mciinfo_dwRetSize DD ? MCI_INFO_PARMS ENDS MCI_GETDEVCAPS_PARMS STRUC mcigdc_dwCallback DD ? mcigdc_dwReturn DD ? mcigdc_dwItem DD ? MCI_GETDEVCAPS_PARMS ENDS MCI_SYSINFO_PARMS STRUC mcisi_dwCallback DD ? mcisi_lpstrReturn DD ? mcisi_dwRetSize DD ? mcisi_dwNumber DD ? mcisi_wDeviceType DW ? mcisi_wReserved0 DW ? MCI_SYSINFO_PARMS ENDS MCI_SET_PARMS STRUC mciset_dwCallback DD ? mciset_dwTimeFormat DD ? mciset_dwAudio DD ? MCI_SET_PARMS ENDS MCI_BREAK_PARMS STRUC mcibreak_dwCallback DD ? mcibreak_nVirtKey DW ? mcibreak_wReserved0 DW ? mcibreak_hwndBreak DW ? mcibreak_wReserved1 DW ? MCI_BREAK_PARMS ENDS MCI_SAVE_PARMS STRUC mcisave_dwCallback DD ? mcisave_lpfilename DD ? MCI_SAVE_PARMS ENDS MCI_LOAD_PARMS STRUC mciload_dwCallback DD ? mciload_lpfilename DD ? MCI_LOAD_PARMS ENDS MCI_RECORD_PARMS STRUC mcirec_dwCallback DD ? mcirec_dwFrom DD ? mcirec_dwTo DD ? MCI_RECORD_PARMS ENDS ; MCI extensions for videodisc devices ; flag for dwReturn field of MCI_STATUS_PARMS ; MCI_STATUS command, (dwItem == MCI_STATUS_MODE) MCI_VD_MODE_PARK EQU (MCI_VD_OFFSET+1) ; flag for dwReturn field of MCI_STATUS_PARMS ; MCI_STATUS command, (dwItem == MCI_VD_STATUS_MEDIA_TYPE) MCI_VD_MEDIA_CLV EQU (MCI_VD_OFFSET+2) MCI_VD_MEDIA_CAV EQU (MCI_VD_OFFSET+3) MCI_VD_MEDIA_OTHER EQU (MCI_VD_OFFSET+4) MCI_VD_FORMAT_TRACK EQU 4001H ; flags for dwFlags parameter of MCI_PLAY command message MCI_VD_PLAY_REVERSE EQU 00010000H MCI_VD_PLAY_FAST EQU 00020000H MCI_VD_PLAY_SPEED EQU 00040000H MCI_VD_PLAY_SCAN EQU 00080000H MCI_VD_PLAY_SLOW EQU 00100000H ; flag for dwFlags parameter of MCI_SEEK command message MCI_VD_SEEK_REVERSE EQU 00010000H ; flags for dwItem field of MCI_STATUS_PARMS parameter block MCI_VD_STATUS_SPEED EQU 00004002H MCI_VD_STATUS_FORWARD EQU 00004003H MCI_VD_STATUS_MEDIA_TYPE EQU 00004004H MCI_VD_STATUS_SIDE EQU 00004005H MCI_VD_STATUS_DISC_SIZE EQU 00004006H ; flags for dwFlags parameter of MCI_GETDEVCAPS command message MCI_VD_GETDEVCAPS_CLV EQU 00010000H MCI_VD_GETDEVCAPS_CAV EQU 00020000H MCI_VD_SPIN_UP EQU 00010000H MCI_VD_SPIN_DOWN EQU 00020000H ; flags for dwItem field of MCI_GETDEVCAPS_PARMS parameter block MCI_VD_GETDEVCAPS_CAN_REVERSE EQU 00004002H MCI_VD_GETDEVCAPS_FAST_RATE EQU 00004003H MCI_VD_GETDEVCAPS_SLOW_RATE EQU 00004004H MCI_VD_GETDEVCAPS_NORMAL_RATE EQU 00004005H ; flags for the dwFlags parameter of MCI_STEP command message MCI_VD_STEP_FRAMES EQU 00010000H MCI_VD_STEP_REVERSE EQU 00020000H ; flag for the MCI_ESCAPE command message MCI_VD_ESCAPE_STRING EQU 00000100H MCI_VD_PLAY_PARMS STRUC mcivdplay_dwCallback DD ? mcivdplay_dwFrom DD ? mcivdplay_dwTo DD ? mcivdplay_dwSpeed DD ? MCI_VD_PLAY_PARMS ENDS MCI_VD_STEP_PARMS STRUC mcivdstep_dwCallback DD ? mcivdstep_dwFrames DD ? MCI_VD_STEP_PARMS ENDS MCI_VD_ESCAPE_PARMS STRUC mcivcesc_dwCallback DD ? mcivcesc_lpstrCommand DD ? MCI_VD_ESCAPE_PARMS ENDS ; MCI extensions for CD audio devices ; flags for the dwItem field of the MCI_STATUS_PARMS parameter block MCI_CDA_STATUS_TYPE_TRACK EQU 00004001H ; flags for the dwReturn field of MCI_STATUS_PARMS parameter block ; MCI_STATUS command, (dwItem == MCI_CDA_STATUS_TYPE_TRACK) MCI_CDA_TRACK_AUDIO EQU (MCI_CD_OFFSET+0) MCI_CDA_TRACK_OTHER EQU (MCI_CD_OFFSET+1) ; MCI extensions for waveform audio devices MCI_WAVE_PCM EQU (MCI_WAVE_OFFSET+0) MCI_WAVE_MAPPER EQU (MCI_WAVE_OFFSET+1) ; flags for the dwFlags parameter of MCI_OPEN command message MCI_WAVE_OPEN_BUFFER EQU 00010000H ; flags for the dwFlags parameter of MCI_SET command message MCI_WAVE_SET_FORMATTAG EQU 00010000H MCI_WAVE_SET_CHANNELS EQU 00020000H MCI_WAVE_SET_SAMPLESPERSEC EQU 00040000H MCI_WAVE_SET_AVGBYTESPERSEC EQU 00080000H MCI_WAVE_SET_BLOCKALIGN EQU 00100000H MCI_WAVE_SET_BITSPERSAMPLE EQU 00200000H ; flags for the dwFlags parameter of MCI_STATUS, MCI_SET command messages MCI_WAVE_INPUT EQU 00400000H MCI_WAVE_OUTPUT EQU 00800000H ; flags for the dwItem field of MCI_STATUS_PARMS parameter block MCI_WAVE_STATUS_FORMATTAG EQU 00004001H MCI_WAVE_STATUS_CHANNELS EQU 00004002H MCI_WAVE_STATUS_SAMPLESPERSEC EQU 00004003H MCI_WAVE_STATUS_AVGBYTESPERSEC EQU 00004004H MCI_WAVE_STATUS_BLOCKALIGN EQU 00004005H MCI_WAVE_STATUS_BITSPERSAMPLE EQU 00004006H MCI_WAVE_STATUS_LEVEL EQU 00004007H ; flags for the dwFlags parameter of MCI_SET command message MCI_WAVE_SET_ANYINPUT EQU 04000000H MCI_WAVE_SET_ANYOUTPUT EQU 08000000H ; flags for the dwFlags parameter of MCI_GETDEVCAPS command message MCI_WAVE_GETDEVCAPS_INPUTS EQU 00004001H MCI_WAVE_GETDEVCAPS_OUTPUTS EQU 00004002H MCI_WAVE_OPEN_PARMS STRUC mciwopen_dwCallback DD ? mciwopen_wDeviceID DW ? mciwopen_wReserved0 DW ? mciwopen_lpstrDeviceType DD ? mciwopen_lpstrElementName DD ? mciwopen_lpstrAlias DD ? mciwopen_dwBufferSeconds DD ? MCI_WAVE_OPEN_PARMS ENDS MCI_WAVE_DELETE_PARMS STRUC mciwdel_dwCallback DD ? mciwdel_dwFrom DD ? mciwdel_dwTo DD ? MCI_WAVE_DELETE_PARMS ENDS MCI_WAVE_SET_PARMS STRUC mciwset_dwCallback DD ? mciwset_dwTimeFormat DD ? mciwset_dwAudio DD ? mciwset_wInput DW ? mciwset_wReserved0 DW ? mciwset_wOutput DW ? mciwset_wReserved1 DW ? mciwset_wFormatTag DW ? mciwset_wReserved2 DW ? mciwset_nChannels DW ? mciwset_wReserved3 DW ? mciwset_nSamplesPerSec DW ? mciwset_nAvgBytesPerSec DW ? mciwset_nBlockAlign DW ? mciwset_wReserved4 DW ? mciwset_wBitsPerSample DW ? mciwset_wReserved5 DW ? MCI_WAVE_SET_PARMS ENDS ; MCI extensions for MIDI sequencer devices ; flags for the dwReturn field of MCI_STATUS_PARMS parameter block ; MCI_STATUS command, (dwItem == MCI_SEQ_STATUS_DIVTYPE) MCI_SEQ_DIV_PPQN EQU (0+MCI_SEQ_OFFSET) MCI_SEQ_DIV_SMPTE_24 EQU (1+MCI_SEQ_OFFSET) MCI_SEQ_DIV_SMPTE_25 EQU (2+MCI_SEQ_OFFSET) MCI_SEQ_DIV_SMPTE_30DROP EQU (3+MCI_SEQ_OFFSET) MCI_SEQ_DIV_SMPTE_30 EQU (4+MCI_SEQ_OFFSET) ; flags for the dwMaster field of MCI_SEQ_SET_PARMS parameter block ; MCI_SET command, (dwFlags == MCI_SEQ_SET_MASTER) MCI_SEQ_FORMAT_SONGPTR EQU 4001H MCI_SEQ_FILE EQU 4002H MCI_SEQ_MIDI EQU 4003H MCI_SEQ_SMPTE EQU 4004H MCI_SEQ_NONE EQU 65533 MCI_SEQ_MAPPER EQU 65535 ; flags for the dwItem field of MCI_STATUS_PARMS parameter block MCI_SEQ_STATUS_TEMPO EQU 00004002H MCI_SEQ_STATUS_PORT EQU 00004003H MCI_SEQ_STATUS_SLAVE EQU 00004007H MCI_SEQ_STATUS_MASTER EQU 00004008H MCI_SEQ_STATUS_OFFSET EQU 00004009H MCI_SEQ_STATUS_DIVTYPE EQU 0000400AH MCI_SEQ_STATUS_NAME EQU 0000400BH MCI_SEQ_STATUS_COPYRIGHT EQU 0000400CH ; flags for the dwFlags parameter of MCI_SET command message MCI_SEQ_SET_TEMPO EQU 00010000H MCI_SEQ_SET_PORT EQU 00020000H MCI_SEQ_SET_SLAVE EQU 00040000H MCI_SEQ_SET_MASTER EQU 00080000H MCI_SEQ_SET_OFFSET EQU 01000000H MCI_SEQ_SET_PARMS STRUC mcisset_dwCallback DD ? mcisset_dwTimeFormat DD ? mcisset_dwAudio DD ? mcisset_dwTempo DD ? mcisset_dwPort DD ? mcisset_dwSlave DD ? mcisset_dwMaster DD ? mcisset_dwOffset DD ? MCI_SEQ_SET_PARMS ENDS ; MCI extensions for animation devices ; flags for dwFlags parameter of MCI_OPEN command message MCI_ANIM_OPEN_WS EQU 00010000H MCI_ANIM_OPEN_PARENT EQU 00020000H MCI_ANIM_OPEN_NOSTATIC EQU 00040000H ; flags for dwFlags parameter of MCI_PLAY command message MCI_ANIM_PLAY_SPEED EQU 00010000H MCI_ANIM_PLAY_REVERSE EQU 00020000H MCI_ANIM_PLAY_FAST EQU 00040000H MCI_ANIM_PLAY_SLOW EQU 00080000H MCI_ANIM_PLAY_SCAN EQU 00100000H ; flags for dwFlags parameter of MCI_STEP command message MCI_ANIM_STEP_REVERSE EQU 00010000H MCI_ANIM_STEP_FRAMES EQU 00020000H ; flags for dwItem field of MCI_STATUS_PARMS parameter block MCI_ANIM_STATUS_SPEED EQU 00004001H MCI_ANIM_STATUS_FORWARD EQU 00004002H MCI_ANIM_STATUS_HWND EQU 00004003H MCI_ANIM_STATUS_HPAL EQU 00004004H MCI_ANIM_STATUS_STRETCH EQU 00004005H ; flags for the dwFlags parameter of MCI_INFO command message MCI_ANIM_INFO_TEXT EQU 00010000H ; flags for dwItem field of MCI_GETDEVCAPS_PARMS parameter block MCI_ANIM_GETDEVCAPS_CAN_REVERSE EQU 00004001H MCI_ANIM_GETDEVCAPS_FAST_RATE EQU 00004002H MCI_ANIM_GETDEVCAPS_SLOW_RATE EQU 00004003H MCI_ANIM_GETDEVCAPS_NORMAL_RATE EQU 00004004H MCI_ANIM_GETDEVCAPS_PALETTES EQU 00004006H MCI_ANIM_GETDEVCAPS_CAN_STRETCH EQU 00004007H MCI_ANIM_GETDEVCAPS_MAX_WINDOWS EQU 00004008H ; flags for the MCI_REALIZE command message MCI_ANIM_REALIZE_NORM EQU 00010000H MCI_ANIM_REALIZE_BKGD EQU 00020000H ; flags for dwFlags parameter of MCI_WINDOW command message MCI_ANIM_WINDOW_HWND EQU 00010000H MCI_ANIM_WINDOW_STATE EQU 00040000H MCI_ANIM_WINDOW_TEXT EQU 00080000H MCI_ANIM_WINDOW_ENABLE_STRETCH EQU 00100000H MCI_ANIM_WINDOW_DISABLE_STRETCH EQU 00200000H ; flags for hWnd field of MCI_ANIM_WINDOW_PARMS parameter block ; MCI_WINDOW command message, (dwFlags == MCI_ANIM_WINDOW_HWND) MCI_ANIM_WINDOW_DEFAULT EQU 00000000H ; flags for dwFlags parameter of MCI_PUT command message MCI_ANIM_RECT EQU 00010000H MCI_ANIM_PUT_SOURCE EQU 00020000H MCI_ANIM_PUT_DESTINATION EQU 00040000H ; flags for dwFlags parameter of MCI_WHERE command message MCI_ANIM_WHERE_SOURCE EQU 00020000H MCI_ANIM_WHERE_DESTINATION EQU 00040000H ; flags for dwFlags parameter of MCI_UPDATE command message MCI_ANIM_UPDATE_HDC EQU 00020000H MCI_ANIM_OPEN_PARMS STRUC mciaopen_dwCallback DD ? mciaopen_wDeviceID DW ? mciaopen_wReserved0 DW ? mciaopen_lpstrDeviceType DD ? mciaopen_lpstrElementName DD ? mciaopen_lpstrAlias DD ? mciaopen_dwStyle DD ? mciaopen_hWndParent DW ? mciaopen_wReserved1 DW ? MCI_ANIM_OPEN_PARMS ENDS MCI_ANIM_PLAY_PARMS STRUC mciaplay_dwCallback DD ? mciaplay_dwFrom DD ? mciaplay_dwTo DD ? mciaplay_dwSpeed DD ? MCI_ANIM_PLAY_PARMS ENDS MCI_ANIM_STEP_PARMS STRUC mciastep_dwCallback DD ? mciastep_dwFrames DD ? MCI_ANIM_STEP_PARMS ENDS MCI_ANIM_WINDOW_PARMS STRUC mciawin_dwCallback DD ? mciawin_hWnd DW ? mciawin_wReserved1 DW ? mciawin_nCmdShow DW ? mciawin_wReserved2 DW ? mciawin_lpstrText DD ? MCI_ANIM_WINDOW_PARMS ENDS MCI_ANIM_RECT_PARMS STRUC mciarect_dwCallback DD ? ifdef MCI_USE_OFFEXT mciarect_ptOffset DB SIZE POINT DUP (?) mciarect_ptExtent DB SIZE POINT DUP (?) else ;ifdef MCI_USE_OFFEXT mciarect_rc DB SIZE RECT DUP (?) endif ;ifdef MCI_USE_OFFEXT MCI_ANIM_RECT_PARMS ENDS MCI_ANIM_UPDATE_PARMS STRUC mciaupd_dwCallback DD ? mciaupd_rc DB SIZE RECT DUP (?) mciaupd_hDC DW ? MCI_ANIM_UPDATE_PARMS ENDS ; MCI extensions for video overlay devices ; flags for dwFlags parameter of MCI_OPEN command message MCI_OVLY_OPEN_WS EQU 00010000H MCI_OVLY_OPEN_PARENT EQU 00020000H ; flags for dwFlags parameter of MCI_STATUS command message MCI_OVLY_STATUS_HWND EQU 00004001H MCI_OVLY_STATUS_STRETCH EQU 00004002H ; flags for dwFlags parameter of MCI_INFO command message MCI_OVLY_INFO_TEXT EQU 00010000H ; flags for dwItem field of MCI_GETDEVCAPS_PARMS parameter block MCI_OVLY_GETDEVCAPS_CAN_STRETCH EQU 00004001H MCI_OVLY_GETDEVCAPS_CAN_FREEZE EQU 00004002H MCI_OVLY_GETDEVCAPS_MAX_WINDOWS EQU 00004003H ; flags for dwFlags parameter of MCI_WINDOW command message MCI_OVLY_WINDOW_HWND EQU 00010000H MCI_OVLY_WINDOW_STATE EQU 00040000H MCI_OVLY_WINDOW_TEXT EQU 00080000H MCI_OVLY_WINDOW_ENABLE_STRETCH EQU 00100000H MCI_OVLY_WINDOW_DISABLE_STRETCH EQU 00200000H ; flags for hWnd parameter of MCI_OVLY_WINDOW_PARMS parameter block MCI_OVLY_WINDOW_DEFAULT EQU 00000000H ; flags for dwFlags parameter of MCI_PUT command message MCI_OVLY_RECT EQU 00010000H MCI_OVLY_PUT_SOURCE EQU 00020000H MCI_OVLY_PUT_DESTINATION EQU 00040000H MCI_OVLY_PUT_FRAME EQU 00080000H MCI_OVLY_PUT_VIDEO EQU 00100000H ; flags for dwFlags parameter of MCI_WHERE command message MCI_OVLY_WHERE_SOURCE EQU 00020000H MCI_OVLY_WHERE_DESTINATION EQU 00040000H MCI_OVLY_WHERE_FRAME EQU 00080000H MCI_OVLY_WHERE_VIDEO EQU 00100000H MCI_OVLY_OPEN_PARMS STRUC mcioopen_dwCallback DD ? mcioopen_wDeviceID DW ? mcioopen_wReserved0 DW ? mcioopen_lpstrDeviceType DD ? mcioopen_lpstrElementName DD ? mcioopen_lpstrAlias DD ? mcioopen_dwStyle DD ? mcioopen_hWndParent DW ? mcioopen_wReserved1 DW ? MCI_OVLY_OPEN_PARMS ENDS MCI_OVLY_WINDOW_PARMS STRUC mciowin_dwCallback DD ? mciowin_hWnd DW ? mciowin_wReserved1 DW ? mciowin_nCmdShow DW ? mciowin_wReserved2 DW ? mciowin_lpstrText DD ? MCI_OVLY_WINDOW_PARMS ENDS MCI_OVLY_RECT_PARMS STRUC mciorect_dwCallback DD ? ifdef MCI_USE_OFFEXT mciorect_ptOffset DB SIZE POINT DUP (?) mciorect_ptExtent DB SIZE POINT DUP (?) else ;ifdef MCI_USE_OFFEXT mciorect_rc DB SIZE RECT DUP (?) endif ;ifdef MCI_USE_OFFEXT MCI_OVLY_RECT_PARMS ENDS MCI_OVLY_SAVE_PARMS STRUC mciosave_dwCallback DD ? mciosave_lpfilename DD ? mciosave_rc DB SIZE RECT DUP (?) MCI_OVLY_SAVE_PARMS ENDS MCI_OVLY_LOAD_PARMS STRUC mcioload_dwCallback DD ? mcioload_lpfilename DD ? mcioload_rc DB SIZE RECT DUP (?) MCI_OVLY_LOAD_PARMS ENDS endif ; ifndef _WIN32_VXD endif ;both; ifndef MMNOMCI ;*************************************************************************** ; DISPLAY Driver extensions ;************************************************************************* ifndef NEWTRANSPARENT NEWTRANSPARENT EQU 3 ; use with SetBkMode() QUERYROPSUPPORT EQU 40 ; use to determine ROP support endif ; ifndef NEWTRANSPARENT ;*************************************************************************** ; DIB Driver extensions ;************************************************************************* SELECTDIB EQU 41 ; DIB.DRV select dib escape ifndef SC_SCREENSAVE SC_SCREENSAVE EQU 0F140H endif ; ifndef SC_SCREENSAVE