Skip to content

Releases: dry-rb/dry-monads

v1.7.0

07 Jan 16:16
v1.7.0
Compare
Choose a tag to compare

Fixed

Changed

Compare v1.6.0...v1.7.0

v1.6.0

04 Nov 17:55
v1.6.0
8c42280
Compare
Choose a tag to compare

Changed

Compare v1.5.0...v1.6.0

v1.5.0

16 Oct 17:54
v1.5.0
Compare
Choose a tag to compare

Changed

Compare v1.4.0...v1.5.0

v1.4.0

20 Jul 08:19
v1.4.0
e2b762a
Compare
Choose a tag to compare

Added

  • Unit destructures to an empty array (flash-gordon)
  • When .value! called on a Failure value the error references to the value (rewritten + flash-gordon)
    begin
      Failure("oops").value!
    rescue => error
      error.receiver # => Failure("oops")
    end
  • Result#alt_map for mapping failure values (flash-gordon)
    Failure("oops").alt_map(&:upcase) # => Failure("OOPS")
  • Try#recover recovers from errors (flash-gordon)
    error = Try { Hash.new.fetch(:missing) }
    error.recover(KeyError) { 'default' } # => Try::Value("default")
  • Maybe#filter runs a predicate against the wrapped value. Returns None if the result is false (flash-gordon)
    Some(3).filter(&:odd?)  # => Some(3)
    Some(3).filter(&:even?) # => None
    # no block given
    Some(3 == 5).filter     # => None
  • RightBiased#| is an alias for #or (flash-gordon)
    None() | Some(6) | Some(7) # => Some(6)
    Failure() | Success("one") | Success("two") # => Success("one")

Fixed

  • Do notation preserves method visibility (anicholson + flash-gordon)

Changed

  • Coercing nil values to None with Some#fmap is officially deprecated. (flash-gordon)
    Switch to Some#maybe when you expect nil.
    This behavior will be dropped in 2.0 but you can opt-out of warnings for the time being
    Dry::Monads::Maybe.warn_on_implicit_nil_coercion false
  • Minimal Ruby version is 2.6

Compare v1.3.5...v1.4.0

v1.3.5

06 Jan 12:22
v1.3.5
895ece7
Compare
Choose a tag to compare

Added

  • Smarter keys deconstruction in pattern matching (flash-gordon)

Compare v1.3.4...v1.3.5

v1.3.4

28 Dec 12:57
v1.3.4
7586406
Compare
Choose a tag to compare

v1.3.4 2019-12-28

Fixed

  • One more delegation warning happenning in do notation (flash-gordon)

Compare v1.3.3...v1.3.4

v1.3.3

11 Dec 08:34
v1.3.3
f77581c
Compare
Choose a tag to compare

v1.3.3 2019-12-11

Fixed

  • Incompatibility with Rails. Internal (!) halt exceptions now use mutable backtraces because spring mutates (!) them. For the record, this a bug in Rails (johnmaxwell)

Compare v1.3.2...v1.3.3

v1.3.2

30 Nov 09:04
v1.3.2
21187f2
Compare
Choose a tag to compare

v1.3.2 2019-11-30

Fixed

  • Warnings about keywords from Ruby 2.7 (flash-gordon)

Added

  • Pattern matching syntax was improved by implementing #deconstruct_keys. Now curly braces aren't necessary when the wrapped value is a Hash (flash-gordon)
    case result
    in Success(code: 200...300) then :ok
    end

Internal

  • Performance of do notation was improved for failing cases (1.2x to 1.3x on synthetic benchmarks) (flash-gordon)

Compare v1.3.1...v1.3.2

v1.3.1

07 Sep 19:08
v1.3.1
fc11921
Compare
Choose a tag to compare

v1.3.1 2019-09-07

Fixed

  • Added missing None#maybe 😅 (flash-gordon)

Compare v1.3.0...v1.3.1

v1.3.0

03 Aug 17:22
v1.3.0
4cec03d
Compare
Choose a tag to compare

v1.3.0 2019-08-03

BREAKING CHANGES

  • Support for Ruby 2.3 was dropped.

Added

  • Result#either (waiting-for-dev)

    Success(1).either(-> x { x + 1 }, -> x { x + 2 }) # => 2
    Failure(1).either(-> x { x + 1 }, -> x { x + 2 }) # => 3
  • Maybe#to_result (SpyMachine + flash-gordon)

    Some(3).to_result(:no_value)   # => Success(3)
    None().to_result { :no_value } # => Failure(:no_value)
    None().to_result               # => Failure()
  • Do notation can be used with extend. This simplifies usage in class methods and in other "complicated" cases (gogiel + flash-gordon)

    class CreateUser
      extend Dry::Monads::Do::Mixin
      extend Dry::Monads[:result]
    
      def self.run(params)
        self.call do
          values = bind Validator.validate(params)
          user = bind UserRepository.create(values)
    
          Success(user)
        end
      end
    end

    Or you can bind values directly:

    ma = Dry::Monads.Success(1)
    mb = Dry::Monads.Success(2)
    
    Dry::Monads::Do.() do
      a = Dry::Monads::Do.bind(ma)
      b = Dry::Monads::Do.bind(mb)
      
      Dry::Monads.Success(a + b)
    end
  • {Some,Success,Failure}#[] shortcuts for building arrays wrapped within monadic value (flash-gordon)

    Success[1, 2] # => Success([1, 2]) 
  • List.unfold yields a block returning Maybe<Any>. If the block returns Some(a) a is appended to the output list. Returning None halts the unfloding (flash-gordon)

    List.unfold(0) do |x|
      if x > 5
        None()
      else
        Some[x + 1, 2**x]
      end
    end # => List[1, 2, 3, 4, 5]
  • Experimental support for pattern matching! 🎉 (flash-gordon)

    case value
    in Failure(_) then :failure
    in Success(10) then :ten
    in Success(100..500 => code) then code
    in Success() then :empty
    in Success(:code, x) then x
    in Success[:status, x] then x
    in Success({ status: x }) then x
    in Success({ code: 200..300 => x }) then x
    end

    Read more about pattern matching in Ruby:

    Keep in mind this feature is experimental and can be changed by 2.7 release. But it rocks already!

Compare v1.2.0...v1.3.0