droids-code-quality
[DROIDS-INTERNAL] Code quality standards and review guidelines. Only activate when invoked by droids plugin agents (code-reviewer) or /droids:* commands. Do NOT auto-activate in regular conversations.
What this skill does
# Code Quality Standards
Use these guidelines when reviewing code quality.
## Code Readability
### Naming Conventions
- Variables: descriptive, camelCase (`userEmail`, `isActive`)
- Functions: verb + noun, describe action (`getUserById`, `validateInput`)
- Classes: PascalCase, noun (`UserService`, `PaymentProcessor`)
- Constants: UPPER_SNAKE_CASE (`MAX_RETRY_COUNT`, `API_BASE_URL`)
### Function Guidelines
- Single responsibility (do one thing well)
- Maximum 20-30 lines per function
- Maximum 3-4 parameters
- Early returns for guard clauses
- Avoid deep nesting (max 3 levels)
### Code Smells to Avoid
- [ ] Long methods (> 50 lines)
- [ ] Large classes (> 300 lines)
- [ ] Deep nesting (> 3 levels)
- [ ] Duplicate code
- [ ] Magic numbers/strings
- [ ] Dead code
- [ ] Commented-out code
- [ ] God objects/classes
## Performance Considerations
### Database
- [ ] No N+1 query problems
- [ ] Proper indexing for queries
- [ ] Pagination for large datasets
- [ ] Connection pooling used
### Memory
- [ ] No memory leaks
- [ ] Large objects cleaned up
- [ ] Streams used for large data
- [ ] Caching implemented where appropriate
### Algorithm
- [ ] Appropriate time complexity
- [ ] Efficient data structures
- [ ] No unnecessary iterations
- [ ] Lazy evaluation where beneficial
## Error Handling
### Best Practices
```javascript
// Good: Specific error handling
try {
await saveUser(user);
} catch (error) {
if (error instanceof ValidationError) {
return res.status(400).json({ error: error.message });
}
if (error instanceof DatabaseError) {
logger.error('Database error:', error);
return res.status(500).json({ error: 'Internal error' });
}
throw error; // Re-throw unknown errors
}
```
### Error Handling Checklist
- [ ] All async operations have error handling
- [ ] Errors are logged with context
- [ ] User-facing errors are user-friendly
- [ ] System errors don't leak sensitive info
- [ ] Resources are cleaned up on error
## Code Organization
### File Structure
```
src/
├── components/ # UI components
├── services/ # Business logic
├── utils/ # Helper functions
├── types/ # Type definitions
├── constants/ # Constants and config
└── tests/ # Test files
```
### Module Guidelines
- One concept per file
- Related code grouped together
- Clear import/export boundaries
- Avoid circular dependencies
## SOLID Principles
| Principle | Description |
|-----------|-------------|
| **S**ingle Responsibility | One reason to change |
| **O**pen/Closed | Open for extension, closed for modification |
| **L**iskov Substitution | Subtypes must be substitutable |
| **I**nterface Segregation | Many specific interfaces |
| **D**ependency Inversion | Depend on abstractions |
## Review Severity Levels
| Level | Description | Action |
|-------|-------------|--------|
| BLOCKER | Prevents merge | Must fix |
| MAJOR | Significant issue | Should fix |
| MINOR | Improvement | Consider fixing |
| SUGGESTION | Nice to have | Optional |
## Quick Quality Checklist
- [ ] Code is readable without comments
- [ ] Functions are small and focused
- [ ] No code duplication
- [ ] Proper error handling
- [ ] No performance issues
- [ ] Follows project conventions
- [ ] No security vulnerabilities
- [ ] Tests are included
Related in Code Review
gstack
IncludedFast headless browser for QA testing and site dogfooding. Navigate pages, interact with elements, verify state, diff before/after, take annotated screenshots, test responsive layouts, forms, uploads, dialogs, and capture bug evidence. Use when asked to open or test a site, verify a deployment, dogfood a user flow, or file a bug with screenshots. (gstack)
startup-due-diligence
IncludedLegal due diligence review for seed-stage and Series A startups (US, Delaware C-Corp focus). Supports both investor and founder perspectives. Capabilities include: (1) Interactive document review and issue spotting; (2) Document request list generation; (3) Cap table and SAFE/convertible note analysis; (4) Red flag identification with severity ratings; (5) Diligence report generation. TRIGGERS: due diligence, DD, startup investment, cap table review, Series A, seed round, investor diligence, legal review startup, SAFE analysis, convertible note, 409A, founder vesting.
interview-master
IncludedThis skill should be used when the user asks to "generate interview questions", "prepare for interview", "optimize resume", "conduct mock interview", "analyze git commits for resume", "generate resume from code", "review my resume", or mentions interview preparation, career assistance, or extracting project experience from git history. Provides comprehensive interview and career development guidance for both job seekers and interviewers.
fix-issue
IncludedFixes GitHub issues using parallel analysis agents for root cause investigation, code exploration, and regression detection. Reads issue context from gh CLI, searches codebase and memory for related patterns, generates a fix with tests, and links the resolution back to the issue via PR. Includes prevention analysis to avoid recurrence. Use when debugging errors, resolving regressions, fixing bugs, or triaging issues.
sf-apex
IncludedGenerates and reviews Salesforce Apex code with 150-point scoring. TRIGGER when: user writes, reviews, or fixes Apex classes, triggers, test classes, batch/queueable/schedulable jobs, or touches .cls/.trigger files. DO NOT TRIGGER when: LWC JavaScript (use sf-lwc), Flow XML (use sf-flow), SOQL-only queries (use sf-soql), or non-Salesforce code.
swift-development
IncludedComprehensive Swift development for building, testing, and deploying iOS/macOS applications. Use when Claude needs to: (1) Build Swift packages or Xcode projects from command line, (2) Run tests with XCTest or Swift Testing framework, (3) Manage iOS simulators with simctl, (4) Handle code signing, provisioning profiles, and app distribution, (5) Format or lint Swift code with SwiftFormat/SwiftLint, (6) Work with Swift Package Manager (SPM), (7) Implement Swift 6 concurrency patterns (async/await, actors, Sendable), (8) Create SwiftUI views with MVVM architecture, (9) Set up Core Data or SwiftData persistence, or any other Swift/iOS/macOS development tasks.