code-formatter
About
This Claude Skill automatically formats and validates code using Prettier for languages like JavaScript, TypeScript, and CSS. Use it when a developer asks to format, clean up, or check code consistency. It handles multiple file types and integrates with standard development tools.
Documentation
Code Formatter Skill
This skill provides comprehensive code formatting and validation capabilities using industry-standard tools like Prettier.
Prerequisites
- Node.js and npm/npx installed
- Prettier available globally or locally
- Write permissions for target files
- Supported file types in the project
Instructions
1. Analyze Current Formatting
First, check the current formatting state of files:
# Check if prettier is available
npx prettier --version || npm install -g prettier
# Find all formattable files
find . -type f \( -name "*.js" -o -name "*.jsx" -o -name "*.ts" -o -name "*.tsx" -o -name "*.json" -o -name "*.css" -o -name "*.md" \) -not -path "*/node_modules/*" -not -path "*/dist/*"
# Check which files need formatting
npx prettier --check "**/*.{js,jsx,ts,tsx,json,css,md}" --ignore-path .prettierignore
2. Configure Formatting Rules
Create or check for existing Prettier configuration:
// .prettierrc
{
"semi": true,
"singleQuote": true,
"tabWidth": 2,
"trailingComma": "es5",
"printWidth": 100,
"bracketSpacing": true,
"arrowParens": "avoid"
}
3. Apply Formatting
Format individual files or entire directories:
# Format a single file
npx prettier --write src/app.js
# Format all JavaScript files
npx prettier --write "**/*.js"
# Format with specific config
npx prettier --write --config .prettierrc "src/**/*.{js,jsx,ts,tsx}"
# Dry run to see what would change
npx prettier --check src/
4. Set Up Ignore Patterns
Create .prettierignore for files to skip:
# Dependencies
node_modules/
vendor/
# Build outputs
dist/
build/
*.min.js
*.min.css
# Generated files
coverage/
*.lock
5. Integrate with Git Hooks (Optional)
Set up pre-commit formatting:
# Install husky and lint-staged
npm install --save-dev husky lint-staged
# Configure in package.json
{
"lint-staged": {
"*.{js,jsx,ts,tsx,json,css,md}": [
"prettier --write"
]
}
}
Output
The formatter provides detailed feedback:
Success Output
✓ Formatted: src/app.js
✓ Formatted: src/components/Button.jsx
✓ Formatted: package.json
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✅ Successfully formatted 3 files
Validation Output
Checking formatting...
[warn] src/app.js
[warn] src/utils/helper.ts
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
⚠ Found 2 files that need formatting
Error Output
✗ Error: Cannot format src/broken.js
SyntaxError: Unexpected token (line 15:8)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
❌ Failed to format 1 file
Error Handling
Common issues and solutions:
1. Prettier Not Found
# Install globally
npm install -g prettier
# Or use npx (no installation needed)
npx prettier --version
2. Syntax Errors
# Validate JavaScript syntax first
npx eslint src/app.js --fix-dry-run
# Check for parsing errors
npx prettier --debug-check src/app.js
3. Configuration Conflicts
# Find all config files
find . -name ".prettier*" -o -name "prettier.config.js"
# Use specific config
npx prettier --config ./custom-prettier.json --write src/
4. Permission Issues
# Check file permissions
ls -la src/app.js
# Fix permissions if needed
chmod u+w src/app.js
Resources
File Type Support
| Extension | Language | Notes |
|---|---|---|
| .js, .jsx | JavaScript | ES6+ supported |
| .ts, .tsx | TypeScript | Type annotations preserved |
| .json | JSON | Sorts keys optionally |
| .css, .scss | CSS/SASS | Vendor prefixes handled |
| .md, .mdx | Markdown | Table formatting |
| .yaml, .yml | YAML | Preserves comments |
| .html | HTML | Attribute formatting |
| .vue | Vue | Template + script + style |
| .svelte | Svelte | Full component support |
Configuration Options
{
// Semicolons
"semi": true, // Add semicolons
// Quotes
"singleQuote": true, // Use single quotes
"jsxSingleQuote": false, // JSX double quotes
// Indentation
"tabWidth": 2, // Spaces per tab
"useTabs": false, // Use spaces
// Line Length
"printWidth": 100, // Line wrap length
"proseWrap": "preserve", // Markdown wrapping
// Trailing Commas
"trailingComma": "es5", // Valid in ES5
// Brackets
"bracketSpacing": true, // { foo: bar }
"bracketSameLine": false, // JSX brackets
// Arrow Functions
"arrowParens": "avoid", // x => x vs (x) => x
// Formatting
"htmlWhitespaceSensitivity": "css",
"endOfLine": "lf",
"embeddedLanguageFormatting": "auto"
}
Command Reference
# Basic formatting
prettier --write <file> # Format file
prettier --check <file> # Check if formatted
prettier --debug-check <file> # Debug parse errors
# Multiple files
prettier --write "src/**/*.js" # Glob pattern
prettier --write . --ignore-path .gitignore
# Configuration
prettier --config <path> # Use specific config
prettier --no-config # Ignore config files
prettier --find-config-path <file> # Show config used
# Output options
prettier --list-different # List unformatted files
prettier --log-level debug # Verbose output
prettier --no-color # Disable colors
# Special options
prettier --require-pragma # Only format with @format
prettier --insert-pragma # Add @format comment
prettier --range-start 10 --range-end 50 # Partial format
Integration Examples
VS Code Integration:
{
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.formatOnSave": true,
"[javascript]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
}
}
CI/CD Pipeline:
# GitHub Actions
- name: Check formatting
run: npx prettier --check .
# Fail on unformatted code
- name: Enforce formatting
run: |
npx prettier --check . || {
echo "Code is not formatted!"
exit 1
}
Pre-commit Hook:
#!/bin/sh
# .git/hooks/pre-commit
files=$(git diff --cached --name-only --diff-filter=ACMR | grep -E '\.(js|jsx|ts|tsx|json|css|md)$')
if [ -n "$files" ]; then
npx prettier --write $files
git add $files
fi
Performance Tips
- Use .prettierignore to skip large/generated files
- Cache node_modules in CI environments
- Run in parallel for multiple files:
find . -name "*.js" | xargs -P 4 -I {} npx prettier --write {} - Use --cache flag for incremental formatting:
npx prettier --write --cache src/
Related Tools
- ESLint - Linting and code quality
- Stylelint - CSS/SCSS linting
- Markdownlint - Markdown style checking
- Black - Python formatting
- rustfmt - Rust formatting
- gofmt - Go formatting
Version: 1.0.0 Last Updated: 2025-12-12 Compatibility: Claude Code v1.5.0+
Quick Install
/plugin add https://github.com/jeremylongshore/claude-code-plugins-plus/tree/main/code-formatterCopy and paste this command in Claude Code to install this skill
GitHub 仓库
Related Skills
sglang
MetaSGLang is a high-performance LLM serving framework that specializes in fast, structured generation for JSON, regex, and agentic workflows using its RadixAttention prefix caching. It delivers significantly faster inference, especially for tasks with repeated prefixes, making it ideal for complex, structured outputs and multi-turn conversations. Choose SGLang over alternatives like vLLM when you need constrained decoding or are building applications with extensive prefix sharing.
Algorithmic Art Generation
MetaThis skill helps developers create algorithmic art using p5.js, focusing on generative art, computational aesthetics, and interactive visualizations. It automatically activates for topics like "generative art" or "p5.js visualization" and guides you through creating unique algorithms with features like seeded randomness, flow fields, and particle systems. Use it when you need to build reproducible, code-driven artistic patterns.
business-rule-documentation
MetaThis skill provides standardized templates for systematically documenting business logic and domain knowledge following Domain-Driven Design principles. It helps developers capture business rules, process flows, decision trees, and terminology glossaries to maintain consistency between requirements and implementation. Use it when documenting domain models, creating business rule repositories, or bridging communication between business and technical teams.
huggingface-accelerate
DevelopmentHuggingFace Accelerate provides the simplest API for adding distributed training to PyTorch scripts with just 4 lines of code. It offers a unified interface for multiple distributed training frameworks like DeepSpeed, FSDP, and DDP while handling automatic device placement and mixed precision. This makes it ideal for developers who want to quickly scale their PyTorch training across multiple GPUs or nodes without complex configuration.
