/* Editor Settings: expandtabs and use 4 spaces for indentation
* ex: set softtabstop=4 tabstop=8 expandtab shiftwidth=4: *
* -*- mode: c, c-basic-offset: 4 -*- */
/*
* Copyright Likewise Software
* All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; either version 2.1 of the license, or (at
* your option) any later version.
*
* This library 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 Lesser
* General Public License for more details. You should have received a copy
* of the GNU Lesser General Public License along with this program. If
* not, see .
*
* LIKEWISE SOFTWARE MAKES THIS SOFTWARE AVAILABLE UNDER OTHER LICENSING
* TERMS AS WELL. IF YOU HAVE ENTERED INTO A SEPARATE LICENSE AGREEMENT
* WITH LIKEWISE SOFTWARE, THEN YOU MAY ELECT TO USE THE SOFTWARE UNDER THE
* TERMS OF THAT SOFTWARE LICENSE AGREEMENT INSTEAD OF THE TERMS OF THE GNU
* LESSER GENERAL PUBLIC LICENSE, NOTWITHSTANDING THE ABOVE NOTICE. IF YOU
* HAVE QUESTIONS, OR WISH TO REQUEST A COPY OF THE ALTERNATE LICENSING
* TERMS OFFERED BY LIKEWISE SOFTWARE, PLEASE CONTACT LIKEWISE SOFTWARE AT
* license@likewisesoftware.com
*/
/*
* Copyright (C) Likewise Software. All rights reserved.
*
* Module Name:
*
* logging.c
*
* Abstract:
*
* Global log accesser functions
*
* Authors: Kyle Stemen
*/
#include "includes.h"
DWORD
LwLogMessage(
IN LwLogLevel level,
IN PCSTR pszFormat,
...
)
{
DWORD dwError = 0;
PSTR pszFormatted = NULL;
va_list args;
BOOLEAN bArgsStarted = FALSE;
if (level <= gLogLevel && gpLogCallback)
{
va_start(args, pszFormat);
bArgsStarted = TRUE;
dwError = LwAllocateStringPrintfV(
&pszFormatted,
pszFormat,
args);
if (dwError == LW_ERROR_OUT_OF_MEMORY)
{
// There isn't enough memory to allocate the formatted string on the
// stack. So instead print a truncated message using the stack.
CHAR szLimited[200];
vsnprintf(
szLimited,
sizeof(szLimited),
pszFormat,
args);
szLimited[sizeof(szLimited)-1] = 0;
gpLogCallback(level, gpLogUserData, szLimited);
dwError = 0;
}
else if (dwError)
{
goto error;
}
else
{
gpLogCallback(level, gpLogUserData, pszFormatted);
}
}
cleanup:
if (bArgsStarted)
{
va_end(args);
}
LW_SAFE_FREE_STRING(pszFormatted);
return dwError;
error:
goto cleanup;
}
DWORD
LwSetLogFunction(
IN LwLogLevel maxLevel,
IN PLWLOG_CALLBACK pCallback,
IN PVOID pUserData
)
{
gpLogUserData = pUserData;
gpLogCallback = pCallback;
gLogLevel = maxLevel;
return 0;
}