mirror of
				https://github.com/ElvishArtisan/rivendell.git
				synced 2025-11-03 23:53:59 +01:00 
			
		
		
		
	* Added a '%wc' ['Industry Standard Commercial Identification (ISCI) Code'] metadata wildcard. * Implemented the '%wc' metadata wildcard for PyPAD. * Added support for the '%wc' wildcards to the '--metadata-pattern=' switch in rdimport(1). * Added '--set-string-isci' switch to rdimport(1). * Added support for the '%wc' wildcard to the '--metadata-pattern=' switch in rdexport(1).
		
			
				
	
	
		
			2385 lines
		
	
	
		
			48 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			2385 lines
		
	
	
		
			48 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
// rdlog_line.cpp
 | 
						|
//
 | 
						|
// A container class for a Rivendell Log Line.
 | 
						|
//
 | 
						|
//   (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 <syslog.h>
 | 
						|
 | 
						|
#include <qobject.h>
 | 
						|
 | 
						|
#include "rdapplication.h"
 | 
						|
#include "rddb.h"
 | 
						|
#include "rdconf.h"
 | 
						|
#include "rd.h"
 | 
						|
#include "rdlog_line.h"
 | 
						|
#include "rdcut.h"
 | 
						|
#include "rdmacro_event.h"
 | 
						|
#include "rdweb.h"
 | 
						|
#include "rdescape_string.h"
 | 
						|
 | 
						|
