惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

aimingoo的专栏
aimingoo的专栏
量子位
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
Schneier on Security
Cisco Talos Blog
Cisco Talos Blog
T
ThreatConnect
J
Java Code Geeks
博客园 - 司徒正美
A
Arctic Wolf
T
True Tiger Recordings
C
Cybersecurity and Infrastructure Security Agency CISA
Cyberwarzone
Cyberwarzone
Know Your Adversary
Know Your Adversary
T
Threat Research - Cisco Blogs
V
Vulnerabilities – Threatpost
Recorded Future
Recorded Future
P
Palo Alto Networks Blog
The Hacker News
The Hacker News
The Register - Security
The Register - Security
S
Securelist
www.infosecurity-magazine.com
www.infosecurity-magazine.com
C
CXSECURITY Database RSS Feed - CXSecurity.com
Application and Cybersecurity Blog
Application and Cybersecurity Blog
I
Intezer
P
Privacy & Cybersecurity Law Blog
Scott Helme
Scott Helme
K
Kaspersky official blog
博客园 - 聂微东
Last Week in AI
Last Week in AI
V
V2EX
小众软件
小众软件
F
Fox-IT International blog
Martin Fowler
Martin Fowler
Apple Machine Learning Research
Apple Machine Learning Research
T
Tenable Blog
F
Future of Privacy Forum
Microsoft Security Blog
Microsoft Security Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
腾讯CDC
Stack Overflow Blog
Stack Overflow Blog
C
Check Point Blog
阮一峰的网络日志
阮一峰的网络日志
GbyAI
GbyAI
T
Threatpost
I
InfoQ
P
Proofpoint News Feed
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
T
Tor Project blog
G
GRAHAM CLULEY
D
DataBreaches.Net

DEV Community

