forked from dimbor-ru/opennx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPAWrapperSimple.cpp
103 lines (93 loc) · 3.73 KB
/
PAWrapperSimple.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
class pawrapper {
public:
pawrapper()
{
wxConfigBase::Get()->Read(wxT("Config/SystemNxDir"), &pactlcmd);
pactlcmd << wxFileName::GetPathSeparator() << wxT("bin")
<< wxFileName::GetPathSeparator() << wxT("pactl.exe");
m_bConnected=wxFileName::IsFileExecutable(pactlcmd);
if (m_bConnected) {
myLogTrace(MYTRACETAG, wxT("PAWrapper: executable \"%s\" found."),
VMB(pactlcmd));
pactlcmd << wxT(" -s 127.0.0.1");
} else
myLogTrace(MYTRACETAG, wxT("PAWrapper: executable \"%s\" not found!"),
VMB(pactlcmd));
}
bool getdefaults(wxString &Sink, wxString &Source)
{
wxString cmd; wxArrayString outtxt; bool ret;
Sink.Empty(); Source.Empty();
cmd << pactlcmd << wxT(" info");
int sterr = ::wxExecute(cmd, outtxt, wxEXEC_SYNC);
ret = (sterr == 0);
if (ret) {
for (int i=0; i<outtxt.GetCount(); i++) {
wxArrayString tks = ::wxStringTokenize(outtxt[i],wxT(":"));
if (tks[0].IsSameAs(wxT("Default Sink")))
Sink = tks[1].Trim(false);
else if (tks[0].IsSameAs(wxT("Default Source")))
Source = tks[1].Trim(false);
}
} else
myLogTrace(MYTRACETAG, wxT("PAWrapper: couldn't get defaults sterr = %d"),
sterr);
return ret;
}
bool findmodules(const wxChar *name, wxArrayString &indexes, wxArrayString &args)
{
wxString cmd, ts; wxArrayString outtxt; bool ret;
cmd << pactlcmd << wxT(" list short");
int sterr = ::wxExecute(cmd, outtxt, wxEXEC_SYNC);
ret = (sterr == 0);
if (ret) {
for (int i=0; i<outtxt.GetCount(); i++) {
wxArrayString tks = ::wxStringTokenize(outtxt[i]);
if (tks[1].IsSameAs(name)) {
indexes.Add(tks[0]);
ts.Empty();
for (int j=2; j<tks.GetCount(); j++) {
if (j!=2)
ts << wxT(" ");
ts << tks[j];
}
args.Add(ts);
}
}
} else
myLogTrace(MYTRACETAG, wxT("PAWrapper: couldn't list modules sterr = %d"),
sterr);
return ret;
}
bool loadmodule(const wxString name, const wxString args)
{
wxString cmd; wxArrayString outtxt; bool ret;
cmd << pactlcmd << wxT(" load-module ")
<< name << wxT(" ") << args;
int sterr = ::wxExecute(cmd, outtxt, wxEXEC_SYNC);
ret = (sterr == 0);
if (!ret)
myLogTrace(MYTRACETAG, wxT("PAWrapper: couldn't load module %s sterr = %d"),
VMB(name), sterr);
return ret;
}
bool unloadmodule(int index)
{
wxString cmd; wxArrayString outtxt; bool ret;
cmd << pactlcmd << wxT(" unload-module ")
<< wxString::Format(wxT("%u"),index);
int sterr = ::wxExecute(cmd, outtxt, wxEXEC_SYNC);
ret = (sterr == 0);
if (!ret)
myLogTrace(MYTRACETAG, wxT("PAWrapper: couldn't load module id %u; sterr = %d"),
index, sterr);
return ret;
}
bool isConnected()
{
return m_bConnected;
}
private:
bool m_bConnected;
wxString pactlcmd;
};