mirror of https://github.com/python/cpython.git
Initial revision
This commit is contained in:
parent
b1ccc6afe0
commit
73b715e259
|
@ -0,0 +1,46 @@
|
|||
Introduction.
|
||||
|
||||
A number of programs have been written which access the Silicon
|
||||
Graphics CD-ROM player. These programs all use the interface defined
|
||||
in readcd.py (see readcd.doc for documentation).
|
||||
|
||||
Specifying music stretches.
|
||||
|
||||
The programs that are capable of reading music CD's all use the same
|
||||
syntax to describe which part of the CD is to be read. The syntax
|
||||
closely corresponds to the available methods in readcd.py.
|
||||
|
||||
The music to be read is divided into stretches of music. Each stretch
|
||||
must be specified as a separate argument on the command line. A
|
||||
stretch can be a whole CD track, specified as a single number; or it
|
||||
can be a start time and a end time. The start and end times must be
|
||||
specified as a tuple, thus: ``(starttime, endtime)''. Don't forget to
|
||||
quote the parenthesis to the shell. Both starttime and endtime can be
|
||||
``None'', a simple number which refers to a CD track, or a tuple
|
||||
consisting of either 3 or 4 elements. A starttime of ``None'' refers
|
||||
to the start of the CD, an endtime of ``None'' refers to the end of
|
||||
the CD. A tuple of 3 elements is an absolute time on the CD. The
|
||||
three elements are (minutes, seconds, frames). A tuple of 4 elements
|
||||
is a track-relative time. The four elements are (track, minutes,
|
||||
seconds, frames).
|
||||
|
||||
When one stretch ends at the end of a track and the following stretch
|
||||
starts at the next track, there is the option of either playing or not
|
||||
playing the pause between the two tracks. When either the end time of
|
||||
the first stretch or the start time of the second stretch is specified
|
||||
using absolute or track-relative times, the pause will not be played.
|
||||
When both times are specified as simple track numbers, the pause will
|
||||
be played.
|
||||
|
||||
If no stretches are specified, the whole CD will be played.
|
||||
|
||||
The programs.
|
||||
|
||||
Currently, the following programs exist.
|
||||
playcd [ stretch specification ]
|
||||
Play (part of) a CD through the system loadspeaker or
|
||||
headphone set.
|
||||
cdaiff [ file [ stretch specification ] ]
|
||||
Copy (part of) a CD to a file. The file will be written in
|
||||
AIFF format. If no file is specified, cdaiff will write to
|
||||
the file ``@'' in the current directory.
|
|
@ -0,0 +1,83 @@
|
|||
# This file implements a class which forms an interface to the .cdplayerrc
|
||||
# file that is maintained by SGI's cdplayer program.
|
||||
#
|
||||
# Usage is as follows:
|
||||
#
|
||||
# import readcd
|
||||
# r = readcd.Readcd().init()
|
||||
# c = Cdplayer().init(r.gettrackinfo())
|
||||
#
|
||||
# Now you can use c.artist, c.title and c.track[trackno] (where trackno
|
||||
# starts at 1). When the CD is not recognized, all values will be the empty
|
||||
# string.
|
||||
# It is also possible to set the above mentioned variables to new values.
|
||||
# You can then use c.write() to write out the changed values to the
|
||||
# .cdplayerrc file.
|
||||
|
||||
cdplayerrc = '.cdplayerrc'
|
||||
|
||||
class Cdplayer():
|
||||
def init(self, tracklist):
|
||||
import string
|
||||
self.artist = ''
|
||||
self.title = ''
|
||||
self.track = [None] + [''] * len(tracklist)
|
||||
self.id = 'd' + string.zfill(len(tracklist), 2)
|
||||
for track in tracklist:
|
||||
start, length = track
|
||||
self.id = self.id + string.zfill(length[0], 2) + \
|
||||
string.zfill(length[1], 2)
|
||||
try:
|
||||
import posix
|
||||
f = open(posix.environ['HOME'] + '/' + cdplayerrc, 'r')
|
||||
except IOError:
|
||||
return self
|
||||
import regex
|
||||
reg = regex.compile('^\\([^:]*\\):\t\\(.*\\)')
|
||||
s = self.id + '.'
|
||||
l = len(s)
|
||||
while 1:
|
||||
line = f.readline()
|
||||
if line == '':
|
||||
break
|
||||
if line[:l] == s:
|
||||
line = line[l:]
|
||||
if reg.match(line) == -1:
|
||||
print 'syntax error in ~/' + cdplayerrc
|
||||
continue
|
||||
name = line[reg.regs[1][0]:reg.regs[1][1]]
|
||||
value = line[reg.regs[2][0]:reg.regs[2][1]]
|
||||
if name == 'title':
|
||||
self.title = value
|
||||
elif name == 'artist':
|
||||
self.artist = value
|
||||
elif name[:5] == 'track':
|
||||
trackno = string.atoi(name[6:])
|
||||
self.track[trackno] = value
|
||||
f.close()
|
||||
return self
|
||||
|
||||
def write(self):
|
||||
import posix
|
||||
filename = posix.environ['HOME'] + '/' + cdplayerrc
|
||||
try:
|
||||
old = open(filename, 'r')
|
||||
except IOError:
|
||||
old = open('/dev/null', 'r')
|
||||
new = open(filename + '.new', 'w')
|
||||
s = self.id + '.'
|
||||
l = len(s)
|
||||
while 1:
|
||||
line = old.readline()
|
||||
if line == '':
|
||||
break
|
||||
if line[:l] <> s:
|
||||
new.write(line)
|
||||
new.write(self.id + '.title:\t' + self.title + '\n')
|
||||
new.write(self.id + '.artist:\t' + self.artist + '\n')
|
||||
for i in range(1, len(self.track)):
|
||||
new.write(self.id + '.track.' + `i` + ':\t' + \
|
||||
self.track[i] + '\n')
|
||||
old.close()
|
||||
new.close()
|
||||
posix.rename(filename + '.new', filename)
|
|
@ -0,0 +1,83 @@
|
|||
# This file implements a class which forms an interface to the .cdplayerrc
|
||||
# file that is maintained by SGI's cdplayer program.
|
||||
#
|
||||
# Usage is as follows:
|
||||
#
|
||||
# import readcd
|
||||
# r = readcd.Readcd().init()
|
||||
# c = Cdplayer().init(r.gettrackinfo())
|
||||
#
|
||||
# Now you can use c.artist, c.title and c.track[trackno] (where trackno
|
||||
# starts at 1). When the CD is not recognized, all values will be the empty
|
||||
# string.
|
||||
# It is also possible to set the above mentioned variables to new values.
|
||||
# You can then use c.write() to write out the changed values to the
|
||||
# .cdplayerrc file.
|
||||
|
||||
cdplayerrc = '.cdplayerrc'
|
||||
|
||||
class Cdplayer():
|
||||
def init(self, tracklist):
|
||||
import string
|
||||
self.artist = ''
|
||||
self.title = ''
|
||||
self.track = [None] + [''] * len(tracklist)
|
||||
self.id = 'd' + string.zfill(len(tracklist), 2)
|
||||
for track in tracklist:
|
||||
start, length = track
|
||||
self.id = self.id + string.zfill(length[0], 2) + \
|
||||
string.zfill(length[1], 2)
|
||||
try:
|
||||
import posix
|
||||
f = open(posix.environ['HOME'] + '/' + cdplayerrc, 'r')
|
||||
except IOError:
|
||||
return self
|
||||
import regex
|
||||
reg = regex.compile('^\\([^:]*\\):\t\\(.*\\)')
|
||||
s = self.id + '.'
|
||||
l = len(s)
|
||||
while 1:
|
||||
line = f.readline()
|
||||
if line == '':
|
||||
break
|
||||
if line[:l] == s:
|
||||
line = line[l:]
|
||||
if reg.match(line) == -1:
|
||||
print 'syntax error in ~/' + cdplayerrc
|
||||
continue
|
||||
name = line[reg.regs[1][0]:reg.regs[1][1]]
|
||||
value = line[reg.regs[2][0]:reg.regs[2][1]]
|
||||
if name == 'title':
|
||||
self.title = value
|
||||
elif name == 'artist':
|
||||
self.artist = value
|
||||
elif name[:5] == 'track':
|
||||
trackno = string.atoi(name[6:])
|
||||
self.track[trackno] = value
|
||||
f.close()
|
||||
return self
|
||||
|
||||
def write(self):
|
||||
import posix
|
||||
filename = posix.environ['HOME'] + '/' + cdplayerrc
|
||||
try:
|
||||
old = open(filename, 'r')
|
||||
except IOError:
|
||||
old = open('/dev/null', 'r')
|
||||
new = open(filename + '.new', 'w')
|
||||
s = self.id + '.'
|
||||
l = len(s)
|
||||
while 1:
|
||||
line = old.readline()
|
||||
if line == '':
|
||||
break
|
||||
if line[:l] <> s:
|
||||
new.write(line)
|
||||
new.write(self.id + '.title:\t' + self.title + '\n')
|
||||
new.write(self.id + '.artist:\t' + self.artist + '\n')
|
||||
for i in range(1, len(self.track)):
|
||||
new.write(self.id + '.track.' + `i` + ':\t' + \
|
||||
self.track[i] + '\n')
|
||||
old.close()
|
||||
new.close()
|
||||
posix.rename(filename + '.new', filename)
|
|
@ -0,0 +1,25 @@
|
|||
# Symbolic constants for use with sunaudiodev module
|
||||
# The names are the same as in audioio.h with the leading AUDIO_
|
||||
# removed.
|
||||
|
||||
# Encoding types, for fields i_encoding and o_encoding
|
||||
|
||||
ENCODING_ULAW = 1
|
||||
ENCODING_ALAW = 2
|
||||
|
||||
# Gain ranges for i_gain, o_gain and monitor_gain
|
||||
|
||||
MIN_GAIN = 0
|
||||
MAX_GAIN = 255
|
||||
|
||||
# Port names for i_port and o_port
|
||||
|
||||
PORT_A = 1
|
||||
PORT_B = 2
|
||||
PORT_C = 3
|
||||
PORT_D = 4
|
||||
|
||||
SPEAKER = PORT_A
|
||||
HEADPHONE = PORT_B
|
||||
|
||||
MICROPHONE = PORT_A
|
|
@ -0,0 +1,25 @@
|
|||
# Symbolic constants for use with sunaudiodev module
|
||||
# The names are the same as in audioio.h with the leading AUDIO_
|
||||
# removed.
|
||||
|
||||
# Encoding types, for fields i_encoding and o_encoding
|
||||
|
||||
ENCODING_ULAW = 1
|
||||
ENCODING_ALAW = 2
|
||||
|
||||
# Gain ranges for i_gain, o_gain and monitor_gain
|
||||
|
||||
MIN_GAIN = 0
|
||||
MAX_GAIN = 255
|
||||
|
||||
# Port names for i_port and o_port
|
||||
|
||||
PORT_A = 1
|
||||
PORT_B = 2
|
||||
PORT_C = 3
|
||||
PORT_D = 4
|
||||
|
||||
SPEAKER = PORT_A
|
||||
HEADPHONE = PORT_B
|
||||
|
||||
MICROPHONE = PORT_A
|
Loading…
Reference in New Issue