Create the GL texture id at texture-binding time.
[wine/multimedia.git] / programs / winecfg / audio.c
blob7d9a9b7e173326bb919129a42025456ecfbb8ca8
1 /*
2 * Audio management UI code
4 * Copyright 2004 Chris Morgan
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 #include "config.h"
23 #include "wine/port.h"
25 #include <assert.h>
26 #include <stdarg.h>
27 #include <stdlib.h>
28 #include <stdio.h>
29 #include <string.h>
31 #include <windef.h>
32 #include <winbase.h>
33 #include <winreg.h>
34 #include <wine/debug.h>
35 #include <shellapi.h>
36 #include <objbase.h>
37 #include <shlguid.h>
38 #include <shlwapi.h>
39 #include <shlobj.h>
41 #include "winecfg.h"
42 #include "resource.h"
44 WINE_DEFAULT_DEBUG_CHANNEL(winecfg);
46 /* Select the correct entry in the combobox based on drivername */
47 void selectAudioDriver(HWND hDlg, char *drivername)
49 int i;
50 const AUDIO_DRIVER *pAudioDrv = NULL;
52 if ((pAudioDrv = getAudioDrivers()))
54 for (i = 0; *pAudioDrv->szName; i++, pAudioDrv++)
56 if (!strcmp (pAudioDrv->szDriver, drivername))
58 set("Winmm", "Drivers", (char *) pAudioDrv->szDriver);
59 SendMessage(GetParent(hDlg), PSM_CHANGED, (WPARAM) hDlg, 0); /* enable apply button */
60 SendDlgItemMessage(hDlg, IDC_AUDIO_DRIVER, CB_SETCURSEL,
61 (WPARAM) i, 0);
67 void initAudioDlg (HWND hDlg)
69 char *curAudioDriver = get("Winmm", "Drivers", "winealsa.drv");
70 const AUDIO_DRIVER *pAudioDrv = NULL;
71 int i;
73 WINE_TRACE("\n");
75 pAudioDrv = getAudioDrivers ();
76 for (i = 0; *pAudioDrv->szName; i++, pAudioDrv++) {
77 SendDlgItemMessage (hDlg, IDC_AUDIO_DRIVER, CB_ADDSTRING,
78 0, (LPARAM) pAudioDrv->szName);
79 if (!strcmp (pAudioDrv->szDriver, curAudioDriver)) {
80 SendDlgItemMessage(hDlg, IDC_AUDIO_DRIVER, CB_SETCURSEL, i, 0);
85 char *audioAutoDetect(void)
87 struct stat buf;
88 const char *argv_new[4];
89 int fd;
91 char *driversFound[10];
92 char *name[10];
93 int numFound = 0;
95 argv_new[0] = "/bin/sh";
96 argv_new[1] = "-c";
97 argv_new[3] = NULL;
99 /* try to detect oss */
100 fd = open("/dev/dsp", O_WRONLY | O_NONBLOCK);
101 if(fd)
103 close(fd);
104 driversFound[numFound] = "wineoss.drv";
105 name[numFound] = "OSS";
106 numFound++;
109 /* try to detect alsa */
110 if(!stat("/proc/asound", &buf))
112 driversFound[numFound] = "winealsa.drv";
113 name[numFound] = "Alsa";
114 numFound++;
117 /* try to detect arts */
118 argv_new[2] = "ps awx|grep artsd|grep -v grep|grep artsd > /dev/null";
119 if(!spawnvp(_P_WAIT, "/bin/sh", argv_new))
121 driversFound[numFound] = "winearts.drv";
122 name[numFound] = "aRts";
123 numFound++;
126 /* try to detect jack */
127 argv_new[2] = "ps awx|grep jackd|grep -v grep|grep jackd > /dev/null";
128 if(!spawnvp(_P_WAIT, "/bin/sh", argv_new))
130 driversFound[numFound] = "winejack.drv";
131 name[numFound] = "jack";
132 numFound++;
135 /* try to detect nas */
136 /* TODO */
138 /* try to detect audioIO (solaris) */
139 /* TODO */
141 if(numFound == 0)
143 MessageBox(NULL, "Could not detect any audio devices/servers", "Failed", MB_OK);
144 return "";
146 else
148 /* TODO: possibly smarter handling of multiple drivers? */
149 char text[128];
150 snprintf(text, sizeof(text), "Found %s", name[0]);
151 MessageBox(NULL, (LPCTSTR)text, "Successful", MB_OK);
152 return driversFound[0];
157 INT_PTR CALLBACK
158 AudioDlgProc (HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
160 switch (uMsg) {
161 case WM_COMMAND:
162 switch (LOWORD(wParam)) {
163 case IDC_AUDIO_AUTODETECT:
164 selectAudioDriver(hDlg, audioAutoDetect());
165 break;
166 case IDC_AUDIO_DRIVER:
167 if ((HIWORD(wParam) == CBN_SELCHANGE) ||
168 (HIWORD(wParam) == CBN_SELCHANGE))
170 const AUDIO_DRIVER *pAudioDrv = getAudioDrivers();
171 int selected_driver = SendDlgItemMessage(hDlg, IDC_AUDIO_DRIVER, CB_GETCURSEL, 0, 0);
172 selectAudioDriver(hDlg, (char*)pAudioDrv[selected_driver].szDriver);
174 break;
176 break;
178 case WM_SHOWWINDOW:
179 set_window_title(hDlg);
180 break;
182 case WM_NOTIFY:
183 switch(((LPNMHDR)lParam)->code) {
184 case PSN_KILLACTIVE:
185 SetWindowLongPtr(hDlg, DWLP_MSGRESULT, FALSE);
186 break;
187 case PSN_APPLY:
188 apply();
189 SetWindowLongPtr(hDlg, DWLP_MSGRESULT, PSNRET_NOERROR);
190 break;
191 case PSN_SETACTIVE:
192 break;
194 break;
196 case WM_INITDIALOG:
197 initAudioDlg(hDlg);
198 break;
201 return FALSE;