Rust Development Guide¶
This guide covers comprehensive Rust development guidance including code organization, patterns, architectural decisions, and formatting standards. For general guidance applicable to all languages, see the main Practices.
Module Organization¶
Follow standard Rust module organization patterns:
src/lib.rs
orsrc/main.rs
as the crate rootUse
src/module.rs
files withsrc/module/
directories for submodulesOrganize related functionality into logical modules
Re-export important items at appropriate levels using
pub use
Apply project nomenclature guidelines from Nomenclature when naming modules, following Rust’s
snake_case
convention for module names.
Naming Conventions¶
Follow standard Rust naming conventions as defined in the Rust API Guidelines:
Types, traits, enums:
PascalCase
Functions, variables, modules:
snake_case
Constants, statics:
SCREAMING_SNAKE_CASE
Macros:
snake_case
(by convention, though not enforced)
Apply project nomenclature guidelines from Nomenclature when naming types, functions, and variables.
Documentation¶
Content Standards¶
Write documentation comments in narrative mood (third person) consistent with project documentation standards.
Use standard Rust documentation patterns:
///
for public API documentation//!
for module-level documentationInclude examples in documentation when helpful
Document error conditions using the standard
# Errors
section:/// Validates user configuration. /// /// # Errors /// /// Returns `CrateError::Validation` if the configuration is invalid. pub fn validate_config(config: &Config) -> Result<(), CrateError> { // implementation }
Visual Formatting¶
Use standard Rust documentation comments (
///
for items,//!
for modules).Write documentation in narrative mood (third person) consistent with project documentation conventions.
✅ Prefer:
/// Validates the configuration data. /// /// Returns the validated configuration or an error if validation fails. pub fn validate_configuration(config: &Config) -> Result<Config, ConfigError> { // implementation }
❌ Avoid:
/// Validate the configuration data. pub fn validate_configuration(config: &Config) -> Result<Config, ConfigError> { // implementation }
Formatting Standards¶
Follow the standard Rust formatting conventions enforced by
rustfmt
. The project’s.rustfmt.toml
configuration defines the specific formatting rules.Use
cargo fmt
to automatically format code according to project standards.Maximum line length follows the general project standard of 79 columns, which may be configured in
.rustfmt.toml
if different from Rust defaults.
Future Development¶
Todo
Expand Rust practices with comprehensive coverage including:
Error handling patterns and hierarchies
Type design (wide/narrow principle, newtype patterns)
Immutability and ownership best practices
Async/await patterns and best practices
Trait design and implementation guidelines
Macro definition patterns
FFI and unsafe code guidelines
Performance optimization patterns
Testing strategies and patterns
Concurrent programming patterns