enumbler 0.7.0 → 0.9.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rubocop.yml +27 -5
- data/Gemfile +1 -1
- data/Gemfile.lock +3 -3
- data/README.md +12 -3
- data/Rakefile +2 -2
- data/bin/console +3 -3
- data/bin/pre_commit_rubocop.rb +19 -9
- data/enumbler.gemspec +25 -25
- data/lefthook.yml +12 -0
- data/lib/enumbler.rb +7 -7
- data/lib/enumbler/collection.rb +1 -1
- data/lib/enumbler/enabler.rb +97 -5
- data/lib/enumbler/version.rb +1 -1
- metadata +8 -7
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ab789606b3b4b29bf976ec57a54ca62c838209f286b440f32946f494c331b92e
|
4
|
+
data.tar.gz: 9bae37ac280295c70380949c7222e643a240f6c8aec3897c76ec4609349cdfa1
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 06d0fa3bfbac702c77a2968e90a53b86a3912c3fa8f18bab1619d3d6c008e5e3c8daeab3f0e0edf5005f83ca02f06d17e58125728b22c26a3e4a3a97c929c793
|
7
|
+
data.tar.gz: 3cad767146fc58f6a103480ab57b749ff5522e80e3a397a71f374423c6a64104cd54f81b9e2107fb66f196dd5b3d445bcbf7204a05aa196a7a5b00c0b06d1746
|
data/.rubocop.yml
CHANGED
@@ -1,7 +1,6 @@
|
|
1
1
|
AllCops:
|
2
|
-
|
3
|
-
|
4
|
-
- 'bin/pre_commit_rubocop.rb'
|
2
|
+
NewCops: enable
|
3
|
+
TargetRubyVersion: 2.5
|
5
4
|
|
6
5
|
Layout/ArgumentAlignment:
|
7
6
|
Enabled: true
|
@@ -11,16 +10,36 @@ Layout/FirstHashElementIndentation:
|
|
11
10
|
Enabled: true
|
12
11
|
EnforcedStyle: consistent
|
13
12
|
|
13
|
+
Layout/HashAlignment:
|
14
|
+
Enabled: true
|
15
|
+
# This allows "implicit" hash arguments (without curly braces) to be aligned
|
16
|
+
# differently.
|
17
|
+
EnforcedLastArgumentHashStyle: ignore_implicit
|
18
|
+
|
14
19
|
Layout/LineLength:
|
15
20
|
AllowURI: true
|
16
21
|
Max: 119
|
17
22
|
|
23
|
+
Layout/MultilineMethodCallIndentation:
|
24
|
+
Enabled: true
|
25
|
+
EnforcedStyle: indented
|
26
|
+
|
18
27
|
Lint/RaiseException:
|
19
28
|
Enabled: true
|
20
29
|
|
21
30
|
Lint/StructNewOverride:
|
22
31
|
Enabled: true
|
23
32
|
|
33
|
+
Metrics:
|
34
|
+
Enabled: false
|
35
|
+
|
36
|
+
Naming/MethodParameterName:
|
37
|
+
Enabled: true
|
38
|
+
AllowedNames: [at, by, db, id, in, ip, of, on, to, tz]
|
39
|
+
|
40
|
+
Naming/PredicateName:
|
41
|
+
Enabled: true
|
42
|
+
|
24
43
|
Style/Documentation:
|
25
44
|
Enabled: false
|
26
45
|
|
@@ -33,6 +52,9 @@ Style/HashTransformKeys:
|
|
33
52
|
Style/HashTransformValues:
|
34
53
|
Enabled: true
|
35
54
|
|
55
|
+
Style/StringLiterals:
|
56
|
+
EnforcedStyle: double_quotes
|
57
|
+
|
36
58
|
Style/TrailingCommaInHashLiteral:
|
37
59
|
Enabled: true
|
38
60
|
EnforcedStyleForMultiline: consistent_comma
|
@@ -41,5 +63,5 @@ Style/TrailingCommaInArrayLiteral:
|
|
41
63
|
Enabled: true
|
42
64
|
EnforcedStyleForMultiline: consistent_comma
|
43
65
|
|
44
|
-
|
45
|
-
|
66
|
+
Style/TrailingCommaInArguments:
|
67
|
+
EnforcedStyleForMultiline: consistent_comma
|
data/Gemfile
CHANGED
data/Gemfile.lock
CHANGED
data/README.md
CHANGED
@@ -91,6 +91,17 @@ Color.ids_from_enumbler(:black, 'does-no-exist') # => [1, nil]
|
|
91
91
|
Color.ids_from_enumbler!(:black, 'does-no-exist') # => raises Enumbler::Error
|
92
92
|
Color.id_from_enumbler!(:does_not_exist) # => raises Enumbler::Error
|
93
93
|
|
94
|
+
# Get a model instance (like `.find_by` in Rails)
|
95
|
+
Color.find_by_enumble(1)
|
96
|
+
Color.find_by_enumble(:black)
|
97
|
+
Color.find_by_enumble("black")
|
98
|
+
Color.find_by_enumble("BLACK")
|
99
|
+
Color.find_by_enumble(Color.black) # => self
|
100
|
+
Color.find_by_enumble("whoops") # => nil
|
101
|
+
|
102
|
+
# Raise ActiveRecord::RecordNotFound error with bang
|
103
|
+
Color.find_by_enumble!("whoops") # => nil
|
104
|
+
|
94
105
|
# Get enumble object by id
|
95
106
|
house = House.create!(color: Color.black)
|
96
107
|
|
@@ -159,14 +170,12 @@ To install this gem onto your local machine, run `bundle exec rake install`. To
|
|
159
170
|
|
160
171
|
## Roadmap
|
161
172
|
|
162
|
-
*
|
163
|
-
* Ideally, we could make this work more like a traditional `enum`; for example, overriding the `.where` method by allowing something like: `House.where(color: :blue)` instead of `House.where_color(:blue)`. But right now am in a rush and not sure how to go about doing that properly.
|
173
|
+
* Ideally, we could make this work more like a traditional `enum`; for example, overriding the `.where` method by allowing something like: `House.where(color: :blue)` instead of `House.color(:blue)`. But right now am in a rush and not sure how to go about doing that properly.
|
164
174
|
|
165
175
|
## Contributing
|
166
176
|
|
167
177
|
Bug reports and pull requests are welcome on GitHub at https://github.com/linguabee/enumbler.
|
168
178
|
|
169
|
-
|
170
179
|
## License
|
171
180
|
|
172
181
|
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
|
data/Rakefile
CHANGED
data/bin/console
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
2
|
# frozen_string_literal: true
|
3
3
|
|
4
|
-
require
|
5
|
-
require
|
4
|
+
require "bundler/setup"
|
5
|
+
require "enumbler"
|
6
6
|
|
7
7
|
# You can add fixtures and/or initialization code here to make experimenting
|
8
8
|
# with your gem easier. You can also use a different console, if you like.
|
@@ -11,5 +11,5 @@ require 'enumbler'
|
|
11
11
|
# require "pry"
|
12
12
|
# Pry.start
|
13
13
|
|
14
|
-
require
|
14
|
+
require "irb"
|
15
15
|
IRB.start(__FILE__)
|
data/bin/pre_commit_rubocop.rb
CHANGED
@@ -1,8 +1,10 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
2
4
|
# Put this file into your path and use `<file> install` to add a new hook
|
3
5
|
# or use it as a binary to check changed files
|
4
6
|
|
5
|
-
require
|
7
|
+
require "shellwords"
|
6
8
|
|
7
9
|
if ARGV == ["install"]
|
8
10
|
exec "ln", "-sf", File.expand_path(File.basename(__FILE__), __dir__), ".git/hooks/pre-commit"
|
@@ -10,15 +12,23 @@ else
|
|
10
12
|
raise unless ARGV == []
|
11
13
|
end
|
12
14
|
|
13
|
-
changed = `git status --porcelain
|
14
|
-
split("\n")
|
15
|
-
map { |l| l.split(" ", 2) }
|
16
|
-
select { |status, _| [
|
17
|
-
map { |_, file| file.delete('"') }
|
15
|
+
changed = `git status --porcelain`
|
16
|
+
.split("\n")
|
17
|
+
.map { |l| l.split(" ", 2) }
|
18
|
+
.select { |status, _| %w[A AM M].include?(status) }
|
19
|
+
.map { |_, file| file.delete('"') }
|
18
20
|
|
19
21
|
exit if changed.empty?
|
20
22
|
|
21
|
-
parallel = (
|
23
|
+
parallel = (if begin
|
24
|
+
File.read(".rubocop.yml").include?("UseCache: false")
|
25
|
+
rescue StandardError
|
26
|
+
false
|
27
|
+
end
|
28
|
+
""
|
29
|
+
else
|
30
|
+
" --parallel"
|
31
|
+
end)
|
22
32
|
result = `bundle exec rubocop #{parallel} --color --force-exclusion #{changed.shelljoin}`
|
23
|
-
puts result unless
|
24
|
-
exit
|
33
|
+
puts result unless $CHILD_STATUS.success?
|
34
|
+
exit $CHILD_STATUS.exitstatus
|
data/enumbler.gemspec
CHANGED
@@ -1,42 +1,42 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require_relative
|
3
|
+
require_relative "lib/enumbler/version"
|
4
4
|
|
5
5
|
Gem::Specification.new do |spec|
|
6
|
-
spec.name =
|
6
|
+
spec.name = "enumbler"
|
7
7
|
spec.version = Enumbler::VERSION
|
8
|
-
spec.authors = [
|
9
|
-
spec.email = [
|
8
|
+
spec.authors = ["Damon Timm"]
|
9
|
+
spec.email = ["damon@linguabee.com"]
|
10
10
|
|
11
11
|
spec.summary = "Enums are terrific, but lack integrity. Let's add some!"
|
12
|
-
spec.description =
|
13
|
-
spec.homepage =
|
14
|
-
spec.license =
|
15
|
-
spec.required_ruby_version = Gem::Requirement.new(
|
12
|
+
spec.description = "A more complete description is forthcoming."
|
13
|
+
spec.homepage = "https://github.com/linguabee/enumbler"
|
14
|
+
spec.license = "MIT"
|
15
|
+
spec.required_ruby_version = Gem::Requirement.new(">= 2.5.0")
|
16
16
|
|
17
|
-
spec.metadata[
|
17
|
+
spec.metadata["allowed_push_host"] = "https://rubygems.org"
|
18
18
|
|
19
|
-
spec.metadata[
|
20
|
-
spec.metadata[
|
21
|
-
spec.metadata[
|
19
|
+
spec.metadata["homepage_uri"] = spec.homepage
|
20
|
+
spec.metadata["source_code_uri"] = spec.homepage
|
21
|
+
spec.metadata["changelog_uri"] = spec.homepage
|
22
22
|
|
23
23
|
# Specify which files should be added to the gem when it is released.
|
24
24
|
# The `git ls-files -z` loads the files in the RubyGem that have been added into git.
|
25
25
|
spec.files = Dir.chdir(File.expand_path(__dir__)) do
|
26
26
|
`git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
|
27
27
|
end
|
28
|
-
spec.bindir =
|
28
|
+
spec.bindir = "exe"
|
29
29
|
spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
|
30
|
-
spec.require_paths = [
|
31
|
-
|
32
|
-
spec.add_dependency
|
33
|
-
spec.add_dependency
|
34
|
-
|
35
|
-
spec.add_development_dependency
|
36
|
-
spec.add_development_dependency
|
37
|
-
spec.add_development_dependency
|
38
|
-
spec.add_development_dependency
|
39
|
-
spec.add_development_dependency
|
40
|
-
spec.add_development_dependency
|
41
|
-
spec.add_development_dependency
|
30
|
+
spec.require_paths = ["lib"]
|
31
|
+
|
32
|
+
spec.add_dependency "activerecord", [">= 5.2.3", "< 7"]
|
33
|
+
spec.add_dependency "activesupport", [">= 5.2.3", "< 7"]
|
34
|
+
|
35
|
+
spec.add_development_dependency "database_cleaner-active_record", "~> 1.8.0"
|
36
|
+
spec.add_development_dependency "fuubar", "~> 2.5"
|
37
|
+
spec.add_development_dependency "pry"
|
38
|
+
spec.add_development_dependency "rake", "~> 12.0"
|
39
|
+
spec.add_development_dependency "rspec", "~> 3.9.0"
|
40
|
+
spec.add_development_dependency "rubocop", "~> 0.91.0"
|
41
|
+
spec.add_development_dependency "sqlite3", "~> 1.4.0"
|
42
42
|
end
|
data/lefthook.yml
ADDED
@@ -0,0 +1,12 @@
|
|
1
|
+
# EXAMPLE USAGE
|
2
|
+
# Refer for explanation to following link:
|
3
|
+
# https://github.com/Arkweid/lefthook/blob/master/docs/full_guide.md
|
4
|
+
|
5
|
+
pre-commit:
|
6
|
+
parallel: true
|
7
|
+
commands:
|
8
|
+
rubocop:
|
9
|
+
tags: backend style
|
10
|
+
glob: "*.rb"
|
11
|
+
exclude: "application.rb|routes.rb"
|
12
|
+
run: bundle exec rubocop --force-exclusion {all_files}
|
data/lib/enumbler.rb
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require
|
3
|
+
require "enumbler/core_ext/symbol/case_equality_operator"
|
4
4
|
|
5
|
-
require
|
6
|
-
require
|
7
|
-
require
|
8
|
-
require
|
5
|
+
require "enumbler/collection"
|
6
|
+
require "enumbler/enumble"
|
7
|
+
require "enumbler/enabler"
|
8
|
+
require "enumbler/version"
|
9
9
|
|
10
|
-
require
|
11
|
-
require
|
10
|
+
require "active_support/concern"
|
11
|
+
require "active_support/inflector"
|
12
12
|
|
13
13
|
# The Enumbler add integrity to our enum implementation!
|
14
14
|
module Enumbler
|
data/lib/enumbler/collection.rb
CHANGED
data/lib/enumbler/enabler.rb
CHANGED
@@ -12,7 +12,7 @@ module Enumbler
|
|
12
12
|
def enumble
|
13
13
|
@enumble = self.class.find_enumble(id)
|
14
14
|
|
15
|
-
raise Error,
|
15
|
+
raise Error, "An enumble is not defined for this record!" if @enumble.nil?
|
16
16
|
|
17
17
|
@enumble
|
18
18
|
end
|
@@ -126,6 +126,51 @@ module Enumbler
|
|
126
126
|
@enumbler_label_column_name = label_column_name
|
127
127
|
end
|
128
128
|
|
129
|
+
# Like `ActiveRecord#find_by`, will try and return an instance of this
|
130
|
+
# model that matches any of our enumble attributes (instance, id, string,
|
131
|
+
# or symbol).
|
132
|
+
#
|
133
|
+
# Color.find_by_enumble(1)
|
134
|
+
# Color.find_by_enumble(:black)
|
135
|
+
# Color.find_by_enumble("black")
|
136
|
+
# Color.find_by_enumble("BLACK")
|
137
|
+
# Color.find_by_enumble(Color.black) # => self
|
138
|
+
# Color.find_by_enumble("whoops") # => nil
|
139
|
+
#
|
140
|
+
# @param arg [Class, String, Integer, Symbol] search argument
|
141
|
+
# @param case_sensitive [Boolean] string search to be case sensitive (default: false)
|
142
|
+
# @param raise_error [Boolean] whether to raise RecordNotFound error (default: false)
|
143
|
+
# @return [self]
|
144
|
+
def find_by_enumble(arg, case_sensitive: false, raise_error: false)
|
145
|
+
return arg if arg.instance_of?(@enumbled_model)
|
146
|
+
|
147
|
+
id = id_from_enumbler(arg, case_sensitive: case_sensitive, raise_error: raise_error)
|
148
|
+
|
149
|
+
find_by = raise_error ? :find_by! : :find_by
|
150
|
+
@enumbled_model.public_send(find_by, id: id)
|
151
|
+
rescue Enumbler::Error
|
152
|
+
raise ActiveRecord::RecordNotFound.new("Couldn't find #{@enumbled_model}", @enumbled_model)
|
153
|
+
end
|
154
|
+
|
155
|
+
# Like `ActiveRecord#find`, will try and return an instance of this model
|
156
|
+
# that matches any of our enumble attributes (instance, id, string, or
|
157
|
+
# symbol) raises a `RecordNotFound` error if none found.
|
158
|
+
#
|
159
|
+
# Color.find_by_enumble!(1)
|
160
|
+
# Color.find_by_enumble!(:black)
|
161
|
+
# Color.find_by_enumble!("black")
|
162
|
+
# Color.find_by_enumble!("BLACK")
|
163
|
+
# Color.find_by_enumble!(Color.black) # => returns self
|
164
|
+
# Color.find_by_enumble!("whoops") # => raise ActiveRecord::RecordNotFound
|
165
|
+
#
|
166
|
+
# @param arg [Class, String, Integer, Symbol] search argument
|
167
|
+
# @param case_sensitive [Boolean] string search to be case sensitive (default: false)
|
168
|
+
# @param raise_error [Boolean] whether to raise RecordNotFound error (default: false)
|
169
|
+
# @return [self]
|
170
|
+
def find_by_enumble!(arg, case_sensitive: false)
|
171
|
+
find_by_enumble(arg, case_sensitive: case_sensitive, raise_error: true)
|
172
|
+
end
|
173
|
+
|
129
174
|
# See {.find_enumbles}. Simply returns the first object. Use when you
|
130
175
|
# want one argument to be found and not returned in an array.
|
131
176
|
# @raise [Error] when there is no [Enumbler::Enumble] to be found and
|
@@ -182,6 +227,8 @@ module Enumbler
|
|
182
227
|
enumble =
|
183
228
|
if arg.is_a?(Symbol)
|
184
229
|
@enumbled_model.enumbles.find { |e| e.enum == arg }
|
230
|
+
elsif arg.is_a?(Enumbler::Enumble)
|
231
|
+
@enumbled_model.enumbles.find { |e| e.enum == arg.enum }
|
185
232
|
elsif arg.is_a?(String)
|
186
233
|
@enumbled_model.enumbles.find do |e|
|
187
234
|
if case_sensitive
|
@@ -285,7 +332,7 @@ module Enumbler
|
|
285
332
|
# longer defined (default: false)
|
286
333
|
# @param validate [Boolean] validate on save?
|
287
334
|
def seed_the_enumbler(delete_missing_records: false, validate: true)
|
288
|
-
max_database_id = all.order(
|
335
|
+
max_database_id = all.order("id desc").take&.id || 0
|
289
336
|
max_enumble_id = @enumbles.map(&:id).max
|
290
337
|
|
291
338
|
# If we are not deleting records, we just need to update each listed
|
@@ -330,11 +377,21 @@ module Enumbler
|
|
330
377
|
method_name = "#{enumble.enum}?"
|
331
378
|
not_method_name = "not_#{enumble.enum}?"
|
332
379
|
alias_method_name = "is_#{enumble.enum}"
|
380
|
+
any_method_name = "any_#{enumble.enum}?"
|
381
|
+
|
382
|
+
[method_name, not_method_name, alias_method_name].each do |mname|
|
383
|
+
detect_enumbler_conflict(enumble.enum, mname)
|
384
|
+
end
|
385
|
+
|
386
|
+
[enumble.enum, any_method_name].each do |mname|
|
387
|
+
detect_enumbler_conflict(enumble.enum, mname, klass_method: true)
|
388
|
+
end
|
333
389
|
|
334
390
|
const_set(enumble.enum.to_s.upcase, enumble.id)
|
335
391
|
define_method(method_name) { id == enumble.id }
|
336
392
|
define_method(not_method_name) { id != enumble.id }
|
337
393
|
alias_method alias_method_name, method_name
|
394
|
+
|
338
395
|
define_singleton_method(enumble.enum) do |attr = nil|
|
339
396
|
return find(enumble.id) if attr.nil?
|
340
397
|
|
@@ -343,13 +400,42 @@ module Enumbler
|
|
343
400
|
raise Enumbler::Error, "The attribute #{attr} is not supported on this Enumble."
|
344
401
|
end
|
345
402
|
|
346
|
-
define_singleton_method(
|
347
|
-
|
403
|
+
define_singleton_method(any_method_name) do
|
404
|
+
exists?(id: enumble.id)
|
348
405
|
rescue NoMethodError
|
349
406
|
raise Enumbler::Error, "The attribute #{attr} is not supported on this Enumble."
|
350
407
|
end
|
351
408
|
end
|
352
409
|
|
410
|
+
# This idea sourced lovingly from ActiveRecord::Enum
|
411
|
+
ENUMBLER_CONFLICT_MESSAGE = <<~TEXT.squish
|
412
|
+
You tried to define the enumble :%<enum>s on the model %<klass>s, but
|
413
|
+
this will generate a %<type>s method `%<method>s`, which is already defined
|
414
|
+
by %<source>s.
|
415
|
+
TEXT
|
416
|
+
|
417
|
+
def detect_enumbler_conflict(enumble_name, method_name, klass_method: false)
|
418
|
+
if klass_method && dangerous_class_method?(method_name)
|
419
|
+
raise_conflict_error(enumble_name, method_name, type: "class")
|
420
|
+
elsif klass_method && method_defined_within?(method_name, ActiveRecord::Relation)
|
421
|
+
raise_conflict_error(enumble_name, method_name, type: "class", source: ActiveRecord::Relation.name)
|
422
|
+
elsif !klass_method && dangerous_attribute_method?(method_name)
|
423
|
+
raise_conflict_error(enumble_name, method_name)
|
424
|
+
end
|
425
|
+
end
|
426
|
+
|
427
|
+
def raise_conflict_error(enumble_name, method_name, type: "instance", source: "ActiveRecord")
|
428
|
+
raise Error,
|
429
|
+
format(
|
430
|
+
ENUMBLER_CONFLICT_MESSAGE,
|
431
|
+
enum: enumble_name,
|
432
|
+
klass: name,
|
433
|
+
type: type,
|
434
|
+
method: method_name,
|
435
|
+
source: source,
|
436
|
+
)
|
437
|
+
end
|
438
|
+
|
353
439
|
# I accidentally forgot to provide an id one time and it was confusing as
|
354
440
|
# the last argument became the hash of options. This should help.
|
355
441
|
def validate_id_is_numeric(enum, id)
|
@@ -366,11 +452,17 @@ module Enumbler
|
|
366
452
|
|
367
453
|
return if unsupported_attrs.blank?
|
368
454
|
|
455
|
+
ActiveRecord::Migration.check_pending!
|
456
|
+
|
369
457
|
raise Enumbler::Error,
|
370
458
|
"The model #{self} does not support the attribute(s): #{unsupported_attrs.keys.map(&:to_s).to_sentence}"
|
459
|
+
rescue ActiveRecord::PendingMigrationError
|
460
|
+
warn "[Enumbler Warning] => The model #{self} does not currently support the attribute(s): #{unsupported_attrs.keys.map(&:to_s).to_sentence}." \
|
461
|
+
" You have a pending migration which hopefully would remedy this! If not, you need to add a migration for this attibrute or" \
|
462
|
+
" remove it from the Enumbler."
|
371
463
|
rescue ActiveRecord::StatementInvalid
|
372
464
|
warn "[Enumbler Warning] => Unable to find a table for #{self}."\
|
373
|
-
|
465
|
+
"This is to be expected if there is a pending migration; however, if there is not then something is amiss."
|
374
466
|
end
|
375
467
|
end
|
376
468
|
end
|
data/lib/enumbler/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: enumbler
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.9.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Damon Timm
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-04-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|
@@ -19,7 +19,7 @@ dependencies:
|
|
19
19
|
version: 5.2.3
|
20
20
|
- - "<"
|
21
21
|
- !ruby/object:Gem::Version
|
22
|
-
version: '
|
22
|
+
version: '7'
|
23
23
|
type: :runtime
|
24
24
|
prerelease: false
|
25
25
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -29,7 +29,7 @@ dependencies:
|
|
29
29
|
version: 5.2.3
|
30
30
|
- - "<"
|
31
31
|
- !ruby/object:Gem::Version
|
32
|
-
version: '
|
32
|
+
version: '7'
|
33
33
|
- !ruby/object:Gem::Dependency
|
34
34
|
name: activesupport
|
35
35
|
requirement: !ruby/object:Gem::Requirement
|
@@ -39,7 +39,7 @@ dependencies:
|
|
39
39
|
version: 5.2.3
|
40
40
|
- - "<"
|
41
41
|
- !ruby/object:Gem::Version
|
42
|
-
version: '
|
42
|
+
version: '7'
|
43
43
|
type: :runtime
|
44
44
|
prerelease: false
|
45
45
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -49,7 +49,7 @@ dependencies:
|
|
49
49
|
version: 5.2.3
|
50
50
|
- - "<"
|
51
51
|
- !ruby/object:Gem::Version
|
52
|
-
version: '
|
52
|
+
version: '7'
|
53
53
|
- !ruby/object:Gem::Dependency
|
54
54
|
name: database_cleaner-active_record
|
55
55
|
requirement: !ruby/object:Gem::Requirement
|
@@ -169,6 +169,7 @@ files:
|
|
169
169
|
- bin/pre_commit_rubocop.rb
|
170
170
|
- bin/setup
|
171
171
|
- enumbler.gemspec
|
172
|
+
- lefthook.yml
|
172
173
|
- lib/enumbler.rb
|
173
174
|
- lib/enumbler/collection.rb
|
174
175
|
- lib/enumbler/core_ext/symbol/case_equality_operator.rb
|
@@ -198,7 +199,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
198
199
|
- !ruby/object:Gem::Version
|
199
200
|
version: '0'
|
200
201
|
requirements: []
|
201
|
-
rubygems_version: 3.1.
|
202
|
+
rubygems_version: 3.1.6
|
202
203
|
signing_key:
|
203
204
|
specification_version: 4
|
204
205
|
summary: Enums are terrific, but lack integrity. Let's add some!
|