On Jan 11 01:10:11, a...@caoua.org wrote: > On Tue, Jan 10, 2023 at 08:22:27PM +0000, John Rigg wrote: > > > > > > # If I recall correctly, I converted to FLAC here because the WAV > > > > headers > > > > # generated by aucat and SoX differed, and so SoX would refuse to play > > > > WAV fil > > > es > > > > # created by aucat. > > > > > > That would be a bug in itself. > > > How exactly does SoX refuse to play the WAVs created by aucat? > > > > sox is strict about headers and will complain if cbSize is inconsistent with > > fmt size. Workaround is to use the '-t sndfile' option. > > > > aucat is not alone here; several other programs write .wav files that > > require this option with sox. > > > > Here's a diff to switch aucat to extended wav format. According to > Microsoft docs, it is needed if bits > 16 or if there are more than 2 > channels, which aucat supports. It fixes the sox problem.
Thank you. One nit that's perhaps related: $ aucat -n in.wav -o out.wav produces a stereo 24bit out.wav, as -c 0:1 -e s24 is the default. Would it make more sense with -n to preserve the characteristics of in.wav instead? Jan > No regressions found with various ports and few windows programs. > > ok? > > Index: afile.c > =================================================================== > RCS file: /cvs/src/usr.bin/aucat/afile.c,v > retrieving revision 1.9 > diff -u -p -u -p -r1.9 afile.c > --- afile.c 24 Oct 2021 21:24:15 -0000 1.9 > +++ afile.c 10 Jan 2023 23:52:47 -0000 > @@ -432,12 +432,17 @@ afile_wav_writehdr(struct afile *f) > le32_set(&hdr.riff.size, f->endpos - sizeof(hdr.riff)); > memcpy(hdr.fmt_hdr.id, wav_id_fmt, 4); > le32_set(&hdr.fmt_hdr.size, sizeof(hdr.fmt)); > - le16_set(&hdr.fmt.fmt, 1); > + le16_set(&hdr.fmt.fmt, WAV_FMT_EXT); > le16_set(&hdr.fmt.nch, f->nch); > le32_set(&hdr.fmt.rate, f->rate); > le32_set(&hdr.fmt.byterate, f->rate * f->par.bps * f->nch); > le16_set(&hdr.fmt.blkalign, f->par.bps * f->nch); > le16_set(&hdr.fmt.bits, f->par.bits); > + le16_set(&hdr.fmt.extsize, > + WAV_FMT_EXT_SIZE - WAV_FMT_SIZE - sizeof(hdr.fmt.extsize)); > + le16_set(&hdr.fmt.valbits, f->par.bits); > + le16_set(&hdr.fmt.extfmt, 1); > + memcpy(&hdr.fmt.guid, wav_guid, sizeof(hdr.fmt.guid)); > memcpy(hdr.data_hdr.id, wav_id_data, 4); > le32_set(&hdr.data_hdr.size, f->endpos - f->startpos); > return afile_writehdr(f, &hdr, sizeof(struct wav_hdr)); > >