Get the FREE Ultimate OpenClaw Setup Guide β†’

clean-code

Scanned
npx machina-cli add skill vudovn/antigravity-kit/clean-code --openclaw
Files (1)
SKILL.md
6.5 KB

Clean Code - Pragmatic AI Coding Standards

CRITICAL SKILL - Be concise, direct, and solution-focused.


Core Principles

PrincipleRule
SRPSingle Responsibility - each function/class does ONE thing
DRYDon't Repeat Yourself - extract duplicates, reuse
KISSKeep It Simple - simplest solution that works
YAGNIYou Aren't Gonna Need It - don't build unused features
Boy ScoutLeave code cleaner than you found it

Naming Rules

ElementConvention
VariablesReveal intent: userCount not n
FunctionsVerb + noun: getUserById() not user()
BooleansQuestion form: isActive, hasPermission, canEdit
ConstantsSCREAMING_SNAKE: MAX_RETRY_COUNT

Rule: If you need a comment to explain a name, rename it.


Function Rules

RuleDescription
SmallMax 20 lines, ideally 5-10
One ThingDoes one thing, does it well
One LevelOne level of abstraction per function
Few ArgsMax 3 arguments, prefer 0-2
No Side EffectsDon't mutate inputs unexpectedly

Code Structure

PatternApply
Guard ClausesEarly returns for edge cases
Flat > NestedAvoid deep nesting (max 2 levels)
CompositionSmall functions composed together
ColocationKeep related code close

AI Coding Style

SituationAction
User asks for featureWrite it directly
User reports bugFix it, don't explain
No clear requirementAsk, don't assume