Designing Configuration for Scalable Treasure Hunts SSH Login Delays: The 10-Second Wait That Drives Us Crazy Building Production Multi-Agent Workflows in n8n: What 50 Deployments Taught Us A 3-layer memory system that gives Claude Code persistent context across sessions. Trishul SNMP Suite 2.0.1: Better MIBs, Traps, and SNMP Labs How I built a production AI SaaS as a solo developer Auto-labelling 1.2M robotics frames with VLMs: a failover story India’s Laws Were Not Built for AI — And Courts Are Filling the Gap skill-insp: A Skill That Scores Other Skills Clprolf Minimalist Messaging in the Age of AI Building Strong Python Basics – Loops, Functions and Logic How to Choose the Right Tech Stack for Your Project I built a free multi-tab JSON editor — here's what I learned HTTP Headers Every Developer Should Know (2026) Building Cross-Platform Digital Products: Challenges and Best Practices Data Privacy in the Age of AI: How Product Teams Can Build Trust with Users What Would WordPress Look Like If It Were Designed Today? Why Backup Success Does Not Mean Database Recoverability Local AI Office Assistant That Never Sends Your Documents to the Cloud Building TaskForge: Translating Enterprise Chaos into an Open-Source Scheduler Tesla P40 in a Homelab: 24GB of Inference on a Budget Llama 4: Meta's Latest — Scout, Maverick, and the MoE Revolution George Hotz called AI code 'slop.' He's half right. Como Construir um Fluxo de Trabalho Baseado em Engenharia de Prompt e Automação We Audited Our Agent Tool-Call Traces. Half Our Eval Data Was Garbage. The Hidden Cost of Downtime: How SRE Error Budgets Protect National Economic Infrastructure Getting started with openHUMANS can be an exciting venture for developers looking to create innovative applications in the realm of human-ce Stack Overflow: A Powerful Community for Developers and Learners From Language Models to Humanoid Minds ✨ Road to Senior #2: How Computers Think in Numbers Why LLM debugging fails on fragmented repository context How to Deploy a LangGraph Agent on AWS Bedrock AgentCore An outreach kit for solo founders whose drafts can't hallucinate Open Satchel is live Amy Kwalwasser and the Growing Importance of Quantum Risk Modeling I Built ShellReq - A Native API Client for VS Code & Terminal If Microsoft and Uber can't afford AI coding, what chance do the rest of us have? MADCAP: Building a Multi-Agent Debate CLI That Argues With Itself So You Don't Have To Why most AI fails at IDOR (and how AMAS fixes it with causal reasoning) How to Audit a Laravel Codebase You've Inherited LangGraph 워크플로우 템플릿 (v34) BugBench: a developer origin story and practical guide for VS Code / Kiro users A solution to messy token systems for Next.js A NestJS reference app that proves the nest-native stack under realistic backend pressure Observability for AI Systems: Monitoring Drift, Hallucinations, and Reliability in Production I Thought “Data Analyst” Was the Whole Game… Then I Entered the Data Avengers Office 👀 Create and configure network security groups How to analyze the cost of Kafka? How I Shipped 2,500+ Commits With AI Agents Using a 12-Phase Workflow [Boost] We built MDCMS, a Markdown-first CMS for teams using AI agents Zero Heap Allocations at 1.18 GB/s: Deep Dive into ForgeZero 4.0.x The Minimum Viable Test Suite for Working with Agents Why Perplexity Started Citing My Blog: 5 Changes That Actually Worked Sync Supabase via OAuth: No Connection String Needed I asked three AI models the same API question. Only one had it right. Implementing Saga Pattern With Lambda Durable Function Why does AI forget what you said (and how to fix it) I built a daily Wordle-style game for AI tools - Here's how Mapping Polish company structures: querying KRS direct via API Built tmpdrop — a tiny self-hosted ephemeral file drop Running Local LLM - 0$ Personal Agentic AI Assistant - Part 3 LLD Object-Oriented Design: Interfaces & Abstract Classes (Designing Contracts) The Smaller Ship: Vitalik, the Ethereum Foundation's Restructuring, and What It Leaves for Investors Looking for 4 people to build something weird with me Building a Local-Only RAG System with Ollama and TypeScript The False Positive Tax: a 1:1 TP:FP analysis of eslint-plugin-security What's new in Data Preprocessor 1.5.x — R codegen, Robust Scaler, and a deadlock post-mortem How I self-hosted my Flask app on an old laptop for almost free I built a free DSA interview prep site because I was tired of the existing options I built an AI agent that migrates Next.js Pages Router to App Router Prisma Query Logging and PostgreSQL: Where the ORM Ends and the Database Begins Prisma query logging y PostgreSQL: dónde termina el ORM y empieza la base From Browser to Server : The Journey of an HTTP Request (Demystifying the Web’s Infrastructure) Santa Augmentcode Intent Ep.6 I Benchmarked 17 ESLint Security Plugins. Only One Found Every Vulnerability. How to Build a High-Performance Image Optimization Pipeline in 5 Minutes 50 Linux Commands Every DevOps Engineer Must Know Less Toil, More Flow - Automating the Path from Request to Implementation The Code Review Checklist I Actually Use How I run a small blog on Astro 5 + Content Collections Git: Best Practices for Professionals How IBM Bob Became My Everyday Coding Companion Solana Passkey Wallet: Replacing Seed Phrases with SIMD-0075 I built a small browser puzzle game about arrows I wrapped Claude Code in a zsh function. Here's every decision I almost got wrong. Mobile Game Optimization: A Unity Developer's Checklist Git: Best Practices for Beginners Three days I lost chasing a ghost that was already dead on disk Why Too Many Parts Hurt ClickHouse Performance Guardrails for Agent Output: Pluggable Validation Before and After LLM Calls Gemma Forge: Local AI Without the Setup Wall From Half‑dead Prototype to Local‑Only AI Medical Assistant: Rewiring MedClinic with GitHub Copilot Runninig a forkbomb in Jenkins What’s Actually Happening When You Use Git Preventing Recursive Tool Loops in LangChain Agents Building a Rock-Paper-Scissors CLI with TypeScript — Union Types, Conditionals, and Jest Your AI Coding Agent Wastes 80% of Its Context. Fixed That with Graph Theory. Why Flutter Has Become the Go-To Framework for Fintech App Development
What's actually in a good .cursorrules file? I built 10 of them — here's what I learned
Ahmed Mustaf · 2026-05-26 · via DEV Community

description: Most .cursorrules files are either too vague to help or too rigid to be useful. Here's what I found actually works after building rules for 10 different stacks.
tags: cursor,ai,webdev,productivity


I've spent a lot of time reading other people's .cursorrules files. Some are fantastic. Most are not.

Not because the authors didn't try — but because there's a gap between what feels like a good instruction and what actually changes how Cursor behaves. After building 10 rules files from scratch for different stacks, I want to share what I learned.

What is a .cursorrules file, and why does it matter?

If you haven't used one yet: a .cursorrules file sits in your project root and gives Cursor a set of persistent instructions. Every time the AI generates code, it uses these rules as context.

Think of it as a briefing document. Instead of re-explaining your preferences on every prompt — "use TypeScript strict mode," "don't use default exports," "we use Tailwind, not plain CSS" — you write them once and they apply automatically.

Done well, it means Cursor generates code that fits your project from the first suggestion. Done poorly, it either does nothing or actively gets in the way.

What bad rules look like

