2015-07-17 12:51:39 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
|
|
|
|
#ifndef mozilla_AutoGlobalTimelineMarker_h_
|
|
|
|
#define mozilla_AutoGlobalTimelineMarker_h_
|
|
|
|
|
|
|
|
#include "mozilla/GuardObjects.h"
|
2015-11-23 07:50:56 -08:00
|
|
|
#include "TimelineMarkerEnums.h"
|
2015-07-17 12:51:39 -07:00
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
|
|
|
|
// # AutoGlobalTimelineMarker
|
|
|
|
//
|
|
|
|
// Similar to `AutoTimelineMarker`, but adds its traced marker to all docshells,
|
|
|
|
// not a single particular one. This is useful for operations that aren't
|
|
|
|
// associated with any one particular doc shell, or when it isn't clear which
|
2015-08-31 05:56:37 -07:00
|
|
|
// docshell triggered the operation.
|
2015-07-17 12:51:39 -07:00
|
|
|
//
|
|
|
|
// Example usage:
|
|
|
|
//
|
|
|
|
// {
|
|
|
|
// AutoGlobalTimelineMarker marker("Cycle Collection");
|
|
|
|
// nsCycleCollector* cc = GetCycleCollector();
|
|
|
|
// cc->Collect();
|
|
|
|
// ...
|
|
|
|
// }
|
2015-09-03 09:15:23 -07:00
|
|
|
class MOZ_RAII AutoGlobalTimelineMarker
|
2015-07-17 12:51:39 -07:00
|
|
|
{
|
|
|
|
MOZ_DECL_USE_GUARD_OBJECT_NOTIFIER;
|
|
|
|
|
|
|
|
// The name of the marker we are adding.
|
|
|
|
const char* mName;
|
2015-11-23 07:50:56 -08:00
|
|
|
// Whether to capture the JS stack or not.
|
|
|
|
MarkerStackRequest mStackRequest;
|
2015-07-17 12:51:39 -07:00
|
|
|
|
|
|
|
public:
|
2015-11-23 07:50:56 -08:00
|
|
|
explicit AutoGlobalTimelineMarker(const char* aName,
|
|
|
|
MarkerStackRequest aStackRequest = MarkerStackRequest::STACK
|
2015-07-17 12:51:39 -07:00
|
|
|
MOZ_GUARD_OBJECT_NOTIFIER_PARAM);
|
|
|
|
~AutoGlobalTimelineMarker();
|
|
|
|
|
|
|
|
AutoGlobalTimelineMarker(const AutoGlobalTimelineMarker& aOther) = delete;
|
|
|
|
void operator=(const AutoGlobalTimelineMarker& aOther) = delete;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
#endif /* mozilla_AutoGlobalTimelineMarker_h_ */
|