changeset in /hg/pulseaudio: 2008-09-03 Omair Majid <omajid at redh...
Omair Majid
omajid at redhat.com
Wed Sep 3 12:12:02 PDT 2008
changeset 8ddfb8d274c7 in /hg/pulseaudio
details: http://icedtea.classpath.org/hg/pulseaudio?cmd=changeset;node=8ddfb8d274c7
description:
2008-09-03 Omair Majid <omajid at redhat.com>
* src/java/org/classpath/icedtea/pulseaudio/PulseAudioClip.java
Moved controls to PulseAudioDataLine.
(PulseAudioClip): Removed lineListeners and controls - They are in a
superclass of PulseAudioClip.
(getBufferSize): Moved method to PulseAudioDataLine.
(getControl): Moved method to PulseAudioLine.
(getControls): Likewise.
(getFormat): Moved method to PulseAudioDataLine.
(getLevel): Likewise.
(getLineInfo): Likewise.
(isControlSupported): Moved to PulseAudioLine.
(isOpen): Likewise.
(isRunning): Moved to PulseAudioDataLine.
(removeLineListeners): Moved to PulseAudioLine.
* src/java/org/classpath/icedtea/pulseaudio/PulseAudioClip.java
(open): Now sets isEngagedInIo when playback starts or stops.
(close): Calls super.close and throws an exception if interrupted.
(start): Removed comments.
(stop): Likewise.
(getBufferSize): New function. Moved from derived class to this class.
(getLineInfo): Likewise.
(getFormat): Likewise.
(getLevel): Likewise.
* src/java/org/classpath/icedtea/pulseaudio/PulseAudioLine.java
Added controls.
(close): New function. Moved from derived class to this class.
(getControl): Likewise.
(getControls): Likewise.
(isControlSupported): Likewise.
(open): Likewise.
* src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java
(getSupportedFormats): Removed redundant comments.
(getLine): Removed unused variables.
(addTargetLine): Renamed from addTargetDataLine.
(removeTargetLine): Renamed from removeTargetDataLine.
* src/java/org/classpath/icedtea/pulseaudio/PulseAduioPort.java
Removed controls
(open): Use the controls List from the parent class.
(getControl): Moved to superclass.
(getControls): Likewise.
(isControlSupported): Likewise.
* src/java/org/classpath/icedtea/pulseaudio/PulseAudioSourceDataLine.java
Removed controls array. Uses the one from parent class.
(open): Fixed to use the controls List.
(write): Added an extra check.
(getBufferSize): Moved to parent class.
(getFormat): Likewise.
(getLevel): Likewise.
(getControl): Likewise.
(getControls): Likewise.
(getLineInfo): Likewise.
(isControlSupported): Likewise.
* src/java/org/classpath/icedate/pulseaudio/PulseAudioTargetDataLine.java
(PulseAudioTargetDataLine): Use lineListeners from parent class.
(close): Fixed function name to call in Mixer.
(open): Likewise.
(read): Added an extra check.
(getBufferSize): Moved to parent class.
(getFormat): Likewise.
(getLevel): Likewise.
(getControl): Likewise.
(getControls): Likewise.
(getLIneInfo): Likewise.
(isControlSupported): Likewise.
* src/java/org/classpath/icedtea/pulseaudio/PulseAudioVolumeControl.java
Formatting fixes.
* src/java/org/classpath/icedtea/pulseaudio/Stream.java
(underflowCallback): Removed debug output.
* unittests/org/classpath/icedtea/pulseaudio/PulseAudioClipTest.java
(testOpenEvent): New test. Checks the OPEN event from PulseAudioClip
(testCloseEvent): New test. Check the CLOSE event from PulseAudioClip
(testPlayTwoClips): Removed redundant try/catch block.
(testSupportedControls): New test. Checks that PulseAudioClip supports at
least two controls.
(testMixerKnowsAboutOpenClips): New test. Checks that open clips are added
to the mixer's list of open source lines.
* unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerRawTest.java
Fixed formatting.
* unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerTest.java
(testOpeneingAgain): Fixed test to detect the IllegalStateException
thrown.
* unittests/org/classpath/icedtea/pulseaudio/PulseAudioSourcePortTest.java
(tearDown): New function. Close the mixer at the end of the test.
* unittests/org/classpath/icedtea/pulseaudio/PulseSourceDataLineTest.java
(testMixerKnowsAoubtOpenLines): Modified the test to check that the lines
are actually the same.
diffstat:
16 files changed, 364 insertions(+), 415 deletions(-)
src/java/org/classpath/icedtea/pulseaudio/PulseAudioClip.java | 88 -----
src/java/org/classpath/icedtea/pulseaudio/PulseAudioDataLine.java | 72 ++--
src/java/org/classpath/icedtea/pulseaudio/PulseAudioLine.java | 62 +++
src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java | 61 ---
src/java/org/classpath/icedtea/pulseaudio/PulseAudioPort.java | 53 ---
src/java/org/classpath/icedtea/pulseaudio/PulseAudioSourceDataLine.java | 71 ----
src/java/org/classpath/icedtea/pulseaudio/PulseAudioTargetDataLine.java | 57 ---
src/java/org/classpath/icedtea/pulseaudio/PulseAudioVolumeControl.java | 22 -
src/java/org/classpath/icedtea/pulseaudio/Stream.java | 1
unittests/org/classpath/icedtea/pulseaudio/PulseAudioClipTest.java | 166 ++++++++--
unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerRawTest.java | 18 -
unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerTest.java | 5
unittests/org/classpath/icedtea/pulseaudio/PulseAudioSourcePortTest.java | 38 +-
unittests/org/classpath/icedtea/pulseaudio/PulseAudioTargetDataLineTest.java | 24 +
unittests/org/classpath/icedtea/pulseaudio/PulseAudioTargetPortTest.java | 37 +-
unittests/org/classpath/icedtea/pulseaudio/PulseSourceDataLineTest.java | 4
diffs (truncated from 1446 to 500 lines):
diff -r b191c8f8cb2d -r 8ddfb8d274c7 src/java/org/classpath/icedtea/pulseaudio/PulseAudioClip.java
--- a/src/java/org/classpath/icedtea/pulseaudio/PulseAudioClip.java Wed Sep 03 10:47:27 2008 -0400
+++ b/src/java/org/classpath/icedtea/pulseaudio/PulseAudioClip.java Wed Sep 03 15:11:46 2008 -0400
@@ -38,21 +38,13 @@ package org.classpath.icedtea.pulseaudio
package org.classpath.icedtea.pulseaudio;
import java.io.IOException;
-import java.util.ArrayList;
-import java.util.List;
import java.util.concurrent.Semaphore;
import javax.sound.sampled.AudioFormat;
import javax.sound.sampled.AudioInputStream;
import javax.sound.sampled.AudioSystem;
-import javax.sound.sampled.BooleanControl;
import javax.sound.sampled.Clip;
-import javax.sound.sampled.Control;
-import javax.sound.sampled.DataLine;
-import javax.sound.sampled.FloatControl;
-import javax.sound.sampled.LineListener;
import javax.sound.sampled.LineUnavailableException;
-import javax.sound.sampled.Control.Type;
import org.classpath.icedtea.pulseaudio.Stream.WriteListener;
@@ -72,8 +64,6 @@ public class PulseAudioClip extends Puls
private int framesSinceOpen = 0;
public static final String DEFAULT_CLIP_NAME = "Clip";
-
- private List<Control> controls = null;
private Object clipLock = new Object();
private boolean clipThreadStarted;
@@ -176,12 +166,11 @@ public class PulseAudioClip extends Puls
AudioFormat defaultFormat) {
supportedFormats = formats;
this.eventLoop = eventLoop;
- this.lineListeners = new ArrayList<LineListener>();
this.defaultFormat = defaultFormat;
this.currentFormat = defaultFormat;
+ this.volume = PulseAudioVolumeControl.MAX_VOLUME;
+
clipThread = new ClipThread();
- this.volume = PulseAudioVolumeControl.MAX_VOLUME;
- controls = new ArrayList<Control>();
}
@@ -241,46 +230,6 @@ public class PulseAudioClip extends Puls
}
@Override
- public int getBufferSize() {
- if (!isOpen) {
- return DEFAULT_BUFFER_SIZE;
- }
- return bufferSize;
- }
-
- @Override
- public Control getControl(Type control) {
- if (isOpen) {
- if (control.getClass() == BooleanControl.Type.MUTE.getClass()) {
- return controls.get(1);
- }
-
- if (control.getClass() == FloatControl.Type.VOLUME.getClass()) {
- return controls.get(0);
- }
- }
- throw new IllegalArgumentException(control.toString()
- + " not supported");
- }
-
- @Override
- public Control[] getControls() {
- if (!isOpen) {
- return new Control[] {};
- }
-
- return (Control[]) controls.toArray(new Control[0]);
- }
-
- @Override
- public AudioFormat getFormat() {
- if (!isOpen) {
- return defaultFormat;
- }
- return currentFormat;
- }
-
- @Override
public int getFrameLength() {
return frameCount;
}
@@ -288,18 +237,6 @@ public class PulseAudioClip extends Puls
@Override
public int getFramePosition() {
return (int) framesSinceOpen;
- }
-
- @Override
- public float getLevel() {
- return AudioSystem.NOT_SPECIFIED;
- }
-
- @Override
- public javax.sound.sampled.Line.Info getLineInfo() {
- return new DataLine.Info(this.getClass(), supportedFormats,
- StreamBufferAttributes.MIN_VALUE,
- StreamBufferAttributes.MAX_VALUE);
}
@Override
@@ -324,22 +261,6 @@ public class PulseAudioClip extends Puls
synchronized (clipLock) {
return framesSinceOpen / currentFormat.getFrameSize();
}
- }
-
- @Override
- public boolean isControlSupported(Type control) {
- return false;
- }
-
- @Override
- public boolean isOpen() {
- return isOpen;
- }
-
- @Override
- public boolean isRunning() {
- // really confused about what this is supposed to do
- return isActive();
}
@Override
@@ -429,11 +350,6 @@ public class PulseAudioClip extends Puls
}
@Override
- public void removeLineListener(LineListener listener) {
- lineListeners.remove(listener);
- }
-
- @Override
public void setFramePosition(int frames) {
if (frames > frameCount) {
diff -r b191c8f8cb2d -r 8ddfb8d274c7 src/java/org/classpath/icedtea/pulseaudio/PulseAudioDataLine.java
--- a/src/java/org/classpath/icedtea/pulseaudio/PulseAudioDataLine.java Wed Sep 03 10:47:27 2008 -0400
+++ b/src/java/org/classpath/icedtea/pulseaudio/PulseAudioDataLine.java Wed Sep 03 15:11:46 2008 -0400
@@ -53,9 +53,6 @@ public abstract class PulseAudioDataLine
protected String streamName = "Java Stream";
- // true between open() and close(). ie represents when a line has acquire
- // resources
-
// true between start() and stop()
protected boolean isStarted = false;
@@ -76,9 +73,6 @@ public abstract class PulseAudioDataLine
public void open(AudioFormat format, int bufferSize)
throws LineUnavailableException {
- if (isOpen) {
- throw new IllegalStateException("Line is already open");
- }
for (AudioFormat myFormat : supportedFormats) {
if (format.matches(myFormat)) {
@@ -90,7 +84,7 @@ public abstract class PulseAudioDataLine
}
currentFormat = format;
- isOpen = true;
+ super.open();
}
}
// no matches found
@@ -122,6 +116,7 @@ public abstract class PulseAudioDataLine
Stream.UnderflowListener stoppedListener = new Stream.UnderflowListener() {
@Override
public void update() {
+ isEngagedInIo = false;
fireLineEvent(new LineEvent(PulseAudioDataLine.this,
LineEvent.Type.STOP, AudioSystem.NOT_SPECIFIED));
}
@@ -131,6 +126,7 @@ public abstract class PulseAudioDataLine
Stream.PlaybackStartedListener startedListener = new Stream.PlaybackStartedListener() {
@Override
public void update() {
+ isEngagedInIo = true;
fireLineEvent(new LineEvent(PulseAudioDataLine.this,
LineEvent.Type.START, AudioSystem.NOT_SPECIFIED));
}
@@ -170,51 +166,31 @@ public abstract class PulseAudioDataLine
}
public void close() {
- // FIXME what should be done here
- assert (isOpen);
+
+ super.close();
synchronized (eventLoop.threadLock) {
- // drain();
+ drain();
stream.disconnect();
}
try {
semaphore.acquire();
} catch (InterruptedException e) {
- // throw new LineUnavailableException("unable to prepare
- // stream");
- }
-
- isOpen = false;
+ throw new RuntimeException("unable to prepare stream");
+ }
}
public void start() {
- // if (isPaused) {
- // synchronized (eventLoop.threadLock) {
- // stream.cork(false);
- // }
- // isPaused = false;
- // }
-
isStarted = true;
-
- /*
- * for(LineListener l :listeners) { l.update(new LineEvent(this,
- * LineEvent.Type.START, 0)); }
- */
-
}
public void stop() {
- // synchronized (eventLoop.threadLock) {
- // stream.cork(true);
- // }
- // isPaused = true;
-
isStarted = false;
-
- }
+ }
+
+ // A BIG FIXME !
/*
* http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=4791152 :
@@ -245,4 +221,30 @@ public abstract class PulseAudioDataLine
return stream;
}
+ @Override
+ public int getBufferSize() {
+ if (!isOpen) {
+ return DEFAULT_BUFFER_SIZE;
+ }
+ return bufferSize;
+ }
+
+ public javax.sound.sampled.Line.Info getLineInfo() {
+ return new DataLine.Info(this.getClass(), supportedFormats,
+ StreamBufferAttributes.MIN_VALUE,
+ StreamBufferAttributes.MAX_VALUE);
+ }
+
+ @Override
+ public AudioFormat getFormat() {
+ if (!isOpen) {
+ return defaultFormat;
+ }
+ return currentFormat;
+ }
+
+ public float getLevel() {
+ return AudioSystem.NOT_SPECIFIED;
+ }
+
}
diff -r b191c8f8cb2d -r 8ddfb8d274c7 src/java/org/classpath/icedtea/pulseaudio/PulseAudioLine.java
--- a/src/java/org/classpath/icedtea/pulseaudio/PulseAudioLine.java Wed Sep 03 10:47:27 2008 -0400
+++ b/src/java/org/classpath/icedtea/pulseaudio/PulseAudioLine.java Wed Sep 03 15:11:46 2008 -0400
@@ -40,20 +40,33 @@ import java.util.ArrayList;
import java.util.ArrayList;
import java.util.List;
+import javax.sound.sampled.Control;
+import javax.sound.sampled.Line;
import javax.sound.sampled.LineEvent;
import javax.sound.sampled.LineListener;
+import javax.sound.sampled.LineUnavailableException;
+import javax.sound.sampled.Control.Type;
-abstract class PulseAudioLine {
+abstract class PulseAudioLine implements Line {
protected List<LineListener> lineListeners = new ArrayList<LineListener>();
+ protected List<Control> controls = new ArrayList<Control>();
+
+ // true between open() and close(). ie represents when a line has acquire
+ // resources
protected boolean isOpen = false;
public void addLineListener(LineListener listener) {
this.lineListeners.add(listener);
}
- public void removeLineListener(LineListener listener) {
- this.lineListeners.remove(listener);
+ @Override
+ public void close() {
+ if (!isOpen) {
+ throw new IllegalStateException("Line is not open");
+ }
+
+ isOpen = false;
}
protected void fireLineEvent(LineEvent e) {
@@ -62,8 +75,51 @@ abstract class PulseAudioLine {
}
}
+ @Override
+ public Control getControl(Type control) {
+ if (isOpen) {
+ for (Control aControl : controls) {
+ if (aControl.getType() == control) {
+ return aControl;
+ }
+ }
+ }
+ throw new IllegalArgumentException(control.toString()
+ + " not supported");
+ }
+
+ @Override
+ public Control[] getControls() {
+ if (!isOpen) {
+ return new Control[] {};
+ }
+
+ return (Control[]) controls.toArray(new Control[0]);
+ }
+
+ public boolean isControlSupported(Type control) {
+ for (Control myControl : controls) {
+ if (myControl.getType().getClass() == control.getClass()) {
+ return true;
+ }
+ }
+ return false;
+ }
+
public boolean isOpen() {
return isOpen;
}
+ @Override
+ public void open() throws LineUnavailableException {
+ if (isOpen) {
+ throw new IllegalStateException("Line is already open");
+ }
+ isOpen = true;
+ }
+
+ public void removeLineListener(LineListener listener) {
+ lineListeners.remove(listener);
+ }
+
}
diff -r b191c8f8cb2d -r 8ddfb8d274c7 src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java
--- a/src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java Wed Sep 03 10:47:27 2008 -0400
+++ b/src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java Wed Sep 03 15:11:46 2008 -0400
@@ -119,15 +119,17 @@ public class PulseAudioMixer implements
Map<String, Object> properties;
- int[] channelSizes = new int[] { 1, 2, 5 };
+ /*
+ * frameSize = sample size (in bytes, not bits) x # of channels ^ From
+ * PulseAudio's sources
+ * http://git.0pointer.de/?p=pulseaudio.git;a=blob;f=src/pulse/sample.c;h=93da2465f4301e27af4976e82737c3a048124a68;hb=82ea8dde8abc51165a781c69bc3b38034d62d969#l63
+ */
+
+ int[] channelSizes = new int[] { 1, 2, 5, 6, 8 };
for (int channelSize : channelSizes) {
properties = new HashMap<String, Object>();
properties.put(PULSEAUDIO_FORMAT_KEY, "PA_SAMPLE_U8");
- // frameSize = sample size (in bytes, not bits) x # of channels
- // ^ that's from PulseAudio sources, so it will pretty much break
- // as soon as they change something
- // FIXME ^
int sampleSize = 8; // in bits
AudioFormat PA_SAMPLE_U8 = new AudioFormat(Encoding.PCM_UNSIGNED, // encoding
AudioSystem.NOT_SPECIFIED, // sample rate
@@ -145,11 +147,6 @@ public class PulseAudioMixer implements
properties = new HashMap<String, Object>();
properties.put(PULSEAUDIO_FORMAT_KEY, "PA_SAMPLE_ALAW");
- // frameSize = sample size (in bytes, not bits) x # of channels
- // ^ that's from PulseAudio sources, so it will pretty much break
- // as soon as they change something
- // FIXME ^
-
int sampleSize = 8;
final AudioFormat PA_SAMPLE_ALAW = new AudioFormat(Encoding.ALAW, // encoding
AudioSystem.NOT_SPECIFIED, // sample rate
@@ -167,11 +164,6 @@ public class PulseAudioMixer implements
properties = new HashMap<String, Object>();
properties.put(PULSEAUDIO_FORMAT_KEY, "PA_SAMPLE_ULAW");
- // frameSize = sample size (in bytes, not bits) x # of channels
- // ^ that's from PulseAudio sources, so it will pretty much break
- // as soon as they change something
- // FIXME ^
-
int sampleSize = 8;
final AudioFormat PA_SAMPLE_ULAW = new AudioFormat(Encoding.ULAW, // encoding
AudioSystem.NOT_SPECIFIED, // sample rate
@@ -188,11 +180,6 @@ public class PulseAudioMixer implements
for (int channelSize : channelSizes) {
properties = new HashMap<String, Object>();
properties.put(PULSEAUDIO_FORMAT_KEY, "PA_SAMPLE_S16BE");
-
- // frameSize = sample size (in bytes, not bits) x # of channels
- // ^ that's from PulseAudio sources, so it will pretty much break
- // as soon as they change something
- // FIXME ^
int sampleSize = 16;
final AudioFormat PA_SAMPLE_S16BE = new AudioFormat(
@@ -212,11 +199,6 @@ public class PulseAudioMixer implements
properties = new HashMap<String, Object>();
properties.put(PULSEAUDIO_FORMAT_KEY, "PA_SAMPLE_S16LE");
- // frameSize = sample size (in bytes, not bits) x # of channels
- // ^ that's from PulseAudio sources, so it will pretty much break
- // as soon as they change something
- // FIXME ^
-
int sampleSize = 16;
final AudioFormat A_SAMPLE_S16LE = new AudioFormat(
Encoding.PCM_SIGNED, // encoding
@@ -235,11 +217,6 @@ public class PulseAudioMixer implements
properties = new HashMap<String, Object>();
properties.put(PULSEAUDIO_FORMAT_KEY, "PA_SAMPLE_S32BE");
- // frameSize = sample size (in bytes, not bits) x # of channels
- // ^ that's from PulseAudio sources, so it will pretty much break
- // as soon as they change something
- // FIXME ^
-
int sampleSize = 32;
final AudioFormat PA_SAMPLE_S32BE = new AudioFormat(
Encoding.PCM_SIGNED, // encoding
@@ -258,11 +235,6 @@ public class PulseAudioMixer implements
properties = new HashMap<String, Object>();
properties.put(PULSEAUDIO_FORMAT_KEY, "PA_SAMPLE_S32LE");
- // frameSize = sample size (in bytes, not bits) x # of channels
- // ^ that's from PulseAudio sources, so it will pretty much break
- // as soon as they change something
- // FIXME ^
-
int sampleSize = 32;
final AudioFormat PA_SAMPLE_S32LE = new AudioFormat(
Encoding.PCM_SIGNED, // encoding
@@ -284,7 +256,7 @@ public class PulseAudioMixer implements
public Line getLine(javax.sound.sampled.Line.Info info)
throws LineUnavailableException {
- if (!this.isOpen) {
+ if (!isOpen) {
throw new LineUnavailableException();
}
@@ -331,12 +303,8 @@ public class PulseAudioMixer implements
return new PulseAudioClip(eventLoop, formats, defaultFormat);
}
- String portName;
- boolean isSource;
-
if (Port.Info.class.isInstance(info)) {
Port.Info portInfo = (Port.Info) info;
- portName = portInfo.getName();
if (portInfo.isSource()) {
return new PulseAudioSourcePort(portInfo.getName(), eventLoop);
More information about the distro-pkg-dev
mailing list