- 
                Notifications
    You must be signed in to change notification settings 
- Fork 0
Note style guide
These are coding guidelines for Rust code.
- Type names, variants - camel case
- function - lowercase with underscores where it helps readability
- Static variables are capitalized
on type implementations, make default private, add pub explicitly where wanted
Trait naming?
- trait examples: Copy, Owned, Const, Add, Sub, Num, Shr, Index, Encode, Decode, Reader, Writer, GenericPath
- extension methods: XUtil? Prefer default methods
- avoid things with prefixes (able, etc). try to use transitive verbs, nouns, and then adjectives in that order
Constructors are static methods called new or new_with_more_details.
use ffi instead of _hl or ll or raw as the module for holding the extern definitions
Wrapped functions:
fn frobnicate(a: bar,
              b: bar)
              -> bar {
    code;
}
note: need to adjust editors to do this automatically - this is not the current convention
The downside of this is, that the indendation level of many lines of code may change when the length of the function name changes.
avoid using cfg directives outside of platform namespace
extern mods, blank line local imports first, then external imports, then pub use.
avoid use of *, except in tests
ok to use use foo = bar;
avoid import of functions, instead mod::func()
- Lines should not be longer than 100 characters.
- Use spaces for indentation not tabs.
put tests in a test module at the bottom of the modules they test. Use #[cfg(test)] to only compile when testing.
#[cfg(test)]
mod test {
}
deref the match target if you can. prefer
match *foo {
    X(...) => ...
    Y(...) => ...
}
instead of
match foo {
    @X(...) => ...
    @Y(...) => ...
}
multiple patterns in a single arm:
match  foo {
    bar(*)
    | baz => quux,
    x
    | y
    | z => {
        quuux
    }
}
only omit braces for single expressions
match foo {
    bar => baz,
    quux => {
        do_something();
        do_something_else();
    }
}
Prefer line comments and avoid block comments. Reason: it avoids the debate about whether to put stars on every line, etc.
Favor outer doc comments
/// Function documentation
fn foo() {
    ...
}
Only use inner doc comments to document crates and file-level modules.
//! The core library.
//!
//! The core library is a something something...
Use full sentences that start with capitals and end with a period. See Doc-using-rustdoc.
Put types first, then implementations
Do we want to prefer 'top-down' organization?
TODO
TODO
Rust code in error messages should be enclosed in backquotes.
Examples:
- found `true` in restricted position
Error messages should use the pattern "expected `X`, found `Y`".
- mismatched types: expected `u16`, found `u8`
Trait names should be capitalized and should follow the pattern of Verb or Verber, except in cases where no verb seems sensible.
Examples:
- Iterate
The names of simple boolean predicates should start with "is_" or similarly be expressed using a "small question word".
The notable exception are generally established predicate names like "lt", "ge", etc.
Examples:
- is_not_empty
A for loop is always preferable to a while loop unless the loop counts in a non-uniform way (making it difficult to express as a for).
All Categories:
- Docs -- For users
- Notes -- For developers
- Libs -- For library authors
- Meeting minutes