Optimized RDAudioPort SQL queries.

This commit is contained in:
Patrick Linstruth 2018-11-25 18:58:18 -08:00
parent 10b08d65a8
commit af0ad25dee
3 changed files with 54 additions and 44 deletions

View File

@ -18055,3 +18055,5 @@
* Removed the 'RDSvc::ImportOs' enumeration. * Removed the 'RDSvc::ImportOs' enumeration.
* Removed the 'Windows Import Path' and 'Windows Preimport Command' * Removed the 'Windows Import Path' and 'Windows Preimport Command'
fields from the 'Edit Service' dialog in rdadmin(1). fields from the 'Edit Service' dialog in rdadmin(1).
2018-11-25 Patrick Linstruth <patrick@deltecent.com>
* Optimized RDAudioPort SQL queries.

View File

@ -26,8 +26,38 @@
// //
RDAudioPort::RDAudioPort(QString station,int card) RDAudioPort::RDAudioPort(QString station,int card)
{ {
QString sql;
RDSqlQuery *q;
port_station=station; port_station=station;
port_card=card; port_card=card;
for(int port=0;port<RD_MAX_PORTS;port++) {
audio_input_port_level[port]=400;
audio_input_port_type[port]=RDAudioPort::Analog;
audio_input_port_mode[port]=RDCae::Normal;
audio_output_port_level[port]=400;
}
sql=QString("select PORT_NUMBER,LEVEL,TYPE,MODE from AUDIO_INPUTS where ")+
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
QString().sprintf("CARD_NUMBER=%d",port_card);
q=new RDSqlQuery(sql);
while(q->next()) {
audio_input_port_level[q->value(0).toInt()]=q->value(1).toInt();
audio_input_port_type[q->value(0).toInt()]=(RDAudioPort::PortType)q->value(2).toInt();
audio_input_port_mode[q->value(0).toInt()]=(RDCae::ChannelMode)q->value(3).toInt();
}
delete q;
sql=QString("select PORT_NUMBER,LEVEL from AUDIO_OUTPUTS where ")+
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
QString().sprintf("CARD_NUMBER=%d",port_card);
q=new RDSqlQuery(sql);
while(q->next()) {
audio_output_port_level[q->value(0).toInt()]=q->value(1).toInt();
}
delete q;
} }
@ -71,25 +101,20 @@ void RDAudioPort::setClockSource(RDCae::ClockSource src)
RDAudioPort::PortType RDAudioPort::inputPortType(int port) RDAudioPort::PortType RDAudioPort::inputPortType(int port)
{ {
RDAudioPort::PortType ret=RDAudioPort::Analog; if(port<0||port>RD_MAX_PORTS) {
QString sql=QString("select TYPE from AUDIO_INPUTS where ")+ return RDAudioPort::Analog;
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
QString().sprintf("CARD_NUMBER=%d && ",port_card)+
QString().sprintf("PORT_NUMBER=%d",port);
RDSqlQuery *q=new RDSqlQuery(sql);
if(q->first()) {
ret=(RDAudioPort::PortType)q->value(0).toInt();
} }
return ret; return audio_input_port_type[port];
} }
void RDAudioPort::setInputPortType(int port,RDAudioPort::PortType type) void RDAudioPort::setInputPortType(int port,RDAudioPort::PortType type)
{ {
if(port<0) { if(port<0||port>RD_MAX_PORTS) {
return; return;
} }
audio_input_port_type[port]=type;
QString sql=QString("update AUDIO_INPUTS set ")+ QString sql=QString("update AUDIO_INPUTS set ")+
QString().sprintf("TYPE=%d where ",type)+ QString().sprintf("TYPE=%d where ",type)+
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+ "STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
@ -102,25 +127,20 @@ void RDAudioPort::setInputPortType(int port,RDAudioPort::PortType type)
RDCae::ChannelMode RDAudioPort::inputPortMode(int port) RDCae::ChannelMode RDAudioPort::inputPortMode(int port)
{ {
RDCae::ChannelMode ret=RDCae::Normal; if(port<0||port>RD_MAX_PORTS) {
QString sql=QString("select MODE from AUDIO_INPUTS where ")+ return RDCae::Normal;
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
QString().sprintf("CARD_NUMBER=%d && ",port_card)+
QString().sprintf("PORT_NUMBER=%d",port);
RDSqlQuery *q=new RDSqlQuery(sql);
if(q->first()) {
ret=(RDCae::ChannelMode)q->value(0).toInt();
} }
return ret; return audio_input_port_mode[port];
} }
void RDAudioPort::setInputPortMode(int port,RDCae::ChannelMode mode) void RDAudioPort::setInputPortMode(int port,RDCae::ChannelMode mode)
{ {
if(port<0) { if(port<0||port>RD_MAX_PORTS) {
return; return;
} }
audio_input_port_mode[port]=mode;
QString sql=QString("update AUDIO_INPUTS set ")+ QString sql=QString("update AUDIO_INPUTS set ")+
QString().sprintf("MODE=%d where ",mode)+ QString().sprintf("MODE=%d where ",mode)+
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+ "STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
@ -133,28 +153,20 @@ void RDAudioPort::setInputPortMode(int port,RDCae::ChannelMode mode)
int RDAudioPort::inputPortLevel(int port) int RDAudioPort::inputPortLevel(int port)
{ {
if(port<0) { if(port<0||port>RD_MAX_PORTS) {
return 400; return 400;
} }
int ret=400;
QString sql=QString("select LEVEL from AUDIO_INPUTS where ")+
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
QString().sprintf("CARD_NUMBER=%d && ",port_card)+
QString().sprintf("PORT_NUMBER=%d",port);
RDSqlQuery *q=new RDSqlQuery(sql);
if(q->first()) {
ret=q->value(0).toInt();
}
return ret; return audio_input_port_level[port];
} }
void RDAudioPort::setInputPortLevel(int port,int level) void RDAudioPort::setInputPortLevel(int port,int level)
{ {
if(port<0) { if(port<0||port>RD_MAX_PORTS) {
return; return;
} }
audio_input_port_level[port]=level;
QString sql=QString("update AUDIO_INPUTS set ")+ QString sql=QString("update AUDIO_INPUTS set ")+
QString().sprintf("LEVEL=%d where ",level)+ QString().sprintf("LEVEL=%d where ",level)+
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+ "STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
@ -167,28 +179,20 @@ void RDAudioPort::setInputPortLevel(int port,int level)
int RDAudioPort::outputPortLevel(int port) int RDAudioPort::outputPortLevel(int port)
{ {
if(port<0) { if(port<0||port>RD_MAX_PORTS) {
return 400; return 400;
} }
int ret=400;
QString sql=QString("select LEVEL from AUDIO_OUTPUTS where ")+
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
QString().sprintf("CARD_NUMBER=%d && ",port_card)+
QString().sprintf("PORT_NUMBER=%d",port);
RDSqlQuery *q=new RDSqlQuery(sql);
if(q->first()) {
ret=q->value(0).toInt();
}
return ret; return audio_output_port_level[port];
} }
void RDAudioPort::setOutputPortLevel(int port,int level) void RDAudioPort::setOutputPortLevel(int port,int level)
{ {
if(port<0) { if(port<0||port>RD_MAX_PORTS) {
return; return;
} }
audio_output_port_level[port]=level;
QString sql=QString("update AUDIO_OUTPUTS set ")+ QString sql=QString("update AUDIO_OUTPUTS set ")+
QString().sprintf("LEVEL=%d where ",level)+ QString().sprintf("LEVEL=%d where ",level)+
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+ "STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+

View File

@ -45,6 +45,10 @@ class RDAudioPort
private: private:
QString port_station; QString port_station;
int port_card; int port_card;
int audio_input_port_level[RD_MAX_PORTS];
int audio_output_port_level[RD_MAX_PORTS];
RDAudioPort::PortType audio_input_port_type[RD_MAX_PORTS];
RDCae::ChannelMode audio_input_port_mode[RD_MAX_PORTS];
}; };