// Copyright (c) 2011 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.
// This file provides support for basic in-memory tracing of short events. We
// keep a static circular buffer where we store the last traced events, so we
// can review the cache recent behavior should we need it.
#ifndef NET_DISK_CACHE_TRACE_H__
#define NET_DISK_CACHE_TRACE_H__
#include "base/basictypes.h"
#include "base/memory/ref_counted.h"
#include "net/base/net_export.h"
namespace disk_cache {
// Create and destroy the tracing buffer.
void InitTrace(void);
void DestroyTrace(void);
// Simple class to handle the trace buffer lifetime. Any object interested in
// tracing should keep a reference to the object returned by GetTraceObject().
class TraceObject : public base::RefCounted<TraceObject> {
friend class base::RefCounted<TraceObject>;
public:
static TraceObject* GetTraceObject();
void EnableTracing(bool enable);
private:
TraceObject();
~TraceObject();
DISALLOW_COPY_AND_ASSIGN(TraceObject);
};
// Traces to the internal buffer.
NET_EXPORT_PRIVATE void Trace(const char* format, ...);
} // namespace disk_cache
#endif // NET_DISK_CACHE_TRACE_H__