105 lines
4.2 KiB
Text
105 lines
4.2 KiB
Text
|
Interface to CD-ROM player.
|
||
|
|
||
|
This module implements an interface to the built-in cd module. The
|
||
|
intention is to provide a more user-friendly interface than the
|
||
|
built-in module.
|
||
|
|
||
|
The module defines a class Readcd with several methods. The
|
||
|
initialization of the class will try to open the CD player. This
|
||
|
means that initialization will fail if the CD player is already in
|
||
|
use. A RuntimeError will be raised by the cd module in that case.
|
||
|
|
||
|
The way to work with this module is as follows. The user specifies
|
||
|
the parts of the CD that are to be read and he specifies callback
|
||
|
functions which are to be called by the system. At some point he can
|
||
|
tell the system to play. The specified parts of the CD will then be
|
||
|
read and the callbacks will be called.
|
||
|
|
||
|
Initialization.
|
||
|
===============
|
||
|
|
||
|
r = readcd.Readcd([cd-player [, mode]])
|
||
|
|
||
|
The optional arguments are the name of the CD device and the mode.
|
||
|
When "mode" is not specified, it defaults to 'r' (which is the only
|
||
|
possible value); when "cd-player" also isn't specified, it defaults
|
||
|
to "None" which indicates the default CD player.
|
||
|
|
||
|
Methods.
|
||
|
========
|
||
|
|
||
|
eject() -- Eject the CD from the player.
|
||
|
|
||
|
reset() -- Reset the list of data stretches to be played.
|
||
|
|
||
|
appendtrack(track) -- Append the specified track to the list of music
|
||
|
stretches.
|
||
|
|
||
|
appendstretch(first, last) -- Append the stretch from "first" to "last"
|
||
|
to the list of music stretches. Both "first" and "last" can be in one
|
||
|
of four forms. "None": for "first", the beginning of the CD, for
|
||
|
"last" the end of the CD; a single integer: a track number--playing
|
||
|
starts at the beginning of the track or ends at the end of the
|
||
|
specified track; a three-tuple: the absolute time from the start of
|
||
|
the CD in minutes, seconds, frames; a four-tuple: track number and
|
||
|
relative time within the track in minutes, seconds, frames.
|
||
|
|
||
|
settracks(tracklist) -- The argument is a list of integers. The list
|
||
|
of stretches is set to argument list. The old list is discarded.
|
||
|
|
||
|
setcallback(type, func, arg) -- Set a callback function for "type".
|
||
|
The function will be called as func(arg, type, data) where "arg" is
|
||
|
the third argument of setcallback, "type" is the type of callback,
|
||
|
"data" is type-dependent data. See the CDsetcallback(3) manual page
|
||
|
for more information. The possible "type" arguments are defined in
|
||
|
the CD module.
|
||
|
|
||
|
removecallback(type) -- Remove the callback for "type".
|
||
|
|
||
|
gettrackinfo([tracklist]) -- Return a list of tuples. Each tuple
|
||
|
consists of start and length information of a track. The start and
|
||
|
length information consist of three-tuples with minutes, seconds and
|
||
|
frames. The optional tracklist argument gives a list of interesting
|
||
|
track numbers. If no tracklist is specified, information about all
|
||
|
tracks is returned.
|
||
|
|
||
|
getstatus() -- Return the status information of the CD.
|
||
|
|
||
|
play() -- Play the preprogrammed stretches of music from the CD. When
|
||
|
nothing was programmed, the whole CD is played.
|
||
|
|
||
|
Specifying stretches.
|
||
|
=====================
|
||
|
|
||
|
There are three methods available to specify a stretch of music to be
|
||
|
played. The easiest way is to use "settracklist(tracklist)" with which
|
||
|
a list of tracks can be specified. "settracklist(tracklist)" is
|
||
|
equivalent to the sequence
|
||
|
reset()
|
||
|
for track in tracklist:
|
||
|
appendtrack(track)
|
||
|
|
||
|
The next method is "appendtrack(track)" with which a whole track can be
|
||
|
added to the list of music to be played. "appendtrack(track)" is
|
||
|
equivalent to "appendstretch(track, track)".
|
||
|
|
||
|
The most complete method is "appendstretch(first, last)". Using this
|
||
|
method, it is possible to specify any stretch of music.
|
||
|
|
||
|
When two consecutive tracks are played, it is possible to choose
|
||
|
whether the pause that may be between the tracks is played as well or
|
||
|
whether the pause should be skipped. When the end of a stretch is
|
||
|
specified using a track number and the next stretch starts at the
|
||
|
beginning of the following track and that was also specified using the
|
||
|
track number (that is, both were specified as integers, not as tuples),
|
||
|
the pause is played. When either value was specified using absolute
|
||
|
time or track-relative time (that is, as three-tuple or as
|
||
|
four-tuple), the pause will not be played.
|
||
|
|
||
|
Errors.
|
||
|
=======
|
||
|
|
||
|
When an error occurs, an exception will be raised. Depending on where
|
||
|
the error occurs, the exception may either be "readcd.Error" or
|
||
|
"RuntimeError".
|