Sha256: f79c73b2855a541ecee18fdc2a5b6aab77a80eb3de8d8cbab02b6e88fb81692a

Contents?: true

Size: 1.41 KB

Versions: 6

Compression:

Stored size: 1.41 KB

Contents

# Ztimer

**Ztimer** is a Ruby gem that allows to get asynchronous delayed notifications. You can enqueue callbacks to be
called after some amount of time. 

## Installation

Add this line to your application's Gemfile:

```ruby
gem 'ztimer'
```

And then execute:

    $ bundle

Or install it yourself as:

    $ gem install ztimer

## Usage

All you have to do is to tell **Ztimer** the delay after which your code have to be executed. An example of how to use it
is illustrated below:

```ruby
require 'ztimer'

delay = 5000 # milliseconds
Ztimer.after(delay) do
  puts "Doing something useful..."
end
```

By default **Ztimer** will run at maximum 20 notifications concurrently, so that if you have 100 notifications to be
executed at the same time, at maximum 20 of them will run at the same time. This is necessary in order to prevent uncontrolled
threads spawn when many notifications have to be sent at the same time.

Anyway, you can change the concurrency by calling `Ztimer.concurrency = <concurrency>`, where `<concurrency>` is the maximum number
of `Ztimer` workers allowed to run in parallel (ex: `Ztimer.concurrency = 50`).

## Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/serioja90/ztimer. This project is intended to be a safe,
welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
ztimer-0.3.2 README.md
ztimer-0.3.1 README.md
ztimer-0.3.0 README.md
ztimer-0.2.0 README.md
ztimer-0.1.1 README.md
ztimer-0.1.0 README.md