js/ipc/CPOWTimer.h
author B2G Bumper Bot <release+b2gbumper@mozilla.com>
Tue, 23 Feb 2016 00:46:33 -0800
changeset 325577 495ccf9c91cd59d7d0b5844b1ad9c529b1323357
parent 294812 31a26ed444843f086c468a98236e8c98b7115b44
child 505383 6f3709b3878117466168c40affa7bca0b60cf75b
permissions -rw-r--r--
Bumping manifests a=b2g-bump

/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
 * vim: set ts=4 sw=4 et 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 CPOWTIMER_H
#define CPOWTIMER_H

#include "prinrval.h"
#include "jsapi.h"

/**
 * A stopwatch measuring the duration of a CPOW call.
 *
 * As the process is consuming neither user time nor system time
 * during a CPOW call, we measure such durations using wallclock time.
 *
 * This stopwatch is active iff JSRuntime::stopwatch.isActive is set.
 * Upon destruction, update JSRuntime::stopwatch.data.totalCPOWTime.
 */
class MOZ_RAII CPOWTimer final {
  public:
    explicit inline CPOWTimer(JSContext* cx MOZ_GUARD_OBJECT_NOTIFIER_PARAM);
    ~CPOWTimer();

  private:
    MOZ_DECL_USE_GUARD_OBJECT_NOTIFIER

    /**
     * The context in which this timer was created, or `nullptr` if
     * CPOW monitoring was off when the timer was created.
     */
    JSContext* cx_;

    /**
     * The instant at which the stopwatch was started. Undefined
     * if CPOW monitoring was off when the timer was created.
     */
    int64_t startInterval_;
};

#endif