-
-
Notifications
You must be signed in to change notification settings - Fork 2.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Document Emitter
trait method panics
#12444
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you, this LGTM, could you add a change file in .changes
directory?
This PR makes all methods on the
Emitter
trait default methods and saves boilerplate
This was done intentionally to customize the documentation example based on the used type, but I guess it is fine to remove.
Package Changes Through 5126966There are 3 changes which include tauri-bundler with patch, tauri-cli with patch, @tauri-apps/cli with patch Planned Package VersionsThe following package releases are the planned based on the context of changes in this pull request.
Add another change file through the GitHub UI by following this link. Read about change files or the docs at github.com/jbolda/covector |
Should we even panic here? It may be good for development for most cases but what if devs use dynamic event names that are derived from some http request for example? idk panicking in a gui library just always sounds awaful to me |
yeah maybe returning an Error here is better, the methods already return Result type |
I've added some changes that inch closer in that direction, replacing the assert with a checked While |
b24dba8
to
62a2262
Compare
This is tangentially related, but I really think the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you
Almost all methods of the
Listener
andEmitter
traits take an event name and will panic if that name does not satisfy some preconditions. This is not documented and this PR fixes this. This PR also moves the panic locations closer to the user-facing code, making it immediately clear what has gone wrong and what methods were responsible for the panic. Prior to this change, the panic pointed to a location of little use to a user oftauri
unless he reverse engineers how that code was called withintauri
.As a drive-by improvement, it was a bit unclear that the
Emitter
trait is purely defined based on methods on theAppManager
. This PR makes all methods on theEmitter
trait default methods and saves boilerplate. This change should not have any downsides becauseEmitter
is a sealed trait that can only be implemented insidetauri
.