summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2013-10-12 15:21:33 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2013-10-12 15:21:33 (GMT)
commit4b5325963bd249479cb6b1abe8ffaa75ac5bb80a (patch)
tree4081d15191b58831bc1f568b9e422bade235673f
parent8aa7b89983ba0e3092a151fd5abbfd301937d07a (diff)
downloadcpython-4b5325963bd249479cb6b1abe8ffaa75ac5bb80a.zip
cpython-4b5325963bd249479cb6b1abe8ffaa75ac5bb80a.tar.gz
cpython-4b5325963bd249479cb6b1abe8ffaa75ac5bb80a.tar.bz2
Issue #19131: The aifc module now correctly reads and writes sampwidth of
compressed streams.
-rw-r--r--Lib/aifc.py9
-rw-r--r--Misc/NEWS3
2 files changed, 8 insertions, 4 deletions
diff --git a/Lib/aifc.py b/Lib/aifc.py
index 3270047..86a5edc 100644
--- a/Lib/aifc.py
+++ b/Lib/aifc.py
@@ -457,15 +457,13 @@ class Aifc_read:
if self._comptype != b'NONE':
if self._comptype == b'G722':
self._convert = self._adpcm2lin
- self._framesize = self._framesize // 4
elif self._comptype in (b'ulaw', b'ULAW'):
self._convert = self._ulaw2lin
- self._framesize = self._framesize // 2
elif self._comptype in (b'alaw', b'ALAW'):
self._convert = self._alaw2lin
- self._framesize = self._framesize // 2
else:
raise Error('unsupported compression type')
+ self._sampwidth = 2
else:
self._comptype = b'NONE'
self._compname = b'not compressed'
@@ -787,7 +785,10 @@ class Aifc_write:
_write_short(self._file, self._nchannels)
self._nframes_pos = self._file.tell()
_write_ulong(self._file, self._nframes)
- _write_short(self._file, self._sampwidth * 8)
+ if self._comptype in (b'ULAW', b'ulaw', b'ALAW', b'alaw', b'G722'):
+ _write_short(self._file, 8)
+ else:
+ _write_short(self._file, self._sampwidth * 8)
_write_float(self._file, self._framerate)
if self._aifc:
self._file.write(self._comptype)
diff --git a/Misc/NEWS b/Misc/NEWS
index 56fd0a5..08ebbbd 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -76,6 +76,9 @@ Core and Builtins
Library
-------
+- Issue #19131: The aifc module now correctly reads and writes sampwidth of
+ compressed streams.
+
- Issue #19158: a rare race in BoundedSemaphore could allow .release() too
often.