Added: Tool logger and path macros.
--HG-- branch : build_pipeline_v3hg/feature/build_pipeline_v3
parent
ade48ff193
commit
3d8be0c891
@ -0,0 +1,47 @@
|
|||||||
|
/**
|
||||||
|
* \file tool_logger.cpp
|
||||||
|
* \brief CToolLogger
|
||||||
|
* \date 2012-02-19 10:33GMT
|
||||||
|
* \author Jan Boon (Kaetemi)
|
||||||
|
* CToolLogger
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2012 by authors
|
||||||
|
*
|
||||||
|
* This file is part of RYZOM CORE PIPELINE.
|
||||||
|
* RYZOM CORE PIPELINE 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, either version 2 of
|
||||||
|
* the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* RYZOM CORE PIPELINE 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 RYZOM CORE PIPELINE; see the file COPYING. If not, see
|
||||||
|
* <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <nel/misc/types_nl.h>
|
||||||
|
#include "tool_logger.h"
|
||||||
|
|
||||||
|
// STL includes
|
||||||
|
|
||||||
|
// NeL includes
|
||||||
|
// #include <nel/misc/debug.h>
|
||||||
|
|
||||||
|
// Project includes
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
// using namespace NLMISC;
|
||||||
|
|
||||||
|
namespace PIPELINE {
|
||||||
|
|
||||||
|
void dummmmmmmyyyyyyyyyyyyyyyyy_tool_logger_cpp() { }
|
||||||
|
|
||||||
|
} /* namespace PIPELINE */
|
||||||
|
|
||||||
|
/* end of file */
|
@ -0,0 +1,148 @@
|
|||||||
|
/**
|
||||||
|
* \file tool_logger.h
|
||||||
|
* \brief CToolLogger
|
||||||
|
* \date 2012-02-19 10:33GMT
|
||||||
|
* \author Jan Boon (Kaetemi)
|
||||||
|
* CToolLogger
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2012 by authors
|
||||||
|
*
|
||||||
|
* This file is part of RYZOM CORE PIPELINE.
|
||||||
|
* RYZOM CORE PIPELINE 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, either version 2 of
|
||||||
|
* the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* RYZOM CORE PIPELINE 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 RYZOM CORE PIPELINE; see the file COPYING. If not, see
|
||||||
|
* <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef PIPELINE_TOOL_LOGGER_H
|
||||||
|
#define PIPELINE_TOOL_LOGGER_H
|
||||||
|
#include <nel/misc/types_nl.h>
|
||||||
|
|
||||||
|
// STL includes
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
// NeL includes
|
||||||
|
#include <nel/misc/file.h>
|
||||||
|
|
||||||
|
// Project includes
|
||||||
|
|
||||||
|
namespace PIPELINE {
|
||||||
|
|
||||||
|
enum EError
|
||||||
|
{
|
||||||
|
ERROR,
|
||||||
|
WARNING,
|
||||||
|
MESSAGE,
|
||||||
|
};
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
const std::string s_Error = "ERROR";
|
||||||
|
const std::string s_Warning = "WARNING";
|
||||||
|
const std::string s_Message = "MESSAGE";
|
||||||
|
|
||||||
|
const std::string s_ErrorHeader = "type\tfile\ttime\terror";
|
||||||
|
const std::string s_DependHeader = "output_file\tinput_file";
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief CToolLogger
|
||||||
|
* \date 2012-02-19 10:33GMT
|
||||||
|
* \author Jan Boon (Kaetemi)
|
||||||
|
* CToolLogger
|
||||||
|
*/
|
||||||
|
class CToolLogger
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
FILE *m_ErrorLog;
|
||||||
|
FILE *m_DependLog;
|
||||||
|
|
||||||
|
CToolLogger()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~CToolLogger()
|
||||||
|
{
|
||||||
|
releaseError();
|
||||||
|
releaseDepend();
|
||||||
|
}
|
||||||
|
|
||||||
|
void initError(const std::string &errorLog)
|
||||||
|
{
|
||||||
|
releaseError();
|
||||||
|
|
||||||
|
m_ErrorLog = fopen(errorLog.c_str(), "wt");
|
||||||
|
fwrite(s_ErrorHeader.c_str(), 1, s_ErrorHeader.length(), m_ErrorLog);
|
||||||
|
fwrite("\n", 1, 1, m_ErrorLog);
|
||||||
|
fflush(m_ErrorLog);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void initDepend(const std::string &dependLog)
|
||||||
|
{
|
||||||
|
releaseDepend();
|
||||||
|
|
||||||
|
m_DependLog = fopen(dependLog.c_str(), "wt");
|
||||||
|
fwrite(s_DependHeader.c_str(), 1, s_DependHeader.length(), m_DependLog);
|
||||||
|
fwrite("\n", 1, 1, m_DependLog);
|
||||||
|
fflush(m_DependLog);
|
||||||
|
}
|
||||||
|
|
||||||
|
void writeError(EError type, const std::string &file, const std::string &error)
|
||||||
|
{
|
||||||
|
if (m_ErrorLog)
|
||||||
|
{
|
||||||
|
// TODO_ERROR_LOG
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void writeDepend(const std::string &outputFile, const std::string &inputFile)
|
||||||
|
{
|
||||||
|
if (m_DependLog)
|
||||||
|
{
|
||||||
|
fwrite(outputFile.c_str(), 1, outputFile.length(), m_DependLog);
|
||||||
|
fwrite("\t", 1, 1, m_DependLog);
|
||||||
|
fwrite(inputFile.c_str(), 1, inputFile.length(), m_DependLog);
|
||||||
|
fwrite("\n", 1, 1, m_DependLog);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void releaseError()
|
||||||
|
{
|
||||||
|
if (m_ErrorLog)
|
||||||
|
{
|
||||||
|
fflush(m_ErrorLog);
|
||||||
|
fclose(m_ErrorLog);
|
||||||
|
m_ErrorLog = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void releaseDepend()
|
||||||
|
{
|
||||||
|
if (m_DependLog)
|
||||||
|
{
|
||||||
|
fflush(m_DependLog);
|
||||||
|
fclose(m_DependLog);
|
||||||
|
m_DependLog = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}; /* class CToolLogger */
|
||||||
|
|
||||||
|
} /* namespace PIPELINE */
|
||||||
|
|
||||||
|
#endif /* #ifndef PIPELINE_TOOL_LOGGER_H */
|
||||||
|
|
||||||
|
/* end of file */
|
Loading…
Reference in New Issue