enumbler 0.7.0 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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!
|