dry-stack 0.1.56 → 0.1.57

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: f703dca5d6c72d78f7634b294ba41b739f19b5ee87c0177301ce0d8fc98e7148
4
- data.tar.gz: 7f70554b5b5b421926ce36dc75e1fec8086d98a2df2f51c9b8763441ad869057
3
+ metadata.gz: 31df24a38beb3fafd6a02537928ab12544183eeb4edeffb8fcdac2033010af3d
4
+ data.tar.gz: 0b3137a155bca51c5464a442f76600517c87e47dcb4234dd7495eac16a2d2cfd
5
5
  SHA512:
6
- metadata.gz: f8f8588139024f0a15c9ac97b103a545a5d0d997d7e6af7b4db07f9574bc242c25c9a2f4a3ff8caf0c6a4b01a4d7e70910a7eb59f6a561edc735ed9297850fd6
7
- data.tar.gz: 37e9151d6f369f35eda3286c418758292c515526106c3c3e04b27c5e391ebc5908482675a0b9a80fe20db7bd6968f5e4e5566bf2b27b1304357f218924def989
6
+ metadata.gz: c27e4576b6f0a01d9fa79124e80447f9b908bef0eca50c595cd466fd2311b52c438b6efe5ab0e82f2f14e153a256cafa08a7178490368bb78970254e989a7a5e
7
+ data.tar.gz: 12aff94e708e1364c0b758c240fbeed909c6582565f9a3939bfcd1c871ab892d03bd253307432eb681a0abad2e79cfd33d58fb77f25ee0995843585b470a8c85
@@ -415,18 +415,31 @@ module Dry
415
415
  (@after_blocks ||=[]) << block
416
416
  end
417
417
 
418
+ def normalize_service_hook_args(name, opts)
419
+ if name.is_a?(Hash) && opts.empty?
420
+ opts = name
421
+ name = nil
422
+ end
423
+
424
+ opts = opts.dup
425
+ except = [opts.delete(:except)].flatten.compact
426
+ [[name].flatten.compact, opts, except]
427
+ end
428
+
418
429
  def BeforeService(name = nil, opts = {}, &block)
419
- (@before_blocks ||=[]).push names: [name].flatten.compact, except: opts[:except],
430
+ names, opts, except = normalize_service_hook_args(name, opts)
431
+ (@before_blocks ||=[]).push names:, except:,
420
432
  block: ->(s_name) {
421
433
  _ServiceImplementation s_name, opts, &block
422
434
  }
423
435
  end
424
436
 
425
437
  def AfterService(name = nil, opts = {}, &block)
438
+ names, opts, except = normalize_service_hook_args(name, opts)
426
439
  After do
427
- names = [name || @services.keys].flatten
428
- names -= [opts[:except]].flatten if opts.key? :except
429
- names.each do |s_name|
440
+ hook_names = names.empty? ? @services.keys : names
441
+ hook_names -= except
442
+ hook_names.each do |s_name|
430
443
  _ServiceImplementation s_name, opts, &block
431
444
  end
432
445
  end
data/lib/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  module Dry
2
2
  class Stack
3
- VERSION = '0.1.56'
3
+ VERSION = '0.1.57'
4
4
  end
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: dry-stack
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.56
4
+ version: 0.1.57
5
5
  platform: ruby
6
6
  authors:
7
7
  - Artyom B
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2026-05-12 00:00:00.000000000 Z
11
+ date: 2026-05-14 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rake