/[svn]/jsampler/trunk/src/org/jsampler/task/CreateAudioDevice.java
ViewVC logotype

Contents of /jsampler/trunk/src/org/jsampler/task/CreateAudioDevice.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 911 - (show annotations) (download)
Mon Aug 7 18:25:58 2006 UTC (17 years, 8 months ago) by iliev
File size: 2202 byte(s)
updating to JSampler 0.3a

1 /*
2 * JSampler - a java front-end for LinuxSampler
3 *
4 * Copyright (C) 2005 Grigor Kirilov Iliev
5 *
6 * This file is part of JSampler.
7 *
8 * JSampler is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2
10 * as published by the Free Software Foundation.
11 *
12 * JSampler is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with JSampler; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
20 * MA 02111-1307 USA
21 */
22
23 package org.jsampler.task;
24
25 import java.util.logging.Level;
26
27 import org.jsampler.CC;
28 import org.jsampler.HF;
29
30 import org.linuxsampler.lscp.AudioOutputDevice;
31 import org.linuxsampler.lscp.Parameter;
32
33 import static org.jsampler.JSI18n.i18n;
34
35
36 /**
37 * This task creates a new audio output device.
38 * @author Grigor Iliev
39 */
40 public class CreateAudioDevice extends EnhancedTask<Integer> {
41 private String driver;
42 private Parameter[] parameters;
43
44
45 /**
46 * Creates a new instance of <code>CreateAudioDevice</code>.
47 * @param driver The desired audio output system.
48 * @param parameters An optional list of driver specific parameters.
49 */
50 public
51 CreateAudioDevice(String driver, Parameter... parameters) {
52 setTitle("CreateAudioDevice_task");
53 setDescription(i18n.getMessage("CreateAudioDevice.description"));
54
55 this.driver = driver;
56 this.parameters = parameters;
57 }
58
59 /** The entry point of the task. */
60 public void
61 run() {
62 try {
63 Integer deviceID =
64 CC.getClient().createAudioOutputDevice(driver, parameters);
65 setResult(deviceID);
66
67 // TODO: This must be done through the LinuxSampler notification system
68 CC.getSamplerModel().addAudioDevice (
69 CC.getClient().getAudioOutputDeviceInfo(deviceID)
70 );
71 } catch(Exception x) {
72 setErrorMessage(getDescription() + ": " + HF.getErrorMessage(x));
73 CC.getLogger().log(Level.FINE, getErrorMessage(), x);
74 }
75 }
76 }

  ViewVC Help
Powered by ViewVC