Arquivos
hhvm/hphp/runtime/base/extended_logger.h
T
Kyle Delong a8e3321fbd HPHP/XHP: 'mixed' type in attribute declarations
We'd like to start using ##mixed## instead of ##var## for attribute types to be consistent with Hack. As a followup to this (once released), we would codemod all ##var## to ##mixed##.
2013-07-18 17:28:37 -07:00

67 linhas
2.9 KiB
C++

/*
+----------------------------------------------------------------------+
| HipHop for PHP |
+----------------------------------------------------------------------+
| Copyright (c) 2010-2013 Facebook, Inc. (http://www.facebook.com) |
| Copyright (c) 1998-2010 Zend Technologies Ltd. (http://www.zend.com) |
+----------------------------------------------------------------------+
| This source file is subject to version 2.00 of the Zend license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.zend.com/license/2_00.txt. |
| If you did not receive a copy of the Zend license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@zend.com so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
*/
#ifndef incl_HPHP_RUNTIME_BASE_EXTENDED_LOGGER_H_
#define incl_HPHP_RUNTIME_BASE_EXTENDED_LOGGER_H_
#include "hphp/util/logger.h"
#include "hphp/util/exception.h"
#include "hphp/util/stack_trace.h"
#include "hphp/runtime/base/complex_types.h"
namespace HPHP {
///////////////////////////////////////////////////////////////////////////////
class ExtendedLogger : public Logger {
public:
static bool EnabledByDefault;
// These logging functions will also print stacktrace at end of each message.
static void Error(const std::string &msg);
static void Warning(const std::string &msg);
static void Info(const std::string &msg);
static void Verbose(const std::string &msg);
static void Error(const char *fmt, ...) ATTRIBUTE_PRINTF(1,2);
static void Warning(const char *fmt, ...) ATTRIBUTE_PRINTF(1,2);
static void Info(const char *fmt, ...) ATTRIBUTE_PRINTF(1,2);
static void Verbose(const char *fmt, ...) ATTRIBUTE_PRINTF(1,2);
// Log additional injected stacktrace.
static void Log(LogLevelType level, CArrRef stackTrace, bool escape = true,
bool escapeMore = false);
// Convenience functions for stringifying.
static std::string StringOfFrame(CArrRef frame, int i, bool escape = false);
static std::string StringOfStackTrace(CArrRef stackTrace);
protected:
virtual void log(LogLevelType level, const char *type, const Exception &e,
const char *file = nullptr, int line = 0);
virtual void log(LogLevelType level, const std::string &msg,
const StackTrace *stackTrace,
bool escape = true, bool escapeMore = false);
private:
static void PrintStackTrace(FILE *f, CArrRef stackTrace,
bool escape = false, bool escapeMore = false);
};
///////////////////////////////////////////////////////////////////////////////
}
#endif // incl_HPHP_RUNTIME_BASE_EXTENDED_LOGGER_H_