diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2013-11-09 21:12:06 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2013-11-09 21:12:06 (GMT) |
commit | a44372fd0b143947b86926d9377f2b4c3a585dca (patch) | |
tree | 16cbd5be020a0c3b243a5611fc42f5fa14b35323 /Lib/wave.py | |
parent | affb9b255bffd032e90dc9e3a73f5053cdd0cd61 (diff) | |
download | cpython-a44372fd0b143947b86926d9377f2b4c3a585dca.zip cpython-a44372fd0b143947b86926d9377f2b4c3a585dca.tar.gz cpython-a44372fd0b143947b86926d9377f2b4c3a585dca.tar.bz2 |
Issue #1575020: Fixed support of 24-bit wave files on big-endian platforms.
Diffstat (limited to 'Lib/wave.py')
-rw-r--r-- | Lib/wave.py | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/Lib/wave.py b/Lib/wave.py index a1daead..6285c74 100644 --- a/Lib/wave.py +++ b/Lib/wave.py @@ -82,15 +82,16 @@ WAVE_FORMAT_PCM = 0x0001 _array_fmts = None, 'b', 'h', None, 'i' -# Determine endian-ness import struct -if struct.pack("h", 1) == b"\000\001": - big_endian = 1 -else: - big_endian = 0 - +import sys from chunk import Chunk +def _byteswap3(data): + ba = bytearray(data) + ba[::3] = data[2::3] + ba[2::3] = data[::3] + return bytes(ba) + class Wave_read: """Variables used in this class: @@ -231,7 +232,7 @@ class Wave_read: self._data_seek_needed = 0 if nframes == 0: return b'' - if self._sampwidth > 1 and big_endian: + if self._sampwidth in (2, 4) and sys.byteorder == 'big': # unfortunately the fromfile() method does not take # something that only looks like a file object, so # we have to reach into the innards of the chunk object @@ -252,6 +253,8 @@ class Wave_read: data = data.tobytes() else: data = self._data_chunk.read(nframes * self._framesize) + if self._sampwidth == 3 and sys.byteorder == 'big': + data = _byteswap3(data) if self._convert and data: data = self._convert(data) self._soundpos = self._soundpos + len(data) // (self._nchannels * self._sampwidth) @@ -419,7 +422,7 @@ class Wave_write: nframes = len(data) // (self._sampwidth * self._nchannels) if self._convert: data = self._convert(data) - if self._sampwidth > 1 and big_endian: + if self._sampwidth in (2, 4) and sys.byteorder == 'big': import array data = array.array(_array_fmts[self._sampwidth], data) assert data.itemsize == self._sampwidth @@ -427,6 +430,8 @@ class Wave_write: data.tofile(self._file) self._datawritten = self._datawritten + len(data) * self._sampwidth else: + if self._sampwidth == 3 and sys.byteorder == 'big': + data = _byteswap3(data) self._file.write(data) self._datawritten = self._datawritten + len(data) self._nframeswritten = self._nframeswritten + nframes |