Esempio n. 1
0
def test_errors():
    a = linuxaudiodev.open("w")
    size = 8
    fmt = linuxaudiodev.AFMT_U8
    rate = 8000
    nchannels = 1
    try:
        a.setparameters(-1, size, nchannels, fmt)
    except ValueError, msg:
        print msg
def test_errors():
    a = linuxaudiodev.open("w")
    size = 8
    fmt = linuxaudiodev.AFMT_U8
    rate = 8000
    nchannels = 1
    try:
        a.setparameters(-1, size, nchannels, fmt)
    except ValueError, msg:
        print msg
Esempio n. 3
0
    def __initport(self):
        fmt = self.__format
        self.__port = linuxaudiodev.open('w')
        if not fmt or not self.__framerate:
            return

        bps = (fmt.getbps() + 7) & ~7
        try:
            self.__port.setparameters(self.__framerate, bps,
                                      fmt.getnchannels(), self.__formats[fmt])
        except linuxaudiodev.error:
            if fmt.getencoding() != 'linear' or \
               self.__framerate != 8000:
                raise Error, 'unsupported format'
Esempio n. 4
0
def play_sound_file(path):
    fp = open(path, 'r')
    size, enc, rate, nchannels, extra = sunaudio.gethdr(fp)
    data = fp.read()
    fp.close()

    if enc != SND_FORMAT_MULAW_8:
        print "Expect .au file with 8-bit mu-law samples"
        return

    try:
        a = linuxaudiodev.open('w')
    except linuxaudiodev.error, msg:
        if msg[0] in (errno.EACCES, errno.ENODEV):
            raise TestSkipped, msg
        raise TestFailed, msg
def play_sound_file(path):
    fp = open(path, 'r')
    size, enc, rate, nchannels, extra = sunaudio.gethdr(fp)
    data = fp.read()
    fp.close()

    if enc != SND_FORMAT_MULAW_8:
        print "Expect .au file with 8-bit mu-law samples"
        return

    try:
        a = linuxaudiodev.open('w')
    except linuxaudiodev.error, msg:
        if msg[0] in (errno.EACCES, errno.ENODEV, errno.EBUSY):
            raise TestSkipped, msg
        raise TestFailed, msg
Esempio n. 6
0
    def __init__(self, freq=44100, fmt='S16_NE'):
        self.f = None
        self.freq = int(freq)
        self.format = fmt.upper()
        self.params = p = {}
        for name, p['bits'], p['signed'], p['byteorder'] in self.Formats:
            if name == self.format:
                break
        else:
            print >> sys.stderr, 'available sound formats:'
            for name, bits, signed, byteorder in self.Formats:
                print >> sys.stderr, '  %-8s  %s' % (name, nicefmttext(
                    bits, signed, byteorder))
            sys.exit(2)

        import linuxaudiodev
        try:
            f = linuxaudiodev.open('w')
            f.setparameters(self.freq, p['bits'], 1,
                            getattr(linuxaudiodev, 'AFMT_' + self.format))
        except Exception, e:
            print >> sys.stderr, "sound disabled: %s: %s" % (
                e.__class__.__name__, e)
            return
Esempio n. 7
0
 def __init__(self):
     import linuxaudiodev
     self.lad = linuxaudiodev
     self.dev = linuxaudiodev.open('w')
     self.dev.setparameters(44100, 16, 2, linuxaudiodev.AFMT_S16_NE)
Esempio n. 8
0
class AudioDevLINUX:
    # default supported formats and frame rates
    __formats = {  #linear_8_mono_signed: linuxaudiodev.AFMT_S8,
        linear_8_mono_excess: linuxaudiodev.AFMT_U8,
        #ulaw_mono: linuxaudiodev.AFMT_MU_LAW,
        #linear_16_mono_big_signed: linuxaudiodev.AFMT_S16_BE,
        #linear_16_mono_big_excess: linuxaudiodev.AFMT_U16_BE,
        linear_16_mono_little_signed: linuxaudiodev.AFMT_S16_LE,
        #linear_16_mono_little_excess: linuxaudiodev.AFMT_U16_LE,
    }
    __rates = (8000, 11025, 16000, 22050, 32000, 44100, 48000)

    try:
        __port = linuxaudiodev.open('w')
    except linuxaudiodev.error:
        # can't open device, so keep the default
        pass
    else:
        # try if hardware supports CD quality
        try:
            __port.setparameters(44100, 16, 2, linuxaudiodev.AFMT_S16_LE)
        except linuxaudiodev.error:
            # CD quality not supported, use phone quality
            __formats = {
                linear_8_mono_signed:
                AudioDevLINUX.__formats[linear_8_mono_signed]
            }
            __rates = (8000, )
        # cleanup
        __port.close()
        del __port

    def __init__(self, fmt=None, qsize=None):
        self.__format = None
        self.__port = None
        self.__framerate = 0
        if fmt:
            self.setformat(fmt)

    def __del__(self):
        self.stop()

    def getformats(self):
        return self.__formats.keys()

    def getframerates(self):
        return self.__rates

    def setformat(self, fmt):
        if not self.__formats.has_key(fmt):
            raise Error, 'bad format'
        self.__format = fmt

    def getformat(self):
        return self.__format

    def setframerate(self, rate):
        if rate not in self.__rates:
            raise Error, 'bad output rate'
        self.__framerate = rate

    def getframerate(self):
        return self.__framerate

    def writeframes(self, data):
        if not self.__format or not self.__framerate:
            raise Error, 'params not specified'
        if not self.__port:
            self.__initport()
        self.__port.write(data)

    def wait(self):
        if not self.__port:
            return
        self.__port.flush()
        self.stop()

    def stop(self):
        port = self.__port
        if port:
            port.flush()
            port.close()
            self.__port = None

    def getfilled(self):
        if self.__port:
            return self.__port.obufcount()
        else:
            return 0

    def getfillable(self):
        inited = 0
        if not self.__port:
            self.__initport()
            inited = 1
        rv = self.__port.obuffree()
        if inited:
            self.__port.close()
            self.__port = None
        return rv

    def __initport(self):
        fmt = self.__format
        self.__port = linuxaudiodev.open('w')
        if not fmt or not self.__framerate:
            return

        bps = (fmt.getbps() + 7) & ~7
        try:
            self.__port.setparameters(self.__framerate, bps,
                                      fmt.getnchannels(), self.__formats[fmt])
        except linuxaudiodev.error:
            if fmt.getencoding() != 'linear' or \
               self.__framerate != 8000:
                raise Error, 'unsupported format'
Esempio n. 9
0
 def open_audio(self):
     import linuxaudiodev
     self.dev = linuxaudiodev.open('w')
     self.dev.setparameters(44100, 16, 2, linuxaudiodev.AFMT_S16_NE)
Esempio n. 10
0
from test_support import verbose, findfile, TestFailed, TestSkipped
Esempio n. 11
0
File: ogg123.py Progetto: imc/pymt
 def __init__(self):
     import linuxaudiodev
     self.lad = linuxaudiodev
     self.dev = linuxaudiodev.open('w')
     self.dev.setparameters(44100, 16, 2, linuxaudiodev.AFMT_S16_NE)
Esempio n. 12
0
from test_support import verbose, findfile, TestFailed, TestSkipped