rawlog_record.cpp
Go to the documentation of this file.
00001 /***********************************************************************************
00002  * Revised BSD License *
00003  * Copyright (c) 2014, Markus Bader <markus.bader@tuwien.ac.at> *
00004  * All rights reserved. *
00005  *                                                                                 *
00006  * Redistribution and use in source and binary forms, with or without *
00007  * modification, are permitted provided that the following conditions are met: *
00008  *     * Redistributions of source code must retain the above copyright *
00009  *       notice, this list of conditions and the following disclaimer. *
00010  *     * Redistributions in binary form must reproduce the above copyright *
00011  *       notice, this list of conditions and the following disclaimer in the *
00012  *       documentation and/or other materials provided with the distribution. *
00013  *     * Neither the name of the Vienna University of Technology nor the *
00014  *       names of its contributors may be used to endorse or promote products *
00015  *       derived from this software without specific prior written permission. *
00016  *                                                                                 *
00017  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00018  *AND *
00019  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00020  **
00021  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE *
00022  * DISCLAIMED. IN NO EVENT SHALL Markus Bader BE LIABLE FOR ANY *
00023  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES *
00024  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00025  **
00026  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND *
00027  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT *
00028  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00029  **
00030  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00031  **                       *
00032  ***********************************************************************************/
00033 #include <stdio.h>
00034 #include <stdarg.h>
00035 
00036 #include <mrpt_rawlog_record/rawlog_record.h>
00037 #include <mrpt_rawlog_record/rawlog_record_defaults.h>
00038 
00039 RawlogRecord::~RawlogRecord()
00040 {
00041         log_info("write data");
00042         MRPT_TODO("RawlogRecord writes the rawlog only on exit (Ctrl-C)");
00043         log_info("pRawLog    entries %i", pRawLog->size());
00044         log_info("pRawLogASF entries %i", pRawLogASF->size());
00045         if (pRawLog->size() > 0)
00046         {
00047                 std::string filename =
00048                         param_->raw_log_folder + "/" + param_->raw_log_name;
00049                 log_info("write %s", filename.c_str());
00050                 pRawLog->saveToRawLogFile(filename);
00051         }
00052         if (pRawLogASF->size() > 0)
00053         {
00054                 std::string filename =
00055                         param_->raw_log_folder + "/" + param_->raw_log_name_asf;
00056                 log_info("write %s", filename.c_str());
00057                 pRawLogASF->saveToRawLogFile(filename);
00058         }
00059         delete pRawLog;
00060         delete pRawLogASF;
00061 }
00062 
00063 RawlogRecord::RawlogRecord(Parameters* param) : param_(param)
00064 {
00065         pRawLog = new CRawlog;
00066         pRawLogASF = new CRawlog;
00067 }
00068 void RawlogRecord::updateRawLogName(const mrpt::system::TTimeStamp& t)
00069 {
00070         uint64_t tmp = (t - ((uint64_t)116444736 * 1000000000));
00071         time_t auxTime = tmp / (uint64_t)10000000;
00072         tm* ptm = localtime(&auxTime);
00073         param_->raw_log_name = mrpt::format(
00074                 "%u-%02u-%02u--%02u-%02u-%02u--%s", 1900 + ptm->tm_year,
00075                 ptm->tm_mon + 1, ptm->tm_mday, ptm->tm_hour, ptm->tm_min,
00076                 (unsigned int)ptm->tm_sec, param_->raw_log_name.c_str());
00077         param_->raw_log_name_asf = mrpt::format(
00078                 "%u-%02u-%02u--%02u-%02u-%02u--%s", 1900 + ptm->tm_year,
00079                 ptm->tm_mon + 1, ptm->tm_mday, ptm->tm_hour, ptm->tm_min,
00080                 (unsigned int)ptm->tm_sec, param_->raw_log_name_asf.c_str());
00081 }
00082 
00083 


mrpt_rawlog
Author(s):
autogenerated on Mon Sep 18 2017 03:12:13