Rivendellaudio/rdlibrary/validate_cut.cpp
Fred Gleason 1615861350 2018-08-14 Fred Gleason <fredg@paravelsystems.com>
* Fixed style inconsistencies in dialogs within rdlibrary(1).
2018-08-14 21:06:37 +00:00

101 lines
3.0 KiB
C++

// validate_cut.cpp
//
// Validate a Rivendell Audio Cut
//
// (C) Copyright 2006-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
// published by the Free Software Foundation.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public
// License along with this program; if not, write to the Free Software
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
//
#include <rddb.h>
#include "validate_cut.h"
QString ValidateCutFields()
{
QString sql;
sql=QString("select ")+
"PLAY_ORDER,"+ // 00
"WEIGHT,"+ // 01
"DESCRIPTION,"+ // 02
"LENGTH,"+ // 03
"LAST_PLAY_DATETIME,"+ // 04
"PLAY_COUNTER,"+ // 05
"ORIGIN_DATETIME,"+ // 06
"ORIGIN_NAME,"+ // 07
"ORIGIN_LOGIN_NAME,"+ // 08
"SOURCE_HOSTNAME,"+ // 09
"OUTCUE,"+ // 10
"CUT_NAME,"+ // 11
"LENGTH,"+ // 12 offsets begin here
"EVERGREEN,"+ // 13
"START_DATETIME,"+ // 14
"END_DATETIME,"+ // 15
"START_DAYPART,"+ // 16
"END_DAYPART,"+ // 17
"MON,"+ // 18
"TUE,"+ // 19
"WED,"+ // 20
"THU,"+ // 21
"FRI,"+ // 22
"SAT,"+ // 23
"SUN,"+ // 24
"SHA1_HASH "+ // 25
"from CUTS";
return sql;
}
RDCart::Validity ValidateCut(RDSqlQuery *q,unsigned offset,
RDCart::Validity prev_validity,
const QDateTime &datetime)
{
if(prev_validity==RDCart::AlwaysValid) {
return RDCart::AlwaysValid;
}
if(q->value(offset).toInt()==0) { // Length
return prev_validity;
}
if(q->value(offset+1).toString()=="Y") { // Evergreen
return RDCart::EvergreenValid;
}
if(q->value(offset+5+datetime.date().dayOfWeek()).toString()!="Y") {
return prev_validity;
}
if(!q->value(offset+2).isNull()) { // Start DateTime
if(q->value(offset+2).toDateTime()>datetime) {
return RDCart::FutureValid;
}
}
if(!q->value(offset+3).isNull()) { // End DateTime
if(q->value(offset+3).toDateTime()<datetime) {
return prev_validity;
}
}
if(!q->value(offset+4).isNull()) { // Start Daypart
if(q->value(offset+4).toTime()>datetime.time()) {
return prev_validity;
}
}
if(!q->value(offset+5).isNull()) { // End Daypart
if(q->value(offset+5).toTime()<datetime.time()) {
return prev_validity;
}
}
return RDCart::AlwaysValid;
}