mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-04-07 01:13:50 +02:00
* Fixed a regression in 'RDEventLine' that caused the 'Append Log' ['AL'] RML to append a copy of the currently loaded log instead of the one specified in the RML command. Signed-off-by: Fred Gleason <fredg@paraelsystems.com>
88 lines
2.9 KiB
C++
88 lines
2.9 KiB
C++
// rdlog_event.h
|
|
//
|
|
// Abstract Rivendell Log Events
|
|
//
|
|
// (C) Copyright 2002-2020 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 <vector>
|
|
|
|
#include <qdatetime.h>
|
|
#include <qsqldatabase.h>
|
|
|
|
#include <rdconfig.h>
|
|
#include <rdlog_line.h>
|
|
|
|
#ifndef RDLOG_EVENT_H
|
|
#define RDLOG_EVENT_H
|
|
|
|
#define INSERT_STEP_SIZE 500
|
|
|
|
class RDLogEvent
|
|
{
|
|
public:
|
|
RDLogEvent(QString logname="");
|
|
~RDLogEvent();
|
|
bool exists();
|
|
bool exists(int line);
|
|
bool exists(const QTime &hard_time,int except_line=-1);
|
|
QString logName() const;
|
|
void setLogName(QString logname);
|
|
QString serviceName() const;
|
|
int load(bool track_ptrs=false);
|
|
void saveModified(RDConfig *config,bool update_tracks=true);
|
|
void save(RDConfig *config,bool update_tracks=true,int line=-1);
|
|
int append(const QString &logname,bool track_ptrs=false);
|
|
int validate(QString *report,const QDate &date);
|
|
void clear();
|
|
void refresh(int line);
|
|
int size() const;
|
|
void insert(int line,int num_lines,bool preserve_trans=false);
|
|
void remove(int line,int num_lines,bool preserve_trans=false);
|
|
void move(int from_line,int to_line);
|
|
void copy(int from_line,int to_line);
|
|
int length(int from_line,int to_line,QTime *sched_time=NULL);
|
|
int lengthToStop(int from_line,QTime *sched_time=NULL);
|
|
bool blockLength(int *nominal_length,int *actual_length,int line);
|
|
QTime blockStartTime(int line);
|
|
RDLogLine *logLine(int line) const;
|
|
void setLogLine(int line,RDLogLine *ll);
|
|
RDLogLine *loglineById(int id, bool ignore_holdovers=false) const;
|
|
int lineById(int id, bool ignore_holdovers=false) const;
|
|
int lineByStartHour(int hour,RDLogLine::StartTimeType type) const;
|
|
int lineByStartHour(int hour) const;
|
|
int nextTimeStart(QTime after);
|
|
RDLogLine::TransType nextTransType(int);
|
|
void removeCustomTransition(int line);
|
|
int nextId() const;
|
|
int nextLinkId() const;
|
|
QString xml() const;
|
|
|
|
private:
|
|
int LoadLines(const QString &logname,int id_offset,bool track_ptrs);
|
|
void SaveLine(int line);
|
|
void InsertLines(QString values);
|
|
void InsertLineValues(QString *query, int line);
|
|
void LoadNowNext(unsigned from_line);
|
|
QString log_name;
|
|
QString log_service_name;
|
|
int log_max_id;
|
|
std::vector<RDLogLine *> log_line;
|
|
};
|
|
|
|
|
|
#endif
|