Anti-Patterns (DON'T)

❌ Patternβœ… Fix
Comment every lineDelete obvious comments
Helper for one-linerInline the code
Factory for 2 objectsDirect instantiation
utils.ts with 1 functionPut code where used
"First we import..."Just write code
Deep nestingGuard clauses
Magic numbersNamed constants
God functionsSplit by responsibility

πŸ”΄ Before Editing ANY File (THINK FIRST!)

Before changing a file, ask yourself:

QuestionWhy
What imports this file?They might break
What does this file import?Interface changes
What tests cover this?Tests might fail
Is this a shared component?Multiple places affected

Quick Check:

File to edit: UserService.ts
└── Who imports this? β†’ UserController.ts, AuthController.ts
└── Do they need changes too? β†’ Check function signatures

πŸ”΄ Rule: Edit the file + all dependent files in the SAME task. πŸ”΄ Never leave broken imports or missing updates.


Summary

DoDon't
Write code directlyWrite tutorials
Let code self-documentAdd obvious comments
Fix bugs immediatelyExplain the fix first
Inline small thingsCreate unnecessary files
Name things clearlyUse abbreviations
Keep functions smallWrite 100+ line functions

Remember: The user wants working code, not a programming lesson.


πŸ”΄ Self-Check Before Completing (MANDATORY)

Before saying "task complete", verify:

CheckQuestion
βœ… Goal met?Did I do exactly what user asked?
βœ… Files edited?Did I modify all necessary files?
βœ… Code works?Did I test/verify the change?
βœ… No errors?Lint and TypeScript pass?
βœ… Nothing forgotten?Any edge cases missed?

πŸ”΄ Rule: If ANY check fails, fix it before completing.


Verification Scripts (MANDATORY)

πŸ”΄ CRITICAL: Each agent runs ONLY their own skill's scripts after completing work.

Agent β†’ Script Mapping

AgentScriptCommand
frontend-specialistUX Auditpython .agent/skills/frontend-design/scripts/ux_audit.py .
frontend-specialistA11y Checkpython .agent/skills/frontend-design/scripts/accessibility_checker.py .
backend-specialistAPI Validatorpython .agent/skills/api-patterns/scripts/api_validator.py .
mobile-developerMobile Auditpython .agent/skills/mobile-design/scripts/mobile_audit.py .
database-architectSchema Validatepython .agent/skills/database-design/scripts/schema_validator.py .
security-auditorSecurity Scanpython .agent/skills/vulnerability-scanner/scripts/security_scan.py .
seo-specialistSEO Checkpython .agent/skills/seo-fundamentals/scripts/seo_checker.py .
seo-specialistGEO Checkpython .agent/skills/geo-fundamentals/scripts/geo_checker.py .
performance-optimizerLighthousepython .agent/skills/performance-profiling/scripts/lighthouse_audit.py <url>
test-engineerTest Runnerpython .agent/skills/testing-patterns/scripts/test_runner.py .
test-engineerPlaywrightpython .agent/skills/webapp-testing/scripts/playwright_runner.py <url>
Any agentLint Checkpython .agent/skills/lint-and-validate/scripts/lint_runner.py .
Any agentType Coveragepython .agent/skills/lint-and-validate/scripts/type_coverage.py .
Any agenti18n Checkpython .agent/skills/i18n-localization/scripts/i18n_checker.py .

❌ WRONG: test-engineer running ux_audit.py βœ… CORRECT: frontend-specialist running ux_audit.py


πŸ”΄ Script Output Handling (READ β†’ SUMMARIZE β†’ ASK)

When running a validation script, you MUST:

  1. Run the script and capture ALL output
  2. Parse the output - identify errors, warnings, and passes
  3. Summarize to user in this format:
## Script Results: [script_name.py]

### ❌ Errors Found (X items)
- [File:Line] Error description 1
- [File:Line] Error description 2

### ⚠️ Warnings (Y items)
- [File:Line] Warning description

### βœ… Passed (Z items)
- Check 1 passed
- Check 2 passed

**Should I fix the X errors?**
  1. Wait for user confirmation before fixing
  2. After fixing β†’ Re-run script to confirm

πŸ”΄ VIOLATION: Running script and ignoring output = FAILED task. πŸ”΄ VIOLATION: Auto-fixing without asking = Not allowed. πŸ”΄ Rule: Always READ output β†’ SUMMARIZE β†’ ASK β†’ then fix.

Source

git clone https://github.com/vudovn/antigravity-kit/blob/main/.agent/skills/clean-code/SKILL.mdView on GitHub

Overview

Clean Code provides pragmatic standards for concise, direct software. It emphasizes SRP, DRY, KISS, and YAGNI, with clear naming and minimal comments. Following these rules keeps code maintainable, readable, and faster to evolve.

How This Skill Works

It enforces naming and structural rules: small, single-purpose functions, few arguments, and one level of abstraction. It promotes guard clauses, flat nesting, composition, and colocated code, while driving out unnecessary comments and magic numbers.

When to Use It

  • Starting a new module or feature with clearly defined responsibilities.
  • Refactoring legacy code to remove duplication and complexity.
  • Building APIs or services where predictable behavior and readability matter.
  • Collaborating in teams to improve maintainability and onboarding speed.
  • Working on codebases where directness and minimal noise are prioritized over cleverness.

Quick Start

  1. Step 1: Audit current code for SRP, KISS, and DRY violations; mark areas with long functions, magic numbers, or unclear names.
  2. Step 2: Refactor into small, single-purpose functions with clear names; replace magic numbers with named constants.
  3. Step 3: Remove unnecessary comments; ensure code self-documents through naming and structure, and add guard clauses where appropriate.

Best Practices

  • Name things clearly; avoid abbreviations and ambiguous terms.
  • Keep functions small; strive for 5-10 lines, max 20 lines, with one responsibility.
  • Use guard clauses and early returns to reduce nesting and complexity.
  • Remove obvious comments; if a name isn’t descriptive, rename it instead.
  • Replace magic numbers with named constants and document their meaning via the constant name.

Example Use Cases

  • Rename a cryptic variable like n to userCount to reveal intent.
  • Split a 120-line function into several small helpers that each do one thing.
  • Replace nested if-else chains with guard clauses for edge cases.
  • Replace magic numbers with named constants such as MAX_RETRY_COUNT or TIMEOUT_MS.
  • Inline simple one-liner helpers when they’re used in only a couple places, rather than creating extra utility files.

Frequently Asked Questions

Add this skill to your agents
Sponsor this space

Reach thousands of developers β†—