Issue #6644: Fix compile error on AIX.
[python.git] / Doc / library / sunau.rst
blob3f231b4952811060929e6eab0ab8f807710d6f96
2 :mod:`sunau` --- Read and write Sun AU files
3 ============================================
5 .. module:: sunau
6    :synopsis: Provide an interface to the Sun AU sound format.
7 .. sectionauthor:: Moshe Zadka <moshez@zadka.site.co.il>
10 The :mod:`sunau` module provides a convenient interface to the Sun AU sound
11 format.  Note that this module is interface-compatible with the modules
12 :mod:`aifc` and :mod:`wave`.
14 An audio file consists of a header followed by the data.  The fields of the
15 header are:
17 +---------------+-----------------------------------------------+
18 | Field         | Contents                                      |
19 +===============+===============================================+
20 | magic word    | The four bytes ``.snd``.                      |
21 +---------------+-----------------------------------------------+
22 | header size   | Size of the header, including info, in bytes. |
23 +---------------+-----------------------------------------------+
24 | data size     | Physical size of the data, in bytes.          |
25 +---------------+-----------------------------------------------+
26 | encoding      | Indicates how the audio samples are encoded.  |
27 +---------------+-----------------------------------------------+
28 | sample rate   | The sampling rate.                            |
29 +---------------+-----------------------------------------------+
30 | # of channels | The number of channels in the samples.        |
31 +---------------+-----------------------------------------------+
32 | info          | ASCII string giving a description of the      |
33 |               | audio file (padded with null bytes).          |
34 +---------------+-----------------------------------------------+
36 Apart from the info field, all header fields are 4 bytes in size. They are all
37 32-bit unsigned integers encoded in big-endian byte order.
39 The :mod:`sunau` module defines the following functions:
42 .. function:: open(file, mode)
44    If *file* is a string, open the file by that name, otherwise treat it as a
45    seekable file-like object. *mode* can be any of
47    ``'r'``
48       Read only mode.
50    ``'w'``
51       Write only mode.
53    Note that it does not allow read/write files.
55    A *mode* of ``'r'`` returns a :class:`AU_read` object, while a *mode* of ``'w'``
56    or ``'wb'`` returns a :class:`AU_write` object.
59 .. function:: openfp(file, mode)
61    A synonym for :func:`.open`, maintained for backwards compatibility.
64 The :mod:`sunau` module defines the following exception:
66 .. exception:: Error
68    An error raised when something is impossible because of Sun AU specs or
69    implementation deficiency.
72 The :mod:`sunau` module defines the following data items:
74 .. data:: AUDIO_FILE_MAGIC
76    An integer every valid Sun AU file begins with, stored in big-endian form.  This
77    is the string ``.snd`` interpreted as an integer.
80 .. data:: AUDIO_FILE_ENCODING_MULAW_8
81           AUDIO_FILE_ENCODING_LINEAR_8
82           AUDIO_FILE_ENCODING_LINEAR_16
83           AUDIO_FILE_ENCODING_LINEAR_24
84           AUDIO_FILE_ENCODING_LINEAR_32
85           AUDIO_FILE_ENCODING_ALAW_8
87    Values of the encoding field from the AU header which are supported by this
88    module.
91 .. data:: AUDIO_FILE_ENCODING_FLOAT
92           AUDIO_FILE_ENCODING_DOUBLE
93           AUDIO_FILE_ENCODING_ADPCM_G721
94           AUDIO_FILE_ENCODING_ADPCM_G722
95           AUDIO_FILE_ENCODING_ADPCM_G723_3
96           AUDIO_FILE_ENCODING_ADPCM_G723_5
98    Additional known values of the encoding field from the AU header, but which are
99    not supported by this module.
102 .. _au-read-objects:
104 AU_read Objects
105 ---------------
107 AU_read objects, as returned by :func:`.open` above, have the following methods:
110 .. method:: AU_read.close()
112    Close the stream, and make the instance unusable. (This is  called automatically
113    on deletion.)
116 .. method:: AU_read.getnchannels()
118    Returns number of audio channels (1 for mone, 2 for stereo).
121 .. method:: AU_read.getsampwidth()
123    Returns sample width in bytes.
126 .. method:: AU_read.getframerate()
128    Returns sampling frequency.
131 .. method:: AU_read.getnframes()
133    Returns number of audio frames.
136 .. method:: AU_read.getcomptype()
138    Returns compression type. Supported compression types are ``'ULAW'``, ``'ALAW'``
139    and ``'NONE'``.
142 .. method:: AU_read.getcompname()
144    Human-readable version of :meth:`getcomptype`.  The supported types have the
145    respective names ``'CCITT G.711 u-law'``, ``'CCITT G.711 A-law'`` and ``'not
146    compressed'``.
149 .. method:: AU_read.getparams()
151    Returns a tuple ``(nchannels, sampwidth, framerate, nframes, comptype,
152    compname)``, equivalent to output of the :meth:`get\*` methods.
155 .. method:: AU_read.readframes(n)
157    Reads and returns at most *n* frames of audio, as a string of bytes.  The data
158    will be returned in linear format.  If the original data is in u-LAW format, it
159    will be converted.
162 .. method:: AU_read.rewind()
164    Rewind the file pointer to the beginning of the audio stream.
166 The following two methods define a term "position" which is compatible between
167 them, and is otherwise implementation dependent.
170 .. method:: AU_read.setpos(pos)
172    Set the file pointer to the specified position.  Only values returned from
173    :meth:`tell` should be used for *pos*.
176 .. method:: AU_read.tell()
178    Return current file pointer position.  Note that the returned value has nothing
179    to do with the actual position in the file.
181 The following two functions are defined for compatibility with the  :mod:`aifc`,
182 and don't do anything interesting.
185 .. method:: AU_read.getmarkers()
187    Returns ``None``.
190 .. method:: AU_read.getmark(id)
192    Raise an error.
195 .. _au-write-objects:
197 AU_write Objects
198 ----------------
200 AU_write objects, as returned by :func:`.open` above, have the following methods:
203 .. method:: AU_write.setnchannels(n)
205    Set the number of channels.
208 .. method:: AU_write.setsampwidth(n)
210    Set the sample width (in bytes.)
213 .. method:: AU_write.setframerate(n)
215    Set the frame rate.
218 .. method:: AU_write.setnframes(n)
220    Set the number of frames. This can be later changed, when and if more  frames
221    are written.
224 .. method:: AU_write.setcomptype(type, name)
226    Set the compression type and description. Only ``'NONE'`` and ``'ULAW'`` are
227    supported on output.
230 .. method:: AU_write.setparams(tuple)
232    The *tuple* should be ``(nchannels, sampwidth, framerate, nframes, comptype,
233    compname)``, with values valid for the :meth:`set\*` methods.  Set all
234    parameters.
237 .. method:: AU_write.tell()
239    Return current position in the file, with the same disclaimer for the
240    :meth:`AU_read.tell` and :meth:`AU_read.setpos` methods.
243 .. method:: AU_write.writeframesraw(data)
245    Write audio frames, without correcting *nframes*.
248 .. method:: AU_write.writeframes(data)
250    Write audio frames and make sure *nframes* is correct.
253 .. method:: AU_write.close()
255    Make sure *nframes* is correct, and close the file.
257    This method is called upon deletion.
259 Note that it is invalid to set any parameters after calling  :meth:`writeframes`
260 or :meth:`writeframesraw`.