Core software engineering principles for code style, documentation, and development workflow. Applies when editing code, working in software repositories, or performing software development tasks.
Software Engineering Principles
Core principles and preferences for code style, documentation, and development workflow.
Code Style and Patterns
-
Avoid unnecessary comments: Code should be self-documenting. Reserve comments for non-obvious design decisions, workarounds, or complex logic. Avoid comments that restate what the code obviously does.
-
Clean codebase: Avoid leaving TODO, FIXME, or temporary comments in committed code UNLESS directed. Either implement the feature, create an issue, or remove the comment. Ignore existing ones.
-
Self-documenting code: Prefer clear naming and structure over explanatory comments. Method, class, and member documentation should use language/stack best practices. Don't add useless inline comments next to statements UNLESS they explain
confusing or complex behaviour.
Documentation
-
Concise and useful: Documentation should be informative but not verbose. READMEs should focus on essential information without unnecessary elaboration.
-
Structure over verbosity: Prefer well-organized, scannable documentation with clear headings over long paragraphs. Use short examples to illustrate concepts.
Development Workflow
-
Workflow detection: Check if project uses spec-first, TDD, or other structured workflows. Look for:
docs/orspecs/directories with specs- Test-first patterns in codebase
- Plan files or structured documentation
- Follow existing workflow patterns when present
-
No git modifications: Do not use Git commands that modify the repository state (such as
git add,git commit,git push) UNLESS directed. Focus on code edits directly. Status and diff commands (git status,git diff) are permitted and encouraged for analysis. -
Fact-based approach: Do not hallucinate or assume. If you don't know something or need additional context about a framework or technology, search the web or use context7 for up-to-date documentation. If clarification is needed, ask the user before making changes.
-
Constructive disagreement: Do not just accept user direction if a better alternative exists. After reviewing the request, explain your reasoning for why an alternative approach might be better, providing technical justification.
-
Stop and ask: Stop and ask user if:
- Uncertain how to proceed
- About to add type ignores, suppressions, or
anytypes - Requirements are unclear
- Better approach exists but needs confirmation
-
Backward compatibility: Only consider backward compatibility for public-facing interfaces (APIs, libraries). For greenfield/internal refactoring, unit, integration, & E2E tests serve as confirmation gate unless explicitly directed otherwise.
Code Organization
-
Single responsibility: Components and functions should have a single, clear purpose. Organize code into logical directories with clear separation of concerns.
-
Consistent patterns: Follow established patterns in the codebase. When introducing new patterns, ensure they align with existing architecture and conventions.
-
Automation and efficiency: Prefer automated solutions and efficient workflows. Look for opportunities to reduce manual work and improve developer experience.
Output Formatting
- No emojis: Do not use emojis in code or output unless explicitly directed
- Unicode symbols: Unicode symbols (✓, ✗, →, ⚠) are acceptable for user-facing output
- Color and formatting: Color and formatting encouraged for user-facing output
- NO_COLOR support: Always respect
NO_COLORenvironment variable - No hardcoded ANSI: Never use hardcoded ANSI color codes - use color libraries (chalk, colors, etc.)
Best Practices
-
Framework conventions: Follow framework and language best practices. Use framework features as intended rather than working around them.
-
Performance awareness: Consider performance implications of code changes, especially for web applications. Prefer static generation and minimal JavaScript when possible.
-
Accessibility: Ensure code is accessible by default. Use semantic HTML, proper ARIA attributes, and test keyboard navigation.
References
For detailed guidance, see:
references/workflow-patterns.md- Workflow patterns and practicesreferences/implementation-workflow.md- Unified implementation workflow
You Might Also Like
Related Skills

coding-agent
Run Codex CLI, Claude Code, OpenCode, or Pi Coding Agent via background process for programmatic control.
openclaw
add-uint-support
Add unsigned integer (uint) type support to PyTorch operators by updating AT_DISPATCH macros. Use when adding support for uint16, uint32, uint64 types to operators, kernels, or when user mentions enabling unsigned types, barebones unsigned types, or uint support.
pytorch
at-dispatch-v2
Convert PyTorch AT_DISPATCH macros to AT_DISPATCH_V2 format in ATen C++ code. Use when porting AT_DISPATCH_ALL_TYPES_AND*, AT_DISPATCH_FLOATING_TYPES*, or other dispatch macros to the new v2 API. For ATen kernel files, CUDA kernels, and native operator implementations.
pytorch
skill-writer
Guide users through creating Agent Skills for Claude Code. Use when the user wants to create, write, author, or design a new Skill, or needs help with SKILL.md files, frontmatter, or skill structure.
pytorch
implementing-jsc-classes-cpp
Implements JavaScript classes in C++ using JavaScriptCore. Use when creating new JS classes with C++ bindings, prototypes, or constructors.
oven-sh
implementing-jsc-classes-zig
Creates JavaScript classes using Bun's Zig bindings generator (.classes.ts). Use when implementing new JS APIs in Zig with JSC integration.
oven-sh