// export_nprsoundex.cpp // // Export a Rivendell NPR SoundExchange Report to an ASCII Text File. // // (C) Copyright 2002-2021 Fred Gleason // // 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 #include #include #include "rdairplay_conf.h" #include "rddatedecode.h" #include "rddb.h" #include "rdescape_string.h" #include "rdget_ath.h" #include "rdlog_line.h" #include "rdreport.h" // // This implements a National Public Radio (NPR) standard. // See http://soundexchange.digitalservices.npr.org/playlist-log-file-guidelines/ // for more information. // bool RDReport::ExportNprSoundEx(const QString &filename,const QDate &startdate, const QDate &enddate,const QString &mixtable) { QString sql; RDSqlQuery *q; QString artist; QString title; QString album; QString label; QString service_name=serviceName(); QString trans_category=stationFormat(); QString channel_name=stationId(); QFile *file=new QFile(filename); if(!file->open(QIODevice::WriteOnly|QIODevice::Truncate)) { report_error_code=RDReport::ErrorCantOpen; delete file; return false; } QTextStream *strm=new QTextStream(file); strm->setCodec("UTF-8"); // // Generate Header // *strm << QString("Start Time\tEnd Time\tTitle\tArtist\tAlbum\tLabel\x0d\x0a"); // // Roll Up Records // sql=QString("select ")+ "`EVENT_DATETIME`,"+ // 00 "`LENGTH`,"+ // 01 "`TITLE`,"+ // 02 "`ARTIST`,"+ // 03 "`ALBUM`,"+ // 04 "`LABEL` "+ // 05 "from `ELR_LINES` where "+ "`SERVICE_NAME`='"+RDEscapeString(mixtable)+"' "+ "order by `EVENT_DATETIME`"; q=new RDSqlQuery(sql); while(q->next()) { *strm << q->value(0).toDateTime().toString("MM/dd/yyyy hh:mm:ss")+"\t"; *strm << q->value(0).toDateTime().addSecs(q->value(1).toInt()/1000). toString("MM/dd/yyyy hh:mm:ss")+"\t"; *strm << q->value(2).toString()+"\t"; *strm << q->value(3).toString()+"\t"; *strm << q->value(4).toString()+"\t"; *strm << q->value(5).toString()+"\x0d\x0a"; } delete q; delete strm; delete file; report_error_code=RDReport::ErrorOk; return true; }