everythingrb 0.1.1 → 0.2.0
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/CHANGELOG.md +28 -1
- data/Rakefile +10 -1
- data/flake.nix +2 -2
- data/lib/everythingrb/core/module.rb +14 -9
- data/lib/everythingrb/version.rb +1 -1
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ecda2000911c11e9c9d062c641b463191810717826f019df27d75c61d41dd0c7
|
4
|
+
data.tar.gz: 5eb00d7c4cf95854d2d32385a3fe5a9d347d69bf7dbf0eed0e706e57bbff45f1
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 9892d5e1391446ca9f1a792f4870575e84bfb5c45118b82c636c0c6d6fe7d6f59c22d089811c56ee7fc4056b7728bca2d331e8fd80eabd1ac0c65e388e35055a
|
7
|
+
data.tar.gz: 631f5da0c0b9dd3afeb4204988bfdf79210975b1e6826bce45a09563473cbe62a41efabe23192edf83678874004f93e9d0b1eecf3cb81cc461d534a0bb753579
|
data/CHANGELOG.md
CHANGED
@@ -14,6 +14,31 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
14
14
|
### Removed
|
15
15
|
|
16
16
|
|
17
|
+
## [0.2.0] - 12025-02-17
|
18
|
+
|
19
|
+
### Added
|
20
|
+
|
21
|
+
- Added Ruby version test matrix
|
22
|
+
|
23
|
+
### Changed
|
24
|
+
|
25
|
+
- Updated `flake.nix` to use 3.4
|
26
|
+
|
27
|
+
### Removed
|
28
|
+
|
29
|
+
- Removed Ruby 3.1 support
|
30
|
+
|
31
|
+
## [0.1.2] - 12025-02-11
|
32
|
+
|
33
|
+
### Added
|
34
|
+
|
35
|
+
- Added `#presence` support to `Module.attr_predicate` if `ActiveSupport` is loaded.
|
36
|
+
|
37
|
+
### Changed
|
38
|
+
|
39
|
+
- Separated out tests that require `ActiveSupport` into their own test process. Files that end with `_active_support` will be tested separately with ActiveSupport loaded
|
40
|
+
|
41
|
+
|
17
42
|
## [0.1.1] - 12025-02-07
|
18
43
|
|
19
44
|
### Added
|
@@ -43,6 +68,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
43
68
|
|
44
69
|
- Added alias `each` to `each_pair` in OpenStruct for better enumerable compatibility
|
45
70
|
|
46
|
-
[unreleased]: https://github.com/itsthedevman/everythingrb/compare/v0.
|
71
|
+
[unreleased]: https://github.com/itsthedevman/everythingrb/compare/v0.2.0...HEAD
|
72
|
+
[0.2.0]: https://github.com/itsthedevman/everythingrb/compare/v0.1.2...v0.2.0
|
73
|
+
[0.1.2]: https://github.com/itsthedevman/everythingrb/compare/v0.1.1...v0.1.2
|
47
74
|
[0.1.1]: https://github.com/itsthedevman/everythingrb/compare/v0.1.0...v0.1.1
|
48
75
|
[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]
|
data/flake.nix
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
{
|
2
|
-
description = "Ruby 3.
|
2
|
+
description = "Ruby 3.4 development environment";
|
3
3
|
|
4
4
|
inputs = {
|
5
5
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
@@ -14,7 +14,7 @@
|
|
14
14
|
{
|
15
15
|
devShells.default = pkgs.mkShell {
|
16
16
|
buildInputs = with pkgs; [
|
17
|
-
(
|
17
|
+
(ruby_3_4.override {
|
18
18
|
jemallocSupport = true;
|
19
19
|
docSupport = false;
|
20
20
|
})
|
@@ -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 <<-
|
41
|
+
module_eval <<-RUBY, __FILE__, __LINE__ + 1
|
40
42
|
def #{attribute}?
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
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
|
-
|
54
|
+
RUBY
|
50
55
|
end
|
51
56
|
|
52
57
|
nil
|
data/lib/everythingrb/version.rb
CHANGED
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.
|
4
|
+
version: 0.2.0
|
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-
|
11
|
+
date: 2025-02-17 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: ostruct
|
@@ -81,7 +81,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
81
81
|
requirements:
|
82
82
|
- - ">="
|
83
83
|
- !ruby/object:Gem::Version
|
84
|
-
version: 3.
|
84
|
+
version: '3.2'
|
85
85
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
86
86
|
requirements:
|
87
87
|
- - ">="
|