Claude-skill-registry code-quality-check
This skill should be used before committing code to ensure it meets Breenix quality standards. Use for running clippy checks, fixing compiler warnings, verifying no log side-effects, checking for dead code, and enforcing project coding standards from CLAUDE.md.
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/code-quality-check" ~/.claude/skills/majiayu000-claude-skill-registry-code-quality-check && rm -rf "$T"
manifest:
skills/data/code-quality-check/SKILL.mdsource content
Code Quality Checks for Breenix
Pre-commit code quality verification for Breenix kernel development.
Purpose
Breenix enforces strict code quality standards. This skill provides the checks and fixes required before committing code.
Core Quality Standards (from CLAUDE.md)
- Fix ALL compiler warnings before committing
- Fix ALL clippy warnings
- Use proper patterns (e.g.,
) to avoid unsafe warningsOnce - Only
for legitimate API functions#[allow(dead_code)]
Pre-Commit Checklist
Before every commit:
# 1. Build kernel and check for warnings cd kernel cargo build --target x86_64-unknown-none 2>&1 | grep warning # 2. Run clippy cargo clippy --target x86_64-unknown-none # 3. Run tests (if modifying core subsystems) cd .. cargo test # 4. Check for log side-effects (manual) grep -R "log::trace!.*(" kernel/src/ | grep -vE '\".*\"' | grep -vE '\.(as_|to_|into_|len|is_|get)'
Clippy Configuration
Project-Specific Clippy Flags
cd kernel RUSTFLAGS="-Aclippy::redundant_closure_for_method_calls" \ cargo clippy --target x86_64-unknown-none \ -- -Dclippy::debug_assert_with_mut_call \ -Dclippy::print_stdout \ -Wclippy::suspicious_operation_groupings
What These Check
: Prevent side-effects in debug assertionsdebug_assert_with_mut_call
: No print!/println! in kernel (use log! macros)print_stdout
: Catch likely logic errorssuspicious_operation_groupings
Common Issues and Fixes
Compiler Warnings
Unused imports:
// BAD use x86_64::{VirtAddr, PageTable, PageTableFlags}; // PageTable unused // GOOD use x86_64::{VirtAddr, PageTableFlags};
Unused variables:
// BAD let result = some_function(); // result unused // GOOD let _result = some_function(); // Explicitly unused // OR some_function(); // Don't capture if not needed
Dead code:
// BAD - function never called fn helper_function() { ... } // GOOD - remove it // OR add #[allow(dead_code)] if it's part of a public API // GOOD - legitimate API function #[allow(dead_code)] // Part of public allocator API pub fn dealloc_stack(&mut self, stack_id: usize) { ... }
Clippy Warnings
Redundant closure:
// BAD items.map(|x| x.to_string()) // GOOD (but we allow this via RUSTFLAGS) items.map(ToString::to_string)
Debug assert with mutation:
// BAD - side effect in assertion debug_assert!(list.pop().is_some()); // GOOD - separate the effect let item = list.pop(); debug_assert!(item.is_some());
Log Side-Effects
Problem: Function calls in log statements execute even when logging disabled.
// BAD - get_state() called even if TRACE disabled log::trace!("State: {:?}", get_state()); // GOOD - only format if needed let state = get_state(); log::trace!("State: {:?}", state); // BETTER - for expensive operations if log::log_enabled!(log::Level::Trace) { let state = expensive_get_state(); log::trace!("State: {:?}", state); }
CI Code Quality Workflow
The
.github/workflows/code-quality.yml runs these checks automatically:
- Clippy checks with project-specific flags
- Log side-effects scan for trace statements with function calls
- Complex log expression check for multi-argument format strings
- Log level regression guard - ensures feature flags control log level
Quick Reference
Before Commit
# Full quality check cd kernel cargo build --target x86_64-unknown-none 2>&1 | tee /tmp/build-warnings.txt cargo clippy --target x86_64-unknown-none 2>&1 | tee /tmp/clippy-warnings.txt # Review warnings grep warning /tmp/build-warnings.txt less /tmp/clippy-warnings.txt # Fix all warnings before committing!
Common Warning Fixes
| Warning | Fix |
|---|---|
| unused import | Remove from use statement |
| unused variable | Prefix with _ or remove |
| dead code | Remove or add #[allow(dead_code)] for API |
| redundant closure | Allow via RUSTFLAGS or fix |
| print_stdout | Replace print! with log::info! |
| debug_assert mutation | Extract to separate statement |
Integration with Git Workflow
# Before committing git status # See what you're about to commit cd kernel cargo clippy --target x86_64-unknown-none # Fix all warnings # Then commit git add kernel/src/... git commit -m "Fix: ..."
Best Practices
- Fix warnings as you go: Don't accumulate them
- Run clippy frequently: Catch issues early
- Use proper logging: log! macros, not print!
- Avoid side-effects in logs: Especially in trace/debug
- Comment allowed dead code: Explain why it's part of the API
- Use feature flags: Control debug vs release behavior
- Test before committing: cargo test if touching core code
Summary
Code quality standards enforce:
- Zero compiler warnings
- Zero clippy warnings
- No side-effects in log statements
- Appropriate use of #[allow] attributes
- Proper logging practices
Run checks before every commit to maintain high code quality.