Lines Matching defs:wav
87 Description: a rudimentary wav file interface
102 * \wav->fp filepointer of type FILE*.
109 HANDLE_WAV wav = (HANDLE_WAV)FDKcalloc(1, sizeof(struct WAV));
112 if (wav == NULL) {
113 FDKprintfErr("WAV_InputOpen(): Unable to allocate WAV struct.\n");
117 wav->fp = FDKfopen(filename, "rb");
118 if (wav->fp == NULL) {
119 FDKprintfErr("WAV_InputOpen(): Unable to open wav file. %s\n", filename);
124 if (FDKfread(&(wav->header.riffType), 1, 4, wav->fp) != 4) {
128 if (FDKstrncmp("RIFF", wav->header.riffType, 4)) {
134 FDKfread_EL(&(wav->header.riffSize), 4, 1, wav->fp);
137 if (FDKfread(&wav->header.waveType, 1, 4, wav->fp) !=4) {
141 if (FDKstrncmp("WAVE", wav->header.waveType, 4)) {
147 if (FDKfread(&(wav->header.formatType), 1, 4, wav->fp) != 4) {
151 if (FDKstrncmp("fmt", wav->header.formatType, 3)) {
157 FDKfread_EL(&wav->header.formatSize, 4, 1, wav->fp); /* should be 16 for PCM-format (uncompressed) */
161 FDKfread_EL(&(wav->header.compressionCode), 2, 1, wav->fp);
162 FDKfread_EL(&(wav->header.numChannels), 2, 1, wav->fp);
163 FDKfread_EL(&(wav->header.sampleRate), 4, 1, wav->fp);
164 FDKfread_EL(&(wav->header.bytesPerSecond), 4, 1, wav->fp);
165 FDKfread_EL(&(wav->header.blockAlign), 2, 1, wav->fp);
166 FDKfread_EL(&(wav->header.bitsPerSample), 2, 1, wav->fp);
168 offset = wav->header.formatSize - 16;
171 if (wav->header.compressionCode == 0xFFFE) {
181 FDKfread_EL(&(extraFormatBytes), 2, 1, wav->fp);
185 FDKfread_EL(&(validBitsPerSample), 2, 1, wav->fp);
186 FDKfread_EL(&(wav->channelMask), 4, 1, wav->fp);
187 FDKfread_EL(&(guid), 16, 1, wav->fp);
191 if (i == 16) wav->header.compressionCode = 0x01;
199 FDKfread(&wav->header.formatSize, 1, 1, wav->fp);
204 if (FDKfread(wav->header.dataType, 1, 4, wav->fp) != 4) {
206 FDKfree(wav);
211 FDKfread_EL(&offset, 4, 1, wav->fp);
214 if (FDKstrncmp("data", wav->header.dataType, 4) == 0) {
215 wav->header.dataSize = offset;
220 FDKfread(&(wav->header.dataSize), 1, 1, wav->fp);
222 } while (!FDKfeof(wav->fp));
225 *pWav = wav;
231 if (wav) {
232 if (wav->fp) {
233 FDKfclose(wav->fp);
234 wav->fp = NULL;
236 FDKfree(wav);
250 * \wav HANDLE_WAV of the wav file.
259 INT WAV_InputRead (HANDLE_WAV wav, void *buffer, UINT numSamples, int nBits)
267 switch (wav->header.compressionCode)
270 if (nBits == wav->header.bitsPerSample) {
271 result = FDKfread_EL(buffer, wav->header.bitsPerSample >> 3, numSamples, wav->fp) ;
277 result += FDKfread_EL(&tmp, wav->header.bitsPerSample >> 3, 1, wav->fp) ;
280 if ( !IS_LITTLE_ENDIAN() && wav->header.bitsPerSample != 24 && wav->header.bitsPerSample < 32) {
281 tmp >>= (32-wav->header.bitsPerSample);
285 if (wav->header.bitsPerSample > nBits)
286 tmp >>= (wav->header.bitsPerSample-nBits);
288 tmp <<= (nBits-wav->header.bitsPerSample);
302 result += FDKfread(&(bptr[i<<1]), 1, 1, wav->fp) ;
316 HANDLE_WAV wav = *pWav;
318 if (wav != NULL) {
319 if (wav->fp != NULL) {
320 FDKfclose(wav->fp);
321 wav->fp = NULL;
323 if (wav) {
324 FDKfree(wav);
376 * \brief Open WAV output/writer handle
377 * \param pWav pointer to WAV handle to be returned
378 * \param sampleRate desired samplerate of the resulting WAV file
379 * \param numChannels desired number of audio channels of the resulting WAV file
380 * \param bitsPerSample desired number of bits per audio sample of the resulting WAV file
387 HANDLE_WAV wav = (HANDLE_WAV)FDKcalloc(1, sizeof(struct WAV));
390 if (wav == NULL) {
391 FDKprintfErr("WAV_OutputOpen(): Unable to allocate WAV struct.\n");
401 wav->fp = FDKfopen(outputFilename, "wb");
402 if (wav->fp == NULL)
408 FDKstrcpy(wav->header.riffType, "RIFF");
409 wav->header.riffSize = LittleEndian32(0x7fffffff); /* in case fseek() doesn't work later in WAV_OutputClose() */
410 FDKstrcpy(wav->header.waveType, "WAVE");
412 FDKstrcpy(wav->header.formatType, "fmt ");
413 wav->header.formatSize = LittleEndian32(16);
415 wav->header.compressionCode = LittleEndian16(0x01);
416 wav->header.bitsPerSample = LittleEndian16((SHORT)bitsPerSample);
417 wav->header.numChannels = LittleEndian16((SHORT)numChannels);
418 wav->header.blockAlign = LittleEndian16((SHORT)(numChannels * (bitsPerSample >> 3)));
419 wav->header.sampleRate = LittleEndian32(sampleRate);
420 wav->header.bytesPerSecond = LittleEndian32(sampleRate * wav->header.blockAlign);
421 FDKstrcpy(wav->header.dataType, "data");
422 wav->header.dataSize = LittleEndian32(0x7fffffff - 36);
426 if (FDKfwrite(&wav->header, 1, size, wav->fp) != size)
433 wav->header.dataSize = wav->header.riffSize = 0;
435 *pWav = wav;
440 if (wav) {
441 if (wav->fp) {
442 FDKfclose(wav->fp);
444 FDKfree(wav);
455 * \brief Write data to WAV file asociated to WAV handle
457 * \param wav handle of wave file
465 INT WAV_OutputWrite(HANDLE_WAV wav, void *sampleBuffer, UINT numberOfSamples, int nBufBits, int nSigBits)
472 int bps = Unpack(wav->header.bitsPerSample);
477 if (FDKfwrite_EL(sampleBuffer, (bps>>3), numberOfSamples, wav->fp) != numberOfSamples)
479 FDKprintfErr("WAV_OutputWrite(): error: unable to write to file %d\n", wav->fp);
508 result=FDKfwrite_EL(&tmp, bps>>3, 1, wav->fp);
510 FDKprintfErr("WAV_OutputWrite(): error: unable to write to file %d\n", wav->fp);
516 wav->header.dataSize += (numberOfSamples * (bps>>3));
523 * \brief Close WAV Output handle
524 * \param pWav pointer to WAV handle. *pWav is set to NULL.
528 HANDLE_WAV wav = *pWav;
531 if ( wav == NULL ) {
535 wav->header.dataSize = LittleEndian32(wav->header.dataSize);
536 wav->header.riffSize = LittleEndian32(wav->header.dataSize + 36);
538 if (wav->fp != NULL)
540 if (FDKfseek(wav->fp, 0, FDKSEEK_SET)) {
545 if (FDKfwrite(&wav->header.riffType, 1, size, wav->fp) != size)
550 if (FDKfclose(wav->fp))
552 FDKprintfErr("WAV_OutputClose(): unable to close wav file\n");
554 wav->fp = NULL;
557 FDKfree(wav);