Giter Club home page Giter Club logo

Comments (10)

flash-gordon avatar flash-gordon commented on July 18, 2024 3

It merged into master, at the moment I'm testing it in production (looks good!). Once I'm confident I'll cut a release. There are also a few other issues to fix.

from dry-types.

flash-gordon avatar flash-gordon commented on July 18, 2024 1

But then this Wrap type becomes a replacement of a Constructor type

Yeah, in a way. Still, constructor will work for most cases. Besides, I'm not sure if this hypothetical "wrap" type will work, mmm, predictably everywhere. dry-types does have some surptising corner cases here and there regarding both usage and implementation. It's not a bad thing, though.

I'll play around with the idea in the free time, soon (as always).

from dry-types.

solnic avatar solnic commented on July 18, 2024

@pyromaniac could you explain how the behavior of default actually changed so that it breaks for you now?

from dry-types.

pyromaniac avatar pyromaniac commented on July 18, 2024

It didn't fallback to the default when nil was passed explicitly. In general, we lack value normalization in dry-types I believe. Something that adjust values after coercion. Normalization, for example, can be used to turn empty string to nil as well. This fallback proposal is simply a nerfed normalization.

from dry-types.

flash-gordon avatar flash-gordon commented on July 18, 2024

I'm thinking about having Wrap types or something like that, it would be more general than constructors:

Types::Integer.wrap do |type, input, &fallback|
  type.(input, &fallback) + 1
end

Similar to how rack middleware works. I'm not quite sure it solves "all the problems" but it does add some flexibility. WDYT?

from dry-types.

pyromaniac avatar pyromaniac commented on July 18, 2024

This would be actually perfect. I'll be able to build my own fallback type basing on this. Not sure if I got the interface right though. Why do we need those arguments? Wouldn't simple

Types::Integer.wrap do |value|
  value + 1
end

work? The same way as constructor works now, just happens after coercion.

from dry-types.

flash-gordon avatar flash-gordon commented on July 18, 2024

The idea is you have full control over when the input gets coerced. I'm against adding post-constructors/normalization steps. We haven't had requests for this so far, this fact alone indicates we shouldn't rush into adding a specific solution. Wrapping types could be useful in a wider number of cases, kinda "by construction".

from dry-types.

pyromaniac avatar pyromaniac commented on July 18, 2024

But then this Wrap type becomes a replacement of a Constructor type, it can do everything and more. Great point though.

from dry-types.

flash-gordon avatar flash-gordon commented on July 18, 2024

Have a look at dry-rb/dry-schema#337, it looks like we're close to having nice support for this 🎉

from dry-types.

pyromaniac avatar pyromaniac commented on July 18, 2024

@flash-gordon it looks awesome, thank you so much for working on this. I believe, DRY lacks this feature in general after default's behavior was changed.

from dry-types.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.