project-principles

0
0
Source

Core architectural and code quality principles that guide all development decisions in the vm0 project

Install

mkdir -p .claude/skills/project-principles && curl -L -o skill.zip "https://mcp.directory/api/skills/download/6597" && unzip -o skill.zip -d .claude/skills/project-principles && rm skill.zip

Installs to .claude/skills/project-principles

About this skill

Project Principles Skill

This skill defines the fundamental design principles and coding standards for the vm0 project. These principles are MANDATORY for all code written in this project and should guide every development decision.

The Four Core Principles

1. YAGNI (You Aren't Gonna Need It) ⭐ CORE PRINCIPLE

Don't add functionality until it's actually needed.

Quick rules:

  • Start with the simplest solution that works
  • Avoid premature abstractions
  • Delete unused code aggressively
  • No "just in case" features

When coding: Ask "Do we need this NOW?" If not, don't add it.

→ For detailed guidelines and examples, read yagni.md

2. Avoid Defensive Programming

Let exceptions propagate naturally. Don't wrap everything in try/catch.

Quick rules:

  • Only catch exceptions when you can meaningfully handle them
  • Let errors bubble up to where they can be properly addressed
  • Avoid defensive try/catch blocks that just log and re-throw
  • Trust the runtime and framework error handling

When coding: Only use try/catch when you have specific error recovery logic.

→ For detailed guidelines and examples, read no-defensive.md

3. Strict Type Checking

Maintain type safety throughout the codebase. Never compromise on type checking.

Quick rules:

  • Absolutely NO use of any type
  • Always provide explicit types where TypeScript can't infer
  • Use proper type narrowing instead of type assertions
  • Define interfaces and types for all data structures

When coding: If you see any, fix it. If types are missing, add them.

→ For detailed guidelines and examples, read type-safety.md

4. Zero Tolerance for Lint Violations

All code must pass linting without exceptions.

Quick rules:

  • Never add eslint-disable comments
  • Never add @ts-ignore or @ts-nocheck
  • Fix the underlying issue, don't suppress the warning
  • All lint rules are there for a reason - respect them

When coding: If lint fails, fix the code, not the linter.

→ For detailed guidelines and examples, read zero-lint.md

Quick Reference: Code Quality Checklist

Before writing any code, verify:

  • ✅ Is this feature needed NOW? (YAGNI)
  • ✅ Am I avoiding unnecessary try/catch? (No Defensive)
  • ✅ Are all types explicit and correct? (Type Safety)
  • ✅ Will this pass linting? (Zero Lint)

When to Load Additional Context

  • Starting a new feature? → Read yagni.md first
  • Handling errors? → Read no-defensive.md
  • Working with TypeScript? → Read type-safety.md
  • Getting lint errors? → Read zero-lint.md

Integration with Workflow

These principles should be applied:

  1. Before writing code - Plan with YAGNI in mind
  2. While writing code - Follow type safety and avoid defensive programming
  3. Before committing - Ensure zero lint violations
  4. During code review - Verify adherence to all principles

Philosophy

These principles exist to:

  • Keep the codebase simple and maintainable
  • Prevent technical debt accumulation
  • Ensure high code quality
  • Make the project easy to understand and modify

They may feel restrictive at first, but they lead to cleaner, more maintainable code.

Conflict Resolution

If principles seem to conflict:

  1. YAGNI takes precedence - simplicity wins
  2. Type safety is non-negotiable
  3. When in doubt, choose the simpler solution

You might also like

flutter-development

aj-geddes

Build beautiful cross-platform mobile apps with Flutter and Dart. Covers widgets, state management with Provider/BLoC, navigation, API integration, and material design.

643969

drawio-diagrams-enhanced

jgtolentino

Create professional draw.io (diagrams.net) diagrams in XML format (.drawio files) with integrated PMP/PMBOK methodologies, extensive visual asset libraries, and industry-standard professional templates. Use this skill when users ask to create flowcharts, swimlane diagrams, cross-functional flowcharts, org charts, network diagrams, UML diagrams, BPMN, project management diagrams (WBS, Gantt, PERT, RACI), risk matrices, stakeholder maps, or any other visual diagram in draw.io format. This skill includes access to custom shape libraries for icons, clipart, and professional symbols.

591705

ui-ux-pro-max

nextlevelbuilder

"UI/UX design intelligence. 50 styles, 21 palettes, 50 font pairings, 20 charts, 8 stacks (React, Next.js, Vue, Svelte, SwiftUI, React Native, Flutter, Tailwind). Actions: plan, build, create, design, implement, review, fix, improve, optimize, enhance, refactor, check UI/UX code. Projects: website, landing page, dashboard, admin panel, e-commerce, SaaS, portfolio, blog, mobile app, .html, .tsx, .vue, .svelte. Elements: button, modal, navbar, sidebar, card, table, form, chart. Styles: glassmorphism, claymorphism, minimalism, brutalism, neumorphism, bento grid, dark mode, responsive, skeuomorphism, flat design. Topics: color palette, accessibility, animation, layout, typography, font pairing, spacing, hover, shadow, gradient."

318399

godot

bfollington

This skill should be used when working on Godot Engine projects. It provides specialized knowledge of Godot's file formats (.gd, .tscn, .tres), architecture patterns (component-based, signal-driven, resource-based), common pitfalls, validation tools, code templates, and CLI workflows. The `godot` command is available for running the game, validating scripts, importing resources, and exporting builds. Use this skill for tasks involving Godot game development, debugging scene/resource files, implementing game systems, or creating new Godot components.

340397

nano-banana-pro

garg-aayush

Generate and edit images using Google's Nano Banana Pro (Gemini 3 Pro Image) API. Use when the user asks to generate, create, edit, modify, change, alter, or update images. Also use when user references an existing image file and asks to modify it in any way (e.g., "modify this image", "change the background", "replace X with Y"). Supports both text-to-image generation and image-to-image editing with configurable resolution (1K default, 2K, or 4K for high resolution). DO NOT read the image file first - use this skill directly with the --input-image parameter.

452339

fastapi-templates

wshobson

Create production-ready FastAPI projects with async patterns, dependency injection, and comprehensive error handling. Use when building new FastAPI applications or setting up backend API projects.

304231

Stay ahead of the MCP ecosystem

Get weekly updates on new skills and servers.