RDLogLine::RDLogLine()
 | 
						|
{
 | 
						|
  clear();
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::RDLogLine(unsigned cartnum)
 | 
						|
{
 | 
						|
  QString sql;
 | 
						|
  RDSqlQuery *q;
 | 
						|
 | 
						|
  clear();
 | 
						|
  log_cart_number=cartnum;
 | 
						|
  sql=QString().sprintf("select GROUP_NAME,TITLE,ARTIST,ALBUM,YEAR,LABEL,\
 | 
						|
                         CLIENT,AGENCY,COMPOSER,PUBLISHER,USER_DEFINED,NOTES \
 | 
						|
                         from CART where NUMBER=%u",log_cart_number);
 | 
						|
  q=new RDSqlQuery(sql);
 | 
						|
  if(q->first()) {
 | 
						|
    log_group_name=q->value(0).toString();
 | 
						|
    log_title=q->value(1).toString();
 | 
						|
    log_artist=q->value(2).toString();
 | 
						|
    log_album=q->value(3).toString();
 | 
						|
    log_year=QDate(q->value(4).toInt(),1,1);
 | 
						|
    log_label=q->value(5).toString();
 | 
						|
    log_client=q->value(6).toString();
 | 
						|
    log_agency=q->value(7).toString();
 | 
						|
    log_composer=q->value(8).toString();
 | 
						|
    log_publisher=q->value(9).toString();
 | 
						|
    log_user_defined=q->value(10).toString();
 | 
						|
    log_cart_notes=q->value(11).toString();
 | 
						|
  }
 | 
						|
  delete q;
 | 
						|
}
 | 
						|
 | 
						|
void RDLogLine::clearModified(void)
 | 
						|
{
 | 
						|
  modified = false;
 | 
						|
}
 | 
						|
 | 
						|
bool RDLogLine::hasBeenModified(void)
 | 
						|
{
 | 
						|
  return modified;
 | 
						|
}
 | 
						|
 | 
						|
void RDLogLine::clear()
 | 
						|
{
 | 
						|
  clearModified();
 | 
						|
  log_id=-1;
 | 
						|
  log_status=RDLogLine::Scheduled;
 | 
						|
  log_state=RDLogLine::Ok;
 | 
						|
  log_validity=RDCart::AlwaysValid;
 | 
						|
  log_pass=0;
 | 
						|
  log_source=RDLogLine::Manual;
 | 
						|
  log_cart_number=0;
 | 
						|
  for(int i=0;i<5;i++) {
 | 
						|
    log_start_time[i]=QTime();
 | 
						|
  }
 | 
						|
  log_time_type=RDLogLine::Relative;
 | 
						|
  log_origin_user="";
 | 
						|
  log_origin_datetime=QDateTime();
 | 
						|
  log_trans_type=RDLogLine::Play;
 | 
						|
  for(unsigned i=0;i<2;i++) {
 | 
						|
    log_start_point[i]=-1;
 | 
						|
    log_end_point[i]=-1;
 | 
						|
    log_segue_start_point[i]=-1;
 | 
						|
    log_segue_end_point[i]=-1;
 | 
						|
    log_fadeup_point[i]=-1;
 | 
						|
    log_fadedown_point[i]=-1;
 | 
						|
  }
 | 
						|
  log_segue_gain=RD_FADE_DEPTH;
 | 
						|
  log_segue_gain_cut=RD_FADE_DEPTH;
 | 
						|
  log_fadedown_gain=0;
 | 
						|
  log_fadeup_gain=0;
 | 
						|
  log_duck_up_gain=0;
 | 
						|
  log_duck_down_gain=0;
 | 
						|
  log_hook_mode=false;
 | 
						|
  log_hook_start=-1;
 | 
						|
  log_hook_end=-1;
 | 
						|
  log_cart_type=RDCart::Audio;
 | 
						|
  log_group_name="";
 | 
						|
  log_group_color=QColor();
 | 
						|
  log_title="";
 | 
						|
  log_artist="";
 | 
						|
  log_publisher="";
 | 
						|
  log_composer="";
 | 
						|
  log_isrc="";
 | 
						|
  log_recording_mbid="";
 | 
						|
  log_release_mbid="";
 | 
						|
  log_album="";
 | 
						|
  log_year=QDate();
 | 
						|
  log_isci="";
 | 
						|
  log_label="";
 | 
						|
  log_conductor="";
 | 
						|
  log_song_id="";
 | 
						|
  log_client="";
 | 
						|
  log_agency="";
 | 
						|
  log_outcue="";
 | 
						|
  log_description="";
 | 
						|
  log_user_defined="";
 | 
						|
  log_usage_code=RDCart::UsageFeature;
 | 
						|
  log_forced_length=0;
 | 
						|
  log_cut_quantity=0;
 | 
						|
  log_last_cut_played=0;
 | 
						|
  log_play_order=RDCart::Sequence;
 | 
						|
  log_enforce_length=false;
 | 
						|
  log_preserve_pitch=false;
 | 
						|
  log_start_datetime=QDateTime();
 | 
						|
  log_end_datetime=QDateTime();
 | 
						|
  log_deck=-1;
 | 
						|
  log_port_name="";
 | 
						|
  log_play_time=QTime();
 | 
						|
  log_cut_number=-1;
 | 
						|
  log_effective_length=-1;
 | 
						|
  log_talk_start=-1;
 | 
						|
  log_talk_end=-1;
 | 
						|
  log_talk_length=-1;
 | 
						|
  log_play_position=0;
 | 
						|
  log_type=RDLogLine::Cart;
 | 
						|
  log_marker_comment="";
 | 
						|
  log_marker_label="";
 | 
						|
  log_marker_post_time=QTime();
 | 
						|
  log_listview=NULL;
 | 
						|
  log_grace_time=0;
 | 
						|
  log_forced_stop=false;
 | 
						|
  log_play_position_changed=false;
 | 
						|
  log_evergreen=false;
 | 
						|
  log_ext_start_time=QTime();
 | 
						|
  log_ext_length=-1;
 | 
						|
  log_ext_cart_name="";
 | 
						|
  log_ext_data="";
 | 
						|
  log_ext_event_id="";
 | 
						|
  log_ext_annc_type="";
 | 
						|
  log_pause_card=-1;
 | 
						|
  log_pause_port=-1;
 | 
						|
  log_now_next_enabled=false;
 | 
						|
  log_zombified=false;
 | 
						|
  log_timescaling_active=false;
 | 
						|
  log_play_deck=NULL;
 | 
						|
  log_asyncronous=false;
 | 
						|
  log_cut_name="";
 | 
						|
  log_average_segue_length=0;
 | 
						|
  log_has_custom_transition=false;
 | 
						|
  log_use_event_length=false;
 | 
						|
  log_event_length=-1;
 | 
						|
  log_link_event_name="";
 | 
						|
  log_link_start_time=QTime();
 | 
						|
  log_link_length=0;
 | 
						|
  log_link_start_slop=0;
 | 
						|
  log_link_end_slop=0;
 | 
						|
  log_link_id=-1;
 | 
						|
  log_link_embedded=false;
 | 
						|
  log_start_source=RDLogLine::StartUnknown;
 | 
						|
  is_holdover = false;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::clearExternalData()
 | 
						|
{
 | 
						|
  log_ext_start_time=QTime();
 | 
						|
  log_ext_length=-1;
 | 
						|
  log_ext_data="";
 | 
						|
  log_ext_event_id="";
 | 
						|
  log_ext_annc_type="";
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::clearTrackData(RDLogLine::TransEdge edge)
 | 
						|
{
 | 
						|
  if((edge==RDLogLine::LeadingTrans)||(edge==RDLogLine::AllTrans)) {
 | 
						|
    log_start_point[RDLogLine::LogPointer]=-1;
 | 
						|
    log_fadeup_point[RDLogLine::LogPointer]=-1;
 | 
						|
    log_fadeup_gain=RD_FADE_DEPTH;
 | 
						|
    log_has_custom_transition=false;
 | 
						|
  }
 | 
						|
  if((edge==RDLogLine::TrailingTrans)||(edge==RDLogLine::AllTrans)) {
 | 
						|
    log_end_point[RDLogLine::LogPointer]=-1;
 | 
						|
    log_fadedown_point[RDLogLine::LogPointer]=-1;
 | 
						|
    log_fadedown_gain=RD_FADE_DEPTH;
 | 
						|
    log_segue_start_point[RDLogLine::LogPointer]=-1;
 | 
						|
    log_segue_end_point[RDLogLine::LogPointer]=-1;
 | 
						|
    log_segue_gain=RD_FADE_DEPTH;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::id() const
 | 
						|
{
 | 
						|
  return log_id;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setId(int id)
 | 
						|
{
 | 
						|
  log_id=id;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::Status RDLogLine::status() const
 | 
						|
{
 | 
						|
  return log_status;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setStatus(RDLogLine::Status stat)
 | 
						|
{
 | 
						|
  log_status=stat;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::State RDLogLine::state() const
 | 
						|
{
 | 
						|
  return log_state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setState(RDLogLine::State state)
 | 
						|
{
 | 
						|
  log_state=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDCart::Validity RDLogLine::validity() const
 | 
						|
{
 | 
						|
  return log_validity;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDCart::Validity RDLogLine::validity(const QDateTime &datetime) const
 | 
						|
{
 | 
						|
  if(datetime.isNull()||log_end_datetime.isNull()) {
 | 
						|
    return log_validity;
 | 
						|
  }
 | 
						|
  if(datetime>log_end_datetime) {
 | 
						|
    return RDCart::NeverValid;
 | 
						|
  }
 | 
						|
  if(datetime<log_start_datetime) {
 | 
						|
    return RDCart::FutureValid;
 | 
						|
  }
 | 
						|
  return log_validity;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setValidity(RDCart::Validity valid)
 | 
						|
{
 | 
						|
  log_validity=valid;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
unsigned RDLogLine::pass() const
 | 
						|
{
 | 
						|
  return log_pass;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::incrementPass()
 | 
						|
{
 | 
						|
  log_pass++;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::clearPass()
 | 
						|
{
 | 
						|
  log_pass=0;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::zombified() const
 | 
						|
{
 | 
						|
  return log_zombified;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setZombified(bool state)
 | 
						|
{
 | 
						|
  log_zombified=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::evergreen() const
 | 
						|
{
 | 
						|
  return log_evergreen;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setEvergreen(bool state)
 | 
						|
{
 | 
						|
  log_evergreen=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::Source RDLogLine::source() const
 | 
						|
{
 | 
						|
  return log_source;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setSource(RDLogLine::Source src)
 | 
						|
{
 | 
						|
  log_source=src;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
unsigned RDLogLine::cartNumber() const
 | 
						|
{
 | 
						|
  return log_cart_number;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setCartNumber(unsigned cart)
 | 
						|
{
 | 
						|
  log_cart_number=cart;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QTime RDLogLine::startTime(RDLogLine::StartTimeType type) const
 | 
						|
{
 | 
						|
  return log_start_time[type];
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setStartTime(RDLogLine::StartTimeType type,QTime time)
 | 
						|
{
 | 
						|
  if(type==RDLogLine::Initial) {
 | 
						|
    log_start_time[RDLogLine::Actual]=time;
 | 
						|
  }
 | 
						|
  log_start_time[type]=time;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::graceTime() const
 | 
						|
{
 | 
						|
  return log_grace_time;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setGraceTime(int time)
 | 
						|
{
 | 
						|
  log_grace_time=time;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::TimeType RDLogLine::timeType() const
 | 
						|
{
 | 
						|
  return log_time_type;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setTimeType(RDLogLine::TimeType type)
 | 
						|
{
 | 
						|
  log_time_type=type;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::originUser() const
 | 
						|
{
 | 
						|
  return log_origin_user;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setOriginUser(const QString &username)
 | 
						|
{
 | 
						|
  log_origin_user=username;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QDateTime RDLogLine::originDateTime() const
 | 
						|
{
 | 
						|
  return log_origin_datetime;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setOriginDateTime(const QDateTime &datetime)
 | 
						|
{
 | 
						|
  log_origin_datetime=datetime;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::TransType RDLogLine::transType() const
 | 
						|
{
 | 
						|
  return log_trans_type;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setTransType(RDLogLine::TransType type)
 | 
						|
{
 | 
						|
  log_trans_type=type;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::startPoint(PointerSource ptr) const
 | 
						|
{
 | 
						|
  if(ptr==RDLogLine::AutoPointer) {
 | 
						|
    if(log_start_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_start_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    return log_start_point[RDLogLine::CartPointer];
 | 
						|
  }
 | 
						|
  return log_start_point[ptr];
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setStartPoint(int point,PointerSource ptr)
 | 
						|
{
 | 
						|
  log_start_point[ptr]=point;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::endPoint(PointerSource ptr) const
 | 
						|
{
 | 
						|
  if(ptr==RDLogLine::AutoPointer) {
 | 
						|
    if(log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_end_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    return log_end_point[RDLogLine::CartPointer];
 | 
						|
  }
 | 
						|
  return log_end_point[ptr];
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setEndPoint(int point,PointerSource ptr)
 | 
						|
{
 | 
						|
  log_end_point[ptr]=point;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::segueStartPoint(PointerSource ptr) const
 | 
						|
{
 | 
						|
  if(ptr==RDLogLine::AutoPointer) {
 | 
						|
    if(log_segue_start_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_segue_start_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    if(log_segue_start_point[RDLogLine::CartPointer]>=0) {
 | 
						|
      return log_segue_start_point[RDLogLine::CartPointer];
 | 
						|
    }
 | 
						|
    if(log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_end_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    return log_end_point[RDLogLine::CartPointer];
 | 
						|
  }
 | 
						|
  return log_segue_start_point[ptr];
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setSegueStartPoint(int point,PointerSource ptr)
 | 
						|
{
 | 
						|
  log_segue_start_point[ptr]=point;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::segueEndPoint(PointerSource ptr) const
 | 
						|
{
 | 
						|
  if(ptr==RDLogLine::AutoPointer) {
 | 
						|
    if(log_segue_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_segue_end_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    if(log_segue_end_point[RDLogLine::CartPointer]>=0) {
 | 
						|
      return log_segue_end_point[RDLogLine::CartPointer];
 | 
						|
    }
 | 
						|
    if(log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_end_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    return log_end_point[RDLogLine::CartPointer];
 | 
						|
  }
 | 
						|
  return log_segue_end_point[ptr];
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setSegueEndPoint(int point,PointerSource ptr)
 | 
						|
{
 | 
						|
  log_segue_end_point[ptr]=point;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::segueGain() const
 | 
						|
{
 | 
						|
  if(log_segue_gain>log_segue_gain_cut) {
 | 
						|
    return log_segue_gain;
 | 
						|
  }
 | 
						|
  else {
 | 
						|
    return log_segue_gain_cut;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setSegueGain(int gain)
 | 
						|
{
 | 
						|
  log_segue_gain=gain;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::fadeupPoint(RDLogLine::PointerSource ptr) const
 | 
						|
{
 | 
						|
  if(ptr==RDLogLine::AutoPointer) {
 | 
						|
    if(log_fadeup_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_fadeup_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    if(log_fadeup_point[RDLogLine::CartPointer]>=0) {
 | 
						|
      return log_fadeup_point[RDLogLine::CartPointer];
 | 
						|
    }
 | 
						|
    if(log_start_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_start_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    return log_start_point[RDLogLine::CartPointer];
 | 
						|
  }
 | 
						|
  return log_fadeup_point[ptr];
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setFadeupPoint(int point,RDLogLine::PointerSource ptr)
 | 
						|
{
 | 
						|
  log_fadeup_point[ptr]=point;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::fadeupGain() const
 | 
						|
{
 | 
						|
  return log_fadeup_gain;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setFadeupGain(int gain)
 | 
						|
{
 | 
						|
  log_fadeup_gain=gain;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::fadedownPoint(RDLogLine::PointerSource ptr) const
 | 
						|
{
 | 
						|
  if(ptr==RDLogLine::AutoPointer) {
 | 
						|
    if(log_fadedown_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_fadedown_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    if(log_fadedown_point[RDLogLine::CartPointer]>=0) {
 | 
						|
      return log_fadedown_point[RDLogLine::CartPointer];
 | 
						|
    }
 | 
						|
    if(log_start_point[RDLogLine::LogPointer]>=0) {
 | 
						|
      return log_end_point[RDLogLine::LogPointer];
 | 
						|
    }
 | 
						|
    return log_end_point[RDLogLine::CartPointer];
 | 
						|
  }
 | 
						|
  return log_fadedown_point[ptr];
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setFadedownPoint(int point,RDLogLine::PointerSource ptr)
 | 
						|
{
 | 
						|
  log_fadedown_point[ptr]=point;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::fadedownGain() const
 | 
						|
{
 | 
						|
  return log_fadedown_gain;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setFadedownGain(int gain)
 | 
						|
{
 | 
						|
  log_fadedown_gain=gain;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::duckUpGain() const
 | 
						|
{
 | 
						|
  return log_duck_up_gain;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setDuckUpGain(int gain)
 | 
						|
{
 | 
						|
  log_duck_up_gain=gain;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
int RDLogLine::duckDownGain() const
 | 
						|
{
 | 
						|
  return log_duck_down_gain;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setDuckDownGain(int gain)
 | 
						|
{
 | 
						|
  log_duck_down_gain=gain;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::talkStartPoint() const
 | 
						|
{
 | 
						|
  return log_talk_start;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setTalkStartPoint(int point)
 | 
						|
{
 | 
						|
  log_talk_start=point;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::talkEndPoint() const
 | 
						|
{
 | 
						|
  return log_talk_end;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setTalkEndPoint(int point)
 | 
						|
{
 | 
						|
  log_talk_end=point;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::hookMode() const
 | 
						|
{
 | 
						|
  return log_hook_mode;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setHookMode(bool state)
 | 
						|
{
 | 
						|
  log_hook_mode=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::hookStartPoint() const
 | 
						|
{
 | 
						|
  return log_hook_start;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setHookStartPoint(int point)
 | 
						|
{
 | 
						|
  log_hook_start=point;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::hookEndPoint() const
 | 
						|
{
 | 
						|
  return log_hook_end;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setHookEndPoint(int point)
 | 
						|
{
 | 
						|
  log_hook_end=point;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDCart::Type RDLogLine::cartType() const
 | 
						|
{
 | 
						|
  return log_cart_type;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setCartType(RDCart::Type type)
 | 
						|
{
 | 
						|
  log_cart_type=type;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::asyncronous() const
 | 
						|
{
 | 
						|
  return log_asyncronous;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setAsyncronous(bool state)
 | 
						|
{
 | 
						|
  log_asyncronous=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::groupName() const
 | 
						|
{
 | 
						|
  return log_group_name;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setGroupName(const QString &name)
 | 
						|
{
 | 
						|
  log_group_name=name;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QColor RDLogLine::groupColor() const
 | 
						|
{
 | 
						|
  return log_group_color;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setGroupColor(const QColor &color)
 | 
						|
{
 | 
						|
  log_group_color=color;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::title() const
 | 
						|
{
 | 
						|
  return log_title;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setTitle(const QString &title)
 | 
						|
{
 | 
						|
  log_title=title;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::artist() const
 | 
						|
{
 | 
						|
  return log_artist;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::publisher() const
 | 
						|
{
 | 
						|
  return log_publisher;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPublisher(const QString &pub)
 | 
						|
{
 | 
						|
  log_publisher=pub;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::composer() const
 | 
						|
{
 | 
						|
  return log_composer;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setComposer(const QString &composer)
 | 
						|
{
 | 
						|
  log_composer=composer;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setArtist(const QString &artist)
 | 
						|
{
 | 
						|
  log_artist=artist;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::album() const
 | 
						|
{
 | 
						|
  return log_album;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setAlbum(const QString &album)
 | 
						|
{
 | 
						|
  log_album=album;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QDate RDLogLine::year() const
 | 
						|
{
 | 
						|
  return log_year;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setYear(QDate year)
 | 
						|
{
 | 
						|
  log_year=year;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::isrc() const
 | 
						|
{
 | 
						|
  return log_isrc;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setIsrc(const QString &string)
 | 
						|
{
 | 
						|
  log_isrc=string;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::recordingMbId() const
 | 
						|
{
 | 
						|
  return log_recording_mbid;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setRecordingMbId(const QString &mbid)
 | 
						|
{
 | 
						|
  log_recording_mbid=mbid;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::releaseMbId() const
 | 
						|
{
 | 
						|
  return log_release_mbid;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setReleaseMbId(const QString &mbid)
 | 
						|
{
 | 
						|
  log_release_mbid=mbid;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::isci() const
 | 
						|
{
 | 
						|
  return log_isci;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setIsci(const QString &string)
 | 
						|
{
 | 
						|
  log_isci=string;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::label() const
 | 
						|
{
 | 
						|
  return log_label;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLabel(const QString &label)
 | 
						|
{
 | 
						|
  log_label=label;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::conductor() const
 | 
						|
{
 | 
						|
  return log_conductor;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setConductor(const QString &cond)
 | 
						|
{
 | 
						|
  log_conductor=cond;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::songId() const
 | 
						|
{
 | 
						|
  return log_song_id;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setSongId(const QString &id)
 | 
						|
{
 | 
						|
  log_song_id=id;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::client() const
 | 
						|
{
 | 
						|
  return log_client;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setClient(const QString &client)
 | 
						|
{
 | 
						|
  log_client=client;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::agency() const
 | 
						|
{
 | 
						|
  return log_agency;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setAgency(const QString &agency)
 | 
						|
{
 | 
						|
  log_agency=agency;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::outcue() const
 | 
						|
{
 | 
						|
  return log_outcue;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setOutcue(const QString &outcue)
 | 
						|
{
 | 
						|
  log_outcue=outcue;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::description() const
 | 
						|
{
 | 
						|
  return log_description;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setDescription(const QString &desc)
 | 
						|
{
 | 
						|
  log_description=desc;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::userDefined() const
 | 
						|
{
 | 
						|
  return log_user_defined;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setUserDefined(const QString &string)
 | 
						|
{
 | 
						|
  log_user_defined=string;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::cartNotes() const
 | 
						|
{
 | 
						|
  return log_cart_notes;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setCartNotes(const QString &str)
 | 
						|
{
 | 
						|
  log_cart_notes=str;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDCart::UsageCode RDLogLine::usageCode() const
 | 
						|
{
 | 
						|
  return log_usage_code;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setUsageCode(RDCart::UsageCode code)
 | 
						|
{
 | 
						|
  log_usage_code=code;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
unsigned RDLogLine::forcedLength() const
 | 
						|
{
 | 
						|
  return log_forced_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setForcedLength(unsigned len)
 | 
						|
{
 | 
						|
  log_forced_length=len;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
unsigned RDLogLine::averageSegueLength() const
 | 
						|
{
 | 
						|
  return log_average_segue_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setAverageSegueLength(unsigned len)
 | 
						|
{
 | 
						|
  log_average_segue_length=len;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
unsigned RDLogLine::cutQuantity() const
 | 
						|
{
 | 
						|
  return log_cut_quantity;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setCutQuantity(unsigned quan)
 | 
						|
{
 | 
						|
  log_cut_quantity=quan;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
unsigned RDLogLine::lastCutPlayed() const
 | 
						|
{
 | 
						|
  return log_last_cut_played;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLastCutPlayed(unsigned cut)
 | 
						|
{
 | 
						|
  log_last_cut_played=cut;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDCart::PlayOrder RDLogLine::playOrder() const
 | 
						|
{
 | 
						|
  return log_play_order;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPlayOrder(RDCart::PlayOrder order)
 | 
						|
{
 | 
						|
  log_play_order=order;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::enforceLength() const
 | 
						|
{
 | 
						|
  return log_enforce_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setEnforceLength(bool state)
 | 
						|
{
 | 
						|
  log_enforce_length=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::preservePitch() const
 | 
						|
{
 | 
						|
  return log_preserve_pitch;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPreservePitch(bool state)
 | 
						|
{
 | 
						|
  log_preserve_pitch=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QDateTime RDLogLine::startDatetime() const
 | 
						|
{
 | 
						|
  return log_start_datetime;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setStartDatetime(const QDateTime &datetime)
 | 
						|
{
 | 
						|
  log_start_datetime=datetime;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QDateTime RDLogLine::endDatetime() const
 | 
						|
{
 | 
						|
  return log_end_datetime;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setEndDatetime(const QDateTime &datetime)
 | 
						|
{
 | 
						|
  log_end_datetime=datetime;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDListViewItem *RDLogLine::listViewItem() const
 | 
						|
{
 | 
						|
  return log_listview;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setListViewItem(RDListViewItem *listview)
 | 
						|
{
 | 
						|
  log_listview=listview;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::Type RDLogLine::type() const
 | 
						|
{
 | 
						|
  return log_type;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setType(RDLogLine::Type type)
 | 
						|
{
 | 
						|
  log_type=type;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::markerComment() const
 | 
						|
{
 | 
						|
  return log_marker_comment;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setMarkerComment(const QString &str)
 | 
						|
{
 | 
						|
  log_marker_comment=str;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::markerLabel() const
 | 
						|
{
 | 
						|
  return log_marker_label;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setMarkerLabel(const QString &str)
 | 
						|
{
 | 
						|
  log_marker_label=str;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::deck() const
 | 
						|
{
 | 
						|
  return log_deck;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setDeck(int deck)
 | 
						|
{
 | 
						|
  log_deck=deck;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QObject *RDLogLine::playDeck()
 | 
						|
{
 | 
						|
  return log_play_deck;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPlayDeck(QObject *deck)
 | 
						|
{
 | 
						|
  log_play_deck=deck;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::portName() const
 | 
						|
{
 | 
						|
  return log_port_name;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPortName(const QString &name)
 | 
						|
{
 | 
						|
  log_port_name=name;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QTime RDLogLine::playTime() const
 | 
						|
{
 | 
						|
  return log_play_time;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPlayTime(QTime time)
 | 
						|
{
 | 
						|
  log_play_time=time;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QTime RDLogLine::extStartTime() const
 | 
						|
{
 | 
						|
  return log_ext_start_time;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setExtStartTime(QTime time)
 | 
						|
{
 | 
						|
  log_ext_start_time=time;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::extLength() const
 | 
						|
{
 | 
						|
  return log_ext_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setExtLength(int length)
 | 
						|
{
 | 
						|
  log_ext_length=length;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::extCartName() const
 | 
						|
{
 | 
						|
  return log_ext_cart_name;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setExtCartName(const QString &name)
 | 
						|
{
 | 
						|
  log_ext_cart_name=name;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::extData() const
 | 
						|
{
 | 
						|
  return log_ext_data;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setExtData(const QString &data)
 | 
						|
{
 | 
						|
  log_ext_data=data;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::extEventId() const
 | 
						|
{
 | 
						|
  return log_ext_event_id;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setExtEventId(const QString &id)
 | 
						|
{
 | 
						|
  log_ext_event_id=id;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::extAnncType() const
 | 
						|
{
 | 
						|
  return log_ext_annc_type;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setExtAnncType(const QString &type)
 | 
						|
{
 | 
						|
  log_ext_annc_type=type;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::cutNumber() const
 | 
						|
{
 | 
						|
  return log_cut_number;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setCutNumber(int cutnum)
 | 
						|
{
 | 
						|
  log_cut_number=cutnum;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::cutName() const
 | 
						|
{
 | 
						|
  return log_cut_name;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setCutName(const QString &cutname)
 | 
						|
{
 | 
						|
  log_cut_name=cutname;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::pauseCard() const
 | 
						|
{
 | 
						|
  return log_pause_card;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPauseCard(int card)
 | 
						|
{
 | 
						|
  log_pause_card=card;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::pausePort() const
 | 
						|
{
 | 
						|
  return log_pause_port;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPausePort(int port)
 | 
						|
{
 | 
						|
  log_pause_port=port;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::timescalingActive() const
 | 
						|
{
 | 
						|
  return log_timescaling_active;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setTimescalingActive(bool state)
 | 
						|
{
 | 
						|
  log_timescaling_active=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::effectiveLength() const
 | 
						|
{
 | 
						|
  if(log_cut_number<0) {
 | 
						|
    return log_forced_length;
 | 
						|
  }
 | 
						|
  return log_effective_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::talkLength() const
 | 
						|
{
 | 
						|
  return log_talk_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::segueLength(RDLogLine::TransType next_trans)
 | 
						|
{
 | 
						|
  switch(type()) {
 | 
						|
      case RDLogLine::Cart:
 | 
						|
	switch(next_trans) {
 | 
						|
	    case RDLogLine::Stop:
 | 
						|
	    case RDLogLine::Play:
 | 
						|
	      return log_effective_length;
 | 
						|
	      
 | 
						|
	    case RDLogLine::Segue:
 | 
						|
	      if(segueStartPoint(RDLogLine::AutoPointer)<0) {
 | 
						|
		return log_effective_length;
 | 
						|
	      }
 | 
						|
	      return segueStartPoint(RDLogLine::AutoPointer)-
 | 
						|
		startPoint(RDLogLine::AutoPointer);
 | 
						|
 | 
						|
	    default:
 | 
						|
	      break;
 | 
						|
	}
 | 
						|
	break;
 | 
						|
 | 
						|
      case RDLogLine::Macro:
 | 
						|
	return log_effective_length;
 | 
						|
 | 
						|
      case RDLogLine::Marker:
 | 
						|
	return 0;
 | 
						|
 | 
						|
      default:
 | 
						|
	break;
 | 
						|
  }
 | 
						|
  return 0;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::segueTail(RDLogLine::TransType next_trans)
 | 
						|
{
 | 
						|
  switch(type()) {
 | 
						|
      case RDLogLine::Cart:
 | 
						|
	switch(next_trans) {
 | 
						|
	    case RDLogLine::Stop:
 | 
						|
	    case RDLogLine::Play:
 | 
						|
	      return 0;
 | 
						|
	      
 | 
						|
	    case RDLogLine::Segue:
 | 
						|
	      return segueEndPoint(RDLogLine::AutoPointer)-
 | 
						|
		segueStartPoint(RDLogLine::AutoPointer);
 | 
						|
 | 
						|
	    default:
 | 
						|
	      break;
 | 
						|
	}
 | 
						|
	break;
 | 
						|
 | 
						|
      default:
 | 
						|
	return 0;
 | 
						|
  }
 | 
						|
  return 0;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::forcedStop() const
 | 
						|
{
 | 
						|
  return log_forced_stop;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::hasCustomTransition() const
 | 
						|
{
 | 
						|
  return log_has_custom_transition;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setHasCustomTransition(bool state)
 | 
						|
{
 | 
						|
  log_has_custom_transition=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
unsigned RDLogLine::playPosition() const
 | 
						|
{
 | 
						|
  return log_play_position;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPlayPosition(unsigned pos)
 | 
						|
{
 | 
						|
  log_play_position=pos;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::playPositionChanged() const
 | 
						|
{
 | 
						|
  return log_play_position_changed;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setPlayPositionChanged(bool state)
 | 
						|
{
 | 
						|
  log_play_position_changed=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::nowNextEnabled() const
 | 
						|
{
 | 
						|
  return log_now_next_enabled;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setNowNextEnabled(bool state)
 | 
						|
{
 | 
						|
  log_now_next_enabled=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::useEventLength() const
 | 
						|
{
 | 
						|
  return log_use_event_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setUseEventLength(bool state)
 | 
						|
{
 | 
						|
  log_use_event_length=state;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::eventLength() const
 | 
						|
{
 | 
						|
  return log_event_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setEventLength(int msec)
 | 
						|
{
 | 
						|
  log_event_length=msec;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::linkEventName() const
 | 
						|
{
 | 
						|
  return log_link_event_name;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLinkEventName(const QString &name)
 | 
						|
{
 | 
						|
  log_link_event_name=name;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QTime RDLogLine::linkStartTime() const
 | 
						|
{
 | 
						|
  return log_link_start_time;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLinkStartTime(const QTime &time)
 | 
						|
{
 | 
						|
  log_link_start_time=time;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::linkLength() const
 | 
						|
{
 | 
						|
  return log_link_length;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLinkLength(int msecs)
 | 
						|
{
 | 
						|
  log_link_length=msecs;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::linkStartSlop() const
 | 
						|
{
 | 
						|
  return log_link_start_slop;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLinkStartSlop(int msecs)
 | 
						|
{
 | 
						|
  log_link_start_slop=msecs;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::linkEndSlop() const
 | 
						|
{
 | 
						|
  return log_link_end_slop;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLinkEndSlop(int msecs)
 | 
						|
{
 | 
						|
  log_link_end_slop=msecs;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int RDLogLine::linkId() const
 | 
						|
{
 | 
						|
  return log_link_id;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLinkId(int id)
 | 
						|
{
 | 
						|
  log_link_id=id;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
bool RDLogLine::linkEmbedded() const
 | 
						|
{
 | 
						|
  return log_link_embedded;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setLinkEmbedded(bool state)
 | 
						|
{
 | 
						|
  log_link_embedded=state;
 | 
						|
  modified=true;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::StartSource RDLogLine::startSource() const
 | 
						|
{
 | 
						|
  return log_start_source;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::setStartSource(RDLogLine::StartSource src)
 | 
						|
{
 | 
						|
  log_start_source=src;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::resolveWildcards(QString pattern,int log_id)
 | 
						|
{
 | 
						|
  //  MAINTAINERS'S NOTE: These mappings must be kept in sync with those
 | 
						|
  //                      of the 'resolvePadFields()' method in
 | 
						|
  //                      'apis/PyPAD/api/PyPAD.py'!
 | 
						|
 | 
						|
  pattern.replace("%a",artist());
 | 
						|
  pattern.replace("%b",label());
 | 
						|
  pattern.replace("%c",client());
 | 
						|
  pattern=RDLogLine::resolveNowNextDateTime(pattern,"%d(",startDatetime());
 | 
						|
  pattern.replace("%e",agency());
 | 
						|
  // %f [unassigned]
 | 
						|
  pattern.replace("%g",groupName());
 | 
						|
  pattern.replace("%h",QString().sprintf("%d",effectiveLength()));
 | 
						|
  pattern.replace("%i",description());
 | 
						|
  pattern.replace("%j",QString().sprintf("%03d",cutNumber()));
 | 
						|
  // %k rdimport(1) parameter
 | 
						|
  pattern.replace("%l",album());
 | 
						|
  pattern.replace("%m",composer());
 | 
						|
  pattern.replace("%n",QString().sprintf("%06u",cartNumber()));
 | 
						|
  pattern.replace("%o",outcue());
 | 
						|
  pattern.replace("%p",publisher());
 | 
						|
  // %q rdimport(1) parameter
 | 
						|
  pattern.replace("%r",conductor());
 | 
						|
  pattern.replace("%s",songId());
 | 
						|
  pattern.replace("%t",title());
 | 
						|
  pattern.replace("%u",userDefined());
 | 
						|
  pattern.replace("%v",QString().sprintf("%d",effectiveLength()/1000));
 | 
						|
  pattern.replace("%wc",isci());
 | 
						|
  pattern.replace("%wi",isrc());
 | 
						|
  pattern.replace("%wm",recordingMbId());
 | 
						|
  pattern.replace("%wr",releaseMbId());
 | 
						|
  if(log_id<0) {
 | 
						|
    pattern.replace("%x",QString().sprintf("%d",id()));
 | 
						|
  }
 | 
						|
  else {
 | 
						|
    pattern.replace("%x",QString().sprintf("%d",log_id));
 | 
						|
  }
 | 
						|
  pattern.replace("%y",QString().sprintf("%d",year().year()));
 | 
						|
  // %z Log Line Number
 | 
						|
 | 
						|
  return pattern;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
RDLogLine::State RDLogLine::setEvent(int mach,RDLogLine::TransType next_type,
 | 
						|
				     bool timescale,int len)
 | 
						|
{
 | 
						|
  RDCart *cart;
 | 
						|
  RDMacroEvent *rml_event;
 | 
						|
  QString sql;
 | 
						|
  RDSqlQuery *q;
 | 
						|
  double time_ratio=1.0;
 | 
						|
 | 
						|
  switch(log_type) {
 | 
						|
  case RDLogLine::Cart:
 | 
						|
    cart=new RDCart(log_cart_number);
 | 
						|
    if(!cart->exists()) {
 | 
						|
      delete cart;
 | 
						|
      rda->syslog(LOG_USER|LOG_DEBUG,
 | 
						|
		  "RDLogLine::setEvent(): no such cart, CART=%06u",
 | 
						|
		  log_cart_number);
 | 
						|
      log_state=RDLogLine::NoCart;
 | 
						|
      return RDLogLine::NoCart;
 | 
						|
    }
 | 
						|
    cart->selectCut(&log_cut_name);
 | 
						|
    if(log_cut_name.isEmpty()) {
 | 
						|
      delete cart;
 | 
						|
      log_state=RDLogLine::NoCut;
 | 
						|
      return RDLogLine::NoCut;
 | 
						|
    }
 | 
						|
    log_cut_number=log_cut_name.right(3).toInt();
 | 
						|
    sql=QString("select ")+
 | 
						|
      "LENGTH,"+                // 00
 | 
						|
      "START_POINT,"+           // 01
 | 
						|
      "END_POINT,"+             // 02
 | 
						|
      "SEGUE_START_POINT,"+     // 03
 | 
						|
      "SEGUE_END_POINT,"+       // 04
 | 
						|
      "SEGUE_GAIN,"+            // 05
 | 
						|
      "TALK_START_POINT,"+      // 06
 | 
						|
      "TALK_END_POINT,"+        // 07
 | 
						|
      "HOOK_START_POINT,"+      // 08
 | 
						|
      "HOOK_END_POINT,"+        // 09
 | 
						|
      "OUTCUE,"+                // 10
 | 
						|
      "ISRC,"+                  // 11
 | 
						|
      "ISCI,"+                  // 12
 | 
						|
      "DESCRIPTION,"+           // 13
 | 
						|
      "RECORDING_MBID,"+        // 14
 | 
						|
      "RELEASE_MBID "+          // 15
 | 
						|
      "from CUTS where CUT_NAME=\""+RDEscapeString(log_cut_name)+"\"";
 | 
						|
    q=new RDSqlQuery(sql);
 | 
						|
    if(!q->first()) {
 | 
						|
      delete q;
 | 
						|
      delete cart;
 | 
						|
      rda->syslog(LOG_DEBUG,
 | 
						|
		  "RDLogLine::setEvent(): no cut record found, SQL=%s",
 | 
						|
		  (const char *)sql);
 | 
						|
      log_state=RDLogLine::NoCut;
 | 
						|
      return RDLogLine::NoCut;
 | 
						|
    }
 | 
						|
    if(q->value(0).toInt()==0) {
 | 
						|
      delete q;
 | 
						|
      delete cart;
 | 
						|
      rda->syslog(LOG_DEBUG,
 | 
						|
		  "RDLogLine::setEvent(): zero length cut audio, SQL=%s",
 | 
						|
		  (const char *)sql);
 | 
						|
      log_state=RDLogLine::NoCut;
 | 
						|
      return RDLogLine::NoCut;
 | 
						|
    }
 | 
						|
    if(timescale) {
 | 
						|
      if(len>0) {
 | 
						|
       log_effective_length=len;
 | 
						|
       log_forced_length=len;
 | 
						|
      }
 | 
						|
      else {
 | 
						|
       if(log_hook_mode&&
 | 
						|
          (q->value(8).toInt()>=0)&&(q->value(9).toInt()>=0)) {
 | 
						|
         log_effective_length=q->value(9).toInt()-q->value(8).toInt();
 | 
						|
         log_forced_length=log_effective_length;
 | 
						|
         time_ratio=1.0;
 | 
						|
         timescale=false;
 | 
						|
       }
 | 
						|
       else {
 | 
						|
         log_effective_length=cart->forcedLength();
 | 
						|
         time_ratio=(double)log_forced_length/
 | 
						|
           (q->value(2).toDouble()-q->value(1).toDouble());
 | 
						|
	 /*
 | 
						|
	  * FIXME: timescale limits need to be applied here
 | 
						|
	  *
 | 
						|
         if(((1.0/time_ratio)<(1.0-log_timescale_limit))||
 | 
						|
            ((1.0/time_ratio)>(1.0+log_timescale_limit))) {
 | 
						|
           timescale=false;
 | 
						|
	 }
 | 
						|
	 */
 | 
						|
       }
 | 
						|
      }
 | 
						|
    }
 | 
						|
    if(timescale) {
 | 
						|
      log_start_point[0]=(int)(q->value(1).toDouble()*time_ratio);
 | 
						|
      log_end_point[0]=(int)(q->value(2).toDouble()*time_ratio);
 | 
						|
      if(q->value(3).toInt()>=0) {
 | 
						|
	log_segue_start_point[0]=(int)(q->value(3).toDouble()*time_ratio);
 | 
						|
	log_segue_end_point[0]=(int)(q->value(4).toDouble()*time_ratio);
 | 
						|
      }
 | 
						|
      else {
 | 
						|
	log_segue_start_point[0]=-1;
 | 
						|
	log_segue_end_point[0]=-1;
 | 
						|
      }
 | 
						|
      if(log_talk_start>=0) {
 | 
						|
	log_talk_start=(int)((double)log_talk_start*time_ratio);
 | 
						|
	log_talk_end=(int)(q->value(7).toDouble()*time_ratio);
 | 
						|
      }
 | 
						|
      else {
 | 
						|
	log_talk_start=-1;
 | 
						|
	log_talk_end=-1;
 | 
						|
      }
 | 
						|
      log_talk_length=log_talk_end-log_talk_start;
 | 
						|
    }
 | 
						|
    else {
 | 
						|
      if(log_hook_mode&&
 | 
						|
	 (q->value(8).toInt()>=0)&&(q->value(9).toInt()>=0)) {
 | 
						|
	log_start_point[0]=q->value(8).toInt();
 | 
						|
	log_end_point[0]=q->value(9).toInt();
 | 
						|
	log_segue_start_point[0]=-1;
 | 
						|
	log_segue_end_point[0]=-1;
 | 
						|
	log_talk_start=-1;
 | 
						|
	log_talk_end=-1;
 | 
						|
      }
 | 
						|
      else {
 | 
						|
       log_start_point[0]=q->value(1).toInt();
 | 
						|
       log_end_point[0]=q->value(2).toInt();
 | 
						|
       if(log_start_point[RDLogLine::LogPointer]>=0 ||
 | 
						|
          log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
         log_effective_length=log_end_point[RDLogLine::LogPointer]-
 | 
						|
           log_start_point[RDLogLine::LogPointer];
 | 
						|
       }
 | 
						|
       else {
 | 
						|
         log_effective_length=q->value(0).toUInt();
 | 
						|
       }
 | 
						|
       log_segue_start_point[0]=q->value(3).toInt();
 | 
						|
       log_segue_end_point[0]=q->value(4).toInt();
 | 
						|
       log_talk_start=q->value(6).toInt();
 | 
						|
       log_talk_end=q->value(7).toInt();
 | 
						|
      }
 | 
						|
      log_hook_start=q->value(8).toInt();
 | 
						|
      log_hook_end=q->value(9).toInt();
 | 
						|
      if(log_talk_end>log_end_point[RDLogLine::LogPointer] && 
 | 
						|
        log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
       log_talk_end=log_end_point[RDLogLine::LogPointer];
 | 
						|
      }
 | 
						|
      if(log_talk_end<log_start_point[RDLogLine::LogPointer]) {
 | 
						|
       log_talk_end=0;
 | 
						|
       log_talk_start=0;
 | 
						|
      }
 | 
						|
      else {
 | 
						|
       if(log_talk_start<log_start_point[RDLogLine::LogPointer]) {
 | 
						|
         log_talk_start=0;
 | 
						|
         log_talk_end-=log_start_point[RDLogLine::LogPointer];
 | 
						|
       }
 | 
						|
       if(log_talk_start>log_end_point[RDLogLine::LogPointer] &&
 | 
						|
          log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
         log_talk_start=0;
 | 
						|
         log_talk_end=0;
 | 
						|
       }
 | 
						|
      }
 | 
						|
      log_talk_length=log_talk_end-log_talk_start;
 | 
						|
    }
 | 
						|
    if(segueStartPoint(RDLogLine::AutoPointer)<0) {
 | 
						|
      log_average_segue_length=cart->averageSegueLength();
 | 
						|
    }
 | 
						|
    else {
 | 
						|
      log_average_segue_length=segueStartPoint(RDLogLine::AutoPointer)-
 | 
						|
       startPoint(RDLogLine::AutoPointer);
 | 
						|
    }
 | 
						|
    log_outcue=q->value(10).toString();
 | 
						|
    log_isrc=q->value(11).toString();
 | 
						|
    log_isci=q->value(12).toString();
 | 
						|
    log_description=q->value(13).toString();
 | 
						|
    log_recording_mbid=q->value(14).toString();
 | 
						|
    log_release_mbid=q->value(15).toString();
 | 
						|
    log_segue_gain_cut=q->value(5).toInt();
 | 
						|
    delete q;
 | 
						|
    delete cart;
 | 
						|
    break;
 | 
						|
 | 
						|
  case RDLogLine::Macro:
 | 
						|
    cart=new RDCart(log_cart_number);
 | 
						|
    log_effective_length=cart->forcedLength();
 | 
						|
    log_average_segue_length=log_effective_length;
 | 
						|
    log_forced_stop=false;
 | 
						|
    rml_event=new RDMacroEvent();
 | 
						|
    rml_event->load(cart->number());
 | 
						|
    for(int i=0;i<rml_event->size();i++) {
 | 
						|
      if(rml_event->command(i)->command()==RDMacro::LL) {
 | 
						|
       if(rml_event->command(i)->arg(0).toInt()==mach) {
 | 
						|
         log_forced_stop=true;
 | 
						|
       }
 | 
						|
      }
 | 
						|
    }
 | 
						|
    log_start_point[0]=-1;
 | 
						|
    log_end_point[0]=-1;
 | 
						|
    log_segue_start_point[0]=-1;
 | 
						|
    log_segue_end_point[0]=-1;
 | 
						|
    log_talk_length=0;
 | 
						|
    log_talk_start=-1;
 | 
						|
    log_talk_end=-1;
 | 
						|
    log_segue_gain_cut=0;
 | 
						|
    delete rml_event;
 | 
						|
    delete cart;
 | 
						|
    break;
 | 
						|
 | 
						|
  case RDLogLine::Chain:
 | 
						|
  case RDLogLine::CloseBracket:
 | 
						|
  case RDLogLine::Marker:
 | 
						|
  case RDLogLine::MusicLink:
 | 
						|
  case RDLogLine::OpenBracket:
 | 
						|
  case RDLogLine::Track:
 | 
						|
  case RDLogLine::TrafficLink:
 | 
						|
  case RDLogLine::UnknownType:
 | 
						|
    log_cut_number=0;
 | 
						|
    log_cut_name="";
 | 
						|
    log_effective_length=0;
 | 
						|
    log_average_segue_length=0;
 | 
						|
    log_forced_stop=false;
 | 
						|
    log_start_point[0]=-1;
 | 
						|
    log_end_point[0]=-1;
 | 
						|
    log_segue_start_point[0]=-1;
 | 
						|
    log_segue_end_point[0]=-1;
 | 
						|
    log_talk_length=0;
 | 
						|
    log_talk_start=-1;
 | 
						|
    log_talk_end=-1;
 | 
						|
    log_segue_gain_cut=0;
 | 
						|
    log_state=RDLogLine::Ok;
 | 
						|
    break;
 | 
						|
  }
 | 
						|
  return RDLogLine::Ok;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::loadCart(int cartnum,RDLogLine::TransType next_type,int mach,
 | 
						|
			 bool timescale,RDLogLine::TransType type,int len)
 | 
						|
{
 | 
						|
  loadCart(cartnum);
 | 
						|
 | 
						|
  if(len>=0) {
 | 
						|
    log_forced_length=len;
 | 
						|
    log_enforce_length=true;
 | 
						|
  }
 | 
						|
  if(type!=RDLogLine::NoTrans) {
 | 
						|
    log_trans_type=type;
 | 
						|
  }
 | 
						|
  log_state=setEvent(mach,next_type,timescale);
 | 
						|
  log_timescaling_active=log_enforce_length&×cale;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::loadCart(int cartnum,int cutnum)
 | 
						|
{
 | 
						|
  QString sql=QString("select ")+
 | 
						|
    "CART.TYPE,"+                  // 00
 | 
						|
    "CART.GROUP_NAME,"+            // 01
 | 
						|
    "CART.TITLE,"+                 // 02
 | 
						|
    "CART.ARTIST,"+                // 03
 | 
						|
    "CART.ALBUM,"+                 // 04
 | 
						|
    "CART.YEAR,"+                  // 05
 | 
						|
    "CART.LABEL,"+                 // 06
 | 
						|
    "CART.CLIENT,"+                // 07
 | 
						|
    "CART.AGENCY,"+                // 08
 | 
						|
    "CART.USER_DEFINED,"+          // 09
 | 
						|
    "CART.CONDUCTOR,"+             // 10
 | 
						|
    "CART.SONG_ID,"+               // 11
 | 
						|
    "CART.FORCED_LENGTH,"+         // 12
 | 
						|
    "CART.CUT_QUANTITY,"+          // 13
 | 
						|
    "CART.LAST_CUT_PLAYED,"+       // 14
 | 
						|
    "CART.PLAY_ORDER,"+            // 15
 | 
						|
    "CART.START_DATETIME,"+        // 16
 | 
						|
    "CART.END_DATETIME,"+          // 17
 | 
						|
    "CART.ENFORCE_LENGTH,"+        // 18
 | 
						|
    "CART.PRESERVE_PITCH,"+        // 19
 | 
						|
    "GROUPS.ENABLE_NOW_NEXT,"+     // 20
 | 
						|
    "CART.ASYNCRONOUS,"+           // 21
 | 
						|
    "CART.PUBLISHER,"+             // 22
 | 
						|
    "CART.COMPOSER,"+              // 23
 | 
						|
    "CART.USAGE_CODE,"+            // 24
 | 
						|
    "CART.AVERAGE_SEGUE_LENGTH,"+  // 25
 | 
						|
    "CART.NOTES,"+                 // 26
 | 
						|
    "GROUPS.COLOR "+               // 27
 | 
						|
    "from CART left join GROUPS "+
 | 
						|
    "on CART.GROUP_NAME=GROUPS.NAME where "+
 | 
						|
    QString().sprintf("(CART.NUMBER=%d)",cartnum);
 | 
						|
  RDSqlQuery *q=new RDSqlQuery(sql);
 | 
						|
  if(!q->first()) {
 | 
						|
    delete q;
 | 
						|
    log_state=RDLogLine::NoCart;
 | 
						|
    return;
 | 
						|
  }
 | 
						|
  log_cart_number=cartnum;
 | 
						|
  log_cart_type=(RDCart::Type)q->value(0).toInt();
 | 
						|
  switch((RDCart::Type)q->value(0).toInt()) {
 | 
						|
      case RDCart::Audio:
 | 
						|
	log_type=RDLogLine::Cart;
 | 
						|
	break;
 | 
						|
 | 
						|
      case RDCart::Macro:
 | 
						|
	log_type=RDLogLine::Macro;
 | 
						|
	break;
 | 
						|
 | 
						|
      default:
 | 
						|
	break;
 | 
						|
  }
 | 
						|
  log_group_name=q->value(1).toString();
 | 
						|
  log_title=q->value(2).toString();
 | 
						|
  log_artist=q->value(3).toString();
 | 
						|
  log_album=q->value(4).toString();
 | 
						|
  log_year=q->value(5).toDate();
 | 
						|
  log_label=q->value(6).toString();
 | 
						|
  log_client=q->value(7).toString();
 | 
						|
  log_agency=q->value(8).toString();
 | 
						|
  log_user_defined=q->value(9).toString();
 | 
						|
  log_conductor=q->value(10).toString();
 | 
						|
  log_song_id=q->value(11).toString();
 | 
						|
  log_cut_quantity=q->value(13).toUInt();
 | 
						|
  log_last_cut_played=q->value(14).toUInt();
 | 
						|
  log_play_order=(RDCart::PlayOrder)q->value(15).toInt();
 | 
						|
  log_start_datetime=q->value(16).toDateTime();
 | 
						|
  log_end_datetime=q->value(17).toDateTime();
 | 
						|
  log_forced_length=q->value(12).toUInt();
 | 
						|
  log_enforce_length=RDBool(q->value(18).toString());
 | 
						|
  log_preserve_pitch=RDBool(q->value(19).toString());
 | 
						|
  log_now_next_enabled=RDBool(q->value(20).toString());
 | 
						|
  log_asyncronous=RDBool(q->value(21).toString());
 | 
						|
  log_publisher=q->value(22).toString();
 | 
						|
  log_composer=q->value(23).toString();
 | 
						|
  log_usage_code=(RDCart::UsageCode)q->value(24).toInt();
 | 
						|
  log_average_segue_length=q->value(25).toInt();
 | 
						|
  log_cart_notes=q->value(26).toString();
 | 
						|
  log_group_color=QColor(q->value(27).toString());
 | 
						|
  log_play_source=RDLogLine::UnknownSource;
 | 
						|
  delete q;
 | 
						|
 | 
						|
  if(cutnum>0) {
 | 
						|
    sql=QString("select ")+
 | 
						|
      "LENGTH,"+                // 00
 | 
						|
      "START_POINT,"+           // 01
 | 
						|
      "END_POINT,"+             // 02
 | 
						|
      "SEGUE_START_POINT,"+     // 03
 | 
						|
      "SEGUE_END_POINT,"+       // 04
 | 
						|
      "SEGUE_GAIN,"+            // 05
 | 
						|
      "TALK_START_POINT,"+      // 06
 | 
						|
      "TALK_END_POINT,"+        // 07
 | 
						|
      "HOOK_START_POINT,"+      // 08
 | 
						|
      "HOOK_END_POINT,"+        // 09
 | 
						|
      "OUTCUE,"+                // 10
 | 
						|
      "ISRC,"+                  // 11
 | 
						|
      "ISCI,"+                  // 12
 | 
						|
      "DESCRIPTION,"+           // 13
 | 
						|
      "RECORDING_MBID,"+        // 14
 | 
						|
      "RELEASE_MBID "+          // 15
 | 
						|
      "from CUTS where CUT_NAME=\""+RDCut::cutName(cartnum,cutnum)+"\"";
 | 
						|
    q=new RDSqlQuery(sql);
 | 
						|
    if(q->first()) {
 | 
						|
      if(log_hook_mode &&(q->value(8).toInt()>=0)&&(q->value(9).toInt()>=0)) {
 | 
						|
	log_start_point[0]=q->value(8).toInt();
 | 
						|
	log_end_point[0]=q->value(9).toInt();
 | 
						|
	log_segue_start_point[0]=-1;
 | 
						|
	log_segue_end_point[0]=-1;
 | 
						|
	log_talk_start=-1;
 | 
						|
	log_talk_end=-1;
 | 
						|
      }
 | 
						|
      else {
 | 
						|
       log_start_point[0]=q->value(1).toInt();
 | 
						|
       log_end_point[0]=q->value(2).toInt();
 | 
						|
       if(log_start_point[RDLogLine::LogPointer]>=0 ||
 | 
						|
          log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
         log_effective_length=log_end_point[RDLogLine::LogPointer]-
 | 
						|
           log_start_point[RDLogLine::LogPointer];
 | 
						|
       }
 | 
						|
       else {
 | 
						|
         log_effective_length=q->value(0).toUInt();
 | 
						|
       }
 | 
						|
       log_segue_start_point[0]=q->value(3).toInt();
 | 
						|
       log_segue_end_point[0]=q->value(4).toInt();
 | 
						|
       log_talk_start=q->value(6).toInt();
 | 
						|
       log_talk_end=q->value(7).toInt();
 | 
						|
      }
 | 
						|
      log_hook_start=q->value(8).toInt();
 | 
						|
      log_hook_end=q->value(9).toInt();
 | 
						|
      if(log_talk_end>log_end_point[RDLogLine::LogPointer] && 
 | 
						|
        log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
       log_talk_end=log_end_point[RDLogLine::LogPointer];
 | 
						|
      }
 | 
						|
      if(log_talk_end<log_start_point[RDLogLine::LogPointer]) {
 | 
						|
       log_talk_end=0;
 | 
						|
       log_talk_start=0;
 | 
						|
      }
 | 
						|
      else {
 | 
						|
       if(log_talk_start<log_start_point[RDLogLine::LogPointer]) {
 | 
						|
         log_talk_start=0;
 | 
						|
         log_talk_end-=log_start_point[RDLogLine::LogPointer];
 | 
						|
       }
 | 
						|
       if(log_talk_start>log_end_point[RDLogLine::LogPointer] &&
 | 
						|
          log_end_point[RDLogLine::LogPointer]>=0) {
 | 
						|
         log_talk_start=0;
 | 
						|
         log_talk_end=0;
 | 
						|
       }
 | 
						|
      }
 | 
						|
      log_talk_length=log_talk_end-log_talk_start;
 | 
						|
    }
 | 
						|
    if(segueStartPoint(RDLogLine::AutoPointer)>=0) {
 | 
						|
      log_average_segue_length=segueStartPoint(RDLogLine::AutoPointer)-
 | 
						|
       startPoint(RDLogLine::AutoPointer);
 | 
						|
    }
 | 
						|
    log_outcue=q->value(10).toString();
 | 
						|
    log_isrc=q->value(11).toString();
 | 
						|
    log_isci=q->value(12).toString();
 | 
						|
    log_description=q->value(13).toString();
 | 
						|
    log_recording_mbid=q->value(14).toString();
 | 
						|
    log_release_mbid=q->value(15).toString();
 | 
						|
    log_segue_gain_cut=q->value(5).toInt();
 | 
						|
    delete q;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void RDLogLine::refreshPointers()
 | 
						|
{
 | 
						|
  if(log_cut_name.isEmpty()) {
 | 
						|
    return;
 | 
						|
  }
 | 
						|
  QString sql;
 | 
						|
  RDSqlQuery *q;
 | 
						|
 | 
						|
  sql=QString("select ")+
 | 
						|
    "START_POINT,"+        // 00
 | 
						|
    "END_POINT,"+          // 01
 | 
						|
    "SEGUE_START_POINT,"+  // 02
 | 
						|
    "SEGUE_END_POINT,"+    // 03
 | 
						|
    "TALK_START_POINT,"+   // 04
 | 
						|
    "TALK_END_POINT,"+     // 05
 | 
						|
    "FADEUP_POINT,"+       // 06
 | 
						|
    "FADEDOWN_POINT,"+     // 07
 | 
						|
    "HOOK_START_POINT,"+   // 08
 | 
						|
    "HOOK_END_POINT "+     // 09
 | 
						|
    "from CUTS where "+
 | 
						|
    "CUT_NAME=\""+RDEscapeString(log_cut_name)+"\"";
 | 
						|
  q=new RDSqlQuery(sql);
 | 
						|
  if(q->first()) {
 | 
						|
    log_start_point[RDLogLine::CartPointer]=q->value(0).toInt();
 | 
						|
    log_end_point[RDLogLine::CartPointer]=q->value(1).toInt();
 | 
						|
    log_segue_start_point[RDLogLine::CartPointer]=q->value(2).toInt();
 | 
						|
    log_segue_end_point[RDLogLine::CartPointer]=q->value(3).toInt();
 | 
						|
    log_talk_start=q->value(4).toInt();
 | 
						|
    log_talk_end=q->value(5).toInt();
 | 
						|
    log_talk_length=log_talk_end-log_talk_start;
 | 
						|
    log_fadeup_point[RDLogLine::CartPointer]=q->value(6).toInt();
 | 
						|
    log_fadedown_point[RDLogLine::CartPointer]=q->value(7).toInt();
 | 
						|
    log_hook_start=q->value(8).toInt();
 | 
						|
    log_hook_end=q->value(9).toInt();
 | 
						|
  }
 | 
						|
  delete q;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::xml(int line) const
 | 
						|
{
 | 
						|
  QString ret;
 | 
						|
  ret+="  <logLine>\n";
 | 
						|
  ret+="    "+RDXmlField("line",line);
 | 
						|
  ret+="    "+RDXmlField("id",id());
 | 
						|
  ret+="    "+RDXmlField("type",RDLogLine::typeText(type()));
 | 
						|
  ret+="    "+RDXmlField("cartType",RDCart::typeText(cartType()));
 | 
						|
  ret+="    "+RDXmlField("cartNumber",cartNumber());
 | 
						|
  ret+="    "+RDXmlField("cutNumber",cutNumber());
 | 
						|
  ret+="    "+RDXmlField("groupName",groupName());
 | 
						|
  ret+="    "+RDXmlField("groupColor",groupColor().name());
 | 
						|
  ret+="    "+RDXmlField("title",title());
 | 
						|
  ret+="    "+RDXmlField("artist",artist());
 | 
						|
  ret+="    "+RDXmlField("publisher",publisher());
 | 
						|
  ret+="    "+RDXmlField("composer",composer());
 | 
						|
  ret+="    "+RDXmlField("album",album());
 | 
						|
  ret+="    "+RDXmlField("label",label());
 | 
						|
  if(year().isValid()) {
 | 
						|
    ret+="    "+RDXmlField("year",year().year());
 | 
						|
  }
 | 
						|
  else {
 | 
						|
    ret+="    "+RDXmlField("year");
 | 
						|
  }
 | 
						|
  ret+="    "+RDXmlField("client",client());
 | 
						|
  ret+="    "+RDXmlField("agency",agency());
 | 
						|
  ret+="    "+RDXmlField("conductor",conductor());
 | 
						|
  ret+="    "+RDXmlField("userDefined",userDefined());
 | 
						|
  ret+="    "+RDXmlField("usageCode",usageCode());
 | 
						|
  ret+="    "+RDXmlField("enforceLength",enforceLength());
 | 
						|
  ret+="    "+RDXmlField("forcedLength",RDGetTimeLength(forcedLength(),true));
 | 
						|
  ret+="    "+RDXmlField("evergreen",evergreen());
 | 
						|
  ret+="    "+RDXmlField("source",RDLogLine::sourceText(source()));
 | 
						|
  ret+="    "+RDXmlField("timeType",RDLogLine::timeTypeText(timeType()));
 | 
						|
  if(startTime(RDLogLine::Logged).isValid()&&
 | 
						|
     (!startTime(RDLogLine::Logged).isNull())) {
 | 
						|
    ret+="    "+RDXmlField("startTime",startTime(RDLogLine::Logged).
 | 
						|
			   toString("hh:mm:ss.zzz"));
 | 
						|
  }
 | 
						|
  else {
 | 
						|
    if(timeType()==RDLogLine::Hard) {
 | 
						|
      ret+="    "+RDXmlField("startTime","00:00:00.000");
 | 
						|
    }
 | 
						|
    else {
 | 
						|
      ret+="    "+RDXmlField("startTime");
 | 
						|
    }
 | 
						|
  }
 | 
						|
  ret+="    "+RDXmlField("transitionType",RDLogLine::transText(transType()));
 | 
						|
  ret+="    "+RDXmlField("cutQuantity",cutQuantity());
 | 
						|
  ret+="    "+RDXmlField("lastCutPlayed",lastCutPlayed());
 | 
						|
  ret+="    "+RDXmlField("markerComment",markerComment());
 | 
						|
  ret+="    "+RDXmlField("markerLabel",markerLabel());
 | 
						|
 | 
						|
  ret+="    "+RDXmlField("description",description());
 | 
						|
  ret+="    "+RDXmlField("isrc",isrc());
 | 
						|
  ret+="    "+RDXmlField("isci",isci());
 | 
						|
  ret+="    "+RDXmlField("recordingMbId",recordingMbId());
 | 
						|
  ret+="    "+RDXmlField("releaseMbId",releaseMbId());
 | 
						|
 | 
						|
  ret+="    "+RDXmlField("originUser",originUser());
 | 
						|
  ret+="    "+RDXmlField("originDateTime",originDateTime());
 | 
						|
  ret+="    "+RDXmlField("startPoint",startPoint(RDLogLine::CartPointer),
 | 
						|
			 "src=\"cart\"");
 | 
						|
  ret+="    "+RDXmlField("startPoint",startPoint(RDLogLine::LogPointer),
 | 
						|
			 "src=\"log\"");
 | 
						|
  ret+="    "+RDXmlField("endPoint",endPoint(RDLogLine::CartPointer),
 | 
						|
			 "src=\"cart\"");
 | 
						|
  ret+="    "+RDXmlField("endPoint",endPoint(RDLogLine::LogPointer),
 | 
						|
			 "src=\"log\"");
 | 
						|
  ret+="    "+RDXmlField("segueStartPoint",
 | 
						|
			 segueStartPoint(RDLogLine::CartPointer),
 | 
						|
			 "src=\"cart\"");
 | 
						|
  ret+="    "+RDXmlField("segueStartPoint",
 | 
						|
			 segueStartPoint(RDLogLine::LogPointer),"src=\"log\"");
 | 
						|
  ret+="    "+RDXmlField("segueEndPoint",
 | 
						|
			 segueEndPoint(RDLogLine::CartPointer),
 | 
						|
			 "src=\"cart\"");
 | 
						|
  ret+="    "+RDXmlField("segueEndPoint",
 | 
						|
			 segueEndPoint(RDLogLine::LogPointer),"src=\"log\"");
 | 
						|
  ret+="    "+RDXmlField("segueGain",segueGain());
 | 
						|
  ret+="    "+RDXmlField("fadeupPoint",
 | 
						|
			 fadeupPoint(RDLogLine::CartPointer),"src=\"cart\"");
 | 
						|
  ret+="    "+RDXmlField("fadeupPoint",
 | 
						|
			 fadeupPoint(RDLogLine::LogPointer),"src=\"log\"");
 | 
						|
  ret+="    "+RDXmlField("fadeupGain",fadeupGain());
 | 
						|
  ret+="    "+RDXmlField("fadedownPoint",
 | 
						|
			 fadedownPoint(RDLogLine::CartPointer),"src=\"cart\"");
 | 
						|
  ret+="    "+RDXmlField("fadedownPoint",
 | 
						|
			 fadedownPoint(RDLogLine::LogPointer),"src=\"log\"");
 | 
						|
  ret+="    "+RDXmlField("fadedownGain",fadedownGain());
 | 
						|
  ret+="    "+RDXmlField("duckUpGain",duckUpGain());
 | 
						|
  ret+="    "+RDXmlField("duckDownGain",duckDownGain());
 | 
						|
  ret+="    "+RDXmlField("talkStartPoint",talkStartPoint());
 | 
						|
  ret+="    "+RDXmlField("talkEndPoint",talkEndPoint());
 | 
						|
  ret+="    "+RDXmlField("hookMode",hookMode());
 | 
						|
  ret+="    "+RDXmlField("hookStartPoint",hookStartPoint());
 | 
						|
  ret+="    "+RDXmlField("hookEndPoint",hookEndPoint());
 | 
						|
 | 
						|
  ret+="    "+RDXmlField("eventLength",eventLength());
 | 
						|
  ret+="    "+RDXmlField("linkEventName",linkEventName());
 | 
						|
  ret+="    "+RDXmlField("linkStartTime",linkStartTime());
 | 
						|
  ret+="    "+RDXmlField("linkStartSlop",linkStartSlop());
 | 
						|
  ret+="    "+RDXmlField("linkEndSlop",linkEndSlop());
 | 
						|
  ret+="    "+RDXmlField("linkId",linkId());
 | 
						|
  ret+="    "+RDXmlField("linkEmbedded",linkEmbedded());
 | 
						|
 | 
						|
  ret+="    "+RDXmlField("extStartTime",extStartTime());
 | 
						|
  ret+="    "+RDXmlField("extLength",extLength());
 | 
						|
  ret+="    "+RDXmlField("extCartName",extCartName());
 | 
						|
  ret+="    "+RDXmlField("extData",extData());
 | 
						|
  ret+="    "+RDXmlField("extEventId",extEventId());
 | 
						|
  ret+="    "+RDXmlField("extAnncType",extAnncType());
 | 
						|
 | 
						|
  ret+="  </logLine>\n";
 | 
						|
 | 
						|
  return ret;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::resolveNowNextDateTime(const QString &str,
 | 
						|
					  const QString &code,
 | 
						|
					  const QDateTime &dt)
 | 
						|
{
 | 
						|
  int ptr=0;
 | 
						|
  std::vector<QString> dts;
 | 
						|
  QString ret=str;
 | 
						|
 | 
						|
  while((ptr=ret.find(code,ptr))>=0) {
 | 
						|
    for(int i=ptr+3;i<ret.length();i++) {
 | 
						|
      if(ret.at(i)==')') {
 | 
						|
	dts.push_back(ret.mid(ptr+3,i-ptr-3));
 | 
						|
	ptr+=(i-ptr-3);
 | 
						|
	break;
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
  if(dt.isValid()&&(!dt.time().isNull())) {
 | 
						|
    for(unsigned i=0;i<dts.size();i++) {
 | 
						|
      ret.replace(code+dts[i]+")",dt.toString(dts[i]));
 | 
						|
    }
 | 
						|
  }
 | 
						|
  else {
 | 
						|
    for(unsigned i=0;i<dts.size();i++) {
 | 
						|
      ret.replace(code+dts[i]+")","");
 | 
						|
    }
 | 
						|
  }
 | 
						|
  return ret;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::resolveWildcards(unsigned cartnum,const QString &pattern,
 | 
						|
				    int cutnum)
 | 
						|
{
 | 
						|
  RDLogLine logline;
 | 
						|
  logline.loadCart(cartnum,cutnum);
 | 
						|
  return logline.resolveWildcards(pattern);
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::startSourceText(RDLogLine::StartSource src)
 | 
						|
{
 | 
						|
  switch(src) {
 | 
						|
      case RDLogLine::StartUnknown:
 | 
						|
	return QObject::tr("Unknown");
 | 
						|
 | 
						|
      case RDLogLine::StartManual:
 | 
						|
	return QObject::tr("Manual");
 | 
						|
 | 
						|
      case RDLogLine::StartPlay:
 | 
						|
	return QObject::tr("Play");
 | 
						|
 | 
						|
      case RDLogLine::StartSegue:
 | 
						|
	return QObject::tr("Segue");
 | 
						|
 | 
						|
      case RDLogLine::StartTime:
 | 
						|
	return QObject::tr("Time");
 | 
						|
 | 
						|
      case RDLogLine::StartPanel:
 | 
						|
	return QObject::tr("Panel");
 | 
						|
 | 
						|
      case RDLogLine::StartMacro:
 | 
						|
	return QObject::tr("Macro");
 | 
						|
 | 
						|
      case RDLogLine::StartChannel:
 | 
						|
	return QObject::tr("Channel");
 | 
						|
  }
 | 
						|
  return QObject::tr("Unknown");
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::transText(RDLogLine::TransType trans)
 | 
						|
{
 | 
						|
  switch(trans) {
 | 
						|
      case RDLogLine::Play:
 | 
						|
	return QObject::tr("PLAY");
 | 
						|
 | 
						|
      case RDLogLine::Segue:
 | 
						|
	return QObject::tr("SEGUE");
 | 
						|
 | 
						|
      case RDLogLine::Stop:
 | 
						|
	return QObject::tr("STOP");
 | 
						|
 | 
						|
      case RDLogLine::NoTrans:
 | 
						|
	return QString("");
 | 
						|
  }
 | 
						|
  return QObject::tr("UNKNOWN");
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::typeText(RDLogLine::Type type)
 | 
						|
{
 | 
						|
  switch(type) {
 | 
						|
      case RDLogLine::Cart:
 | 
						|
	return QObject::tr("Audio");
 | 
						|
 | 
						|
      case RDLogLine::Marker:
 | 
						|
	return QObject::tr("Marker");
 | 
						|
 | 
						|
      case RDLogLine::Macro:
 | 
						|
	return QObject::tr("Macro");
 | 
						|
 | 
						|
      case RDLogLine::OpenBracket:
 | 
						|
	return QObject::tr("Open Bracket");
 | 
						|
 | 
						|
      case RDLogLine::CloseBracket:
 | 
						|
	return QObject::tr("Close Bracket");
 | 
						|
 | 
						|
      case RDLogLine::Chain:
 | 
						|
	return QObject::tr("Chain");
 | 
						|
 | 
						|
      case RDLogLine::Track:
 | 
						|
	return QObject::tr("Track");
 | 
						|
 | 
						|
      case RDLogLine::MusicLink:
 | 
						|
	return QObject::tr("MusicLink");
 | 
						|
 | 
						|
      case RDLogLine::TrafficLink:
 | 
						|
	return QObject::tr("TrafficLink");
 | 
						|
 | 
						|
      case RDLogLine::UnknownType:
 | 
						|
	return QObject::tr("Unknown");
 | 
						|
  }
 | 
						|
  return QObject::tr("Unknown");
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::timeTypeText(RDLogLine::TimeType type)
 | 
						|
{
 | 
						|
  QString ret=QObject::tr("Unknown");
 | 
						|
 | 
						|
  switch(type) {
 | 
						|
  case RDLogLine::Relative:
 | 
						|
    ret=QObject::tr("Relative");
 | 
						|
    break;
 | 
						|
 | 
						|
  case RDLogLine::Hard:
 | 
						|
    ret=QObject::tr("Hard");
 | 
						|
    break;
 | 
						|
 | 
						|
  case RDLogLine::NoTime:
 | 
						|
    ret=QObject::tr("NoTime");
 | 
						|
    break;
 | 
						|
  }
 | 
						|
 | 
						|
  return ret;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
QString RDLogLine::sourceText(RDLogLine::Source src)
 | 
						|
{
 | 
						|
  switch(src) {
 | 
						|
      case RDLogLine::Manual:
 | 
						|
	return QObject::tr("Manual");
 | 
						|
 | 
						|
      case RDLogLine::Traffic:
 | 
						|
	return QObject::tr("Traffic");
 | 
						|
 | 
						|
      case RDLogLine::Music:
 | 
						|
	return QObject::tr("Music");
 | 
						|
 | 
						|
      case RDLogLine::Template:
 | 
						|
	return QObject::tr("RDLogManager");
 | 
						|
 | 
						|
      case RDLogLine::Tracker:
 | 
						|
	return QObject::tr("Tracker");
 | 
						|
  }
 | 
						|
  return QObject::tr("Unknown");
 | 
						|
}
 | 
						|
 | 
						|
bool RDLogLine::isHoldover() const
 | 
						|
{
 | 
						|
  return is_holdover;
 | 
						|
}
 | 
						|
 | 
						|
void RDLogLine::setHoldover(bool b)
 | 
						|
{
 | 
						|
  is_holdover = b;
 | 
						|
}
 |