// Copyright 2006-2009 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef V8_LOG_INL_H_
#define V8_LOG_INL_H_
#include "src/log.h"
#include "src/isolate.h"
#include "src/objects-inl.h"
#include "src/tracing/trace-event.h"
namespace v8 {
namespace internal {
Logger::LogEventsAndTags Logger::ToNativeByScript(Logger::LogEventsAndTags tag,
Script* script) {
if ((tag == FUNCTION_TAG || tag == LAZY_COMPILE_TAG || tag == SCRIPT_TAG) &&
script->type() == Script::TYPE_NATIVE) {
switch (tag) {
case FUNCTION_TAG: return NATIVE_FUNCTION_TAG;
case LAZY_COMPILE_TAG: return NATIVE_LAZY_COMPILE_TAG;
case SCRIPT_TAG: return NATIVE_SCRIPT_TAG;
default: return tag;
}
} else {
return tag;
}
}
void Logger::CallEventLogger(Isolate* isolate, const char* name, StartEnd se,
bool expose_to_api) {
if (isolate->event_logger() != NULL) {
if (isolate->event_logger() == DefaultEventLoggerSentinel) {
LOG(isolate, TimerEvent(se, name));
} else if (expose_to_api) {
isolate->event_logger()(name, se);
}
}
if (expose_to_api) {
if (se == START) {
TRACE_EVENT_BEGIN0("v8", name);
} else {
TRACE_EVENT_END0("v8", name);
}
} else {
if (se == START) {
TRACE_EVENT_BEGIN0(TRACE_DISABLED_BY_DEFAULT("v8"), name);
} else {
TRACE_EVENT_END0(TRACE_DISABLED_BY_DEFAULT("v8"), name);
}
}
}
} // namespace internal
} // namespace v8
#endif // V8_LOG_INL_H_