1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
|
/*****************************************************************************
* *
* PrimeSense PSCommon Library *
* Copyright (C) 2012 PrimeSense Ltd. *
* *
* This file is part of PSCommon. *
* *
* Licensed under the Apache License, Version 2.0 (the "License"); *
* you may not use this file except in compliance with the License. *
* You may obtain a copy of the License at *
* *
* http://www.apache.org/licenses/LICENSE-2.0 *
* *
* Unless required by applicable law or agreed to in writing, software *
* distributed under the License is distributed on an "AS IS" BASIS, *
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
* See the License for the specific language governing permissions and *
* limitations under the License. *
* *
*****************************************************************************/
//---------------------------------------------------------------------------
// Includes
//---------------------------------------------------------------------------
#include "XnLogFileWriter.h"
//---------------------------------------------------------------------------
// Code
//---------------------------------------------------------------------------
XnLogFileWriter::XnLogFileWriter() :
m_fLogFile(XN_INVALID_FILE_HANDLE),
m_bWriteLineInfo(TRUE)
{
m_strCurrFileName[0] = '\0';
}
XnLogFileWriter::~XnLogFileWriter()
{
CloseFile();
}
void XnLogFileWriter::WriteEntry(const XnLogEntry* pEntry)
{
// make sure file is open
if (m_fLogFile == XN_INVALID_FILE_HANDLE)
{
return;
}
// write timestamp and severity
const XnUInt32 nMaxMessageSize = 2047;
XnChar strBuffer[nMaxMessageSize + 1];
XnUInt32 nMessageLen = 0;
XnUInt32 nChars = 0;
xnOSStrFormat(strBuffer + nMessageLen, nMaxMessageSize - nMessageLen, &nChars, "%9llu\t%-10s\t%s\t", pEntry->nTimestamp, pEntry->strSeverity, pEntry->strMask);
nMessageLen += nChars;
if (m_bWriteLineInfo)
{
// write line info
XnChar fileName[XN_FILE_MAX_PATH];
XnStatus nRetVal = xnOSGetFileName(pEntry->strFile, fileName, sizeof(fileName));
if (nRetVal == XN_STATUS_OK)
{
xnOSStrFormat(strBuffer + nMessageLen, nMaxMessageSize - nMessageLen, &nChars, "%s\t%d\t", fileName, pEntry->nLine);
nMessageLen += nChars;
}
}
xnOSStrFormat(strBuffer + nMessageLen, nMaxMessageSize - nMessageLen, &nChars, "%s\n", pEntry->strMessage);
nMessageLen += nChars;
xnOSWriteFile(m_fLogFile, strBuffer, nMessageLen);
}
void XnLogFileWriter::WriteUnformatted(const XnChar* strMessage)
{
xnOSWriteFile(m_fLogFile, strMessage, xnOSStrLen(strMessage) + 1);
}
XnStatus XnLogFileWriter::OpenFile()
{
if (m_fLogFile == XN_INVALID_FILE_HANDLE)
{
// open file
XnStatus nRetVal = xnLogCreateNewFile("log", TRUE, m_strCurrFileName, XN_FILE_MAX_PATH, &m_fLogFile);
if (nRetVal != XN_STATUS_OK)
{
// we don't have much to do if files can't be open. Logs will not be written to file
printf("Couldn't create log file! Logs will not be written (error: %s)\n", xnGetStatusString(nRetVal));
m_fLogFile = XN_INVALID_FILE_HANDLE;
return nRetVal;
}
}
return XN_STATUS_OK;
}
void XnLogFileWriter::CloseFile()
{
if (m_fLogFile != XN_INVALID_FILE_HANDLE)
{
xnOSCloseFile(&m_fLogFile);
m_fLogFile = XN_INVALID_FILE_HANDLE;
}
}
void XnLogFileWriter::SetLineInfo(XnBool bLineInfo)
{
m_bWriteLineInfo = bLineInfo;
}
void XnLogFileWriter::OnRegister()
{
OpenFile();
}
void XnLogFileWriter::OnUnregister()
{
CloseFile();
}
|