|
Packit |
f0b94e |
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
|
Packit |
f0b94e |
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
Packit |
f0b94e |
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
Packit |
f0b94e |
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
#include "nsBrowserStatusFilter.h"
|
|
Packit |
f0b94e |
#include "mozilla/SystemGroup.h"
|
|
Packit |
f0b94e |
#include "nsIChannel.h"
|
|
Packit |
f0b94e |
#include "nsITimer.h"
|
|
Packit |
f0b94e |
#include "nsIServiceManager.h"
|
|
Packit |
f0b94e |
#include "nsString.h"
|
|
Packit |
f0b94e |
#include "nsThreadUtils.h"
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
using namespace mozilla;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
// nsBrowserStatusFilter <public>
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::nsBrowserStatusFilter()
|
|
Packit |
f0b94e |
: mTarget(GetMainThreadEventTarget()),
|
|
Packit |
f0b94e |
mCurProgress(0),
|
|
Packit |
f0b94e |
mMaxProgress(0),
|
|
Packit |
f0b94e |
mCurrentPercentage(0),
|
|
Packit |
f0b94e |
mStatusIsDirty(true),
|
|
Packit |
f0b94e |
mIsLoadingDocument(false),
|
|
Packit |
f0b94e |
mDelayedStatus(false),
|
|
Packit |
f0b94e |
mDelayedProgress(false) {}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::~nsBrowserStatusFilter() {
|
|
Packit |
f0b94e |
if (mTimer) {
|
|
Packit |
f0b94e |
mTimer->Cancel();
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
// nsBrowserStatusFilter::nsISupports
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMPL_CYCLE_COLLECTION(nsBrowserStatusFilter, mListener, mTarget)
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_INTERFACE_MAP_BEGIN_CYCLE_COLLECTION(nsBrowserStatusFilter)
|
|
Packit |
f0b94e |
NS_INTERFACE_MAP_ENTRY(nsIWebProgress)
|
|
Packit |
f0b94e |
NS_INTERFACE_MAP_ENTRY(nsIWebProgressListener)
|
|
Packit |
f0b94e |
NS_INTERFACE_MAP_ENTRY(nsIWebProgressListener2)
|
|
Packit |
f0b94e |
NS_INTERFACE_MAP_ENTRY(nsISupportsWeakReference)
|
|
Packit |
f0b94e |
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsISupports, nsIWebProgress)
|
|
Packit |
f0b94e |
NS_INTERFACE_MAP_END
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMPL_CYCLE_COLLECTING_ADDREF(nsBrowserStatusFilter)
|
|
Packit |
f0b94e |
NS_IMPL_CYCLE_COLLECTING_RELEASE(nsBrowserStatusFilter)
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
// nsBrowserStatusFilter::nsIWebProgress
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::AddProgressListener(nsIWebProgressListener *aListener,
|
|
Packit |
f0b94e |
uint32_t aNotifyMask) {
|
|
Packit |
f0b94e |
mListener = aListener;
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::RemoveProgressListener(
|
|
Packit |
f0b94e |
nsIWebProgressListener *aListener) {
|
|
Packit |
f0b94e |
if (aListener == mListener) mListener = nullptr;
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::GetDOMWindow(mozIDOMWindowProxy **aResult) {
|
|
Packit |
f0b94e |
NS_NOTREACHED("nsBrowserStatusFilter::GetDOMWindow");
|
|
Packit |
f0b94e |
return NS_ERROR_NOT_IMPLEMENTED;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::GetDOMWindowID(uint64_t *aResult) {
|
|
Packit |
f0b94e |
*aResult = 0;
|
|
Packit |
f0b94e |
NS_NOTREACHED("nsBrowserStatusFilter::GetDOMWindowID");
|
|
Packit |
f0b94e |
return NS_ERROR_NOT_IMPLEMENTED;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::GetInnerDOMWindowID(uint64_t *aResult) {
|
|
Packit |
f0b94e |
*aResult = 0;
|
|
Packit |
f0b94e |
NS_NOTREACHED("nsBrowserStatusFilter::GetInnerDOMWindowID");
|
|
Packit |
f0b94e |
return NS_ERROR_NOT_IMPLEMENTED;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::GetIsTopLevel(bool *aIsTopLevel) {
|
|
Packit |
f0b94e |
*aIsTopLevel = false;
|
|
Packit |
f0b94e |
NS_NOTREACHED("nsBrowserStatusFilter::GetIsTopLevel");
|
|
Packit |
f0b94e |
return NS_ERROR_NOT_IMPLEMENTED;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::GetIsLoadingDocument(bool *aIsLoadingDocument) {
|
|
Packit |
f0b94e |
NS_NOTREACHED("nsBrowserStatusFilter::GetIsLoadingDocument");
|
|
Packit |
f0b94e |
return NS_ERROR_NOT_IMPLEMENTED;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::GetLoadType(uint32_t *aLoadType) {
|
|
Packit |
f0b94e |
*aLoadType = 0;
|
|
Packit |
f0b94e |
NS_NOTREACHED("nsBrowserStatusFilter::GetLoadType");
|
|
Packit |
f0b94e |
return NS_ERROR_NOT_IMPLEMENTED;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::GetTarget(nsIEventTarget **aTarget) {
|
|
Packit |
f0b94e |
nsCOMPtr<nsIEventTarget> target = mTarget;
|
|
Packit |
f0b94e |
target.forget(aTarget);
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::SetTarget(nsIEventTarget *aTarget) {
|
|
Packit |
f0b94e |
mTarget = aTarget;
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
// nsBrowserStatusFilter::nsIWebProgressListener
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::OnStateChange(nsIWebProgress *aWebProgress,
|
|
Packit |
f0b94e |
nsIRequest *aRequest, uint32_t aStateFlags,
|
|
Packit |
f0b94e |
nsresult aStatus) {
|
|
Packit |
f0b94e |
if (!mListener) return NS_OK;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (aStateFlags & STATE_START) {
|
|
Packit |
f0b94e |
// Reset members on beginning of document loading, but we don't want
|
|
Packit |
f0b94e |
// subframe document loading followed by the root document loading
|
|
Packit |
f0b94e |
// resets members accidentally, so for non-toplevel load we check if
|
|
Packit |
f0b94e |
// there hasn't been a document load started.
|
|
Packit |
f0b94e |
if (aStateFlags & STATE_IS_DOCUMENT) {
|
|
Packit |
f0b94e |
bool isTopLevel = false;
|
|
Packit |
f0b94e |
aWebProgress->GetIsTopLevel(&isTopLevel);
|
|
Packit |
f0b94e |
if (!mIsLoadingDocument || isTopLevel) {
|
|
Packit |
f0b94e |
ResetMembers();
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
mIsLoadingDocument = true;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
} else if (aStateFlags & STATE_STOP) {
|
|
Packit |
f0b94e |
// Flush pending status / progress update during document loading.
|
|
Packit |
f0b94e |
if (mIsLoadingDocument) {
|
|
Packit |
f0b94e |
bool isLoadingDocument = true;
|
|
Packit |
f0b94e |
aWebProgress->GetIsLoadingDocument(&isLoadingDocument);
|
|
Packit |
f0b94e |
mIsLoadingDocument &= isLoadingDocument;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (mTimer) {
|
|
Packit |
f0b94e |
mTimer->Cancel();
|
|
Packit |
f0b94e |
ProcessTimeout();
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
} else {
|
|
Packit |
f0b94e |
// No need to forward this state change.
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// Only notify listener for STATE_IS_NETWORK.
|
|
Packit |
f0b94e |
if (aStateFlags & STATE_IS_NETWORK) {
|
|
Packit |
f0b94e |
return mListener->OnStateChange(aWebProgress, aRequest, aStateFlags,
|
|
Packit |
f0b94e |
aStatus);
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::OnProgressChange(nsIWebProgress *aWebProgress,
|
|
Packit |
f0b94e |
nsIRequest *aRequest,
|
|
Packit |
f0b94e |
int32_t aCurSelfProgress,
|
|
Packit |
f0b94e |
int32_t aMaxSelfProgress,
|
|
Packit |
f0b94e |
int32_t aCurTotalProgress,
|
|
Packit |
f0b94e |
int32_t aMaxTotalProgress) {
|
|
Packit |
f0b94e |
if (!mListener) return NS_OK;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
//
|
|
Packit |
f0b94e |
// limit frequency of calls to OnProgressChange
|
|
Packit |
f0b94e |
//
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
mCurProgress = (int64_t)aCurTotalProgress;
|
|
Packit |
f0b94e |
mMaxProgress = (int64_t)aMaxTotalProgress;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (mDelayedProgress) return NS_OK;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (!mDelayedStatus) {
|
|
Packit |
f0b94e |
MaybeSendProgress();
|
|
Packit |
f0b94e |
StartDelayTimer();
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
mDelayedProgress = true;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::OnLocationChange(nsIWebProgress *aWebProgress,
|
|
Packit |
f0b94e |
nsIRequest *aRequest, nsIURI *aLocation,
|
|
Packit |
f0b94e |
uint32_t aFlags) {
|
|
Packit |
f0b94e |
if (!mListener) return NS_OK;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
return mListener->OnLocationChange(aWebProgress, aRequest, aLocation, aFlags);
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::OnStatusChange(nsIWebProgress *aWebProgress,
|
|
Packit |
f0b94e |
nsIRequest *aRequest, nsresult aStatus,
|
|
Packit |
f0b94e |
const char16_t *aMessage) {
|
|
Packit |
f0b94e |
if (!mListener) return NS_OK;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
//
|
|
Packit |
f0b94e |
// limit frequency of calls to OnStatusChange
|
|
Packit |
f0b94e |
//
|
|
Packit |
f0b94e |
if (mStatusIsDirty || !mCurrentStatusMsg.Equals(aMessage)) {
|
|
Packit |
f0b94e |
mStatusIsDirty = true;
|
|
Packit |
f0b94e |
mStatusMsg = aMessage;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (mDelayedStatus) return NS_OK;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (!mDelayedProgress) {
|
|
Packit |
f0b94e |
MaybeSendStatus();
|
|
Packit |
f0b94e |
StartDelayTimer();
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
mDelayedStatus = true;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::OnSecurityChange(nsIWebProgress *aWebProgress,
|
|
Packit |
f0b94e |
nsIRequest *aRequest, uint32_t aState) {
|
|
Packit |
f0b94e |
if (!mListener) return NS_OK;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
return mListener->OnSecurityChange(aWebProgress, aRequest, aState);
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
// nsBrowserStatusFilter::nsIWebProgressListener2
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::OnProgressChange64(nsIWebProgress *aWebProgress,
|
|
Packit |
f0b94e |
nsIRequest *aRequest,
|
|
Packit |
f0b94e |
int64_t aCurSelfProgress,
|
|
Packit |
f0b94e |
int64_t aMaxSelfProgress,
|
|
Packit |
f0b94e |
int64_t aCurTotalProgress,
|
|
Packit |
f0b94e |
int64_t aMaxTotalProgress) {
|
|
Packit |
f0b94e |
// XXX truncates 64-bit to 32-bit
|
|
Packit |
f0b94e |
return OnProgressChange(aWebProgress, aRequest, (int32_t)aCurSelfProgress,
|
|
Packit |
f0b94e |
(int32_t)aMaxSelfProgress, (int32_t)aCurTotalProgress,
|
|
Packit |
f0b94e |
(int32_t)aMaxTotalProgress);
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
NS_IMETHODIMP
|
|
Packit |
f0b94e |
nsBrowserStatusFilter::OnRefreshAttempted(nsIWebProgress *aWebProgress,
|
|
Packit |
f0b94e |
nsIURI *aUri, int32_t aDelay,
|
|
Packit |
f0b94e |
bool aSameUri, bool *allowRefresh) {
|
|
Packit |
f0b94e |
nsCOMPtr<nsIWebProgressListener2> listener = do_QueryInterface(mListener);
|
|
Packit |
f0b94e |
if (!listener) {
|
|
Packit |
f0b94e |
*allowRefresh = true;
|
|
Packit |
f0b94e |
return NS_OK;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
return listener->OnRefreshAttempted(aWebProgress, aUri, aDelay, aSameUri,
|
|
Packit |
f0b94e |
allowRefresh);
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
// nsBrowserStatusFilter <private>
|
|
Packit |
f0b94e |
//-----------------------------------------------------------------------------
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
void nsBrowserStatusFilter::ResetMembers() {
|
|
Packit |
f0b94e |
mMaxProgress = 0;
|
|
Packit |
f0b94e |
mCurProgress = 0;
|
|
Packit |
f0b94e |
mCurrentPercentage = 0;
|
|
Packit |
f0b94e |
mStatusIsDirty = true;
|
|
Packit |
f0b94e |
// We don't reset mIsLoadingDocument here.
|
|
Packit |
f0b94e |
// It's controlled by OnStateChange based on webProgress states.
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
void nsBrowserStatusFilter::MaybeSendProgress() {
|
|
Packit |
f0b94e |
if (mCurProgress > mMaxProgress || mCurProgress <= 0) return;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// check our percentage
|
|
Packit |
f0b94e |
int32_t percentage = (int32_t) double(mCurProgress) * 100 / mMaxProgress;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
// The progress meter only updates for increases greater than 3 percent
|
|
Packit |
f0b94e |
if (percentage > (mCurrentPercentage + 3)) {
|
|
Packit |
f0b94e |
mCurrentPercentage = percentage;
|
|
Packit |
f0b94e |
// XXX truncates 64-bit to 32-bit
|
|
Packit |
f0b94e |
mListener->OnProgressChange(nullptr, nullptr, 0, 0, (int32_t)mCurProgress,
|
|
Packit |
f0b94e |
(int32_t)mMaxProgress);
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
void nsBrowserStatusFilter::MaybeSendStatus() {
|
|
Packit |
f0b94e |
if (mStatusIsDirty) {
|
|
Packit |
f0b94e |
mListener->OnStatusChange(nullptr, nullptr, NS_OK, mStatusMsg.get());
|
|
Packit |
f0b94e |
mCurrentStatusMsg = mStatusMsg;
|
|
Packit |
f0b94e |
mStatusIsDirty = false;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
nsresult nsBrowserStatusFilter::StartDelayTimer() {
|
|
Packit |
f0b94e |
NS_ASSERTION(!DelayInEffect(), "delay should not be in effect");
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
return NS_NewTimerWithFuncCallback(getter_AddRefs(mTimer), TimeoutHandler,
|
|
Packit |
f0b94e |
this, 160, nsITimer::TYPE_ONE_SHOT,
|
|
Packit |
f0b94e |
"nsBrowserStatusFilter::TimeoutHandler",
|
|
Packit |
f0b94e |
mTarget);
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
void nsBrowserStatusFilter::ProcessTimeout() {
|
|
Packit |
f0b94e |
mTimer = nullptr;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (!mListener) return;
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (mDelayedStatus) {
|
|
Packit |
f0b94e |
mDelayedStatus = false;
|
|
Packit |
f0b94e |
MaybeSendStatus();
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
if (mDelayedProgress) {
|
|
Packit |
f0b94e |
mDelayedProgress = false;
|
|
Packit |
f0b94e |
MaybeSendProgress();
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
void nsBrowserStatusFilter::TimeoutHandler(nsITimer *aTimer, void *aClosure) {
|
|
Packit |
f0b94e |
nsBrowserStatusFilter *self =
|
|
Packit |
f0b94e |
reinterpret_cast<nsBrowserStatusFilter *>(aClosure);
|
|
Packit |
f0b94e |
if (!self) {
|
|
Packit |
f0b94e |
NS_ERROR("no self");
|
|
Packit |
f0b94e |
return;
|
|
Packit |
f0b94e |
}
|
|
Packit |
f0b94e |
|
|
Packit |
f0b94e |
self->ProcessTimeout();
|
|
Packit |
f0b94e |
}
|