Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/withoutboats/fehler
Rust doesn't have exceptions
https://github.com/withoutboats/fehler
Last synced: 3 days ago
JSON representation
Rust doesn't have exceptions
- Host: GitHub
- URL: https://github.com/withoutboats/fehler
- Owner: withoutboats
- License: other
- Created: 2019-07-16T12:54:45.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-08-17T10:04:10.000Z (over 4 years ago)
- Last Synced: 2025-01-11T06:04:04.077Z (10 days ago)
- Language: Rust
- Size: 56.6 KB
- Stars: 631
- Watchers: 21
- Forks: 24
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README
# Der Fehler
[![Documentation](https://docs.rs/fehler/badge.svg)](https://docs.rs/fehler/*/fehler/)
Der Fehler is a library to add support for "throwing functions" to Rust through
procedural macros. Functions marked with the `throws` attribute return
`Result`, but the "Ok" path is used by default and you don't need to wrap ok
return values in `Ok`. To throw errors, use `?` or the `throws` macro.Der Fehler provides these items:
### The `#[throws]` attribute
The throws attribute modifies a function or method to make it return a
`Result`. It takes an optional typename as an argument to the attribute which
will be the error type of this function; if no typename is supplied, it uses
the default error type for this crate.Within the function body, `return`s (including the implicit final return) are
automatically "Ok-wrapped." To raise errors, use `?` or the `throws!` macro.For example, these two functions are equivalent:
```rust
#[throws(i32)]
fn foo(x: bool) -> i32 {
if x {
0
} else {
throw!(1);
}
}fn bar(x: bool) -> Result {
if x {
Ok(0)
} else {
Err(1)
}
}
```## In functions that return `Option`
The attribute can be used to make a function that returns an Option using the
`as Option` syntax, demonstrated below:```rust
// This function returns `Option`
#[throws(as Option)]
fn foo(x: bool) -> i32 {
if x {
return 0;
} else {
throw!();
}
}
```### The `throw!` macro
`throw!` is a macro which is equivalent to the `Err($e)?` pattern. It takes an
error type and "throws" it.One important aspect of the `throw!` macro is that it allows you to return
errors inside of functions marked with `throws`. You cannot just `return`
errors from these functions, you need to use this macro.# TODO
* Make throws work on closures and async blocks (attributes are not allowed on
expressions on stable)
* Make throws work on Try types other than Result and Option (TRy is not on
stable).## License
Licensed under either of
* Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)at your option.
#### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.