All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.sciss.synth.Bus.scala Maven / Gradle / Ivy

The newest version!
/*
 *  Bus.scala
 *  (ScalaCollider)
 *
 *  Copyright (c) 2008-2013 Hanns Holger Rutz. All rights reserved.
 *
 *  This software is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU General Public License
 *  as published by the Free Software Foundation; either
 *  version 2, june 1991 of the License, or (at your option) any later version.
 *
 *  This software is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 *  General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public
 *  License (gpl.txt) along with this software; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 *
 *  For further information, please contact Hanns Holger Rutz at
 *  [email protected]
 */

package de.sciss.synth

object Bus {
	def control( server: Server = Server.default, numChannels: Int = 1 ) = {
		val id = server.allocControlBus( numChannels )
		if( id == -1 ) {
         throw AllocatorExhaustedException( "Bus.control: failed to get a bus allocated (" +
            numChannels + " channels on " + server.name + ")" )
		}
		ControlBus( server, id, numChannels )
	}
  
	def audio( server: Server = Server.default, numChannels: Int = 1 ) = {
		val id = server.allocAudioBus( numChannels )
		if( id == -1 ) {
         throw AllocatorExhaustedException( "Bus.audio: failed to get a bus allocated (" +
            numChannels + " channels on " + server.name + ")" )
		}
		AudioBus( server, id, numChannels )
	}
}

sealed trait Bus {
   def rate: Rate
   def index: Int
   def numChannels: Int
   def server: Server
   def free(): Unit
}

final case class ControlBus( server: Server, index: Int, numChannels: Int )
extends Bus {
	private var released = false

   def rate : Rate = control

	def free() {
	   if( released ) sys.error( this.toString + " : has already been freed" )
		server.freeControlBus( index )
	   released = true
	}

   def setMsg( v: Float ) = {
      require( numChannels == 1 )
      osc.ControlBusSetMessage( (index, v) )
   }

   def setMsg( pairs: (Int, Float)* ) = {
      require( pairs.forall( tup => (tup._1 >= 0 && tup._1 < numChannels) ))
      osc.ControlBusSetMessage( pairs.map( tup => (tup._1 + index, tup._2) ): _* )
   }

   def setnMsg( v: IndexedSeq[ Float ]) = {
      require( v.size == numChannels )
      osc.ControlBusSetnMessage( (index, v.toIndexedSeq) )
   }

   def setnMsg( pairs: (Int, IndexedSeq[ Float ])* ) = {
      require( pairs.forall( tup => (tup._1 >= 0 && (tup._1 + tup._2.size) <= numChannels) ))
      val ipairs = pairs.map( tup => (tup._1 + index, tup._2.toIndexedSeq ))
      osc.ControlBusSetnMessage( ipairs: _* )
   }

   def getMsg = {
      require( numChannels == 1 )
      osc.ControlBusGetMessage( index )
   }

   def getMsg( offset: Int = 0 ) = {
      require( offset >= 0 && offset < numChannels )
      osc.ControlBusGetMessage( offset + index )
   }

   def getMsg( offsets: Int* ) = {
      require( offsets.forall( o => (o >= 0 && o < numChannels) ))
      osc.ControlBusGetMessage( offsets.map( _ + index ): _* )
   }
}

final case class AudioBus( server: Server, index: Int, numChannels: Int )
extends Bus {
   private var released = false

   def rate : Rate = audio

   def free() {
      if( released ) sys.error( this.toString + " : has already been freed" )
      server.freeAudioBus( index )
      released = true
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy