[ICO]NameLast modifiedSizeDescription
[PARENTDIR]Parent Directory  -  
[DIR]tests/2023-06-15 18:18 -  
[TXT]README.md2016-06-20 16:55 2.1Kd7c1522 post receive test [كارل مبارك]
[   ]package.json2023-06-15 18:21 1.5K 
[   ]index.js2016-06-20 16:55 1.3K 
[   ]LICENSE2016-06-20 16:48 1.1K 
# reInterval
![TRAVIS](https://travis-ci.org/4rzael/reInterval.svg)

[![NPM](https://nodei.co/npm/reinterval.png?downloads=true&downloadRank=true)](https://nodei.co/npm/reinterval/)

Reschedulable setInterval for node.js.

###### Note: Work highly inspired by [mcollina](https://github.com/mcollina)'s [retimer](https://github.com/mcollina/retimer).

## Example

```js
var reInterval = require('reInterval');

var inter = reInterval(function () {
  console.log('this should be called after 13s');
}, 10 * 1000);

// This will reset/reschedule the interval after 3 seconds, therefore
// the interval callback won't be called for at least 13 seconds.
setTimeout(function () {
  inter.reschedule(10 * 1000);
}, 3 * 1000);
```


## API:

###`reInterval(callback, interval[, param1, param2, ...])`

This is exactly like setInterval.

_Arguments:_
  - `callback`: The callback to be executed repeatedly.
  - `interval`: The number of milliseconds (thousandths of a second) that the `reInterval()` function should wait before each call to `callback`.
  - `param1, param2, ...`: *(OPTIONAL)* These arguments are passed to the `callback` function.

####returns an `interval` object with the following methods:

###`interval.reschedule([interval])`

This function resets the `interval` and restarts it now.

_Arguments:_
  - `interval`: *(OPTIONAL)* This argument can be used to change the amount of milliseconds to wait before each call to the `callback` passed to the `reInterval()` function.

###`interval.clear()`

This function clears the interval. Can be used to temporarily clear the `interval`, which can be rescheduled at a later time.

###`interval.destroy()`

This function clears the interval, and will also clear the `callback` and `params` passed to reInterval, so calling this essentially just makes this object ready for overwriting with a new `interval` object. 

#### Note:
Please ensure that either the `interval.clear()` or `interval.destroy()` function is called before overwriting the `interval` object, because the internal `interval` can continue to run in the background unless cleared.

## license

**MIT**