// Copyright (c) 2009 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. // An abstraction for functions used to control execution time profiling. // All methods are effectively no-ops unless this program is being run through // a supported tool (currently only Quantify, a companion tool to Purify) #ifndef BASE_PROFILER_H__ #define BASE_PROFILER_H__ #pragma once #include "base/basictypes.h" namespace base { class Profiler { public: // Starts or resumes recording. static void StartRecording(); // Stops recording until StartRecording is called or the program exits. static void StopRecording(); // Throw away data collected so far. This can be useful to call before // your first call to StartRecording, for instance to avoid counting any // time in application startup. static void ClearData(); // Flushes all recorded data to disk. No-op until recording is started. static void Flush(); // Sets the name of the current thread for display in the profiler's UI. static void SetThreadName(const char *name); private: DISALLOW_IMPLICIT_CONSTRUCTORS(Profiler); }; } // namespace base #endif // BASE_PROFILER_H__