mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-04-09 22:43:11 +02:00
* Refactored routines for parsing/writing standard date/time strings (RFC822 and XML xs:dateTime formats) into 'lib/rddatetime.[cpp|h]. * Removed the 'RDWebDateTime()', 'RDGetWebDateTime()', 'RDGetWebDate()', 'RDGetWebTime()', 'RDGetWebMonth()', 'RDXmlDate()', 'RDXmlTime()', 'RDXmlDateTime()' and 'RDXmlTimeZoneSuffix()' functions from 'lib/rdweb.[cpp|h]. * Added a 'dateparse_test' test harness.
602 lines
13 KiB
C++
602 lines
13 KiB
C++
// rdclilogedit.cpp
|
|
//
|
|
// A command-line log editor for Rivendell
|
|
//
|
|
// (C) Copyright 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
|
|
// 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 <stdlib.h>
|
|
|
|
#include <rdapplication.h>
|
|
#include <rdweb.h>
|
|
|
|
#include <rddatetime.h>
|
|
|
|
#include "rdclilogedit.h"
|
|
|
|
void MainObject::DispatchCommand(QString cmd)
|
|
{
|
|
bool processed=false;
|
|
int line;
|
|
QTime time;
|
|
bool ok=false;
|
|
bool overwrite=!edit_modified;
|
|
QStringList cmds;
|
|
QString verb;
|
|
|
|
cmd=cmd.stripWhiteSpace();
|
|
if(cmd.right(1)=="!") {
|
|
overwrite=true;
|
|
cmd=cmd.left(cmd.length()-1).stripWhiteSpace();
|
|
}
|
|
cmds=cmd.split(" ",QString::SkipEmptyParts);
|
|
verb=cmds[0].lower();
|
|
|
|
//
|
|
// No loaded log needed for these
|
|
//
|
|
if(verb=="deletelog") {
|
|
if(rda->user()->deleteLog()) {
|
|
if(cmds.size()==2) {
|
|
Deletelog(cmds[1]);
|
|
}
|
|
else {
|
|
fprintf(stderr,"deletelog: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"deletelog: insufficient privileges [Delete Log]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if((verb=="exit")||(verb=="quit")||(verb=="bye")) {
|
|
if(overwrite) {
|
|
if(edit_log_lock!=NULL) {
|
|
delete edit_log_lock;
|
|
}
|
|
exit(0);
|
|
}
|
|
else {
|
|
OverwriteError(verb);
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if((verb=="help")||(verb=="?")) {
|
|
Help(cmds);
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="listlogs") {
|
|
ListLogs();
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="listservices") {
|
|
Listservices();
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="load") {
|
|
if(overwrite) {
|
|
if(cmds.size()==2) {
|
|
Load(cmds[1]);
|
|
}
|
|
else {
|
|
fprintf(stderr,"load: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
OverwriteError("load");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="new") {
|
|
if(overwrite) {
|
|
if(cmds.size()==2) {
|
|
New(cmds[1]);
|
|
}
|
|
else {
|
|
fprintf(stderr,"new: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
OverwriteError("new");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
//
|
|
// These need a log loaded
|
|
//
|
|
if((processed)||(edit_log_event!=NULL)) {
|
|
if(verb=="addcart") {
|
|
if(rda->user()->addtoLog()) {
|
|
if(cmds.size()==3) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)) {
|
|
unsigned cartnum=cmds[2].toUInt(&ok);
|
|
if(ok&&(cartnum<=RD_MAX_CART_NUMBER)) {
|
|
Addcart(line,cartnum);
|
|
}
|
|
else {
|
|
fprintf(stderr,"addcart: invalid cart number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addcart: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addcart: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addcart: insufficient privileges [Add Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="addchain") {
|
|
if(rda->user()->addtoLog()) {
|
|
if(cmds.size()==3) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)) {
|
|
Addchain(line,cmds[2]);
|
|
}
|
|
else {
|
|
fprintf(stderr,"addchain: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addchain: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addchain: insufficient privileges [Add Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="addmarker") {
|
|
if(rda->user()->addtoLog()) {
|
|
if(cmds.size()==2) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)) {
|
|
Addmarker(line);
|
|
}
|
|
else {
|
|
fprintf(stderr,"addmarker: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addmarker: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addmarker: insufficient privileges [Add Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="addtrack") {
|
|
if(rda->user()->addtoLog()) {
|
|
if(cmds.size()==2) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)) {
|
|
Addtrack(line);
|
|
}
|
|
else {
|
|
fprintf(stderr,"addtrack: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addtrack: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"addtrack: insufficient privileges [Add Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="header") {
|
|
Header();
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="list") {
|
|
List();
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="remove") {
|
|
if(rda->user()->removefromLog()) {
|
|
if(cmds.size()==2) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)&&(line<edit_log_event->size())) {
|
|
Remove(line);
|
|
}
|
|
else {
|
|
fprintf(stderr,"remove: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"remove: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"remove: insufficient privileges [Delete Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="save") {
|
|
if(rda->user()->arrangeLog()) {
|
|
Save();
|
|
}
|
|
else {
|
|
fprintf(stderr,"save: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="saveas") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==2) {
|
|
if(cmds[1].length()>64) {
|
|
fprintf(stderr,"saveas: log name too long\n");
|
|
}
|
|
Saveas(cmds[1]);
|
|
}
|
|
else {
|
|
fprintf(stderr,"saveas: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"saveas: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setautorefresh") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==2) {
|
|
QString arg=cmds[1].lower();
|
|
if((arg=="yes")||(arg=="true")||(arg=="y")) {
|
|
Setautorefresh(true);
|
|
processed=true;
|
|
}
|
|
if((arg=="no")||(arg=="false")||(arg=="n")) {
|
|
Setautorefresh(false);
|
|
processed=true;
|
|
}
|
|
if(!processed) {
|
|
fprintf(stderr,"setautorefresh: invalid command argument\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"setautorefresh: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setautorefresh: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setcart") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==3) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)&&(line<edit_log_event->size())) {
|
|
unsigned cartnum=cmds[2].toUInt(&ok);
|
|
if(ok&&(cartnum<=RD_MAX_CART_NUMBER)) {
|
|
Setcart(line,cartnum);
|
|
}
|
|
else {
|
|
fprintf(stderr,"setcart: invalid cart number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"setcart: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"setcart: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setcart: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setcomment") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()>=3) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)&&(line<edit_log_event->size())) {
|
|
cmds.remove(cmds.begin());
|
|
cmds.remove(cmds.begin());
|
|
Setcomment(line,cmds.join(" "));
|
|
}
|
|
else {
|
|
fprintf(stderr,"setcomment: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"setcomment: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setcomment: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setdesc") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()>=2) {
|
|
cmds.erase(cmds.begin());
|
|
Setdesc(cmds.join(" "));
|
|
}
|
|
else {
|
|
fprintf(stderr,"setdesc: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setdesc: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setenddate") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==1) {
|
|
Setenddate(QDate());
|
|
}
|
|
else {
|
|
if(cmds.size()==2) {
|
|
QDate date=QDate::fromString(cmds[1],Qt::ISODate);
|
|
if(date.isValid()) {
|
|
Setenddate(date);
|
|
}
|
|
else {
|
|
fprintf(stderr,"setenddate: invalid date format\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"setenddate: invalid command arguments\n");
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setenddate: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setlabel") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==3) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)&&(line<edit_log_event->size())) {
|
|
Setlabel(line,cmds[2]);
|
|
}
|
|
else {
|
|
fprintf(stderr,"setlabel: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"setlabel: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setlabel: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setpurgedate") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==1) {
|
|
Setpurgedate(QDate());
|
|
}
|
|
else {
|
|
if(cmds.size()==2) {
|
|
QDate date=QDate::fromString(cmds[1],Qt::ISODate);
|
|
if(date.isValid()) {
|
|
Setpurgedate(date);
|
|
}
|
|
else {
|
|
fprintf(stderr,"setpurgedate: invalid date format\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"setpurgedate: invalid command arguments\n");
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setpurgedate: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setservice") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==2) {
|
|
Setservice(cmds[1]);
|
|
}
|
|
else {
|
|
fprintf(stderr,"setservice: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setservice: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="setstartdate") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==1) {
|
|
Setstartdate(QDate());
|
|
}
|
|
else {
|
|
if(cmds.size()==2) {
|
|
QDate date=QDate::fromString(cmds[1],Qt::ISODate);
|
|
if(date.isValid()) {
|
|
Setstartdate(date);
|
|
}
|
|
else {
|
|
fprintf(stderr,"setstartdate: invalid date format\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"setstartdate: invalid command arguments\n");
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"setstartdate: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="settime") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()>=3) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)&&(line<edit_log_event->size())) {
|
|
RDLogLine::TimeType ttype=RDLogLine::NoTime;
|
|
if(cmds[2].lower()=="hard") {
|
|
ttype=RDLogLine::Hard;
|
|
}
|
|
if(cmds[2].lower()=="none") {
|
|
ttype=RDLogLine::Relative;
|
|
}
|
|
switch(ttype) {
|
|
case RDLogLine::Hard:
|
|
if(cmds.size()>=4) {
|
|
time=RDParseXmlTime(cmds[3],&ok);
|
|
if(ok) {
|
|
Settime(line,ttype,time);
|
|
}
|
|
else {
|
|
fprintf(stderr,"settime: invalid time value\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"settime: missing time value\n");
|
|
}
|
|
break;
|
|
|
|
case RDLogLine::Relative:
|
|
Settime(line,ttype);
|
|
break;
|
|
|
|
case RDLogLine::NoTime:
|
|
fprintf(stderr,"settime: invalid time type\n");
|
|
break;
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"settime: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"settime: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"settime: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="settrans") {
|
|
if(rda->user()->arrangeLog()) {
|
|
if(cmds.size()==3) {
|
|
line=cmds[1].toInt(&ok);
|
|
if(ok&&(line>=0)&&(line<edit_log_event->size())) {
|
|
RDLogLine::TransType trans=RDLogLine::NoTrans;
|
|
if(cmds[2].lower()=="play") {
|
|
trans=RDLogLine::Play;
|
|
}
|
|
if(cmds[2].lower()=="segue") {
|
|
trans=RDLogLine::Segue;
|
|
}
|
|
if(cmds[2].lower()=="stop") {
|
|
trans=RDLogLine::Stop;
|
|
}
|
|
if(trans!=RDLogLine::NoTrans) {
|
|
Settrans(line,trans);
|
|
}
|
|
else {
|
|
fprintf(stderr,"settrans: invalid transition type\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"settrans: invalid line number\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"settrans: invalid command arguments\n");
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,
|
|
"settrans: insufficient privileges [Rearrange Log Items]\n");
|
|
}
|
|
processed=true;
|
|
}
|
|
|
|
if(verb=="unload") {
|
|
if(overwrite) {
|
|
Unload();
|
|
}
|
|
else {
|
|
OverwriteError("unload");
|
|
}
|
|
processed=true;
|
|
}
|
|
}
|
|
else {
|
|
fprintf(stderr,"%s: no log loaded\n",(const char *)verb);
|
|
processed=true;
|
|
}
|
|
|
|
if(!processed) {
|
|
fprintf(stderr,"invalid command\n");
|
|
}
|
|
PrintPrompt();
|
|
}
|