changeset in /hg/pulseaudio: 2009-09-12 Omair Majid <omajid at redh...
Omair Majid
omajid at redhat.com
Fri Sep 12 13:40:23 PDT 2008
changeset 7ba42a599d59 in /hg/pulseaudio
details: http://icedtea.classpath.org/hg/pulseaudio?cmd=changeset;node=7ba42a599d59
description:
2009-09-12 Omair Majid <omajid at redhat.com>
* src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java
Changed sourceLineInfos and targetLineInfos to List<Line.Info> from
Line.Info[].
(PulseAudioMixer): Fixed to work with the change in sourceLineInfos and
targetLineInfos.
(getSourceLineInfo): Likewise.
(getSourceLineInfo): Likewise.
(getTargetLineInfo): Likewise.
(isLineSupported): Likewise.
(open): Moved the initialization of Port infomration to the actual
implementation in openRemote.
(openRemote): Added the Port initialization info. Now it doesnt overwrite
any Clip info.
* unittests/org/classpath/icedtea/pulseaudio/OtherSourndProvidersAvailableTest.java
(testOtherSoundProviders): Made the test more verbose and not fail if
using the default Mixer.
* unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerProviderTest.java
Made the test more verbose and print out more information. Also tries to
open a source line.
* unittests/org/classpath/icedtea/pulseaudio/PulseAUdioMixerTest.java
(testSourceLinesExist): Now tests if at least one SourceDataLine, Clip and
Port are available.
diffstat:
4 files changed, 151 insertions(+), 109 deletions(-)
src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java | 75 +++------
unittests/org/classpath/icedtea/pulseaudio/OtherSoundProvidersAvailableTest.java | 81 +++++----
unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerProviderTest.java | 83 ++++++----
unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerTest.java | 21 ++
diffs (435 lines):
diff -r 9eb090e7c22c -r 7ba42a599d59 src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java
--- a/src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java Fri Sep 12 09:43:49 2008 -0400
+++ b/src/java/org/classpath/icedtea/pulseaudio/PulseAudioMixer.java Fri Sep 12 11:19:27 2008 -0400
@@ -70,9 +70,8 @@ public class PulseAudioMixer implements
public EventLoop eventLoop;
public Thread eventLoopThread;
- private Line.Info[] sourceLineInfos;
- private Line.Info[] targetLineInfos;
- private Line.Info[] clipInfos;
+ private List<Line.Info> sourceLineInfos = new ArrayList<Line.Info>();
+ private List<Line.Info> targetLineInfos = new ArrayList<Line.Info>();
private static PulseAudioMixer _instance = null;
@@ -88,21 +87,17 @@ public class PulseAudioMixer implements
private PulseAudioMixer() {
AudioFormat[] formats = getSupportedFormats();
- List<Line.Info> sourceLineInfoList = new ArrayList<Line.Info>();
- sourceLineInfoList.add(new DataLine.Info(SourceDataLine.class, formats,
+
+ sourceLineInfos.add(new DataLine.Info(SourceDataLine.class, formats,
StreamBufferAttributes.MIN_VALUE,
StreamBufferAttributes.MAX_VALUE));
- sourceLineInfos = new Line.Info[] { new DataLine.Info(
- SourceDataLine.class, formats,
+ sourceLineInfos.add(new DataLine.Info(Clip.class, formats,
StreamBufferAttributes.MIN_VALUE,
- StreamBufferAttributes.MAX_VALUE) };
- targetLineInfos = new Line.Info[] { new DataLine.Info(
- TargetDataLine.class, formats,
+ StreamBufferAttributes.MAX_VALUE));
+
+ targetLineInfos.add(new DataLine.Info(TargetDataLine.class, formats,
StreamBufferAttributes.MIN_VALUE,
- StreamBufferAttributes.MAX_VALUE) };
- clipInfos = new Line.Info[] { new DataLine.Info(Clip.class, formats,
- StreamBufferAttributes.MIN_VALUE,
- StreamBufferAttributes.MAX_VALUE) };
+ StreamBufferAttributes.MAX_VALUE));
}
@@ -327,16 +322,13 @@ public class PulseAudioMixer implements
}
public javax.sound.sampled.Line.Info[] getSourceLineInfo() {
- Line.Info[] localArray = new Line.Info[sourceLineInfos.length];
- System.arraycopy(sourceLineInfos, 0, localArray, 0,
- sourceLineInfos.length);
- return localArray;
+ return sourceLineInfos.toArray(new Line.Info[0]);
}
@Override
public javax.sound.sampled.Line.Info[] getSourceLineInfo(
javax.sound.sampled.Line.Info info) {
- ArrayList<javax.sound.sampled.Line.Info> infos = new ArrayList<javax.sound.sampled.Line.Info>();
+ ArrayList<Line.Info> infos = new ArrayList<Line.Info>();
for (Line.Info supportedInfo : sourceLineInfos) {
if (info.matches(supportedInfo)) {
@@ -354,10 +346,7 @@ public class PulseAudioMixer implements
@Override
public javax.sound.sampled.Line.Info[] getTargetLineInfo() {
- Line.Info[] localArray = new Line.Info[targetLineInfos.length];
- System.arraycopy(targetLineInfos, 0, localArray, 0,
- targetLineInfos.length);
- return localArray;
+ return targetLineInfos.toArray(new Line.Info[0]);
}
@Override
@@ -381,23 +370,18 @@ public class PulseAudioMixer implements
@Override
public boolean isLineSupported(javax.sound.sampled.Line.Info info) {
if (info != null) {
- for (int i = 0; i < sourceLineInfos.length; i++) {
- if (info.matches(sourceLineInfos[i])) {
+ for (Line.Info myInfo : sourceLineInfos) {
+ if (info.matches(myInfo)) {
return true;
}
}
- for (int i = 0; i < targetLineInfos.length; i++) {
- if (info.matches(targetLineInfos[i])) {
+ for (Line.Info myInfo : targetLineInfos) {
+ if (info.matches(myInfo)) {
return true;
}
}
- for (Line.Info clipInfo : clipInfos) {
- if (info.matches(clipInfo)) {
- return true;
- }
- }
}
return false;
@@ -493,22 +477,6 @@ public class PulseAudioMixer implements
@Override
public void open() throws LineUnavailableException {
openLocal();
- // the sourceLineInfo and targetLineInfo arrays need to be updated with
- // port infos, which can only be obtained after EventLoop had started
-
- ArrayList<Line.Info> sourceLineInfoList = new ArrayList<Line.Info>();
- sourceLineInfoList.add(sourceLineInfos[0]);
- for (String portName : eventLoop.updateSourcePortNameList()) {
- sourceLineInfoList.add(new Port.Info(Port.class, portName, true));
- }
- sourceLineInfos = sourceLineInfoList.toArray(new Line.Info[0]);
-
- ArrayList<Line.Info> targetLineInfoList = new ArrayList<Line.Info>();
- targetLineInfoList.add(targetLineInfos[0]);
- for (String portName : eventLoop.updateTargetPortNameList()) {
- targetLineInfoList.add(new Port.Info(Port.class, portName, false));
- }
- targetLineInfos = targetLineInfoList.toArray(new Line.Info[0]);
}
@@ -621,6 +589,17 @@ public class PulseAudioMixer implements
this.isOpen = true;
+ // sourceLineInfo and targetLineInfo need to be updated with
+ // port infos, which can only be obtained after EventLoop had started
+
+ for (String portName : eventLoop.updateSourcePortNameList()) {
+ sourceLineInfos.add(new Port.Info(Port.class, portName, true));
+ }
+
+ for (String portName : eventLoop.updateTargetPortNameList()) {
+ targetLineInfos.add(new Port.Info(Port.class, portName, false));
+ }
+
}
@Override
diff -r 9eb090e7c22c -r 7ba42a599d59 unittests/org/classpath/icedtea/pulseaudio/OtherSoundProvidersAvailableTest.java
--- a/unittests/org/classpath/icedtea/pulseaudio/OtherSoundProvidersAvailableTest.java Fri Sep 12 09:43:49 2008 -0400
+++ b/unittests/org/classpath/icedtea/pulseaudio/OtherSoundProvidersAvailableTest.java Fri Sep 12 11:19:27 2008 -0400
@@ -33,8 +33,7 @@ this exception to your version of the li
this exception to your version of the library, but you are not
obligated to do so. If you do not wish to do so, delete this
exception statement from your version.
-*/
-
+ */
package org.classpath.icedtea.pulseaudio;
@@ -48,58 +47,72 @@ import junit.framework.JUnit4TestAdapter
import org.junit.Test;
+public class OtherSoundProvidersAvailableTest {
-public class OtherSoundProvidersAvailableTest {
-
- public static junit.framework.Test suite() {
- return new JUnit4TestAdapter(OtherSoundProvidersAvailableTest.class);
+ public static junit.framework.Test suite() {
+ return new JUnit4TestAdapter(OtherSoundProvidersAvailableTest.class);
}
-
+
@Test
public void testOtherSoundProviders() {
+ System.out.println("This tests if alsa mixers are still available");
- Mixer.Info mixerInfos [] = AudioSystem.getMixerInfo();
+ Mixer.Info mixerInfos[] = AudioSystem.getMixerInfo();
Mixer.Info selectedMixerInfo = null;
Mixer selectedMixer;
-
+
+ boolean selected = false;
int i = 0;
- for ( Mixer.Info info: mixerInfos) {
- System.out.println("Mixer Line " + i++ + ": " + info.getName() + " " + info.getDescription());
- if ( info.getName().contains("0,4")) {
- selectedMixerInfo = info;
+ System.out.println("Available Mixers:");
+ // use 0,0 or the default
+ for (Mixer.Info info : mixerInfos) {
+ System.out.println("Mixer Line " + i++ + ": " + info.getName()
+ + " " + info.getDescription());
+ if (info.getName().contains("0,0") && !selected) {
+ System.out.println("^ selecting as the mixer to use");
+ selectedMixerInfo = info;
+ selected = true;
}
}
- System.out.println(selectedMixerInfo.toString());
- System.out.println("getting information from selected mixer:");
-
- // use 0,4 or the default
+
+ if (selectedMixerInfo != null) {
+ System.out.println(selectedMixerInfo.toString());
+ }
+
+ System.out.print("Selected mixer is of class: ");
+
selectedMixer = AudioSystem.getMixer(selectedMixerInfo);
- System.out.println(selectedMixer.toString());
+ System.out.println(selectedMixer.getClass().toString());
try {
Line.Info sourceDataLineInfo = null;
-
- selectedMixer.open(); // initialize the mixer
-
+
+ selectedMixer.open(); // initialize the mixer
+
Line.Info allLineInfo[] = selectedMixer.getSourceLineInfo();
+ System.out.println("Source lines supported by mixer: ");
int j = 0;
- for ( Line.Info lineInfo : allLineInfo) {
- System.out.println("Source Line " + j++ + ": " + lineInfo.getLineClass());
- if ( lineInfo.getLineClass().toString().contains("SourceDataLine")) {
+ for (Line.Info lineInfo : allLineInfo) {
+ System.out.println("Source Line " + j++ + ": "
+ + lineInfo.getLineClass());
+ if (lineInfo.toString().contains("SourceDataLine")) {
sourceDataLineInfo = lineInfo;
}
+
}
-
- SourceDataLine sourceDataLine = (SourceDataLine) selectedMixer.getLine(sourceDataLineInfo);
- sourceDataLine.open();
- //sourceDataLine.write('a', 0, 2);
- sourceDataLine.close();
-
- } catch ( LineUnavailableException e ) {
+ if (sourceDataLineInfo == null) {
+ System.out.println("Mixer supports no SourceDataLines");
+ } else {
+ SourceDataLine sourceDataLine = (SourceDataLine) selectedMixer
+ .getLine(sourceDataLineInfo);
+
+ sourceDataLine.open();
+ // sourceDataLine.write('a', 0, 2);
+ sourceDataLine.close();
+ }
+ } catch (LineUnavailableException e) {
System.out.println("Line unavailable");
}
-
-
-
+
}
}
diff -r 9eb090e7c22c -r 7ba42a599d59 unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerProviderTest.java
--- a/unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerProviderTest.java Fri Sep 12 09:43:49 2008 -0400
+++ b/unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerProviderTest.java Fri Sep 12 11:19:27 2008 -0400
@@ -33,61 +33,92 @@ this exception to your version of the li
this exception to your version of the library, but you are not
obligated to do so. If you do not wish to do so, delete this
exception statement from your version.
-*/
+ */
package org.classpath.icedtea.pulseaudio;
-import static org.junit.Assert.*;
+import static org.junit.Assert.assertNotNull;
+import javax.sound.sampled.AudioFormat;
import javax.sound.sampled.AudioSystem;
+import javax.sound.sampled.Line;
import javax.sound.sampled.LineUnavailableException;
import javax.sound.sampled.Mixer;
+import javax.sound.sampled.SourceDataLine;
import junit.framework.JUnit4TestAdapter;
-import org.junit.After;
-import org.junit.Before;
import org.junit.Test;
public class PulseAudioMixerProviderTest {
- private Mixer selectedMixer;
- private Mixer.Info selectedMixerInfo;
+ public static junit.framework.Test suite() {
+ return new JUnit4TestAdapter(PulseAudioMixerProviderTest.class);
+ }
+
+ AudioFormat aSupportedFormat = new AudioFormat(
+ AudioFormat.Encoding.PCM_UNSIGNED, 44100f, 8, 1, 1, 44100f, true);
- public static junit.framework.Test suite() {
- return new JUnit4TestAdapter(PulseAudioMixerProviderTest.class);
- }
+ @Test
+ public void testMixerProvider() throws LineUnavailableException {
- @Before
- public void setUp() throws Exception {
+ System.out
+ .println("This test checks that the PulseAudio mixer exists and is usable");
- Mixer.Info mixerInfos [] = AudioSystem.getMixerInfo();
+ Mixer selectedMixer = null;
+ Mixer.Info selectedMixerInfo = null;
+
+ Mixer.Info mixerInfos[] = AudioSystem.getMixerInfo();
int i = 0;
- for ( Mixer.Info info: mixerInfos) {
- System.out.println("Mixer Line " + i++ + ": " + info.getName() + " " + info.getDescription());
- if ( info.getName().contains("PulseAudio")) {
- selectedMixerInfo = info;
+ for (Mixer.Info info : mixerInfos) {
+ System.out.println("Mixer Line " + i++ + ": " + info.getName()
+ + " " + info.getDescription());
+ if (info.getName().contains("PulseAudio")) {
+ System.out.println(" ^ found PulseAudio Mixer!");
+ selectedMixerInfo = info;
}
}
+
assertNotNull(selectedMixerInfo);
- }
- @Test
- public void testMixerProvider() throws LineUnavailableException {
- System.out.println(selectedMixerInfo.toString());
- System.out.println("getting information from selected mixer:");
+ System.out.println("Getting information from selected mixer:");
+ System.out.println("Name: "+ selectedMixerInfo.getName());
+ System.out.println("Version: " + selectedMixerInfo.getVersion());
+
selectedMixer = AudioSystem.getMixer(selectedMixerInfo);
assertNotNull(selectedMixer);
- System.out.println(selectedMixer.toString());
- }
+ System.out.println("Implemented in class: " + selectedMixer.getClass().toString());
+ selectedMixer.open(); // initialize the mixer
- @After
- public void tearDown() throws Exception {
+ Line.Info sourceDataLineInfo = null;
+ Line.Info allLineInfo[] = selectedMixer.getSourceLineInfo();
+ System.out.println("Source lines supported by mixer: ");
+ int j = 0;
+ for (Line.Info lineInfo : allLineInfo) {
+ System.out.println("Source Line " + j++ + ": "
+ + lineInfo.getLineClass());
+ if (lineInfo.toString().contains("SourceDataLine")) {
+ sourceDataLineInfo = lineInfo;
+ }
+
+ }
+
+ if (sourceDataLineInfo == null) {
+ System.out.println("Mixer supports no SourceDataLines");
+ } else {
+ SourceDataLine sourceDataLine = (SourceDataLine) selectedMixer
+ .getLine(sourceDataLineInfo);
+
+ sourceDataLine.open(aSupportedFormat);
+ // sourceDataLine.write('a', 0, 2);
+ sourceDataLine.close();
+ }
+
+ selectedMixer.close();
}
-
}
diff -r 9eb090e7c22c -r 7ba42a599d59 unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerTest.java
--- a/unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerTest.java Fri Sep 12 09:43:49 2008 -0400
+++ b/unittests/org/classpath/icedtea/pulseaudio/PulseAudioMixerTest.java Fri Sep 12 11:19:27 2008 -0400
@@ -64,7 +64,7 @@ public class PulseAudioMixerTest {
PulseAudioMixer selectedMixer;
AudioFormat aSupportedFormat = new AudioFormat(
- AudioFormat.Encoding.PCM_UNSIGNED, 44100f, 8, 1, 1, 10, true);
+ AudioFormat.Encoding.PCM_UNSIGNED, 44100f, 8, 1, 1, 44100f, true);
public static junit.framework.Test suite() {
return new JUnit4TestAdapter(PulseAudioMixerTest.class);
@@ -147,19 +147,38 @@ public class PulseAudioMixerTest {
@Test
public void testSourceLinesExist() throws LineUnavailableException {
+ System.out.println("This tests that source lines exist");
selectedMixer.open();
Line.Info allLineInfo[] = selectedMixer.getSourceLineInfo();
Assert.assertNotNull(allLineInfo);
Assert.assertTrue(allLineInfo.length > 0);
+
+ boolean foundSourceDataLine = false;
+ boolean foundClip = false;
+ boolean foundPort = false;
+
int j = 0;
for (Line.Info lineInfo : allLineInfo) {
System.out.println("Source Line " + j++ + ": "
+ lineInfo.getLineClass());
+ if (lineInfo.getLineClass().toString().contains("SourceDataLine")) {
+ foundSourceDataLine = true;
+ } else if (lineInfo.getLineClass().toString().contains("Clip")) {
+ foundClip = true;
+ } else if (lineInfo.getLineClass().toString().contains("Port")) {
+ foundPort = true;
+ } else {
+ Assert.assertFalse("Found a new type of Line", true);
+ }
Line sourceLine = (Line) selectedMixer.getLine(lineInfo);
assertNotNull(sourceLine);
}
+ Assert.assertTrue("Couldnt find a SourceDataLine", foundSourceDataLine);
+ Assert.assertTrue("Couldnt find a Clip", foundClip);
+ Assert.assertTrue("Couldnt find a Port", foundPort);
+
}
@Test
More information about the distro-pkg-dev
mailing list