aboutsummaryrefslogtreecommitdiffstats
path: root/src/com/jsyn/ports/PortBlockPart.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/jsyn/ports/PortBlockPart.java')
-rw-r--r--src/com/jsyn/ports/PortBlockPart.java205
1 files changed, 0 insertions, 205 deletions
diff --git a/src/com/jsyn/ports/PortBlockPart.java b/src/com/jsyn/ports/PortBlockPart.java
deleted file mode 100644
index ad75211..0000000
--- a/src/com/jsyn/ports/PortBlockPart.java
+++ /dev/null
@@ -1,205 +0,0 @@
-/*
- * Copyright 2009 Phil Burk, Mobileer Inc
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.jsyn.ports;
-
-import java.util.ArrayList;
-
-import com.jsyn.Synthesizer;
-import com.jsyn.engine.SynthesisEngine;
-import com.softsynth.shared.time.ScheduledCommand;
-import com.softsynth.shared.time.TimeStamp;
-
-/**
- * Part of a multi-part port, for example, the left side of a stereo port.
- *
- * @author Phil Burk (C) 2009 Mobileer Inc
- */
-public class PortBlockPart implements ConnectableOutput, ConnectableInput {
- private double[] values = new double[Synthesizer.FRAMES_PER_BLOCK];
- private ArrayList<PortBlockPart> connections = new ArrayList<PortBlockPart>();
- private UnitBlockPort unitBlockPort;
-
- protected PortBlockPart(UnitBlockPort unitBlockPort, double defaultValue) {
- this.unitBlockPort = unitBlockPort;
- setValue(defaultValue);
- }
-
- public double[] getValues() {
- return values;
- }
-
- public double getValue() {
- return values[0];
- }
-
- public double get() {
- return values[0];
- }
-
- protected void setValue(double value) {
- for (int i = 0; i < values.length; i++) {
- values[i] = value;
- }
- }
-
- protected boolean isConnected() {
- return (connections.size() > 0);
- }
-
- private void addConnection(PortBlockPart otherPart) {
- // System.out.println("addConnection from " + this + " to " + otherPart
- // );
- if (connections.contains(otherPart)) {
- System.out.println("addConnection already had connection from " + this + " to "
- + otherPart);
- } else {
- connections.add(otherPart);
- }
- }
-
- private void removeConnection(PortBlockPart otherPart) {
- // System.out.println("removeConnection from " + this + " to " +
- // otherPart );
- connections.remove(otherPart);
- }
-
- private void connectNow(PortBlockPart otherPart) {
- addConnection(otherPart);
- otherPart.addConnection(this);
- }
-
- private void disconnectNow(PortBlockPart otherPart) {
- removeConnection(otherPart);
- otherPart.removeConnection(this);
- }
-
- private void disconnectAllNow() {
- for (PortBlockPart part : connections) {
- part.removeConnection(this);
- }
- connections.clear();
- }
-
- public PortBlockPart getConnection(int i) {
- return connections.get(i);
- }
-
- public int getConnectionCount() {
- return connections.size();
- }
-
- /** Set all values to the last value. */
- protected void flatten() {
- double lastValue = values[values.length - 1];
- for (int i = 0; i < values.length - 1; i++) {
- values[i] = lastValue;
- }
- }
-
- protected UnitBlockPort getPort() {
- return unitBlockPort;
- }
-
- private void checkConnection(PortBlockPart destination) {
- SynthesisEngine sourceSynth = unitBlockPort.getSynthesisEngine();
- SynthesisEngine destSynth = destination.unitBlockPort.getSynthesisEngine();
- if ((sourceSynth != destSynth) && (sourceSynth != null) && (destSynth != null)) {
- throw new RuntimeException("Connection between units on different synths.");
- }
- }
-
- protected void connect(final PortBlockPart destination) {
- checkConnection(destination);
- unitBlockPort.queueCommand(new ScheduledCommand() {
- @Override
- public void run() {
- connectNow(destination);
- }
- });
- }
-
- protected void connect(final PortBlockPart destination, TimeStamp timeStamp) {
- unitBlockPort.scheduleCommand(timeStamp, new ScheduledCommand() {
- @Override
- public void run() {
- connectNow(destination);
- }
- });
- }
-
- protected void disconnect(final PortBlockPart destination) {
- unitBlockPort.queueCommand(new ScheduledCommand() {
- @Override
- public void run() {
- disconnectNow(destination);
- }
- });
- }
-
- protected void disconnect(final PortBlockPart destination, TimeStamp timeStamp) {
- unitBlockPort.scheduleCommand(timeStamp, new ScheduledCommand() {
- @Override
- public void run() {
- disconnectNow(destination);
- }
- });
- }
-
- protected void disconnectAll() {
- unitBlockPort.queueCommand(new ScheduledCommand() {
- @Override
- public void run() {
- disconnectAllNow();
- }
- });
- }
-
- @Override
- public void connect(ConnectableInput other) {
- connect(other.getPortBlockPart());
- }
-
- @Override
- public void connect(ConnectableOutput other) {
- other.connect(this);
- }
-
- @Override
- public void disconnect(ConnectableOutput other) {
- other.disconnect(this);
- }
-
- @Override
- public void disconnect(ConnectableInput other) {
- disconnect(other.getPortBlockPart());
- }
-
- /** To implement ConnectableInput */
- @Override
- public PortBlockPart getPortBlockPart() {
- return this;
- }
-
- @Override
- public void pullData(long frameCount, int start, int limit) {
- for (int i = 0; i < getConnectionCount(); i++) {
- PortBlockPart part = getConnection(i);
- part.getPort().getUnitGenerator().pullData(frameCount, start, limit);
- }
- }
-
-}