Follow Rust coding guidelines. When adding new feature or adding an API try to adhere to Rust API Guidelines. Avoid using unsafe code.
Always use rustfmt before you commit as your code won't pass CI pipeline if rustfmt is not applied. We adhere to default settings.
$ cargo fmt
Clippy is used to catch common mistakes and we run it as part of our CI pipeline.
$ cargo clippy
Ideally, all code should be unit tested. Unit tests should be in module file or if the file or tests are very long in separate file tests.rs
in the same directory as mod.rs
.
Error handling suggestions follow the Rust book guidance. Recoverable errors should be handled with Result. Our suggestions on unrecoverable errors are listed below:
- Panic (the code should not panic)
unwrap()
- Unwrap should only be used for mutexes (e.g.lock().unwrap()
) and test code. For all other use cases, preferexpect()
. The only exception is if the error message is custom-generated, in which case use.unwrap_or_else(|| panic!("error: {}", foo))
expect()
- Expect should be invoked when a system invariant is expected to be preserved.expect()
is preferred overunwrap()
and should contain a detailed error message on failure in most cases.assert!()
- This macro is kept in both debug/release and should be used to protect invariants of the system as necessary.