forked from mirrors/gecko-dev
The reason why the global ScrollGeneration::sCounter doesn't work for the APZ case is the APZ sampler thread is per our top level browser window, so if there are multiple browser windows at the same time, the sCounter will be muted from different sampler threads. Differential Revision: https://phabricator.services.mozilla.com/D133439
49 lines
1.4 KiB
C++
49 lines
1.4 KiB
C++
/* 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/. */
|
|
|
|
#include "ScrollGeneration.h"
|
|
|
|
#include <ostream>
|
|
|
|
namespace mozilla {
|
|
|
|
template <typename Tag>
|
|
ScrollGeneration<Tag>::ScrollGeneration() : mValue(0) {}
|
|
|
|
template <typename Tag>
|
|
ScrollGeneration<Tag>::ScrollGeneration(uint64_t aValue) : mValue(aValue) {}
|
|
|
|
template <typename Tag>
|
|
bool ScrollGeneration<Tag>::operator<(
|
|
const ScrollGeneration<Tag>& aOther) const {
|
|
return mValue < aOther.mValue;
|
|
}
|
|
|
|
template <typename Tag>
|
|
bool ScrollGeneration<Tag>::operator==(
|
|
const ScrollGeneration<Tag>& aOther) const {
|
|
return mValue == aOther.mValue;
|
|
}
|
|
|
|
template <typename Tag>
|
|
bool ScrollGeneration<Tag>::operator!=(
|
|
const ScrollGeneration<Tag>& aOther) const {
|
|
return !(*this == aOther);
|
|
}
|
|
|
|
template <typename Tag>
|
|
std::ostream& operator<<(std::ostream& aStream,
|
|
const ScrollGeneration<Tag>& aGen) {
|
|
return aStream << aGen.mValue;
|
|
}
|
|
|
|
template struct ScrollGeneration<APZTag>;
|
|
template struct ScrollGeneration<MainThreadTag>;
|
|
|
|
template std::ostream& operator<<(std::ostream&,
|
|
const ScrollGeneration<APZTag>&);
|
|
template std::ostream& operator<<(std::ostream&,
|
|
const ScrollGeneration<MainThreadTag>&);
|
|
|
|
} // namespace mozilla
|