mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-10-11 09:03:40 +02:00
2018-05-21 Fred Gleason <fredg@paravelsystems.com>
* Added an 'AUDIO_CARDS' table to the database. * Dropped the 'STATIONS.CARD<n>_DRIVER', 'STATIONS.CARD<n>NAME', 'STATIONS.CARD<n>_INPUTS' and 'STATIONS.CARD<n>OUTPUTS' fields from the database. * Incremented the database version to 282. * Added an 'AUDIO_CARDS.CLOCK_SOURCE' field to the database. * Added an 'AUDIO_INPUTS' table to the database. * Added an 'AUDIO_OUTPUTS' table to the database. * Dropped the 'AUDIO_PORTS' table from the database. * Incremented the database version to 283. * Changed the legend on the 'Audio Ports' button to 'ASI Audio Ports' on the 'Edit Host' dialog in rdadmin(1). * Changed the title of the 'Configure Audio Ports' dialog to 'Configure AudioScience Audio Ports' on the 'Edit Host' dialog in rdadmin(1).
This commit is contained in:
@@ -2,7 +2,7 @@
|
||||
//
|
||||
// Abstract a Rivendell Audio Port.
|
||||
//
|
||||
// (C) Copyright 2002-2003,2016 Fred Gleason <fredg@paravelsystems.com>
|
||||
// (C) Copyright 2002-2003,2016-2018 Fred Gleason <fredg@paravelsystems.com>
|
||||
//
|
||||
// This program is free software; you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License version 2 as
|
||||
@@ -19,35 +19,15 @@
|
||||
//
|
||||
#include <rddb.h>
|
||||
#include <rdaudio_port.h>
|
||||
|
||||
#include <rdescape_string.h>
|
||||
|
||||
//
|
||||
// Global Classes
|
||||
//
|
||||
RDAudioPort::RDAudioPort(QString station,int card,bool create)
|
||||
RDAudioPort::RDAudioPort(QString station,int card)
|
||||
{
|
||||
RDSqlQuery *q;
|
||||
QString sql;
|
||||
|
||||
port_station=station;
|
||||
port_card=card;
|
||||
|
||||
if(create) {
|
||||
sql=QString().sprintf("select ID from AUDIO_PORTS where \
|
||||
(STATION_NAME=\"%s\")&&(CARD_NUMBER=%d)",(const char *)port_station,port_card);
|
||||
q=new RDSqlQuery(sql);
|
||||
if(q->size()!=1) {
|
||||
delete q;
|
||||
sql=QString().sprintf("INSERT INTO AUDIO_PORTS SET STATION_NAME=\"%s\",\
|
||||
CARD_NUMBER=%d",
|
||||
(const char *)port_station,port_card);
|
||||
q=new RDSqlQuery(sql);
|
||||
delete q;
|
||||
}
|
||||
else {
|
||||
delete q;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -65,23 +45,43 @@ int RDAudioPort::card() const
|
||||
|
||||
RDCae::ClockSource RDAudioPort::clockSource()
|
||||
{
|
||||
return (RDCae::ClockSource)GetIntValue("CLOCK_SOURCE");
|
||||
RDCae::ClockSource ret=RDCae::InternalClock;
|
||||
QString sql=QString("select CLOCK_SOURCE from AUDIO_CARDS where ")+
|
||||
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
|
||||
QString().sprintf("CARD_NUMBER=%d",port_card);
|
||||
RDSqlQuery *q=new RDSqlQuery(sql);
|
||||
if(q->first()) {
|
||||
ret=(RDCae::ClockSource)q->value(0).toInt();
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
void RDAudioPort::setClockSource(RDCae::ClockSource src)
|
||||
{
|
||||
SetRow("CLOCK_SOURCE",(int)src);
|
||||
QString sql=QString("update AUDIO_CARDS set ")+
|
||||
QString().sprintf("CLOCK_SOURCE=%d where ",src)+
|
||||
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
|
||||
QString().sprintf("CARD_NUMBER=%d",port_card);
|
||||
RDSqlQuery *q=new RDSqlQuery(sql);
|
||||
delete q;
|
||||
}
|
||||
|
||||
|
||||
RDAudioPort::PortType RDAudioPort::inputPortType(int port)
|
||||
{
|
||||
if(port<0) {
|
||||
return RDAudioPort::Analog;
|
||||
RDAudioPort::PortType ret=RDAudioPort::Analog;
|
||||
QString sql=QString("select TYPE 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=(RDAudioPort::PortType)q->value(0).toInt();
|
||||
}
|
||||
return
|
||||
(RDAudioPort::PortType)GetIntValue(QString().sprintf("INPUT_%d_TYPE",port));
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
@@ -90,17 +90,29 @@ void RDAudioPort::setInputPortType(int port,RDAudioPort::PortType type)
|
||||
if(port<0) {
|
||||
return;
|
||||
}
|
||||
SetRow(QString().sprintf("INPUT_%d_TYPE",port),(int)type);
|
||||
QString sql=QString("update AUDIO_INPUTS set ")+
|
||||
QString().sprintf("TYPE=%d where ",type)+
|
||||
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
|
||||
QString().sprintf("CARD_NUMBER=%d && ",port_card)+
|
||||
QString().sprintf("PORT_NUMBER=%d",port);
|
||||
RDSqlQuery *q=new RDSqlQuery(sql);
|
||||
delete q;
|
||||
}
|
||||
|
||||
|
||||
RDCae::ChannelMode RDAudioPort::inputPortMode(int port)
|
||||
{
|
||||
if(port<0) {
|
||||
return RDCae::Normal;
|
||||
RDCae::ChannelMode ret=RDCae::Normal;
|
||||
QString sql=QString("select MODE 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=(RDCae::ChannelMode)q->value(0).toInt();
|
||||
}
|
||||
return
|
||||
(RDCae::ChannelMode)GetIntValue(QString().sprintf("INPUT_%d_MODE",port));
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
@@ -109,7 +121,13 @@ void RDAudioPort::setInputPortMode(int port,RDCae::ChannelMode mode)
|
||||
if(port<0) {
|
||||
return;
|
||||
}
|
||||
SetRow(QString().sprintf("INPUT_%d_MODE",port),(int)mode);
|
||||
QString sql=QString("update AUDIO_INPUTS set ")+
|
||||
QString().sprintf("MODE=%d where ",mode)+
|
||||
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
|
||||
QString().sprintf("CARD_NUMBER=%d && ",port_card)+
|
||||
QString().sprintf("PORT_NUMBER=%d",port);
|
||||
RDSqlQuery *q=new RDSqlQuery(sql);
|
||||
delete q;
|
||||
}
|
||||
|
||||
|
||||
@@ -118,7 +136,17 @@ int RDAudioPort::inputPortLevel(int port)
|
||||
if(port<0) {
|
||||
return 400;
|
||||
}
|
||||
return GetIntValue(QString().sprintf("INPUT_%d_LEVEL",port));
|
||||
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;
|
||||
}
|
||||
|
||||
|
||||
@@ -127,7 +155,13 @@ void RDAudioPort::setInputPortLevel(int port,int level)
|
||||
if(port<0) {
|
||||
return;
|
||||
}
|
||||
SetRow(QString().sprintf("INPUT_%d_LEVEL",port),level);
|
||||
QString sql=QString("update AUDIO_INPUTS set ")+
|
||||
QString().sprintf("LEVEL=%d where ",level)+
|
||||
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
|
||||
QString().sprintf("CARD_NUMBER=%d && ",port_card)+
|
||||
QString().sprintf("PORT_NUMBER=%d",port);
|
||||
RDSqlQuery *q=new RDSqlQuery(sql);
|
||||
delete q;
|
||||
}
|
||||
|
||||
|
||||
@@ -136,7 +170,17 @@ int RDAudioPort::outputPortLevel(int port)
|
||||
if(port<0) {
|
||||
return 400;
|
||||
}
|
||||
return GetIntValue(QString().sprintf("OUTPUT_%d_LEVEL",port));
|
||||
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;
|
||||
}
|
||||
|
||||
|
||||
@@ -145,43 +189,11 @@ void RDAudioPort::setOutputPortLevel(int port,int level)
|
||||
if(port<0) {
|
||||
return;
|
||||
}
|
||||
SetRow(QString().sprintf("OUTPUT_%d_LEVEL",port),level);
|
||||
}
|
||||
|
||||
|
||||
int RDAudioPort::GetIntValue(QString field)
|
||||
{
|
||||
QString sql;
|
||||
RDSqlQuery *q;
|
||||
int accum;
|
||||
|
||||
sql=QString().sprintf("select %s from AUDIO_PORTS where \
|
||||
(STATION_NAME=\"%s\")&&(CARD_NUMBER=%d)",(const char *)field,
|
||||
(const char *)port_station,port_card);
|
||||
q=new RDSqlQuery(sql);
|
||||
if(q->first()) {
|
||||
accum=q->value(0).toInt();
|
||||
delete q;
|
||||
return accum;
|
||||
}
|
||||
delete q;
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
void RDAudioPort::SetRow(QString param,int value)
|
||||
{
|
||||
RDSqlQuery *q;
|
||||
QString sql;
|
||||
|
||||
sql=QString().sprintf("UPDATE AUDIO_PORTS SET %s=%d \
|
||||
WHERE (STATION_NAME=\"%s\")&&(CARD_NUMBER=%d)",
|
||||
(const char *)param,
|
||||
value,
|
||||
(const char *)port_station,
|
||||
port_card);
|
||||
q=new RDSqlQuery(sql);
|
||||
QString sql=QString("update AUDIO_OUTPUTS set ")+
|
||||
QString().sprintf("LEVEL=%d where ",level)+
|
||||
"STATION_NAME=\""+RDEscapeString(port_station)+"\" && "+
|
||||
QString().sprintf("CARD_NUMBER=%d && ",port_card)+
|
||||
QString().sprintf("PORT_NUMBER=%d",port);
|
||||
RDSqlQuery *q=new RDSqlQuery(sql);
|
||||
delete q;
|
||||
}
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user