// Part of BNC, a utility for retrieving decoding and
// converting GNSS data streams from NTRIP broadcasters.
//
// Copyright (C) 2007
// German Federal Agency for Cartography and Geodesy (BKG)
// http://www.bkg.bund.de
// Czech Technical University Prague, Department of Geodesy
// http://www.fsv.cvut.cz
//
// Email: euref-ip@bkg.bund.de
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation, version 2.
//
// 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.

/* -------------------------------------------------------------------------
 * BKG NTRIP Client
 * -------------------------------------------------------------------------
 *
 * Class:      bncRawFile
 *
 * Purpose:    This class stores/reads BNC raw file
 *
 * Author:     L. Mervart
 *
 * Created:    23-Aug-2010
 *
 * Changes:    
 *
 * -----------------------------------------------------------------------*/

#include "bncrawfile.h" 
#include "bnccore.h"
#include "bncutils.h"
#include "bncsettings.h"

using namespace std;

#define RAW_FILE_VERSION "1"

// Constructor
////////////////////////////////////////////////////////////////////////////
bncRawFile::bncRawFile(const QByteArray& fileName, const QByteArray& staID,
                       inpOutFlag ioFlg) {

  _fileName   = fileName; expandEnvVar(_fileName);
  _format     = "unset";
  _staID      = staID;
  _inpFile    = 0;
  _outFile    = 0;
  _version    = 0;

  // Initialize for Input
  // --------------------
  if (ioFlg == input) {
    _inpFile = new QFile(_fileName);
    _inpFile->open(QIODevice::ReadOnly);
    QString     line = _inpFile->readLine();
    QStringList lst  = line.split(' ');
    _version = lst.value(0).toInt();
  }

  // Initialize for Output
  // ---------------------
  else {    
    QDate currDate = currentDateAndTimeGPS().date();
    _currentFileName = _fileName + "_" + currDate.toString("yyMMdd");
    _outFile = new QFile(_currentFileName);     
    bncSettings settings;
    if ( Qt::CheckState(settings.value("rnxAppend").toInt()) == Qt::Checked &&
         QFile::exists(_currentFileName) ) {
      _outFile->open(QIODevice::WriteOnly | QIODevice::Append);
    }
    else {
      _outFile->open(QIODevice::WriteOnly);
      _outFile->write(RAW_FILE_VERSION " Version of BNC raw file");
    }
  }
}

// Destructor
////////////////////////////////////////////////////////////////////////////
bncRawFile::~bncRawFile() {
  delete _inpFile;
  delete _outFile;
}

// Raw Output
////////////////////////////////////////////////////////////////////////////
void bncRawFile::writeRawData(const QByteArray& data, const QByteArray& staID,
                              const QByteArray& format) {
  if (_outFile) {
    QDate currDate = currentDateAndTimeGPS().date();
    QString hlp = _fileName + "_" + currDate.toString("yyMMdd");
    if (hlp != _currentFileName) {
      _currentFileName = hlp;
      delete _outFile;
      _outFile = new QFile(_currentFileName);
      _outFile->open(QIODevice::WriteOnly);
      _outFile->write(RAW_FILE_VERSION " Version of BNC raw file");
    }

    QString chunkHeader = QString("\n%1 %2 %3 %4\n")
                 .arg(currentDateAndTimeGPS().toString(Qt::ISODate))
                 .arg(QString(staID))
                 .arg(QString(format))
                 .arg(data.size());
    _outFile->write(chunkHeader.toAscii());
    _outFile->write(data);
    _outFile->flush();
  }
}


// Raw Input
////////////////////////////////////////////////////////////////////////////
QByteArray bncRawFile::readChunk(){

  QByteArray data;

  if (_inpFile) {
    QString     line = _inpFile->readLine();
    if (line.indexOf("Version of BNC raw file") != -1) {
      line = _inpFile->readLine();
    }
    if (!line.isEmpty()) {
      QStringList lst  = line.split(' ');
      
      BNC_CORE->setDateAndTimeGPS(QDateTime(QDateTime::fromString(lst.value(0), Qt::ISODate)));
      
      _staID  = lst.value(1).toAscii();
      _format = lst.value(2).toAscii();
      int nBytes = lst.value(3).toInt();
      
      data = _inpFile->read(nBytes);
      
      _inpFile->read(1); // read '\n' character
    }
  }

  return data;
}