/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code 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
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/**
* DirectAudioDevice provider.
*
* @author Florian Bomers
*/
// STATIC VARIABLES
/**
* Set of info objects for all port input devices on the system.
*/
/**
* Set of all port input devices on the system.
*/
// STATIC
static {
// initialize
}
// CONSTRUCTOR
/**
* Required public no-arg constructor.
*/
public DirectAudioDeviceProvider() {
synchronized (DirectAudioDeviceProvider.class) {
if (Platform.isDirectAudioEnabled()) {
init();
} else {
}
}
}
private static void init() {
// get the number of input devices
int numDevices = nGetNumDevices();
// initialize the arrays
// fill in the info objects now.
infos[i] = nNewDirectAudioDeviceInfo(i);
}
if (Printer.trace) Printer.trace("DirectAudioDeviceProvider: init(): found numDevices: " + numDevices);
}
}
synchronized (DirectAudioDeviceProvider.class) {
return localArray;
}
}
synchronized (DirectAudioDeviceProvider.class) {
// if the default device is asked, we provide the mixer
// with SourceDataLine's
return mixer;
}
}
}
// otherwise get the first mixer that matches
// the requested info object
}
}
}
throw new IllegalArgumentException("Mixer " + info.toString() + " not supported by this provider.");
}
}
}
// INNER CLASSES
/**
* Info class for DirectAudioDevices. Adds an index value and a string for
* making native references to a particular device.
* This constructor is called from native.
*/
private final int index;
private final int maxSimulLines;
// For ALSA, the deviceID contains the encoded card index, device index, and sub-device-index
private final int deviceID;
this.maxSimulLines = maxSimulLines;
}
int getIndex() {
return index;
}
int getMaxSimulLines() {
return maxSimulLines;
}
int getDeviceID() {
return deviceID;
}
} // class DirectAudioDeviceInfo
// NATIVE METHODS
private static native int nGetNumDevices();
// index: [0..nGetNumDevices()-1]
}