// Copyright (c) 2014 GitHub, Inc. // Use of this source code is governed by the MIT license that can be // found in the LICENSE file. #include #include #include "atom/common/native_mate_converters/callback.h" #include "atom/common/native_mate_converters/file_path_converter.h" #include "base/bind.h" #include "base/files/file_util.h" #include "content/public/browser/tracing_controller.h" #include "native_mate/dictionary.h" #include "atom/common/node_includes.h" using content::TracingController; namespace mate { template<> struct Converter { static bool FromV8(v8::Isolate* isolate, v8::Local val, base::trace_event::CategoryFilter* out) { std::string filter; if (!ConvertFromV8(isolate, val, &filter)) return false; *out = base::trace_event::CategoryFilter(filter); return true; } }; template<> struct Converter { static bool FromV8(v8::Isolate* isolate, v8::Local val, base::trace_event::TraceOptions* out) { std::string options; if (!ConvertFromV8(isolate, val, &options)) return false; return out->SetFromString(options); } }; } // namespace mate namespace { using CompletionCallback = base::Callback; scoped_refptr GetTraceDataSink( const base::FilePath& path, const CompletionCallback& callback) { base::FilePath result_file_path = path; if (result_file_path.empty() && !base::CreateTemporaryFile(&result_file_path)) LOG(ERROR) << "Creating temporary file failed"; return TracingController::CreateFileSink(result_file_path, base::Bind(callback, result_file_path)); } void StopRecording(const base::FilePath& path, const CompletionCallback& callback) { TracingController::GetInstance()->DisableRecording( GetTraceDataSink(path, callback)); } void CaptureMonitoringSnapshot(const base::FilePath& path, const CompletionCallback& callback) { TracingController::GetInstance()->CaptureMonitoringSnapshot( GetTraceDataSink(path, callback)); } void Initialize(v8::Local exports, v8::Local unused, v8::Local context, void* priv) { auto controller = base::Unretained(TracingController::GetInstance()); mate::Dictionary dict(context->GetIsolate(), exports); dict.SetMethod("getCategories", base::Bind( &TracingController::GetCategories, controller)); dict.SetMethod("startRecording", base::Bind( &TracingController::EnableRecording, controller)); dict.SetMethod("stopRecording", &StopRecording); dict.SetMethod("startMonitoring", base::Bind( &TracingController::EnableMonitoring, controller)); dict.SetMethod("stopMonitoring", base::Bind( &TracingController::DisableMonitoring, controller)); dict.SetMethod("captureMonitoringSnapshot", &CaptureMonitoringSnapshot); dict.SetMethod("getTraceBufferUsage", base::Bind( &TracingController::GetTraceBufferUsage, controller)); dict.SetMethod("setWatchEvent", base::Bind( &TracingController::SetWatchEvent, controller)); dict.SetMethod("cancelWatchEvent", base::Bind( &TracingController::CancelWatchEvent, controller)); } } // namespace NODE_MODULE_CONTEXT_AWARE_BUILTIN(atom_browser_content_tracing, Initialize)