2018-07-09 Fred Gleason <fredg@paravelsystems.com>

* Added a 'RULE_LINES' table to the database.
	* Incremented the database version to 292.
This commit is contained in:
Fred Gleason
2018-07-10 08:30:06 -04:00
parent 1008b69076
commit 08c01373cb
10 changed files with 194 additions and 52 deletions

View File

@@ -18,30 +18,18 @@
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
//
#include <qmessagebox.h>
#include <rdclock.h>
#include <rddb.h>
#include <rdescape_string.h>
#include <schedruleslist.h>
#include <qmessagebox.h>
SchedRulesList::SchedRulesList(QString clockname,RDConfig *config)
{
QString sql;
RDSqlQuery *q;
RDSqlQuery *q1;
QString clkname=clockname;
clkname.replace(" ","_");
sql=QString("create table if not exists `")+
clkname+"_RULES` ("+
"CODE varchar(10) not null primary key,"+
"MAX_ROW int unsigned,"+
"MIN_WAIT int unsigned,"+
"NOT_AFTER varchar(10),"+
"OR_AFTER varchar(10),"+
"OR_AFTER_II varchar(10)) "+
config->createTablePostfix();
q=new RDSqlQuery(sql);
delete q;
sql=QString().sprintf("select CODE,DESCRIPTION from SCHED_CODES order by `CODE` asc");
@@ -60,27 +48,32 @@ SchedRulesList::SchedRulesList(QString clockname,RDConfig *config)
q->next();
sched_code[i] = q->value(0).toString();
description[i] = q->value(1).toString();
sql=QString().sprintf("select MAX_ROW,MIN_WAIT,NOT_AFTER,OR_AFTER,OR_AFTER_II from %s_RULES where CODE=\"%s\"",
(const char *)clockname.replace(" ","_"),(const char *)sched_code[i]);
sql=QString("select ")+
"MAX_ROW,"+ // 00
"MIN_WAIT,"+ // 01
"NOT_AFTER,"+ // 02
"OR_AFTER,"+ // 03
"OR_AFTER_II "+ // 04
"from RULE_LINES where "+
"CLOCK_NAME=\""+RDEscapeString(clockname)+"\" && "+
"CODE=\""+RDEscapeString(sched_code[i])+"\"";
q1=new RDSqlQuery(sql);
if(q1->first())
{
if(q1->first()) {
max_row[i] = q1->value(0).toInt();
min_wait[i] = q1->value(1).toInt();
not_after[i] = q1->value(2).toString();
or_after[i] = q1->value(3).toString();
or_after_II[i] = q1->value(3).toString();
}
else
{
}
else {
max_row[i] = 1;
min_wait[i] = 0;
not_after[i] = "";
or_after[i] = "";
or_after_II[i] = "";
}
delete q1;
}
delete q1;
}
delete q;
}
@@ -147,18 +140,21 @@ int SchedRulesList::getNumberOfItems(void)
void SchedRulesList::Save(QString clockname)
{
QString sql;
RDSqlQuery *q;
sql=QString().sprintf("delete from %s_RULES",
(const char *)clockname.replace(" ","_"));
q=new RDSqlQuery(sql);
delete q;
for (int i=0;i<itemcounter;i++)
{
sql=QString().sprintf("insert into %s_RULES set CODE=\"%s\",MAX_ROW=%d,MIN_WAIT=%d,NOT_AFTER=\"%s\",OR_AFTER=\"%s\",OR_AFTER_II=\"%s\"",(const char *)clockname.replace(" ","_"),(const char *)sched_code[i],max_row[i],min_wait[i],(const char *)not_after[i],(const char *)or_after[i],(const char *)or_after_II[i]);
q=new RDSqlQuery(sql);
delete q;
}
sql=QString("delete from RULE_LINES where ")+
"CLOCK_NAME=\""+RDEscapeString(clockname)+"\"";
RDSqlQuery::apply(sql);
for (int i=0;i<itemcounter;i++) {
sql=QString("insert into RULE_LINES set ")+
"CLOCK_NAME=\""+RDEscapeString(clockname)+"\","+
"CODE=\""+RDEscapeString(sched_code[i])+"\","+
QString().sprintf("MAX_ROW=%d,",max_row[i])+
QString().sprintf("MIN_WAIT=%d,",min_wait[i])+
"NOT_AFTER=\""+RDEscapeString(not_after[i])+"\","+
"OR_AFTER=\""+RDEscapeString(or_after[i])+"\","+
"OR_AFTER_II=\""+RDEscapeString(or_after_II[i])+"\"";
RDSqlQuery::apply(sql);
}
}