Coder Social home page Coder Social logo

Comments (5)

eernstg avatar eernstg commented on August 19, 2024

Thanks for spotting this! It is a bug when you get the 'Unexpected situation' exception (a fix will be included in the next commit), but it will not help you much: admitSubtypeCapability has not yet been implemented, and you would just get an UnimplementedError exception instead.

There is a rather detailed discussion about this capability in the design document https://github.com/dart-lang/reflectable/blob/master/reflectable/doc/TheDesignOfReflectableCapabilities.md which illustrates why the whole concept is questionable (and hence it might be dropped). However, if it would be very helpful for you then please make the case for it, and then we can keep your arguments in mind because they are on the issue list.

PS: That would then be a new issue, because this one gets closed when the bug fix is available.

from reflectable.dart.

sigurdm avatar sigurdm commented on August 19, 2024

I think @lassedamgaard mentions superclassQuantifyCapability, not admitSubtypeCapability.
@lassedamgaard: Are you sure this is the only capability spec in your program? - the error message suggest you are using admitSubtypeCapability, and that is still unimplemented.

from reflectable.dart.

lassedamgaard avatar lassedamgaard commented on August 19, 2024

Sorry guys, wrong copy-pasta, the capability spec was supposed to say admitSubtypeCapability. I've corrected it.
Anyway, I don't have a need for this capability at the moment, just spotted this trying some things out and thought it should have a better error message. In general if there are going to be capabilities that aren't supported by the transformer I think they should be checked early and generate a descriptive error message instead of throwing.

from reflectable.dart.

eernstg avatar eernstg commented on August 19, 2024

The error message for admitSubtypeCapability was plain wrong (a certain test for whether we encountered such a capability was wrong, so we missed that case and continued to the final catch-all case that we should never reach -- hence the "Unexpected situation"). It is fixed in the next upcoming commit.

With respect to the diagnostic message: There is already issue #39 requesting a similar thing, namely that errors should be reported but then caught, such that the transformer can continue transforming the remaining entry points rather than stopping entirely.

from reflectable.dart.

eernstg avatar eernstg commented on August 19, 2024

Addressed by commit 5a835be on https://github.com/dart-lang/reflectable/commits/master.

from reflectable.dart.

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.