Giter Site home page Giter Site logo

Comments (8)

clue avatar clue commented on June 22, 2024 1

See PR #253 which adds stricter types for all callable arguments.

Spent the better half of the day working on all edge cases and making sure this is fully covered in our tests. I hope this helps! 👍 If so, consider supporting this project, for example by becoming a sponsor ❤️

from promise.

WyriHaximus avatar WyriHaximus commented on June 22, 2024 1

Thanks for filing this @stof just approved and merged #253. Looking forward to your follow up 👍

from promise.

clue avatar clue commented on June 22, 2024

@stof Thanks for reporting and linking the downstream ticket 👍

I think we all agree that adding more specific types for callables would be useful. I'm happy to look into this once time allows, otherwise we're happy to accept PRs. :shipit:

For the record, this appears to be clearly documented behavior with its BC implications mentioned in the changelog, so this would be more of feature addition or maintenance rather than a bug, see also related tickets #213, #246 and #247.

from promise.

stof avatar stof commented on June 22, 2024

@clue sure, the upgrade guide does not actually mention anything for the signature of the $resolve callback for the API of the promise constructor (even though I totally understand that this change is related to #213, it isn't mentioned anywhere).
And the changelog entry for that change mention Improve type safety of promises, but this particular change does not provide any type safety given that it is not reported in types...

from promise.

clue avatar clue commented on June 22, 2024

It is no longer possible to resolve a promise without a value (use `null` instead) or reject a promise without a reason (use `Throwable` instead).

from promise.

stof avatar stof commented on June 22, 2024

@clue what I mean is that none of the code examples mention that API as an impacted one (and it is the only API for which static analysis won't help, so I would say it would probably have been the most important one to show explicitly)

from promise.

stof avatar stof commented on June 22, 2024

@clue I started to look at that and I'm struggling with the type of the $canceller callback of the promise constructor. It looks like the canceller can actually be called with $resolve and $reject (same than the $resolver callback), but what would be the expected argument for $resolve then ? Does it even make sense to call it ?

from promise.

stof avatar stof commented on June 22, 2024

@clue do you have any insight on the expected behavior for the canceller callback ?

from promise.

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.