mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-12-04 02:57:38 +00:00
115 lines
3.2 KiB
C++
115 lines
3.2 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 "SQLiteInterposer.h"
|
|
|
|
using namespace mozilla;
|
|
|
|
static StaticAutoPtr<SQLiteInterposer> sSingleton;
|
|
static const char* sModuleInfo = "SQLite";
|
|
|
|
/* static */ IOInterposerModule*
|
|
SQLiteInterposer::GetInstance(IOInterposeObserver* aObserver,
|
|
IOInterposeObserver::Operation aOpsToInterpose)
|
|
{
|
|
// We can't actually use this assertion because we initialize this code
|
|
// before XPCOM is initialized, so NS_IsMainThread() always returns false.
|
|
// MOZ_ASSERT(NS_IsMainThread());
|
|
if (!sSingleton) {
|
|
nsAutoPtr<SQLiteInterposer> newObj(new SQLiteInterposer());
|
|
if (!newObj->Init(aObserver, aOpsToInterpose)) {
|
|
return nullptr;
|
|
}
|
|
sSingleton = newObj.forget();
|
|
}
|
|
return sSingleton;
|
|
}
|
|
|
|
/* static */ void
|
|
SQLiteInterposer::ClearInstance()
|
|
{
|
|
// We can't actually use this assertion because we execute this code
|
|
// after XPCOM is shut down, so NS_IsMainThread() always returns false.
|
|
// MOZ_ASSERT(NS_IsMainThread());
|
|
sSingleton = nullptr;
|
|
}
|
|
|
|
SQLiteInterposer::SQLiteInterposer()
|
|
:mObserver(nullptr),
|
|
mOps(IOInterposeObserver::OpNone),
|
|
mEnabled(false)
|
|
{
|
|
}
|
|
|
|
SQLiteInterposer::~SQLiteInterposer()
|
|
{
|
|
// We can't actually use this assertion because we execute this code
|
|
// after XPCOM is shut down, so NS_IsMainThread() always returns false.
|
|
// MOZ_ASSERT(NS_IsMainThread());
|
|
mOps = IOInterposeObserver::OpNone;
|
|
sSingleton = nullptr;
|
|
Enable(false);
|
|
}
|
|
|
|
bool
|
|
SQLiteInterposer::Init(IOInterposeObserver* aObserver,
|
|
IOInterposeObserver::Operation aOpsToInterpose)
|
|
{
|
|
// We can't actually use this assertion because we initialize this code
|
|
// before XPCOM is initialized, so NS_IsMainThread() always returns false.
|
|
// MOZ_ASSERT(NS_IsMainThread());
|
|
if (!aObserver || !(aOpsToInterpose & IOInterposeObserver::OpAll)) {
|
|
return false;
|
|
}
|
|
mObserver = aObserver;
|
|
mOps = aOpsToInterpose;
|
|
return true;
|
|
}
|
|
|
|
void
|
|
SQLiteInterposer::Enable(bool aEnable)
|
|
{
|
|
mEnabled = aEnable ? 1 : 0;
|
|
}
|
|
|
|
/* static */ void
|
|
SQLiteInterposer::OnRead(double& aDuration)
|
|
{
|
|
if (!NS_IsMainThread() || !sSingleton) {
|
|
return;
|
|
}
|
|
if (sSingleton->mEnabled &&
|
|
(sSingleton->mOps & IOInterposeObserver::OpRead)) {
|
|
sSingleton->mObserver->Observe(IOInterposeObserver::OpRead, aDuration,
|
|
sModuleInfo);
|
|
}
|
|
}
|
|
|
|
/* static */ void
|
|
SQLiteInterposer::OnWrite(double& aDuration)
|
|
{
|
|
if (!NS_IsMainThread() || !sSingleton) {
|
|
return;
|
|
}
|
|
if (sSingleton->mEnabled &&
|
|
(sSingleton->mOps & IOInterposeObserver::OpWrite)) {
|
|
sSingleton->mObserver->Observe(IOInterposeObserver::OpWrite, aDuration,
|
|
sModuleInfo);
|
|
}
|
|
}
|
|
|
|
/* static */ void
|
|
SQLiteInterposer::OnFSync(double& aDuration)
|
|
{
|
|
if (!NS_IsMainThread() || !sSingleton) {
|
|
return;
|
|
}
|
|
if (sSingleton->mEnabled &&
|
|
(sSingleton->mOps & IOInterposeObserver::OpFSync)) {
|
|
sSingleton->mObserver->Observe(IOInterposeObserver::OpFSync, aDuration,
|
|
sModuleInfo);
|
|
}
|
|
}
|
|
|