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
45af4922
Commit
45af4922
authored
Oct 19, 2002
by
Michael Günnewig
Committed by
Alexandre Julliard
Oct 19, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- Fixed loading of wave files.
- Corrected AVIFILEINFOW structure updates. - Implemented saving of wave files.
parent
6b953ffc
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
114 additions
and
14 deletions
+114
-14
Makefile.in
dlls/Makefile.in
+2
-2
Makefile.in
dlls/avifil32/Makefile.in
+1
-1
wavfile.c
dlls/avifil32/wavfile.c
+111
-11
No files found.
dlls/Makefile.in
View file @
45af4922
...
...
@@ -763,8 +763,8 @@ x11drv/__install__: x11drv.dll$(DLLEXT)
advapi32
:
kernel32.dll$(DLLEXT) ntdll.dll$(DLLEXT)
avicap32
:
ntdll.dll$(DLLEXT)
avifil32
:
ms
vfw32.dll$(DLLEXT) shell32.dll$(DLLEXT) winmm.dll$(DLLEXT) user32
.dll$(DLLEXT)
\
advapi32.dll$(DLLEXT) kernel32.dll$(DLLEXT)
avifil32
:
ms
acm32.dll$(DLLEXT) msvfw32.dll$(DLLEXT) shell32.dll$(DLLEXT) winmm
.dll$(DLLEXT)
\
user32.dll$(DLLEXT)
advapi32.dll$(DLLEXT) kernel32.dll$(DLLEXT)
comcat
:
ole32.dll$(DLLEXT) user32.dll$(DLLEXT) advapi32.dll$(DLLEXT) kernel32.dll$(DLLEXT)
comctl32
:
user32.dll$(DLLEXT) gdi32.dll$(DLLEXT) advapi32.dll$(DLLEXT) kernel32.dll$(DLLEXT)
\
winmm.dll$(DLLEXT)
...
...
dlls/avifil32/Makefile.in
View file @
45af4922
...
...
@@ -3,7 +3,7 @@ TOPOBJDIR = ../..
SRCDIR
=
@srcdir@
VPATH
=
@srcdir@
MODULE
=
avifil32.dll
IMPORTS
=
msvfw32 shell32 winmm user32 advapi32 kernel32
IMPORTS
=
ms
acm32 ms
vfw32 shell32 winmm user32 advapi32 kernel32
ALTNAMES
=
avifile.dll
EXTRALIBS
=
$(LIBUUID)
...
...
dlls/avifil32/wavfile.c
View file @
45af4922
...
...
@@ -25,6 +25,7 @@
#include "windowsx.h"
#include "mmsystem.h"
#include "vfw.h"
#include "msacm.h"
#include "avifile_private.h"
#include "extrachunk.h"
...
...
@@ -285,11 +286,15 @@ static HRESULT WINAPI IAVIFile_fnInfo(IAVIFile *iface, LPAVIFILEINFOW afi,
This
->
fInfo
.
dwFlags
=
0
;
This
->
fInfo
.
dwCaps
=
AVIFILECAPS_CANREAD
|
AVIFILECAPS_CANWRITE
;
if
(
This
->
lpFormat
!=
NULL
)
{
assert
(
This
->
sInfo
.
dwScale
!=
0
);
This
->
fInfo
.
dwStreams
=
1
;
This
->
fInfo
.
dwScale
=
This
->
sInfo
.
dwScale
;
This
->
fInfo
.
dwRate
=
This
->
sInfo
.
dwRate
;
This
->
fInfo
.
dwLength
=
This
->
sInfo
.
dwLength
;
This
->
fInfo
.
dwSuggestedBufferSize
=
This
->
ckData
.
cksize
;
This
->
fInfo
.
dwMaxBytesPerSec
=
MulDiv
(
This
->
sInfo
.
dwSampleSize
,
This
->
sInfo
.
dwRate
,
This
->
sInfo
.
dwScale
);
}
memcpy
(
afi
,
&
This
->
fInfo
,
min
(
size
,
sizeof
(
This
->
fInfo
)));
...
...
@@ -1000,6 +1005,7 @@ static HRESULT AVIFILE_LoadFile(IAVIFileImpl *This)
This
->
fDirty
=
FALSE
;
/* search for RIFF chunk */
ckRIFF
.
fccType
=
0
;
/* find any */
if
(
mmioDescend
(
This
->
hmmio
,
&
ckRIFF
,
NULL
,
MMIO_FINDRIFF
)
!=
S_OK
)
{
return
AVIFILE_LoadSunFile
(
This
);
}
...
...
@@ -1010,7 +1016,7 @@ static HRESULT AVIFILE_LoadFile(IAVIFileImpl *This)
/* search WAVE format chunk */
ck
.
ckid
=
ckidWAVEFORMAT
;
if
(
FindChunkAndKeepExtras
(
&
This
->
extra
,
This
->
hmmio
,
&
ck
,
&
ckRIFF
,
MMIO_FINDCHUNK
!=
S_OK
)
)
&
ckRIFF
,
MMIO_FINDCHUNK
)
!=
S_OK
)
return
AVIERR_FILEREAD
;
/* get memory for format and read it */
...
...
@@ -1024,14 +1030,9 @@ static HRESULT AVIFILE_LoadFile(IAVIFileImpl *This)
if
(
mmioAscend
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEREAD
;
/* non-pcm formats have a fact chunk */
if
(
This
->
lpFormat
->
wFormatTag
!=
WAVE_FORMAT_PCM
)
{
ck
.
ckid
=
ckidWAVEFACT
;
if
(
mmioDescend
(
This
->
hmmio
,
&
ck
,
NULL
,
MMIO_FINDCHUNK
)
!=
S_OK
)
{
/* FIXME: if codec is installed could ask him */
return
AVIERR_BADFORMAT
;
}
}
/* Non-pcm formats have a fact chunk.
* We don't need it, so simply add it to the extra chunks.
*/
/* find the big data chunk */
This
->
ckData
.
ckid
=
ckidWAVEDATA
;
...
...
@@ -1047,6 +1048,8 @@ static HRESULT AVIFILE_LoadFile(IAVIFileImpl *This)
This
->
sInfo
.
dwLength
=
This
->
ckData
.
cksize
/
This
->
lpFormat
->
nBlockAlign
;
This
->
sInfo
.
dwSuggestedBufferSize
=
This
->
ckData
.
cksize
;
This
->
fInfo
.
dwStreams
=
1
;
if
(
mmioAscend
(
This
->
hmmio
,
&
This
->
ckData
,
0
)
!=
S_OK
)
{
/* seems to be truncated */
WARN
(
": file seems to be truncated!
\n
"
);
...
...
@@ -1064,12 +1067,109 @@ static HRESULT AVIFILE_LoadFile(IAVIFileImpl *This)
static
HRESULT
AVIFILE_LoadSunFile
(
IAVIFileImpl
*
This
)
{
FIXME
(
": pherh
pa
s sun-audio file -- not implemented !
\n
"
);
FIXME
(
": pherh
ap
s sun-audio file -- not implemented !
\n
"
);
return
AVIERR_UNSUPPORTED
;
}
static
HRESULT
AVIFILE_SaveFile
(
IAVIFileImpl
*
This
)
{
return
AVIERR_UNSUPPORTED
;
MMCKINFO
ckRIFF
;
MMCKINFO
ck
;
mmioSeek
(
This
->
hmmio
,
0
,
SEEK_SET
);
/* create the RIFF chunk with formtype WAVE */
ckRIFF
.
fccType
=
formtypeWAVE
;
ckRIFF
.
cksize
=
0
;
if
(
mmioCreateChunk
(
This
->
hmmio
,
&
ckRIFF
,
MMIO_CREATERIFF
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
/* the next chunk is the format */
ck
.
ckid
=
ckidWAVEFORMAT
;
ck
.
cksize
=
This
->
cbFormat
;
if
(
mmioCreateChunk
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
if
(
This
->
lpFormat
!=
NULL
&&
This
->
cbFormat
>
0
)
{
if
(
mmioWrite
(
This
->
hmmio
,
(
HPSTR
)
This
->
lpFormat
,
ck
.
cksize
)
!=
ck
.
cksize
)
return
AVIERR_FILEWRITE
;
}
if
(
mmioAscend
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
/* fact chunk is needed for non-pcm waveforms */
if
(
This
->
lpFormat
!=
NULL
&&
This
->
cbFormat
>
sizeof
(
PCMWAVEFORMAT
)
&&
This
->
lpFormat
->
wFormatTag
!=
WAVE_FORMAT_PCM
)
{
WAVEFORMATEX
wfx
;
DWORD
dwFactLength
;
HACMSTREAM
has
;
/* try to open an appropriate audio codec to figure out
* data for fact-chunk */
wfx
.
wFormatTag
=
WAVE_FORMAT_PCM
;
if
(
acmFormatSuggest
((
HACMDRIVER
)
NULL
,
This
->
lpFormat
,
&
wfx
,
sizeof
(
wfx
),
ACM_FORMATSUGGESTF_WFORMATTAG
))
{
acmStreamOpen
(
&
has
,
(
HACMDRIVER
)
NULL
,
This
->
lpFormat
,
&
wfx
,
NULL
,
0
,
0
,
ACM_STREAMOPENF_NONREALTIME
);
acmStreamSize
(
has
,
This
->
ckData
.
cksize
,
&
dwFactLength
,
ACM_STREAMSIZEF_SOURCE
);
dwFactLength
/=
wfx
.
nBlockAlign
;
acmStreamClose
(
has
,
0
);
/* crete the fact chunk */
ck
.
ckid
=
ckidWAVEFACT
;
ck
.
cksize
=
sizeof
(
dwFactLength
);
/* test for enough space before data chunk */
if
(
mmioSeek
(
This
->
hmmio
,
0
,
SEEK_CUR
)
>
This
->
ckData
.
dwDataOffset
-
ck
.
cksize
-
4
*
sizeof
(
DWORD
))
return
AVIERR_FILEWRITE
;
if
(
mmioCreateChunk
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
if
(
mmioWrite
(
This
->
hmmio
,
(
HPSTR
)
&
dwFactLength
,
ck
.
cksize
)
!=
ck
.
cksize
)
return
AVIERR_FILEWRITE
;
if
(
mmioAscend
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
}
else
ERR
(
": fact chunk is needed for non-pcm files -- currently no codec found, so skipped!
\n
"
);
}
/* if here was extra stuff, we need to fill it with JUNK */
if
(
mmioSeek
(
This
->
hmmio
,
0
,
SEEK_CUR
)
+
2
*
sizeof
(
DWORD
)
<
This
->
ckData
.
dwDataOffset
)
{
ck
.
ckid
=
ckidAVIPADDING
;
ck
.
cksize
=
0
;
if
(
mmioCreateChunk
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
if
(
mmioSeek
(
This
->
hmmio
,
This
->
ckData
.
dwDataOffset
-
2
*
sizeof
(
DWORD
),
SEEK_SET
)
==
-
1
)
return
AVIERR_FILEWRITE
;
if
(
mmioAscend
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
}
/* crete the data chunk */
ck
.
ckid
=
ckidWAVEDATA
;
ck
.
cksize
=
This
->
ckData
.
cksize
;
if
(
mmioCreateChunk
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
if
(
mmioSeek
(
This
->
hmmio
,
This
->
ckData
.
cksize
,
SEEK_CUR
)
==
-
1
)
return
AVIERR_FILEWRITE
;
if
(
mmioAscend
(
This
->
hmmio
,
&
ck
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
/* some optional extra chunks? */
if
(
This
->
extra
.
lp
!=
NULL
&&
This
->
extra
.
cb
>
0
)
{
/* chunk headers are already in structure */
if
(
mmioWrite
(
This
->
hmmio
,
This
->
extra
.
lp
,
This
->
extra
.
cb
)
!=
This
->
extra
.
cb
)
return
AVIERR_FILEWRITE
;
}
/* close RIFF chunk */
if
(
mmioAscend
(
This
->
hmmio
,
&
ckRIFF
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
if
(
mmioFlush
(
This
->
hmmio
,
0
)
!=
S_OK
)
return
AVIERR_FILEWRITE
;
return
AVIERR_OK
;
}
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