Here's a real example of the kind of rule that shows up a lot:

Always write clean, readable, maintainable code.
Follow best practices.
Use meaningful variable names.

Enter fullscreen mode Exit fullscreen mode

This is useless. Not wrong — just useless. "Write clean code" is not an instruction. Cursor already tries to write clean code. You haven't told it anything it didn't already know.

A slightly better but still weak version:

Use TypeScript.
Add comments to complex functions.
Prefer async/await over callbacks.

Enter fullscreen mode Exit fullscreen mode

These are real preferences, but they're still too generic. Every modern TypeScript project uses async/await. Saying it here adds no signal.

The problem with both examples is that they're stack-agnostic. They would apply equally to any project, so they don't actually help Cursor understand your project.

What good rules look like

Good rules are specific to the stack and specific to the project's conventions. Here's a before/after for a Next.js project:

Weak:

Use Next.js best practices.
Structure components properly.
Handle errors appropriately.

Enter fullscreen mode Exit fullscreen mode

Strong:

This project uses Next.js 14 with the App Router. All components in /app are Server Components by default.
Only add 'use client' when the component requires interactivity (event handlers, useState, useEffect).
Do not use getServerSideProps or getStaticProps — those are Pages Router patterns.
Data fetching happens in Server Components using async/await directly. Never fetch in useEffect for initial data loads.

Enter fullscreen mode Exit fullscreen mode

Notice the difference. The second version tells Cursor something it wouldn't otherwise know: that this is App Router, not Pages Router, and what the rules of that environment are. It also explicitly flags a common mistake — the Pages Router data-fetching patterns — because that's exactly the kind of thing AI models get wrong with App Router projects.

Here's another example, this time for FastAPI:

Weak:

Follow FastAPI conventions.
Use Pydantic for validation.

Enter fullscreen mode Exit fullscreen mode

Strong:

This project uses FastAPI with Pydantic v2. Use model_validator and field_validator (not @validator, which is Pydantic v1).
Response models use model_config = ConfigDict(from_attributes=True), not class Config.
All database access goes through SQLAlchemy async sessions. Never use synchronous session patterns.
Route functions should be async. Dependencies go in Depends(), not imported directly into route functions.

Enter fullscreen mode Exit fullscreen mode

The weak version would have Cursor defaulting to Pydantic v1 syntax half the time — because that's what's most common in its training data. The strong version explicitly says "Pydantic v2" and names the specific patterns that differ, so Cursor uses the right ones.

Three things that make rules effective

After writing rules for 10 stacks, I found a few patterns that consistently made a difference:

1. Name the version, not just the tool

"Use React" is fine. "Use React 18 with concurrent features where appropriate" is better. Version specificity matters because AI models have seen a lot of different version patterns and will default to the most common one, which may not be current.

2. Explain what to avoid, not just what to do

It's often more useful to say "do not use X" than "use Y." When Cursor knows what the wrong path looks like, it avoids generating the plausible-but-wrong code that you'd otherwise have to catch and fix. For Go projects, for example, specifying "do not use global variables for state; use dependency injection" catches a common pattern that works at small scale but creates problems in production.

3. Describe your project structure

If your project has non-obvious structure — a monorepo, a specific folder layout, a separation between domain and infrastructure layers — put it in the rules. Cursor uses the file tree as context, but a brief description of what lives where and why helps it make better decisions about where to put new code.

What to avoid in rules files

Keep them focused. A .cursorrules file that's 500 lines long is a problem — it dilutes the important instructions with noise. If everything is emphasized, nothing is.

Avoid instructions that are just philosophy: "Think carefully before writing code." "Consider edge cases." These do not change behavior.

And avoid contradictions. If you say "always add JSDoc comments" and also "keep code concise," you'll get inconsistent results because those goals conflict.

The payoff

When your rules file is doing its job, you stop noticing it — in a good way. Cursor just generates code that fits. You're not correcting the same mistakes repeatedly. You're not re-explaining your conventions every session. The suggestions match what you'd actually write.

That compounding effect is real. Over a day of coding it's maybe a few frustrations avoided and a few minutes saved. Over a month it's meaningful.


After going through this process for 10 different stacks — Next.js, React, FastAPI, Django, Node.js, Go, Vue 3, Svelte, React Native, and Full-Stack SaaS — I packaged the resulting rules files into a single pack if you want a starting point rather than building from scratch. Each file reflects the stack-specific conventions and gotchas I've described here, not just generic advice.

You can find the pack here: Stackdrop Cursor Rules Pack


What rules have you found actually make a difference in your .cursorrules files? Curious what others have figured out — especially for stacks I haven't covered. Drop your best rules in the comments.