blob: 882c1a7db6c8258764369a2cd06c591e75b3c6b3 [file] [log] [blame]
// Copyright 2019 The Chromium 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 PLATFORM_API_TRACE_LOGGING_PLATFORM_H_
#define PLATFORM_API_TRACE_LOGGING_PLATFORM_H_
#include "platform/api/time.h"
#include "platform/base/error.h"
#include "platform/base/trace_logging_activation.h"
#include "platform/base/trace_logging_types.h"
namespace openscreen {
// Optional platform API to support logging trace events from Open Screen. To
// use this, implement the TraceLoggingPlatform interface and call
// StartTracing() and StopTracing() to turn tracing on/off (see
// platform/base/trace_logging_activation.h).
//
// All methods must be thread-safe and re-entrant.
class TraceLoggingPlatform {
public:
virtual ~TraceLoggingPlatform();
// Determines whether trace logging is enabled for the given category.
virtual bool IsTraceLoggingEnabled(TraceCategory::Value category) = 0;
// Log a synchronous trace.
virtual void LogTrace(const char* name,
const uint32_t line,
const char* file,
Clock::time_point start_time,
Clock::time_point end_time,
TraceIdHierarchy ids,
Error::Code error) = 0;
// Log an asynchronous trace start.
virtual void LogAsyncStart(const char* name,
const uint32_t line,
const char* file,
Clock::time_point timestamp,
TraceIdHierarchy ids) = 0;
// Log an asynchronous trace end.
virtual void LogAsyncEnd(const uint32_t line,
const char* file,
Clock::time_point timestamp,
TraceId trace_id,
Error::Code error) = 0;
};
} // namespace openscreen
#endif // PLATFORM_API_TRACE_LOGGING_PLATFORM_H_