Some methods to detect whether an Enumerable object contains a constrained number of elements that match a given condition
A second reason to create this gem is to explore various other services -- see the status list below.
Add this line to your application's Gemfile:
gem 'limit_detectors'
And then execute:
$ bundle
Or install it yourself as:
$ gem install limit_detectors
In your code, you can require 'limit_detectors'
then define your classes and include
module LimitDetectors
in your class, or create enumerable objects and extend
these objects with LimitDetectors
. Then call at_most?
(or t_least?
) on your object.
For example using pry
(you can use irb
as well) you can do this:
[3] pry(main)> a.at_most?(4){|e| e.odd?}
=> true # There are indeed no more than 4 odd numbers in the array
[4] pry(main)> a.at_most?(1){|e| e.even?}
=> false # In fact there are two even numbers in the array
$ pry -I lib -r limit_detectors
[1] pry(main)> a = [1, 2, 3, 4, 5]
=> [1, 2, 3, 4, 5]
[2] pry(main)> a.extend LimitDetectors
=> [1, 2, 3, 4, 5]
[3] pry(main)> a.at_most?(4){|e| e.odd?}
=> true # There are indeed no more than 4 odd numbers in the array
[4] pry(main)> a.at_most?(4, &:odd?)
=> true # The same behaviour using a different notation
[5] pry(main)> a.at_most?(1){|e| e.even?}
=> false # In fact there are two even numbers in the array
In code the usage may look like this (see example/example.rb for the file):
require 'limit_detectors'
class Example
include Enumerable
def each
('a'..'d').each { |c| yield c }
end
end
e = Example.new
e.extend LimitDetectors
puts e.at_least?(1) { |c| 'f' == c }
puts e.at_least?(1) { |c| 'b' == c }
puts e.at_most?(0) { |c| 'b' == c }
puts e.at_most?(42) { |c| 'b' == c }
This gem is tested with these Ruby versions (MRI, unless JRuby):
- 3.1.x
- 3.2.x
- 3.3.x
- 3.4.x
as well as a current version of JRuby and TruffleRuby
- Fork it ( https://github.com/[my-github-username]/limit_detectors/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
A more detailed description is at https://opensource.com/article/19/7/create-pull-request-github
After bundle install
(or update
) you can now use Guard
.
In the project directory run
bundle exec guard
Now, RSpec should run when files are saved (or changed otherwise). Note though, that this may or may not work out-of-the-box on all operating systems.
Please, provide answers to the following questions, when submitting a bug report:
- What's actually happening? What is the observed behaviour?
- What's the expectation, i.e. what should have happened?
- Why did you expect this behaviour?
If you provide an RSpec
check that demonstrates the bug, would give extra good karma,
especially in case of a minimal check, something that just demonstrates the bug without
any (or much) overhead.