提交 290daf15 authored 作者: Andrew Thompson's avatar Andrew Thompson

Add support for 'pa devlist xml' to return the device list and which are the…

Add support for 'pa devlist xml' to return the device list and which are the ring/in/out devices in XML format


git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@11253 d0543943-73ff-0310-b7d9-9358b9ac24b2
上级 a5c06514
...@@ -1037,34 +1037,51 @@ static switch_status_t devlist(char **argv, int argc, switch_stream_handle_t *st ...@@ -1037,34 +1037,51 @@ static switch_status_t devlist(char **argv, int argc, switch_stream_handle_t *st
if (numDevices < 0) { if (numDevices < 0) {
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
} }
for (i = 0; i < numDevices; i++) {
deviceInfo = Pa_GetDeviceInfo(i);
stream->write_function(stream, "%d;%s;%d;%d;", i, deviceInfo->name, deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels);
prev = 0; if (argv[0] && !strcasecmp(argv[0], "xml")) {
if (globals.ringdev == i) { stream->write_function(stream, "<xml>\n\t<devices>\n");
stream->write_function(stream, "r");
prev = 1; for (i = 0; i < numDevices; i++) {
deviceInfo = Pa_GetDeviceInfo(i);
stream->write_function(stream, "\t\t<device id=\"%d\" name=\"%s\" inputs=\"%d\" outputs=\"%d\" />\n", i, deviceInfo->name, deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels);
} }
if (globals.indev == i) { stream->write_function(stream, "\t</devices>\n\t<bindings>\n"
if (prev) { "\t\t<ring device=\"%d\" />\n"
stream->write_function(stream, ","); "\t\t<input device=\"%d\" />\n"
"\t\t<output device=\"%d\" />\n"
"\t</bindings>\n</xml>\n", globals.ringdev, globals.indev, globals.outdev);
} else {
for (i = 0; i < numDevices; i++) {
deviceInfo = Pa_GetDeviceInfo(i);
stream->write_function(stream, "%d;%s;%d;%d;", i, deviceInfo->name, deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels);
prev = 0;
if (globals.ringdev == i) {
stream->write_function(stream, "r");
prev = 1;
} }
stream->write_function(stream, "i");
prev = 1;
}
if (globals.outdev == i) { if (globals.indev == i) {
if (prev) { if (prev) {
stream->write_function(stream, ","); stream->write_function(stream, ",");
}
stream->write_function(stream, "i");
prev = 1;
}
if (globals.outdev == i) {
if (prev) {
stream->write_function(stream, ",");
}
stream->write_function(stream, "o");
prev = 1;
} }
stream->write_function(stream, "o");
prev = 1;
}
stream->write_function(stream, "\n"); stream->write_function(stream, "\n");
}
} }
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
...@@ -1670,7 +1687,7 @@ SWITCH_STANDARD_API(pa_cmd) ...@@ -1670,7 +1687,7 @@ SWITCH_STANDARD_API(pa_cmd)
"pa switch [<call_id>|none]\n" "pa switch [<call_id>|none]\n"
"pa dtmf <digit string>\n" "pa dtmf <digit string>\n"
"pa flags [on|off] [ear] [mouth]\n" "pa flags [on|off] [ear] [mouth]\n"
"pa devlist\n" "pa devlist [xml]\n"
"pa indev #<num>|<partial name>\n" "pa indev #<num>|<partial name>\n"
"pa outdev #<num>|<partial name>\n" "pa outdev #<num>|<partial name>\n"
"pa ringdev #<num>|<partial name>\n" "pa ringdev #<num>|<partial name>\n"
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论