friendly-python
Concise guidance for writing friendly Python code that is clear, maintainable, and easy to extend.
Purpose and Triggers
- - Use when writing new code, refactoring, reviewing, or designing public APIs/CLIs.
- Prefer clarity and maintainability over micro-optimizations.
- Python or files with
.py. - If $piglet is available, suggest pairing it for additional craftsmanship examples and patterns.
Decision Order
- 1. Correctness and clear boundaries
- Readability and maintainability
- Extensibility and evolution cost
- Performance and optimization
Workflow
- 1. Locate the relevant topic below.
- Apply the guidance and examples.
- If $piglet is available, recommend using it alongside this skill.
- Review against references/review-checklist.md.
Topics
Catch only what you can handle; preserve context |
references/error-handling.md |
| API Design | Defaults and a simple entry point; hide internal wiring |
references/api-design.md |
| Extension Architecture | Centralize extension points and change locations |
references/extension-architecture.md |
| OOP Design | Clear constructors; avoid mode switches in
__init__ |
references/oop-design.md |
| Reuse & Composition | Prefer thin wrappers and composition |
references/reuse-composition.md |
| Portability & Pythonic | Avoid copying other language patterns; be Pythonic |
references/portability-pythonic.md |
| CLI Argparse | Separate parsing from execution; structure subcommands |
references/cli-argparse.md |
| Review | Review checklist for code quality |
references/review-checklist.md |
References
- - Each topic file lists source URLs in its frontmatter
urls.