2011-06-24 10:41:16 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
2012-05-21 04:12:37 -07:00
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
2011-06-24 10:41:16 -07:00
|
|
|
|
|
|
|
#ifndef MOZILLA_GFX_LOGGING_H_
|
|
|
|
#define MOZILLA_GFX_LOGGING_H_
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <sstream>
|
2011-06-29 15:13:21 -07:00
|
|
|
#include <stdio.h>
|
2011-06-24 10:41:16 -07:00
|
|
|
|
|
|
|
#include "Point.h"
|
2012-01-04 15:02:59 -08:00
|
|
|
#include "Matrix.h"
|
2011-06-24 10:41:16 -07:00
|
|
|
|
|
|
|
#ifdef WIN32
|
2014-02-18 18:59:34 -08:00
|
|
|
// This file gets included from nsGlobalWindow.cpp, which doesn't like
|
|
|
|
// having windows.h included in it. Since OutputDebugStringA is the only
|
|
|
|
// thing we need from windows.h, we just declare it here directly.
|
|
|
|
// Note: the function's documented signature is
|
|
|
|
// WINBASEAPI void WINAPI OutputDebugStringA(LPCSTR lpOutputString)
|
|
|
|
// but if we don't include windows.h, the macros WINBASEAPI, WINAPI, and
|
|
|
|
// LPCSTR are not defined, so we need to replace them with their expansions.
|
|
|
|
extern "C" __declspec(dllimport) void __stdcall OutputDebugStringA(const char* lpOutputString);
|
2011-06-24 10:41:16 -07:00
|
|
|
#endif
|
|
|
|
|
2014-02-18 18:59:34 -08:00
|
|
|
#if defined(DEBUG) || defined(PR_LOGGING)
|
2011-06-24 10:41:16 -07:00
|
|
|
#include <prlog.h>
|
|
|
|
|
2014-02-18 18:59:34 -08:00
|
|
|
extern GFX2D_API PRLogModuleInfo *GetGFX2DLog();
|
2011-06-24 10:41:16 -07:00
|
|
|
#endif
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace gfx {
|
|
|
|
|
|
|
|
const int LOG_DEBUG = 1;
|
|
|
|
const int LOG_WARNING = 2;
|
|
|
|
|
2014-02-18 18:59:34 -08:00
|
|
|
#if defined(DEBUG) || defined(PR_LOGGING)
|
2011-06-24 10:41:16 -07:00
|
|
|
|
|
|
|
inline PRLogModuleLevel PRLogLevelForLevel(int aLevel) {
|
|
|
|
switch (aLevel) {
|
|
|
|
case LOG_DEBUG:
|
|
|
|
return PR_LOG_DEBUG;
|
|
|
|
case LOG_WARNING:
|
|
|
|
return PR_LOG_WARNING;
|
|
|
|
}
|
|
|
|
return PR_LOG_DEBUG;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2014-02-18 18:59:34 -08:00
|
|
|
extern GFX2D_API int sGfxLogLevel;
|
2011-06-24 10:41:16 -07:00
|
|
|
|
2012-10-03 10:43:37 -07:00
|
|
|
static inline void OutputMessage(const std::string &aString, int aLevel) {
|
2011-06-24 10:41:16 -07:00
|
|
|
#if defined(WIN32) && !defined(PR_LOGGING)
|
|
|
|
if (aLevel >= sGfxLogLevel) {
|
|
|
|
::OutputDebugStringA(aString.c_str());
|
|
|
|
}
|
|
|
|
#elif defined(PR_LOGGING)
|
2012-10-29 16:32:10 -07:00
|
|
|
if (PR_LOG_TEST(GetGFX2DLog(), PRLogLevelForLevel(aLevel))) {
|
2011-06-24 10:41:16 -07:00
|
|
|
PR_LogPrint(aString.c_str());
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
if (aLevel >= sGfxLogLevel) {
|
2011-09-29 12:25:07 -07:00
|
|
|
printf("%s", aString.c_str());
|
2011-06-24 10:41:16 -07:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
class NoLog
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
NoLog() {}
|
|
|
|
~NoLog() {}
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
NoLog &operator <<(const T &aLogText) { return *this; }
|
|
|
|
};
|
|
|
|
|
|
|
|
template<int L>
|
|
|
|
class Log
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Log() {}
|
|
|
|
~Log() { mMessage << '\n'; WriteLog(mMessage.str()); }
|
|
|
|
|
|
|
|
Log &operator <<(const std::string &aLogText) { mMessage << aLogText; return *this; }
|
2013-11-18 06:29:54 -08:00
|
|
|
Log &operator <<(const char aStr[]) { mMessage << static_cast<const char*>(aStr); return *this; }
|
|
|
|
Log &operator <<(bool aBool) { mMessage << (aBool ? "true" : "false"); return *this; }
|
|
|
|
Log &operator <<(int aInt) { mMessage << aInt; return *this; }
|
2011-06-24 10:41:16 -07:00
|
|
|
Log &operator <<(unsigned int aInt) { mMessage << aInt; return *this; }
|
2013-12-23 05:03:16 -08:00
|
|
|
Log &operator <<(long aLong) { mMessage << aLong; return *this; }
|
|
|
|
Log &operator <<(unsigned long aLong) { mMessage << aLong; return *this; }
|
2013-11-18 06:29:54 -08:00
|
|
|
Log &operator <<(Float aFloat) { mMessage << aFloat; return *this; }
|
|
|
|
Log &operator <<(double aDouble) { mMessage << aDouble; return *this; }
|
|
|
|
Log &operator <<(const Point &aPoint)
|
|
|
|
{ mMessage << "Point(" << aPoint.x << "," << aPoint.y << ")"; return *this; }
|
2011-06-24 10:41:16 -07:00
|
|
|
Log &operator <<(const Size &aSize)
|
2013-11-18 06:29:54 -08:00
|
|
|
{ mMessage << "Size(" << aSize.width << "," << aSize.height << ")"; return *this; }
|
2011-06-24 10:41:16 -07:00
|
|
|
Log &operator <<(const IntSize &aSize)
|
2013-11-18 06:29:54 -08:00
|
|
|
{ mMessage << "IntSize(" << aSize.width << "," << aSize.height << ")"; return *this; }
|
|
|
|
Log &operator <<(const Rect &aRect)
|
|
|
|
{ mMessage << "Rect(" << aRect.x << "," << aRect.y << "," << aRect.width << "," << aRect.height << ")"; return *this; }
|
2012-01-04 15:02:59 -08:00
|
|
|
Log &operator<<(const Matrix& aMatrix)
|
2013-11-18 06:29:54 -08:00
|
|
|
{ mMessage << "Matrix(" << aMatrix._11 << " " << aMatrix._12 << " ; " << aMatrix._21 << " " << aMatrix._22 << " ; " << aMatrix._31 << " " << aMatrix._32 << ")"; return *this; }
|
2012-01-04 15:02:59 -08:00
|
|
|
|
2011-06-24 10:41:16 -07:00
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
void WriteLog(const std::string &aString) {
|
|
|
|
OutputMessage(aString, L);
|
|
|
|
}
|
|
|
|
|
|
|
|
std::stringstream mMessage;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef Log<LOG_DEBUG> DebugLog;
|
|
|
|
typedef Log<LOG_WARNING> WarningLog;
|
|
|
|
|
|
|
|
#ifdef GFX_LOG_DEBUG
|
|
|
|
#define gfxDebug DebugLog
|
|
|
|
#else
|
|
|
|
#define gfxDebug if (1) ; else NoLog
|
|
|
|
#endif
|
|
|
|
#ifdef GFX_LOG_WARNING
|
|
|
|
#define gfxWarning WarningLog
|
|
|
|
#else
|
|
|
|
#define gfxWarning if (1) ; else NoLog
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* MOZILLA_GFX_LOGGING_H_ */
|