everythingrb 0.1.1 → 0.1.2

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d123add89382cd34312ff1a63460d11ce0adc8d878944b961416f9b6df389560
4
- data.tar.gz: 89de33c7ded15da7c5fdcbe1b86bdf245809124ae72fc15927b4b8c956610c7e
3
+ metadata.gz: f89e80920d664c010fe41afbc614d77ed2d45e16cef5a88a67a4c953a492c2b5
4
+ data.tar.gz: 34940dce0a2fa7f374642bc046f619789bc698deea66ef94a4c55f6743c5a44e
5
5
  SHA512:
6
- metadata.gz: 477ab5cd210a43f60baf7a437efa35ecf51d0b48a88e462748fe4581bb280892cf48fb7370f61ab6927b86c3adcd846bc438c113f1d7ecbbb085a2fc02ac724d
7
- data.tar.gz: 8a92dcba15b53f3aa35ff503ee17bda989e5d6c19efb28526928e2c821f7856ecfb0404c353f7c5bc6535d1d33d27fc93fa52ea64d76a5571367480bce2507c3
6
+ metadata.gz: 95811ed4b2df3ba3cbec346139c606421b11935bfc37fa0ff3874edae00a40ed9b358551d11f86d6dba12979131f84050fe9fd96edeea11e24767f013964bec4
7
+ data.tar.gz: cc9655f063282b211ff79c3308d814f598d8131b4a86b1c15ec76a7f8563e590fc96f2e22e8a1e467a650769f765ecb8676705fb2b56d2781ac14b0c2448bed8
data/CHANGELOG.md CHANGED
@@ -13,6 +13,16 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
13
13
 
14
14
  ### Removed
15
15
 
16
+ ## [0.1.2] - 12025-02-11
17
+
18
+ ### Added
19
+
20
+ - Added `#presence` support to `Module.attr_predicate` if `ActiveSupport` is loaded.
21
+
22
+ ### Changed
23
+
24
+ - Separated out tests that require `ActiveSupport` into their own test process. Files that end with `_active_support` will be tested separately with ActiveSupport loaded
25
+
16
26
 
17
27
  ## [0.1.1] - 12025-02-07
18
28
 
@@ -43,6 +53,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
43
53
 
44
54
  - Added alias `each` to `each_pair` in OpenStruct for better enumerable compatibility
45
55
 
46
- [unreleased]: https://github.com/itsthedevman/everythingrb/compare/v0.1.1...HEAD
56
+ [unreleased]: https://github.com/itsthedevman/everythingrb/compare/v0.1.2...HEAD
57
+ [0.1.2]: https://github.com/itsthedevman/everythingrb/compare/v0.1.1...v0.1.2
47
58
  [0.1.1]: https://github.com/itsthedevman/everythingrb/compare/v0.1.0...v0.1.1
48
59
  [0.1.0]: https://github.com/itsthedevman/everythingrb/compare/5870052e137cb430d084eab1ec3934f3c50b4501...v0.1.0
data/Rakefile CHANGED
@@ -3,8 +3,17 @@
3
3
  require "bundler/gem_tasks"
4
4
  require "minitest/test_task"
5
5
 
6
- Minitest::TestTask.create
6
+ Minitest::TestTask.create(:test_regular) do |t|
7
+ # I couldn't get extra_args to work
8
+ t.test_globs = Dir.glob("test/**/test_*.rb").reject { |f| f.include?("active_support") }
9
+ end
10
+
11
+ Minitest::TestTask.create(:test_active_support) do |t|
12
+ t.test_globs = ["test/**/test_*_active_support.rb"]
13
+ t.test_prelude = "ENV[\"LOAD_ACTIVE_SUPPORT\"] = \"true\""
14
+ end
7
15
 
8
16
  require "standard/rake"
9
17
 
18
+ task test: [:test_regular, :test_active_support]
10
19
  task default: %i[test standard]
@@ -6,6 +6,8 @@ class Module
6
6
  # Similar to attr_reader, attr_writer, etc. Designed to work with
7
7
  # regular classes, Struct, and Data objects.
8
8
  #
9
+ # Note: If ActiveSupport is loaded, this will check if the value is present? instead of truthy
10
+ #
9
11
  # @param *attributes [Array<Symbol, String>] Attribute names
10
12
  #
11
13
  # @return [nil]
@@ -36,17 +38,20 @@ class Module
36
38
  raise ArgumentError, "Cannot create predicate method on #{self.class} - #{attribute}? is already defined. Please choose a different name or remove the existing method."
37
39
  end
38
40
 
39
- module_eval <<-STR, __FILE__, __LINE__ + 1
41
+ module_eval <<-RUBY, __FILE__, __LINE__ + 1
40
42
  def #{attribute}?
41
- if instance_variable_defined?(:@#{attribute})
42
- !!@#{attribute}
43
- elsif respond_to?(:#{attribute})
44
- !!self.#{attribute}
45
- else
46
- false
47
- end
43
+ value =
44
+ if instance_variable_defined?(:@#{attribute})
45
+ @#{attribute}
46
+ elsif respond_to?(:#{attribute})
47
+ self.#{attribute}
48
+ end
49
+
50
+ return false if value.nil?
51
+
52
+ defined?(ActiveSupport) ? !!value.presence : !!value
48
53
  end
49
- STR
54
+ RUBY
50
55
  end
51
56
 
52
57
  nil
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Everythingrb
4
- VERSION = "0.1.1"
4
+ VERSION = "0.1.2"
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: everythingrb
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.1
4
+ version: 0.1.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Bryan
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-02-08 00:00:00.000000000 Z
11
+ date: 2025-02-11 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: ostruct