Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
6168a2ea
Commit
6168a2ea
authored
Mar 04, 2003
by
Robert Reif
Committed by
Alexandre Julliard
Mar 04, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added waveIn tests.
parent
6bf8542d
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
163 additions
and
5 deletions
+163
-5
wave.c
dlls/winmm/tests/wave.c
+162
-4
winmm.c
dlls/winmm/winmm.c
+1
-1
No files found.
dlls/winmm/tests/wave.c
View file @
6168a2ea
...
@@ -192,7 +192,7 @@ static void wave_out_tests()
...
@@ -192,7 +192,7 @@ static void wave_out_tests()
rc
=
waveOutGetDevCapsA
(
ndev
+
1
,
&
caps
,
sizeof
(
caps
));
rc
=
waveOutGetDevCapsA
(
ndev
+
1
,
&
caps
,
sizeof
(
caps
));
ok
(
rc
==
MMSYSERR_BADDEVICEID
,
ok
(
rc
==
MMSYSERR_BADDEVICEID
,
"waveOutGetDevCa
psA: MMSYSERR_BADDEVICEID expected, got %d"
,
rc
);
"waveOutGetDevCapsA: MMSYSERR_BADDEVICEID expected, got %d"
,
rc
);
format
.
wFormatTag
=
WAVE_FORMAT_PCM
;
format
.
wFormatTag
=
WAVE_FORMAT_PCM
;
format
.
nChannels
=
2
;
format
.
nChannels
=
2
;
...
@@ -208,7 +208,7 @@ static void wave_out_tests()
...
@@ -208,7 +208,7 @@ static void wave_out_tests()
for
(
d
=
0
;
d
<
ndev
;
d
++
)
{
for
(
d
=
0
;
d
<
ndev
;
d
++
)
{
rc
=
waveOutGetDevCapsA
(
d
,
&
caps
,
sizeof
(
caps
));
rc
=
waveOutGetDevCapsA
(
d
,
&
caps
,
sizeof
(
caps
));
ok
(
rc
==
MMSYSERR_NOERROR
||
rc
==
MMSYSERR_BADDEVICEID
,
ok
(
rc
==
MMSYSERR_NOERROR
||
rc
==
MMSYSERR_BADDEVICEID
,
"failed to get capabilities of device %d: rc=%d"
,
d
,
rc
);
"
waveOutGetDevCapsA:
failed to get capabilities of device %d: rc=%d"
,
d
,
rc
);
if
(
rc
==
MMSYSERR_BADDEVICEID
)
if
(
rc
==
MMSYSERR_BADDEVICEID
)
continue
;
continue
;
...
@@ -236,7 +236,7 @@ static void wave_out_tests()
...
@@ -236,7 +236,7 @@ static void wave_out_tests()
format
.
cbSize
=
0
;
format
.
cbSize
=
0
;
rc
=
waveOutOpen
(
&
wout
,
d
,
&
format
,
0
,
0
,
CALLBACK_NULL
);
rc
=
waveOutOpen
(
&
wout
,
d
,
&
format
,
0
,
0
,
CALLBACK_NULL
);
ok
(
rc
==
WAVERR_BADFORMAT
,
ok
(
rc
==
WAVERR_BADFORMAT
,
"opening the device at 2MHz should fail %d: rc=%d"
,
d
,
rc
);
"
waveOutOpen:
opening the device at 2MHz should fail %d: rc=%d"
,
d
,
rc
);
if
(
rc
==
MMSYSERR_NOERROR
)
{
if
(
rc
==
MMSYSERR_NOERROR
)
{
trace
(
" got %ldx%2dx%d for %dx%2dx%d
\n
"
,
trace
(
" got %ldx%2dx%d for %dx%2dx%d
\n
"
,
format
.
nSamplesPerSec
,
format
.
wBitsPerSample
,
format
.
nSamplesPerSec
,
format
.
wBitsPerSample
,
...
@@ -255,7 +255,7 @@ static void wave_out_tests()
...
@@ -255,7 +255,7 @@ static void wave_out_tests()
format
.
cbSize
=
0
;
format
.
cbSize
=
0
;
rc
=
waveOutOpen
(
&
wout
,
d
,
&
format
,
0
,
0
,
CALLBACK_NULL
|
WAVE_FORMAT_DIRECT
);
rc
=
waveOutOpen
(
&
wout
,
d
,
&
format
,
0
,
0
,
CALLBACK_NULL
|
WAVE_FORMAT_DIRECT
);
ok
(
rc
==
WAVERR_BADFORMAT
||
rc
==
MMSYSERR_INVALFLAG
,
ok
(
rc
==
WAVERR_BADFORMAT
||
rc
==
MMSYSERR_INVALFLAG
,
"opening the device at 2MHz should fail %d: rc=%d"
,
d
,
rc
);
"
waveOutOpen:
opening the device at 2MHz should fail %d: rc=%d"
,
d
,
rc
);
if
(
rc
==
MMSYSERR_NOERROR
)
{
if
(
rc
==
MMSYSERR_NOERROR
)
{
trace
(
" got %ldx%2dx%d for %dx%2dx%d
\n
"
,
trace
(
" got %ldx%2dx%d for %dx%2dx%d
\n
"
,
format
.
nSamplesPerSec
,
format
.
wBitsPerSample
,
format
.
nSamplesPerSec
,
format
.
wBitsPerSample
,
...
@@ -267,7 +267,165 @@ static void wave_out_tests()
...
@@ -267,7 +267,165 @@ static void wave_out_tests()
}
}
}
}
static
void
wave_in_test_deviceIn
(
int
device
,
int
format
,
DWORD
flags
)
{
WAVEFORMATEX
wfx
;
HWAVEIN
win
;
HANDLE
hevent
;
WAVEHDR
frag
;
MMRESULT
rc
;
hevent
=
CreateEvent
(
NULL
,
FALSE
,
FALSE
,
NULL
);
ok
(
hevent
!=
NULL
,
"CreateEvent: error=%ld
\n
"
,
GetLastError
());
if
(
hevent
==
NULL
)
return
;
wfx
.
wFormatTag
=
WAVE_FORMAT_PCM
;
wfx
.
nChannels
=
win_formats
[
format
][
3
];
wfx
.
wBitsPerSample
=
win_formats
[
format
][
2
];
wfx
.
nSamplesPerSec
=
win_formats
[
format
][
1
];
wfx
.
nBlockAlign
=
wfx
.
nChannels
*
wfx
.
wBitsPerSample
/
8
;
wfx
.
nAvgBytesPerSec
=
wfx
.
nSamplesPerSec
*
wfx
.
nBlockAlign
;
wfx
.
cbSize
=
0
;
win
=
NULL
;
rc
=
waveInOpen
(
&
win
,
device
,
&
wfx
,(
DWORD
)
hevent
,
0
,
CALLBACK_EVENT
|
flags
);
/* Note: Win9x doesn't know WAVE_FORMAT_DIRECT */
ok
(
rc
==
MMSYSERR_NOERROR
||
rc
==
MMSYSERR_BADDEVICEID
||
(
rc
==
MMSYSERR_INVALFLAG
&&
(
flags
&
WAVE_FORMAT_DIRECT
)),
"waveInOpen: device=%d rc=%d"
,
device
,
rc
);
if
(
rc
!=
MMSYSERR_NOERROR
)
{
CloseHandle
(
hevent
);
return
;
}
ok
(
wfx
.
nChannels
==
win_formats
[
format
][
3
]
&&
wfx
.
wBitsPerSample
==
win_formats
[
format
][
2
]
&&
wfx
.
nSamplesPerSec
==
win_formats
[
format
][
1
],
"got the wrong format: %ldx%2dx%d instead of %dx%2dx%d
\n
"
,
wfx
.
nSamplesPerSec
,
wfx
.
wBitsPerSample
,
wfx
.
nChannels
,
win_formats
[
format
][
1
],
win_formats
[
format
][
2
],
win_formats
[
format
][
3
]);
frag
.
lpData
=
malloc
(
wfx
.
nAvgBytesPerSec
);
frag
.
dwBufferLength
=
wfx
.
nAvgBytesPerSec
;
frag
.
dwFlags
=
0
;
frag
.
dwLoops
=
0
;
rc
=
waveInPrepareHeader
(
win
,
&
frag
,
sizeof
(
frag
));
ok
(
rc
==
MMSYSERR_NOERROR
,
"waveOutPrepareHeader: device=%d rc=%d
\n
"
,
device
,
rc
);
if
(
winetest_interactive
&&
rc
==
MMSYSERR_NOERROR
)
{
trace
(
"Recording at %ldx%2dx%d %04lx
\n
"
,
wfx
.
nSamplesPerSec
,
wfx
.
wBitsPerSample
,
wfx
.
nChannels
,
flags
);
rc
=
waveInAddBuffer
(
win
,
&
frag
,
sizeof
(
frag
));
ok
(
rc
==
MMSYSERR_NOERROR
,
"waveInAddBuffer: device=%d rc=%d
\n
"
,
device
,
rc
);
rc
=
waveInStart
(
win
);
ok
(
rc
==
MMSYSERR_NOERROR
,
"waveInStart: device=%d rc=%d
\n
"
,
device
,
rc
);
WaitForSingleObject
(
hevent
,
INFINITE
);
}
rc
=
waveInUnprepareHeader
(
win
,
&
frag
,
sizeof
(
frag
));
ok
(
rc
==
MMSYSERR_NOERROR
,
"waveInUnprepareHeader: device=%d rc=%d
\n
"
,
device
,
rc
);
free
(
frag
.
lpData
);
CloseHandle
(
hevent
);
waveInClose
(
win
);
}
static
void
wave_in_tests
()
{
WAVEINCAPS
caps
;
WAVEFORMATEX
format
;
HWAVEIN
win
;
MMRESULT
rc
;
UINT
ndev
,
d
,
f
;
ndev
=
waveInGetNumDevs
();
trace
(
"found %d WaveIn devices
\n
"
,
ndev
);
rc
=
waveInGetDevCapsA
(
ndev
+
1
,
&
caps
,
sizeof
(
caps
));
ok
(
rc
==
MMSYSERR_BADDEVICEID
,
"waveInGetDevCapsA: MMSYSERR_BADDEVICEID expected, got %d"
,
rc
);
format
.
wFormatTag
=
WAVE_FORMAT_PCM
;
format
.
nChannels
=
2
;
format
.
wBitsPerSample
=
16
;
format
.
nSamplesPerSec
=
44100
;
format
.
nBlockAlign
=
format
.
nChannels
*
format
.
wBitsPerSample
/
8
;
format
.
nAvgBytesPerSec
=
format
.
nSamplesPerSec
*
format
.
nBlockAlign
;
format
.
cbSize
=
0
;
rc
=
waveInOpen
(
&
win
,
ndev
+
1
,
&
format
,
0
,
0
,
CALLBACK_NULL
);
ok
(
rc
==
MMSYSERR_BADDEVICEID
,
"waveInOpen: MMSYSERR_BADDEVICEID expected, got %d"
,
rc
);
for
(
d
=
0
;
d
<
ndev
;
d
++
)
{
rc
=
waveInGetDevCapsA
(
d
,
&
caps
,
sizeof
(
caps
));
ok
(
rc
==
MMSYSERR_NOERROR
||
rc
==
MMSYSERR_BADDEVICEID
,
"waveInGetDevCapsA: failed to get capabilities of device %d: rc=%d"
,
d
,
rc
);
if
(
rc
==
MMSYSERR_BADDEVICEID
)
continue
;
trace
(
" %d:
\"
%s
\"
%d.%d (%d:%d): channels=%d formats=%04lx
\n
"
,
d
,
caps
.
szPname
,
caps
.
vDriverVersion
>>
8
,
caps
.
vDriverVersion
&
0xff
,
caps
.
wMid
,
caps
.
wPid
,
caps
.
wChannels
,
caps
.
dwFormats
);
for
(
f
=
0
;
f
<
NB_WIN_FORMATS
;
f
++
)
{
if
(
caps
.
dwFormats
&
win_formats
[
f
][
0
])
{
wave_in_test_deviceIn
(
d
,
f
,
0
);
wave_in_test_deviceIn
(
d
,
f
,
WAVE_FORMAT_DIRECT
);
}
}
/* Try an invalid format to test error handling */
trace
(
"Testing invalid 2MHz format
\n
"
);
format
.
wFormatTag
=
WAVE_FORMAT_PCM
;
format
.
nChannels
=
2
;
format
.
wBitsPerSample
=
16
;
format
.
nSamplesPerSec
=
2000000
;
/* 2MHz! */
format
.
nBlockAlign
=
format
.
nChannels
*
format
.
wBitsPerSample
/
8
;
format
.
nAvgBytesPerSec
=
format
.
nSamplesPerSec
*
format
.
nBlockAlign
;
format
.
cbSize
=
0
;
rc
=
waveInOpen
(
&
win
,
d
,
&
format
,
0
,
0
,
CALLBACK_NULL
);
ok
(
rc
==
WAVERR_BADFORMAT
,
"waveInOpen: opening the device at 2MHz should fail %d: rc=%d"
,
d
,
rc
);
if
(
rc
==
MMSYSERR_NOERROR
)
{
trace
(
" got %ldx%2dx%d for %dx%2dx%d
\n
"
,
format
.
nSamplesPerSec
,
format
.
wBitsPerSample
,
format
.
nChannels
,
win_formats
[
f
][
1
],
win_formats
[
f
][
2
],
win_formats
[
f
][
3
]);
waveInClose
(
win
);
}
format
.
wFormatTag
=
WAVE_FORMAT_PCM
;
format
.
nChannels
=
2
;
format
.
wBitsPerSample
=
16
;
format
.
nSamplesPerSec
=
2000000
;
/* 2MHz! */
format
.
nBlockAlign
=
format
.
nChannels
*
format
.
wBitsPerSample
/
8
;
format
.
nAvgBytesPerSec
=
format
.
nSamplesPerSec
*
format
.
nBlockAlign
;
format
.
cbSize
=
0
;
rc
=
waveInOpen
(
&
win
,
d
,
&
format
,
0
,
0
,
CALLBACK_NULL
|
WAVE_FORMAT_DIRECT
);
ok
(
rc
==
WAVERR_BADFORMAT
||
rc
==
MMSYSERR_INVALFLAG
,
"waveInOpen: opening the device at 2MHz should fail %d: rc=%d"
,
d
,
rc
);
if
(
rc
==
MMSYSERR_NOERROR
)
{
trace
(
" got %ldx%2dx%d for %dx%2dx%d
\n
"
,
format
.
nSamplesPerSec
,
format
.
wBitsPerSample
,
format
.
nChannels
,
win_formats
[
f
][
1
],
win_formats
[
f
][
2
],
win_formats
[
f
][
3
]);
waveInClose
(
win
);
}
}
}
START_TEST
(
wave
)
START_TEST
(
wave
)
{
{
wave_out_tests
();
wave_out_tests
();
wave_in_tests
();
}
}
dlls/winmm/winmm.c
View file @
6168a2ea
...
@@ -2629,7 +2629,7 @@ UINT WINAPI waveInGetDevCapsA(UINT uDeviceID, LPWAVEINCAPSA lpCaps, UINT uSize)
...
@@ -2629,7 +2629,7 @@ UINT WINAPI waveInGetDevCapsA(UINT uDeviceID, LPWAVEINCAPSA lpCaps, UINT uSize)
TRACE
(
"(%u %p %u)!
\n
"
,
uDeviceID
,
lpCaps
,
uSize
);
TRACE
(
"(%u %p %u)!
\n
"
,
uDeviceID
,
lpCaps
,
uSize
);
if
((
wmld
=
MMDRV_Get
((
HANDLE
)
uDeviceID
,
MMDRV_WAVEIN
,
TRUE
))
==
NULL
)
if
((
wmld
=
MMDRV_Get
((
HANDLE
)
uDeviceID
,
MMDRV_WAVEIN
,
TRUE
))
==
NULL
)
return
MMSYSERR_
INVALHANDLE
;
return
MMSYSERR_
BADDEVICEID
;
return
MMDRV_Message
(
wmld
,
WIDM_GETDEVCAPS
,
(
DWORD
)
lpCaps
,
uSize
,
TRUE
);
return
MMDRV_Message
(
wmld
,
WIDM_GETDEVCAPS
,
(
DWORD
)
lpCaps
,
uSize
,
TRUE
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment