2017-10-27 20:33:53 +03: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: */
|
2012-05-21 15:12:37 +04:00
|
|
|
/* 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/. */
|
1999-08-20 02:16:23 +04:00
|
|
|
|
|
|
|
//
|
|
|
|
// nsRepeatService
|
|
|
|
//
|
|
|
|
#ifndef nsRepeatService_h__
|
|
|
|
#define nsRepeatService_h__
|
|
|
|
|
|
|
|
#include "nsCOMPtr.h"
|
|
|
|
#include "nsITimer.h"
|
2018-11-04 21:30:37 +03:00
|
|
|
#include "nsString.h"
|
1999-08-20 02:16:23 +04:00
|
|
|
|
2009-12-12 01:03:31 +03:00
|
|
|
#define INITAL_REPEAT_DELAY 250
|
|
|
|
|
|
|
|
#ifdef XP_MACOSX
|
|
|
|
# define REPEAT_DELAY 25
|
|
|
|
#else
|
|
|
|
# define REPEAT_DELAY 50
|
|
|
|
#endif
|
|
|
|
|
1999-08-20 02:16:23 +04:00
|
|
|
class nsITimer;
|
|
|
|
|
2019-01-02 16:05:23 +03:00
|
|
|
namespace mozilla {
|
|
|
|
namespace dom {
|
|
|
|
class Document;
|
|
|
|
}
|
|
|
|
} // namespace mozilla
|
|
|
|
|
2017-03-29 10:54:49 +03:00
|
|
|
class nsRepeatService final {
|
1999-08-20 02:16:23 +04:00
|
|
|
public:
|
2008-02-15 05:04:34 +03:00
|
|
|
typedef void (*Callback)(void* aData);
|
2017-03-29 10:54:49 +03:00
|
|
|
|
|
|
|
~nsRepeatService();
|
1999-08-20 02:16:23 +04:00
|
|
|
|
2008-02-15 05:04:34 +03:00
|
|
|
// Start dispatching timer events to the callback. There is no memory
|
|
|
|
// management of aData here; it is the caller's responsibility to call
|
|
|
|
// Stop() before aData's memory is released.
|
2017-03-29 11:32:52 +03:00
|
|
|
//
|
|
|
|
// aCallbackName is the label of the callback, used to pass to
|
|
|
|
// InitWithNamedCallbackFunc.
|
2017-03-29 11:40:05 +03:00
|
|
|
//
|
|
|
|
// aDocument is used to get the event target in Start(). We need an event
|
|
|
|
// target to init mRepeatTimer.
|
2019-01-02 16:05:23 +03:00
|
|
|
void Start(Callback aCallback, void* aCallbackData,
|
|
|
|
mozilla::dom::Document* aDocument, const nsACString& aCallbackName,
|
2012-08-22 19:56:38 +04:00
|
|
|
uint32_t aInitialDelay = INITAL_REPEAT_DELAY);
|
2008-02-15 05:04:34 +03:00
|
|
|
// Stop dispatching timer events to the callback. If the repeat service
|
|
|
|
// is not currently configured with the given callback and data, this
|
|
|
|
// is just ignored.
|
|
|
|
void Stop(Callback aCallback, void* aData);
|
1999-08-20 02:16:23 +04:00
|
|
|
|
|
|
|
static nsRepeatService* GetInstance();
|
2000-11-08 06:20:22 +03:00
|
|
|
static void Shutdown();
|
1999-08-20 02:16:23 +04:00
|
|
|
|
|
|
|
protected:
|
|
|
|
nsRepeatService();
|
|
|
|
|
|
|
|
private:
|
2017-03-29 10:40:04 +03:00
|
|
|
// helper function to initialize callback function to mRepeatTimer
|
|
|
|
void InitTimerCallback(uint32_t aInitialDelay);
|
|
|
|
|
2008-02-15 05:04:34 +03:00
|
|
|
Callback mCallback;
|
|
|
|
void* mCallbackData;
|
2017-03-29 11:32:52 +03:00
|
|
|
nsCString mCallbackName;
|
2008-02-15 05:04:34 +03:00
|
|
|
nsCOMPtr<nsITimer> mRepeatTimer;
|
1999-08-20 02:16:23 +04:00
|
|
|
|
|
|
|
}; // class nsRepeatService
|
|
|
|
|
|
|
|
#endif
|